").append(x.parseHTML(e)).find(i):e)}).complete(r&&function(e,t){s.each(r,o||[e.responseText,t,e])}),this},x.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){x.fn[t]=function(e){return this.on(t,e)}}),x.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:yn,type:"GET",isLocal:Cn.test(mn[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Dn,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":x.parseJSON,"text xml":x.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?_n(_n(e,x.ajaxSettings),t):_n(x.ajaxSettings,e)},ajaxPrefilter:Hn(An),ajaxTransport:Hn(jn),ajax:function(e,n){"object"==typeof e&&(n=e,e=t),n=n||{};var r,i,o,a,s,l,u,c,p=x.ajaxSetup({},n),f=p.context||p,d=p.context&&(f.nodeType||f.jquery)?x(f):x.event,h=x.Deferred(),g=x.Callbacks("once memory"),m=p.statusCode||{},y={},v={},b=0,w="canceled",C={readyState:0,getResponseHeader:function(e){var t;if(2===b){if(!c){c={};while(t=Tn.exec(a))c[t[1].toLowerCase()]=t[2]}t=c[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return 2===b?a:null},setRequestHeader:function(e,t){var n=e.toLowerCase();return b||(e=v[n]=v[n]||e,y[e]=t),this},overrideMimeType:function(e){return b||(p.mimeType=e),this},statusCode:function(e){var t;if(e)if(2>b)for(t in e)m[t]=[m[t],e[t]];else C.always(e[C.status]);return this},abort:function(e){var t=e||w;return u&&u.abort(t),k(0,t),this}};if(h.promise(C).complete=g.add,C.success=C.done,C.error=C.fail,p.url=((e||p.url||yn)+"").replace(xn,"").replace(kn,mn[1]+"//"),p.type=n.method||n.type||p.method||p.type,p.dataTypes=x.trim(p.dataType||"*").toLowerCase().match(T)||[""],null==p.crossDomain&&(r=En.exec(p.url.toLowerCase()),p.crossDomain=!(!r||r[1]===mn[1]&&r[2]===mn[2]&&(r[3]||("http:"===r[1]?"80":"443"))===(mn[3]||("http:"===mn[1]?"80":"443")))),p.data&&p.processData&&"string"!=typeof p.data&&(p.data=x.param(p.data,p.traditional)),qn(An,p,n,C),2===b)return C;l=p.global,l&&0===x.active++&&x.event.trigger("ajaxStart"),p.type=p.type.toUpperCase(),p.hasContent=!Nn.test(p.type),o=p.url,p.hasContent||(p.data&&(o=p.url+=(bn.test(o)?"&":"?")+p.data,delete p.data),p.cache===!1&&(p.url=wn.test(o)?o.replace(wn,"$1_="+vn++):o+(bn.test(o)?"&":"?")+"_="+vn++)),p.ifModified&&(x.lastModified[o]&&C.setRequestHeader("If-Modified-Since",x.lastModified[o]),x.etag[o]&&C.setRequestHeader("If-None-Match",x.etag[o])),(p.data&&p.hasContent&&p.contentType!==!1||n.contentType)&&C.setRequestHeader("Content-Type",p.contentType),C.setRequestHeader("Accept",p.dataTypes[0]&&p.accepts[p.dataTypes[0]]?p.accepts[p.dataTypes[0]]+("*"!==p.dataTypes[0]?", "+Dn+"; q=0.01":""):p.accepts["*"]);for(i in p.headers)C.setRequestHeader(i,p.headers[i]);if(p.beforeSend&&(p.beforeSend.call(f,C,p)===!1||2===b))return C.abort();w="abort";for(i in{success:1,error:1,complete:1})C[i](p[i]);if(u=qn(jn,p,n,C)){C.readyState=1,l&&d.trigger("ajaxSend",[C,p]),p.async&&p.timeout>0&&(s=setTimeout(function(){C.abort("timeout")},p.timeout));try{b=1,u.send(y,k)}catch(N){if(!(2>b))throw N;k(-1,N)}}else k(-1,"No Transport");function k(e,n,r,i){var c,y,v,w,T,N=n;2!==b&&(b=2,s&&clearTimeout(s),u=t,a=i||"",C.readyState=e>0?4:0,c=e>=200&&300>e||304===e,r&&(w=Mn(p,C,r)),w=On(p,w,C,c),c?(p.ifModified&&(T=C.getResponseHeader("Last-Modified"),T&&(x.lastModified[o]=T),T=C.getResponseHeader("etag"),T&&(x.etag[o]=T)),204===e||"HEAD"===p.type?N="nocontent":304===e?N="notmodified":(N=w.state,y=w.data,v=w.error,c=!v)):(v=N,(e||!N)&&(N="error",0>e&&(e=0))),C.status=e,C.statusText=(n||N)+"",c?h.resolveWith(f,[y,N,C]):h.rejectWith(f,[C,N,v]),C.statusCode(m),m=t,l&&d.trigger(c?"ajaxSuccess":"ajaxError",[C,p,c?y:v]),g.fireWith(f,[C,N]),l&&(d.trigger("ajaxComplete",[C,p]),--x.active||x.event.trigger("ajaxStop")))}return C},getJSON:function(e,t,n){return x.get(e,t,n,"json")},getScript:function(e,n){return x.get(e,t,n,"script")}}),x.each(["get","post"],function(e,n){x[n]=function(e,r,i,o){return x.isFunction(r)&&(o=o||i,i=r,r=t),x.ajax({url:e,type:n,dataType:o,data:r,success:i})}});function Mn(e,n,r){var i,o,a,s,l=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),o===t&&(o=e.mimeType||n.getResponseHeader("Content-Type"));if(o)for(s in l)if(l[s]&&l[s].test(o)){u.unshift(s);break}if(u[0]in r)a=u[0];else{for(s in r){if(!u[0]||e.converters[s+" "+u[0]]){a=s;break}i||(i=s)}a=a||i}return a?(a!==u[0]&&u.unshift(a),r[a]):t}function On(e,t,n,r){var i,o,a,s,l,u={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)u[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!l&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),l=o,o=c.shift())if("*"===o)o=l;else if("*"!==l&&l!==o){if(a=u[l+" "+o]||u["* "+o],!a)for(i in u)if(s=i.split(" "),s[1]===o&&(a=u[l+" "+s[0]]||u["* "+s[0]])){a===!0?a=u[i]:u[i]!==!0&&(o=s[0],c.unshift(s[1]));break}if(a!==!0)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(p){return{state:"parsererror",error:a?p:"No conversion from "+l+" to "+o}}}return{state:"success",data:t}}x.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(e){return x.globalEval(e),e}}}),x.ajaxPrefilter("script",function(e){e.cache===t&&(e.cache=!1),e.crossDomain&&(e.type="GET",e.global=!1)}),x.ajaxTransport("script",function(e){if(e.crossDomain){var n,r=a.head||x("head")[0]||a.documentElement;return{send:function(t,i){n=a.createElement("script"),n.async=!0,e.scriptCharset&&(n.charset=e.scriptCharset),n.src=e.url,n.onload=n.onreadystatechange=function(e,t){(t||!n.readyState||/loaded|complete/.test(n.readyState))&&(n.onload=n.onreadystatechange=null,n.parentNode&&n.parentNode.removeChild(n),n=null,t||i(200,"success"))},r.insertBefore(n,r.firstChild)},abort:function(){n&&n.onload(t,!0)}}}});var Fn=[],Bn=/(=)\?(?=&|$)|\?\?/;x.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Fn.pop()||x.expando+"_"+vn++;return this[e]=!0,e}}),x.ajaxPrefilter("json jsonp",function(n,r,i){var o,a,s,l=n.jsonp!==!1&&(Bn.test(n.url)?"url":"string"==typeof n.data&&!(n.contentType||"").indexOf("application/x-www-form-urlencoded")&&Bn.test(n.data)&&"data");return l||"jsonp"===n.dataTypes[0]?(o=n.jsonpCallback=x.isFunction(n.jsonpCallback)?n.jsonpCallback():n.jsonpCallback,l?n[l]=n[l].replace(Bn,"$1"+o):n.jsonp!==!1&&(n.url+=(bn.test(n.url)?"&":"?")+n.jsonp+"="+o),n.converters["script json"]=function(){return s||x.error(o+" was not called"),s[0]},n.dataTypes[0]="json",a=e[o],e[o]=function(){s=arguments},i.always(function(){e[o]=a,n[o]&&(n.jsonpCallback=r.jsonpCallback,Fn.push(o)),s&&x.isFunction(a)&&a(s[0]),s=a=t}),"script"):t});var Pn,Rn,Wn=0,$n=e.ActiveXObject&&function(){var e;for(e in Pn)Pn[e](t,!0)};function In(){try{return new e.XMLHttpRequest}catch(t){}}function zn(){try{return new e.ActiveXObject("Microsoft.XMLHTTP")}catch(t){}}x.ajaxSettings.xhr=e.ActiveXObject?function(){return!this.isLocal&&In()||zn()}:In,Rn=x.ajaxSettings.xhr(),x.support.cors=!!Rn&&"withCredentials"in Rn,Rn=x.support.ajax=!!Rn,Rn&&x.ajaxTransport(function(n){if(!n.crossDomain||x.support.cors){var r;return{send:function(i,o){var a,s,l=n.xhr();if(n.username?l.open(n.type,n.url,n.async,n.username,n.password):l.open(n.type,n.url,n.async),n.xhrFields)for(s in n.xhrFields)l[s]=n.xhrFields[s];n.mimeType&&l.overrideMimeType&&l.overrideMimeType(n.mimeType),n.crossDomain||i["X-Requested-With"]||(i["X-Requested-With"]="XMLHttpRequest");try{for(s in i)l.setRequestHeader(s,i[s])}catch(u){}l.send(n.hasContent&&n.data||null),r=function(e,i){var s,u,c,p;try{if(r&&(i||4===l.readyState))if(r=t,a&&(l.onreadystatechange=x.noop,$n&&delete Pn[a]),i)4!==l.readyState&&l.abort();else{p={},s=l.status,u=l.getAllResponseHeaders(),"string"==typeof l.responseText&&(p.text=l.responseText);try{c=l.statusText}catch(f){c=""}s||!n.isLocal||n.crossDomain?1223===s&&(s=204):s=p.text?200:404}}catch(d){i||o(-1,d)}p&&o(s,c,p,u)},n.async?4===l.readyState?setTimeout(r):(a=++Wn,$n&&(Pn||(Pn={},x(e).unload($n)),Pn[a]=r),l.onreadystatechange=r):r()},abort:function(){r&&r(t,!0)}}}});var Xn,Un,Vn=/^(?:toggle|show|hide)$/,Yn=RegExp("^(?:([+-])=|)("+w+")([a-z%]*)$","i"),Jn=/queueHooks$/,Gn=[nr],Qn={"*":[function(e,t){var n=this.createTween(e,t),r=n.cur(),i=Yn.exec(t),o=i&&i[3]||(x.cssNumber[e]?"":"px"),a=(x.cssNumber[e]||"px"!==o&&+r)&&Yn.exec(x.css(n.elem,e)),s=1,l=20;if(a&&a[3]!==o){o=o||a[3],i=i||[],a=+r||1;do s=s||".5",a/=s,x.style(n.elem,e,a+o);while(s!==(s=n.cur()/r)&&1!==s&&--l)}return i&&(a=n.start=+a||+r||0,n.unit=o,n.end=i[1]?a+(i[1]+1)*i[2]:+i[2]),n}]};function Kn(){return setTimeout(function(){Xn=t}),Xn=x.now()}function Zn(e,t,n){var r,i=(Qn[t]||[]).concat(Qn["*"]),o=0,a=i.length;for(;a>o;o++)if(r=i[o].call(n,t,e))return r}function er(e,t,n){var r,i,o=0,a=Gn.length,s=x.Deferred().always(function(){delete l.elem}),l=function(){if(i)return!1;var t=Xn||Kn(),n=Math.max(0,u.startTime+u.duration-t),r=n/u.duration||0,o=1-r,a=0,l=u.tweens.length;for(;l>a;a++)u.tweens[a].run(o);return s.notifyWith(e,[u,o,n]),1>o&&l?n:(s.resolveWith(e,[u]),!1)},u=s.promise({elem:e,props:x.extend({},t),opts:x.extend(!0,{specialEasing:{}},n),originalProperties:t,originalOptions:n,startTime:Xn||Kn(),duration:n.duration,tweens:[],createTween:function(t,n){var r=x.Tween(e,u.opts,t,n,u.opts.specialEasing[t]||u.opts.easing);return u.tweens.push(r),r},stop:function(t){var n=0,r=t?u.tweens.length:0;if(i)return this;for(i=!0;r>n;n++)u.tweens[n].run(1);return t?s.resolveWith(e,[u,t]):s.rejectWith(e,[u,t]),this}}),c=u.props;for(tr(c,u.opts.specialEasing);a>o;o++)if(r=Gn[o].call(u,e,c,u.opts))return r;return x.map(c,Zn,u),x.isFunction(u.opts.start)&&u.opts.start.call(e,u),x.fx.timer(x.extend(l,{elem:e,anim:u,queue:u.opts.queue})),u.progress(u.opts.progress).done(u.opts.done,u.opts.complete).fail(u.opts.fail).always(u.opts.always)}function tr(e,t){var n,r,i,o,a;for(n in e)if(r=x.camelCase(n),i=t[r],o=e[n],x.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),a=x.cssHooks[r],a&&"expand"in a){o=a.expand(o),delete e[r];for(n in o)n in e||(e[n]=o[n],t[n]=i)}else t[r]=i}x.Animation=x.extend(er,{tweener:function(e,t){x.isFunction(e)?(t=e,e=["*"]):e=e.split(" ");var n,r=0,i=e.length;for(;i>r;r++)n=e[r],Qn[n]=Qn[n]||[],Qn[n].unshift(t)},prefilter:function(e,t){t?Gn.unshift(e):Gn.push(e)}});function nr(e,t,n){var r,i,o,a,s,l,u=this,c={},p=e.style,f=e.nodeType&&nn(e),d=x._data(e,"fxshow");n.queue||(s=x._queueHooks(e,"fx"),null==s.unqueued&&(s.unqueued=0,l=s.empty.fire,s.empty.fire=function(){s.unqueued||l()}),s.unqueued++,u.always(function(){u.always(function(){s.unqueued--,x.queue(e,"fx").length||s.empty.fire()})})),1===e.nodeType&&("height"in t||"width"in t)&&(n.overflow=[p.overflow,p.overflowX,p.overflowY],"inline"===x.css(e,"display")&&"none"===x.css(e,"float")&&(x.support.inlineBlockNeedsLayout&&"inline"!==ln(e.nodeName)?p.zoom=1:p.display="inline-block")),n.overflow&&(p.overflow="hidden",x.support.shrinkWrapBlocks||u.always(function(){p.overflow=n.overflow[0],p.overflowX=n.overflow[1],p.overflowY=n.overflow[2]}));for(r in t)if(i=t[r],Vn.exec(i)){if(delete t[r],o=o||"toggle"===i,i===(f?"hide":"show"))continue;c[r]=d&&d[r]||x.style(e,r)}if(!x.isEmptyObject(c)){d?"hidden"in d&&(f=d.hidden):d=x._data(e,"fxshow",{}),o&&(d.hidden=!f),f?x(e).show():u.done(function(){x(e).hide()}),u.done(function(){var t;x._removeData(e,"fxshow");for(t in c)x.style(e,t,c[t])});for(r in c)a=Zn(f?d[r]:0,r,u),r in d||(d[r]=a.start,f&&(a.end=a.start,a.start="width"===r||"height"===r?1:0))}}function rr(e,t,n,r,i){return new rr.prototype.init(e,t,n,r,i)}x.Tween=rr,rr.prototype={constructor:rr,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||"swing",this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(x.cssNumber[n]?"":"px")},cur:function(){var e=rr.propHooks[this.prop];return e&&e.get?e.get(this):rr.propHooks._default.get(this)},run:function(e){var t,n=rr.propHooks[this.prop];return this.pos=t=this.options.duration?x.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):rr.propHooks._default.set(this),this}},rr.prototype.init.prototype=rr.prototype,rr.propHooks={_default:{get:function(e){var t;return null==e.elem[e.prop]||e.elem.style&&null!=e.elem.style[e.prop]?(t=x.css(e.elem,e.prop,""),t&&"auto"!==t?t:0):e.elem[e.prop]},set:function(e){x.fx.step[e.prop]?x.fx.step[e.prop](e):e.elem.style&&(null!=e.elem.style[x.cssProps[e.prop]]||x.cssHooks[e.prop])?x.style(e.elem,e.prop,e.now+e.unit):e.elem[e.prop]=e.now}}},rr.propHooks.scrollTop=rr.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},x.each(["toggle","show","hide"],function(e,t){var n=x.fn[t];x.fn[t]=function(e,r,i){return null==e||"boolean"==typeof e?n.apply(this,arguments):this.animate(ir(t,!0),e,r,i)}}),x.fn.extend({fadeTo:function(e,t,n,r){return this.filter(nn).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(e,t,n,r){var i=x.isEmptyObject(e),o=x.speed(t,n,r),a=function(){var t=er(this,x.extend({},e),o);(i||x._data(this,"finish"))&&t.stop(!0)};return a.finish=a,i||o.queue===!1?this.each(a):this.queue(o.queue,a)},stop:function(e,n,r){var i=function(e){var t=e.stop;delete e.stop,t(r)};return"string"!=typeof e&&(r=n,n=e,e=t),n&&e!==!1&&this.queue(e||"fx",[]),this.each(function(){var t=!0,n=null!=e&&e+"queueHooks",o=x.timers,a=x._data(this);if(n)a[n]&&a[n].stop&&i(a[n]);else for(n in a)a[n]&&a[n].stop&&Jn.test(n)&&i(a[n]);for(n=o.length;n--;)o[n].elem!==this||null!=e&&o[n].queue!==e||(o[n].anim.stop(r),t=!1,o.splice(n,1));(t||!r)&&x.dequeue(this,e)})},finish:function(e){return e!==!1&&(e=e||"fx"),this.each(function(){var t,n=x._data(this),r=n[e+"queue"],i=n[e+"queueHooks"],o=x.timers,a=r?r.length:0;for(n.finish=!0,x.queue(this,e,[]),i&&i.stop&&i.stop.call(this,!0),t=o.length;t--;)o[t].elem===this&&o[t].queue===e&&(o[t].anim.stop(!0),o.splice(t,1));for(t=0;a>t;t++)r[t]&&r[t].finish&&r[t].finish.call(this);delete n.finish})}});function ir(e,t){var n,r={height:e},i=0;for(t=t?1:0;4>i;i+=2-t)n=Zt[i],r["margin"+n]=r["padding"+n]=e;return t&&(r.opacity=r.width=e),r}x.each({slideDown:ir("show"),slideUp:ir("hide"),slideToggle:ir("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,t){x.fn[e]=function(e,n,r){return this.animate(t,e,n,r)}}),x.speed=function(e,t,n){var r=e&&"object"==typeof e?x.extend({},e):{complete:n||!n&&t||x.isFunction(e)&&e,duration:e,easing:n&&t||t&&!x.isFunction(t)&&t};return r.duration=x.fx.off?0:"number"==typeof r.duration?r.duration:r.duration in x.fx.speeds?x.fx.speeds[r.duration]:x.fx.speeds._default,(null==r.queue||r.queue===!0)&&(r.queue="fx"),r.old=r.complete,r.complete=function(){x.isFunction(r.old)&&r.old.call(this),r.queue&&x.dequeue(this,r.queue)},r},x.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2}},x.timers=[],x.fx=rr.prototype.init,x.fx.tick=function(){var e,n=x.timers,r=0;for(Xn=x.now();n.length>r;r++)e=n[r],e()||n[r]!==e||n.splice(r--,1);n.length||x.fx.stop(),Xn=t},x.fx.timer=function(e){e()&&x.timers.push(e)&&x.fx.start()},x.fx.interval=13,x.fx.start=function(){Un||(Un=setInterval(x.fx.tick,x.fx.interval))},x.fx.stop=function(){clearInterval(Un),Un=null},x.fx.speeds={slow:600,fast:200,_default:400},x.fx.step={},x.expr&&x.expr.filters&&(x.expr.filters.animated=function(e){return x.grep(x.timers,function(t){return e===t.elem}).length}),x.fn.offset=function(e){if(arguments.length)return e===t?this:this.each(function(t){x.offset.setOffset(this,e,t)});var n,r,o={top:0,left:0},a=this[0],s=a&&a.ownerDocument;if(s)return n=s.documentElement,x.contains(n,a)?(typeof a.getBoundingClientRect!==i&&(o=a.getBoundingClientRect()),r=or(s),{top:o.top+(r.pageYOffset||n.scrollTop)-(n.clientTop||0),left:o.left+(r.pageXOffset||n.scrollLeft)-(n.clientLeft||0)}):o},x.offset={setOffset:function(e,t,n){var r=x.css(e,"position");"static"===r&&(e.style.position="relative");var i=x(e),o=i.offset(),a=x.css(e,"top"),s=x.css(e,"left"),l=("absolute"===r||"fixed"===r)&&x.inArray("auto",[a,s])>-1,u={},c={},p,f;l?(c=i.position(),p=c.top,f=c.left):(p=parseFloat(a)||0,f=parseFloat(s)||0),x.isFunction(t)&&(t=t.call(e,n,o)),null!=t.top&&(u.top=t.top-o.top+p),null!=t.left&&(u.left=t.left-o.left+f),"using"in t?t.using.call(e,u):i.css(u)}},x.fn.extend({position:function(){if(this[0]){var e,t,n={top:0,left:0},r=this[0];return"fixed"===x.css(r,"position")?t=r.getBoundingClientRect():(e=this.offsetParent(),t=this.offset(),x.nodeName(e[0],"html")||(n=e.offset()),n.top+=x.css(e[0],"borderTopWidth",!0),n.left+=x.css(e[0],"borderLeftWidth",!0)),{top:t.top-n.top-x.css(r,"marginTop",!0),left:t.left-n.left-x.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent||s;while(e&&!x.nodeName(e,"html")&&"static"===x.css(e,"position"))e=e.offsetParent;return e||s})}}),x.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(e,n){var r=/Y/.test(n);x.fn[e]=function(i){return x.access(this,function(e,i,o){var a=or(e);return o===t?a?n in a?a[n]:a.document.documentElement[i]:e[i]:(a?a.scrollTo(r?x(a).scrollLeft():o,r?o:x(a).scrollTop()):e[i]=o,t)},e,i,arguments.length,null)}});function or(e){return x.isWindow(e)?e:9===e.nodeType?e.defaultView||e.parentWindow:!1}x.each({Height:"height",Width:"width"},function(e,n){x.each({padding:"inner"+e,content:n,"":"outer"+e},function(r,i){x.fn[i]=function(i,o){var a=arguments.length&&(r||"boolean"!=typeof i),s=r||(i===!0||o===!0?"margin":"border");return x.access(this,function(n,r,i){var o;return x.isWindow(n)?n.document.documentElement["client"+e]:9===n.nodeType?(o=n.documentElement,Math.max(n.body["scroll"+e],o["scroll"+e],n.body["offset"+e],o["offset"+e],o["client"+e])):i===t?x.css(n,r,s):x.style(n,r,i,s)},n,a?i:t,a,null)}})}),x.fn.size=function(){return this.length},x.fn.andSelf=x.fn.addBack,"object"==typeof module&&module&&"object"==typeof module.exports?module.exports=x:(e.jQuery=e.$=x,"function"==typeof define&&define.amd&&define("jquery",[],function(){return x}))})(window);
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery-1.10.2.min.map b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery-1.10.2.min.map
new file mode 100644
index 000000000..4dc4920bb
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery-1.10.2.min.map
@@ -0,0 +1 @@
+{"version":3,"file":"jquery-1.10.2.min.js","sources":["jquery-1.10.2.js"],"names":["window","undefined","readyList","rootjQuery","core_strundefined","location","document","docElem","documentElement","_jQuery","jQuery","_$","$","class2type","core_deletedIds","core_version","core_concat","concat","core_push","push","core_slice","slice","core_indexOf","indexOf","core_toString","toString","core_hasOwn","hasOwnProperty","core_trim","trim","selector","context","fn","init","core_pnum","source","core_rnotwhite","rtrim","rquickExpr","rsingleTag","rvalidchars","rvalidbraces","rvalidescape","rvalidtokens","rmsPrefix","rdashAlpha","fcamelCase","all","letter","toUpperCase","completed","event","addEventListener","type","readyState","detach","ready","removeEventListener","detachEvent","prototype","jquery","constructor","match","elem","this","charAt","length","exec","find","merge","parseHTML","nodeType","ownerDocument","test","isPlainObject","isFunction","attr","getElementById","parentNode","id","makeArray","toArray","call","get","num","pushStack","elems","ret","prevObject","each","callback","args","promise","done","apply","arguments","first","eq","last","i","len","j","map","end","sort","splice","extend","src","copyIsArray","copy","name","options","clone","target","deep","isArray","expando","Math","random","replace","noConflict","isReady","readyWait","holdReady","hold","wait","body","setTimeout","resolveWith","trigger","off","obj","Array","isWindow","isNumeric","isNaN","parseFloat","isFinite","String","key","e","support","ownLast","isEmptyObject","error","msg","Error","data","keepScripts","parsed","scripts","createElement","buildFragment","remove","childNodes","parseJSON","JSON","parse","Function","parseXML","xml","tmp","DOMParser","parseFromString","ActiveXObject","async","loadXML","getElementsByTagName","noop","globalEval","execScript","camelCase","string","nodeName","toLowerCase","value","isArraylike","text","arr","results","Object","inArray","max","second","l","grep","inv","retVal","arg","guid","proxy","access","chainable","emptyGet","raw","bulk","now","Date","getTime","swap","old","style","Deferred","attachEvent","top","frameElement","doScroll","doScrollCheck","split","cachedruns","Expr","getText","isXML","compile","outermostContext","sortInput","setDocument","documentIsHTML","rbuggyQSA","rbuggyMatches","matches","contains","preferredDoc","dirruns","classCache","createCache","tokenCache","compilerCache","hasDuplicate","sortOrder","a","b","strundefined","MAX_NEGATIVE","hasOwn","pop","push_native","booleans","whitespace","characterEncoding","identifier","attributes","pseudos","RegExp","rcomma","rcombinators","rsibling","rattributeQuotes","rpseudo","ridentifier","matchExpr","ID","CLASS","TAG","ATTR","PSEUDO","CHILD","bool","needsContext","rnative","rinputs","rheader","rescape","runescape","funescape","_","escaped","escapedWhitespace","high","fromCharCode","els","Sizzle","seed","m","groups","nid","newContext","newSelector","getElementsByClassName","qsa","tokenize","getAttribute","setAttribute","toSelector","join","querySelectorAll","qsaError","removeAttribute","select","keys","cache","cacheLength","shift","markFunction","assert","div","removeChild","addHandle","attrs","handler","attrHandle","siblingCheck","cur","diff","sourceIndex","nextSibling","createInputPseudo","createButtonPseudo","createPositionalPseudo","argument","matchIndexes","node","doc","parent","defaultView","className","appendChild","createComment","innerHTML","firstChild","getById","getElementsByName","filter","attrId","getAttributeNode","tag","input","matchesSelector","webkitMatchesSelector","mozMatchesSelector","oMatchesSelector","msMatchesSelector","disconnectedMatch","compareDocumentPosition","adown","bup","compare","sortDetached","aup","ap","bp","unshift","expr","elements","val","specified","uniqueSort","duplicates","detectDuplicates","sortStable","textContent","nodeValue","selectors","createPseudo","relative",">","dir"," ","+","~","preFilter","excess","unquoted","nodeNameSelector","pattern","operator","check","result","what","simple","forward","ofType","outerCache","nodeIndex","start","useCache","lastChild","pseudo","setFilters","idx","matched","not","matcher","unmatched","has","innerText","lang","elemLang","hash","root","focus","activeElement","hasFocus","href","tabIndex","enabled","disabled","checked","selected","selectedIndex","empty","header","button","even","odd","lt","gt","radio","checkbox","file","password","image","submit","reset","filters","parseOnly","tokens","soFar","preFilters","cached","addCombinator","combinator","base","checkNonElements","doneName","dirkey","elementMatcher","matchers","condense","newUnmatched","mapped","setMatcher","postFilter","postFinder","postSelector","temp","preMap","postMap","preexisting","multipleContexts","matcherIn","matcherOut","matcherFromTokens","checkContext","leadingRelative","implicitRelative","matchContext","matchAnyContext","matcherFromGroupMatchers","elementMatchers","setMatchers","matcherCachedRuns","bySet","byElement","superMatcher","expandContext","setMatched","matchedCount","outermost","contextBackup","dirrunsUnique","group","contexts","token","div1","defaultValue","unique","isXMLDoc","optionsCache","createOptions","object","flag","Callbacks","firing","memory","fired","firingLength","firingIndex","firingStart","list","stack","once","fire","stopOnFalse","self","disable","add","index","lock","locked","fireWith","func","tuples","state","always","deferred","fail","then","fns","newDefer","tuple","action","returned","resolve","reject","progress","notify","pipe","stateString","when","subordinate","resolveValues","remaining","updateFunc","values","progressValues","notifyWith","progressContexts","resolveContexts","fragment","opt","eventName","isSupported","cssText","getSetAttribute","leadingWhitespace","tbody","htmlSerialize","hrefNormalized","opacity","cssFloat","checkOn","optSelected","enctype","html5Clone","cloneNode","outerHTML","inlineBlockNeedsLayout","shrinkWrapBlocks","pixelPosition","deleteExpando","noCloneEvent","reliableMarginRight","boxSizingReliable","noCloneChecked","optDisabled","radioValue","createDocumentFragment","appendChecked","checkClone","click","change","focusin","backgroundClip","clearCloneStyle","container","marginDiv","tds","divReset","offsetHeight","display","reliableHiddenOffsets","zoom","boxSizing","offsetWidth","getComputedStyle","width","marginRight","rbrace","rmultiDash","internalData","pvt","acceptData","thisCache","internalKey","isNode","toJSON","internalRemoveData","isEmptyDataObject","cleanData","noData","applet","embed","hasData","removeData","_data","_removeData","dataAttr","queue","dequeue","startLength","hooks","_queueHooks","next","stop","setter","delay","time","fx","speeds","timeout","clearTimeout","clearQueue","count","defer","nodeHook","boolHook","rclass","rreturn","rfocusable","rclickable","ruseDefault","getSetInput","removeAttr","prop","removeProp","propFix","addClass","classes","clazz","proceed","removeClass","toggleClass","stateVal","classNames","hasClass","valHooks","set","option","one","optionSet","nType","attrHooks","propName","attrNames","for","class","notxml","propHooks","tabindex","parseInt","getter","setAttributeNode","createAttribute","coords","contenteditable","rformElems","rkeyEvent","rmouseEvent","rfocusMorph","rtypenamespace","returnTrue","returnFalse","safeActiveElement","err","global","types","events","t","handleObjIn","special","eventHandle","handleObj","handlers","namespaces","origType","elemData","handle","triggered","dispatch","delegateType","bindType","namespace","delegateCount","setup","mappedTypes","origCount","teardown","removeEvent","onlyHandlers","ontype","bubbleType","eventPath","Event","isTrigger","namespace_re","noBubble","parentWindow","isPropagationStopped","preventDefault","isDefaultPrevented","_default","fix","handlerQueue","delegateTarget","preDispatch","currentTarget","isImmediatePropagationStopped","stopPropagation","postDispatch","sel","originalEvent","fixHook","fixHooks","mouseHooks","keyHooks","props","srcElement","metaKey","original","which","charCode","keyCode","eventDoc","fromElement","pageX","clientX","scrollLeft","clientLeft","pageY","clientY","scrollTop","clientTop","relatedTarget","toElement","load","blur","beforeunload","returnValue","simulate","bubble","isSimulated","defaultPrevented","getPreventDefault","timeStamp","cancelBubble","stopImmediatePropagation","mouseenter","mouseleave","orig","related","submitBubbles","form","_submit_bubble","changeBubbles","propertyName","_just_changed","focusinBubbles","attaches","on","origFn","triggerHandler","isSimple","rparentsprev","rneedsContext","guaranteedUnique","children","contents","prev","targets","winnow","is","closest","pos","prevAll","addBack","sibling","parents","parentsUntil","until","nextAll","nextUntil","prevUntil","siblings","contentDocument","contentWindow","reverse","n","r","qualifier","createSafeFragment","nodeNames","safeFrag","rinlinejQuery","rnoshimcache","rleadingWhitespace","rxhtmlTag","rtagName","rtbody","rhtml","rnoInnerhtml","manipulation_rcheckableType","rchecked","rscriptType","rscriptTypeMasked","rcleanScript","wrapMap","legend","area","param","thead","tr","col","td","safeFragment","fragmentDiv","optgroup","tfoot","colgroup","caption","th","append","createTextNode","domManip","manipulationTarget","prepend","insertBefore","before","after","keepData","getAll","setGlobalEval","dataAndEvents","deepDataAndEvents","html","replaceWith","allowIntersection","hasScripts","iNoClone","disableScript","restoreScript","_evalUrl","content","refElements","cloneCopyEvent","dest","oldData","curData","fixCloneNodeIssues","defaultChecked","defaultSelected","appendTo","prependTo","insertAfter","replaceAll","insert","found","fixDefaultChecked","destElements","srcElements","inPage","selection","wrap","safe","nodes","url","ajax","dataType","throws","wrapAll","wrapInner","unwrap","iframe","getStyles","curCSS","ralpha","ropacity","rposition","rdisplayswap","rmargin","rnumsplit","rnumnonpx","rrelNum","elemdisplay","BODY","cssShow","position","visibility","cssNormalTransform","letterSpacing","fontWeight","cssExpand","cssPrefixes","vendorPropName","capName","origName","isHidden","el","css","showHide","show","hidden","css_defaultDisplay","styles","hide","toggle","cssHooks","computed","cssNumber","columnCount","fillOpacity","lineHeight","order","orphans","widows","zIndex","cssProps","float","extra","_computed","minWidth","maxWidth","getPropertyValue","currentStyle","left","rs","rsLeft","runtimeStyle","pixelLeft","setPositiveNumber","subtract","augmentWidthOrHeight","isBorderBox","getWidthOrHeight","valueIsBorderBox","actualDisplay","write","close","$1","visible","margin","padding","border","prefix","suffix","expand","expanded","parts","r20","rbracket","rCRLF","rsubmitterTypes","rsubmittable","serialize","serializeArray","traditional","s","encodeURIComponent","ajaxSettings","buildParams","v","hover","fnOver","fnOut","bind","unbind","delegate","undelegate","ajaxLocParts","ajaxLocation","ajax_nonce","ajax_rquery","rhash","rts","rheaders","rlocalProtocol","rnoContent","rprotocol","rurl","_load","prefilters","transports","allTypes","addToPrefiltersOrTransports","structure","dataTypeExpression","dataTypes","inspectPrefiltersOrTransports","originalOptions","jqXHR","inspected","seekingTransport","inspect","prefilterOrFactory","dataTypeOrTransport","ajaxExtend","flatOptions","params","response","responseText","complete","status","active","lastModified","etag","isLocal","processData","contentType","accepts","*","json","responseFields","converters","* text","text html","text json","text xml","ajaxSetup","settings","ajaxPrefilter","ajaxTransport","cacheURL","responseHeadersString","timeoutTimer","fireGlobals","transport","responseHeaders","callbackContext","globalEventContext","completeDeferred","statusCode","requestHeaders","requestHeadersNames","strAbort","getResponseHeader","getAllResponseHeaders","setRequestHeader","lname","overrideMimeType","mimeType","code","abort","statusText","finalText","success","method","crossDomain","hasContent","ifModified","headers","beforeSend","send","nativeStatusText","responses","isSuccess","modified","ajaxHandleResponses","ajaxConvert","rejectWith","getJSON","getScript","firstDataType","ct","finalDataType","conv2","current","conv","dataFilter","script","text script","head","scriptCharset","charset","onload","onreadystatechange","isAbort","oldCallbacks","rjsonp","jsonp","jsonpCallback","originalSettings","callbackName","overwritten","responseContainer","jsonProp","xhrCallbacks","xhrSupported","xhrId","xhrOnUnloadAbort","createStandardXHR","XMLHttpRequest","createActiveXHR","xhr","cors","username","open","xhrFields","firefoxAccessException","unload","fxNow","timerId","rfxtypes","rfxnum","rrun","animationPrefilters","defaultPrefilter","tweeners","tween","createTween","unit","scale","maxIterations","createFxNow","animation","collection","Animation","properties","stopped","tick","currentTime","startTime","duration","percent","tweens","run","opts","specialEasing","originalProperties","Tween","easing","gotoEnd","propFilter","timer","anim","tweener","prefilter","oldfire","dataShow","unqueued","overflow","overflowX","overflowY","eased","step","cssFn","speed","animate","genFx","fadeTo","to","optall","doAnimation","finish","stopQueue","timers","includeWidth","height","slideDown","slideUp","slideToggle","fadeIn","fadeOut","fadeToggle","linear","p","swing","cos","PI","interval","setInterval","clearInterval","slow","fast","animated","offset","setOffset","win","box","getBoundingClientRect","getWindow","pageYOffset","pageXOffset","curElem","curOffset","curCSSTop","curCSSLeft","calculatePosition","curPosition","curTop","curLeft","using","offsetParent","parentOffset","scrollTo","Height","Width","defaultExtra","funcName","size","andSelf","module","exports","define","amd"],"mappings":";;;CAaA,SAAWA,EAAQC,GAOnB,GAECC,GAGAC,EAIAC,QAA2BH,GAG3BI,EAAWL,EAAOK,SAClBC,EAAWN,EAAOM,SAClBC,EAAUD,EAASE,gBAGnBC,EAAUT,EAAOU,OAGjBC,EAAKX,EAAOY,EAGZC,KAGAC,KAEAC,EAAe,SAGfC,EAAcF,EAAgBG,OAC9BC,EAAYJ,EAAgBK,KAC5BC,EAAaN,EAAgBO,MAC7BC,EAAeR,EAAgBS,QAC/BC,EAAgBX,EAAWY,SAC3BC,EAAcb,EAAWc,eACzBC,EAAYb,EAAac,KAGzBnB,EAAS,SAAUoB,EAAUC,GAE5B,MAAO,IAAIrB,GAAOsB,GAAGC,KAAMH,EAAUC,EAAS5B,IAI/C+B,EAAY,sCAAsCC,OAGlDC,EAAiB,OAGjBC,EAAQ,qCAKRC,EAAa,sCAGbC,EAAa,6BAGbC,EAAc,gBACdC,EAAe,uBACfC,EAAe,qCACfC,EAAe,kEAGfC,EAAY,QACZC,EAAa,eAGbC,EAAa,SAAUC,EAAKC,GAC3B,MAAOA,GAAOC,eAIfC,EAAY,SAAUC,IAGhB7C,EAAS8C,kBAAmC,SAAfD,EAAME,MAA2C,aAAxB/C,EAASgD,cACnEC,IACA7C,EAAO8C,UAITD,EAAS,WACHjD,EAAS8C,kBACb9C,EAASmD,oBAAqB,mBAAoBP,GAAW,GAC7DlD,EAAOyD,oBAAqB,OAAQP,GAAW,KAG/C5C,EAASoD,YAAa,qBAAsBR,GAC5ClD,EAAO0D,YAAa,SAAUR,IAIjCxC,GAAOsB,GAAKtB,EAAOiD,WAElBC,OAAQ7C,EAER8C,YAAanD,EACbuB,KAAM,SAAUH,EAAUC,EAAS5B,GAClC,GAAI2D,GAAOC,CAGX,KAAMjC,EACL,MAAOkC,KAIR,IAAyB,gBAAblC,GAAwB,CAUnC,GAPCgC,EAF2B,MAAvBhC,EAASmC,OAAO,IAAyD,MAA3CnC,EAASmC,OAAQnC,EAASoC,OAAS,IAAepC,EAASoC,QAAU,GAE7F,KAAMpC,EAAU,MAGlBQ,EAAW6B,KAAMrC,IAIrBgC,IAAUA,EAAM,IAAO/B,EAqDrB,OAAMA,GAAWA,EAAQ6B,QACtB7B,GAAW5B,GAAaiE,KAAMtC,GAKhCkC,KAAKH,YAAa9B,GAAUqC,KAAMtC,EAxDzC,IAAKgC,EAAM,GAAK,CAWf,GAVA/B,EAAUA,YAAmBrB,GAASqB,EAAQ,GAAKA,EAGnDrB,EAAO2D,MAAOL,KAAMtD,EAAO4D,UAC1BR,EAAM,GACN/B,GAAWA,EAAQwC,SAAWxC,EAAQyC,eAAiBzC,EAAUzB,GACjE,IAIIiC,EAAWkC,KAAMX,EAAM,KAAQpD,EAAOgE,cAAe3C,GACzD,IAAM+B,IAAS/B,GAETrB,EAAOiE,WAAYX,KAAMF,IAC7BE,KAAMF,GAAS/B,EAAS+B,IAIxBE,KAAKY,KAAMd,EAAO/B,EAAS+B,GAK9B,OAAOE,MAQP,GAJAD,EAAOzD,EAASuE,eAAgBf,EAAM,IAIjCC,GAAQA,EAAKe,WAAa,CAG9B,GAAKf,EAAKgB,KAAOjB,EAAM,GACtB,MAAO3D,GAAWiE,KAAMtC,EAIzBkC,MAAKE,OAAS,EACdF,KAAK,GAAKD,EAKX,MAFAC,MAAKjC,QAAUzB,EACf0D,KAAKlC,SAAWA,EACTkC,KAcH,MAAKlC,GAASyC,UACpBP,KAAKjC,QAAUiC,KAAK,GAAKlC,EACzBkC,KAAKE,OAAS,EACPF,MAIItD,EAAOiE,WAAY7C,GACvB3B,EAAWqD,MAAO1B,IAGrBA,EAASA,WAAa7B,IAC1B+D,KAAKlC,SAAWA,EAASA,SACzBkC,KAAKjC,QAAUD,EAASC,SAGlBrB,EAAOsE,UAAWlD,EAAUkC,QAIpClC,SAAU,GAGVoC,OAAQ,EAERe,QAAS,WACR,MAAO7D,GAAW8D,KAAMlB,OAKzBmB,IAAK,SAAUC,GACd,MAAc,OAAPA,EAGNpB,KAAKiB,UAGG,EAANG,EAAUpB,KAAMA,KAAKE,OAASkB,GAAQpB,KAAMoB,IAKhDC,UAAW,SAAUC,GAGpB,GAAIC,GAAM7E,EAAO2D,MAAOL,KAAKH,cAAeyB,EAO5C,OAJAC,GAAIC,WAAaxB,KACjBuB,EAAIxD,QAAUiC,KAAKjC,QAGZwD,GAMRE,KAAM,SAAUC,EAAUC,GACzB,MAAOjF,GAAO+E,KAAMzB,KAAM0B,EAAUC,IAGrCnC,MAAO,SAAUxB,GAIhB,MAFAtB,GAAO8C,MAAMoC,UAAUC,KAAM7D,GAEtBgC,MAGR3C,MAAO,WACN,MAAO2C,MAAKqB,UAAWjE,EAAW0E,MAAO9B,KAAM+B,aAGhDC,MAAO,WACN,MAAOhC,MAAKiC,GAAI,IAGjBC,KAAM,WACL,MAAOlC,MAAKiC,GAAI,KAGjBA,GAAI,SAAUE,GACb,GAAIC,GAAMpC,KAAKE,OACdmC,GAAKF,GAAU,EAAJA,EAAQC,EAAM,EAC1B,OAAOpC,MAAKqB,UAAWgB,GAAK,GAASD,EAAJC,GAAYrC,KAAKqC,SAGnDC,IAAK,SAAUZ,GACd,MAAO1B,MAAKqB,UAAW3E,EAAO4F,IAAItC,KAAM,SAAUD,EAAMoC,GACvD,MAAOT,GAASR,KAAMnB,EAAMoC,EAAGpC,OAIjCwC,IAAK,WACJ,MAAOvC,MAAKwB,YAAcxB,KAAKH,YAAY,OAK5C1C,KAAMD,EACNsF,QAASA,KACTC,UAAWA,QAIZ/F,EAAOsB,GAAGC,KAAK0B,UAAYjD,EAAOsB,GAElCtB,EAAOgG,OAAShG,EAAOsB,GAAG0E,OAAS,WAClC,GAAIC,GAAKC,EAAaC,EAAMC,EAAMC,EAASC,EAC1CC,EAASlB,UAAU,OACnBI,EAAI,EACJjC,EAAS6B,UAAU7B,OACnBgD,GAAO,CAqBR,KAlBuB,iBAAXD,KACXC,EAAOD,EACPA,EAASlB,UAAU,OAEnBI,EAAI,GAIkB,gBAAXc,IAAwBvG,EAAOiE,WAAWsC,KACrDA,MAII/C,IAAWiC,IACfc,EAASjD,OACPmC,GAGSjC,EAAJiC,EAAYA,IAEnB,GAAmC,OAA7BY,EAAUhB,UAAWI,IAE1B,IAAMW,IAAQC,GACbJ,EAAMM,EAAQH,GACdD,EAAOE,EAASD,GAGXG,IAAWJ,IAKXK,GAAQL,IAAUnG,EAAOgE,cAAcmC,KAAUD,EAAclG,EAAOyG,QAAQN,MAC7ED,GACJA,GAAc,EACdI,EAAQL,GAAOjG,EAAOyG,QAAQR,GAAOA,MAGrCK,EAAQL,GAAOjG,EAAOgE,cAAciC,GAAOA,KAI5CM,EAAQH,GAASpG,EAAOgG,OAAQQ,EAAMF,EAAOH,IAGlCA,IAAS5G,IACpBgH,EAAQH,GAASD,GAOrB,OAAOI,IAGRvG,EAAOgG,QAGNU,QAAS,UAAarG,EAAesG,KAAKC,UAAWC,QAAS,MAAO,IAErEC,WAAY,SAAUN,GASrB,MARKlH,GAAOY,IAAMF,IACjBV,EAAOY,EAAID,GAGPuG,GAAQlH,EAAOU,SAAWA,IAC9BV,EAAOU,OAASD,GAGVC,GAIR+G,SAAS,EAITC,UAAW,EAGXC,UAAW,SAAUC,GACfA,EACJlH,EAAOgH,YAEPhH,EAAO8C,OAAO,IAKhBA,MAAO,SAAUqE,GAGhB,GAAKA,KAAS,KAASnH,EAAOgH,WAAYhH,EAAO+G,QAAjD,CAKA,IAAMnH,EAASwH,KACd,MAAOC,YAAYrH,EAAO8C,MAI3B9C,GAAO+G,SAAU,EAGZI,KAAS,KAAUnH,EAAOgH,UAAY,IAK3CxH,EAAU8H,YAAa1H,GAAYI,IAG9BA,EAAOsB,GAAGiG,SACdvH,EAAQJ,GAAW2H,QAAQ,SAASC,IAAI,YAO1CvD,WAAY,SAAUwD,GACrB,MAA4B,aAArBzH,EAAO2C,KAAK8E,IAGpBhB,QAASiB,MAAMjB,SAAW,SAAUgB,GACnC,MAA4B,UAArBzH,EAAO2C,KAAK8E,IAGpBE,SAAU,SAAUF,GAEnB,MAAc,OAAPA,GAAeA,GAAOA,EAAInI,QAGlCsI,UAAW,SAAUH,GACpB,OAAQI,MAAOC,WAAWL,KAAUM,SAAUN,IAG/C9E,KAAM,SAAU8E,GACf,MAAY,OAAPA,EACWA,EAARO,GAEc,gBAARP,IAAmC,kBAARA,GACxCtH,EAAYW,EAAc0D,KAAKiD,KAAU,eAClCA,IAGTzD,cAAe,SAAUyD,GACxB,GAAIQ,EAKJ,KAAMR,GAA4B,WAArBzH,EAAO2C,KAAK8E,IAAqBA,EAAI5D,UAAY7D,EAAO2H,SAAUF,GAC9E,OAAO,CAGR,KAEC,GAAKA,EAAItE,cACPnC,EAAYwD,KAAKiD,EAAK,iBACtBzG,EAAYwD,KAAKiD,EAAItE,YAAYF,UAAW,iBAC7C,OAAO,EAEP,MAAQiF,GAET,OAAO,EAKR,GAAKlI,EAAOmI,QAAQC,QACnB,IAAMH,IAAOR,GACZ,MAAOzG,GAAYwD,KAAMiD,EAAKQ,EAMhC,KAAMA,IAAOR,IAEb,MAAOQ,KAAQ1I,GAAayB,EAAYwD,KAAMiD,EAAKQ,IAGpDI,cAAe,SAAUZ,GACxB,GAAIrB,EACJ,KAAMA,IAAQqB,GACb,OAAO,CAER,QAAO,GAGRa,MAAO,SAAUC,GAChB,KAAUC,OAAOD,IAMlB3E,UAAW,SAAU6E,EAAMpH,EAASqH,GACnC,IAAMD,GAAwB,gBAATA,GACpB,MAAO,KAEgB,kBAAZpH,KACXqH,EAAcrH,EACdA,GAAU,GAEXA,EAAUA,GAAWzB,CAErB,IAAI+I,GAAS9G,EAAW4B,KAAMgF,GAC7BG,GAAWF,KAGZ,OAAKC,IACKtH,EAAQwH,cAAeF,EAAO,MAGxCA,EAAS3I,EAAO8I,eAAiBL,GAAQpH,EAASuH,GAC7CA,GACJ5I,EAAQ4I,GAAUG,SAEZ/I,EAAO2D,SAAWgF,EAAOK,cAGjCC,UAAW,SAAUR,GAEpB,MAAKnJ,GAAO4J,MAAQ5J,EAAO4J,KAAKC,MACxB7J,EAAO4J,KAAKC,MAAOV,GAGb,OAATA,EACGA,EAGa,gBAATA,KAGXA,EAAOzI,EAAOmB,KAAMsH,GAEfA,GAGC3G,EAAYiC,KAAM0E,EAAK5B,QAAS7E,EAAc,KACjD6E,QAAS5E,EAAc,KACvB4E,QAAS9E,EAAc,MAEXqH,SAAU,UAAYX,MAKtCzI,EAAOsI,MAAO,iBAAmBG,GAAjCzI,IAIDqJ,SAAU,SAAUZ,GACnB,GAAIa,GAAKC,CACT,KAAMd,GAAwB,gBAATA,GACpB,MAAO,KAER,KACMnJ,EAAOkK,WACXD,EAAM,GAAIC,WACVF,EAAMC,EAAIE,gBAAiBhB,EAAO,cAElCa,EAAM,GAAII,eAAe,oBACzBJ,EAAIK,MAAQ,QACZL,EAAIM,QAASnB,IAEb,MAAOP,GACRoB,EAAM/J,EAKP,MAHM+J,IAAQA,EAAIxJ,kBAAmBwJ,EAAIO,qBAAsB,eAAgBrG,QAC9ExD,EAAOsI,MAAO,gBAAkBG,GAE1Ba,GAGRQ,KAAM,aAKNC,WAAY,SAAUtB,GAChBA,GAAQzI,EAAOmB,KAAMsH,KAIvBnJ,EAAO0K,YAAc,SAAUvB,GAChCnJ,EAAe,KAAEkF,KAAMlF,EAAQmJ,KAC3BA,IAMPwB,UAAW,SAAUC,GACpB,MAAOA,GAAOrD,QAAS3E,EAAW,OAAQ2E,QAAS1E,EAAYC,IAGhE+H,SAAU,SAAU9G,EAAM+C,GACzB,MAAO/C,GAAK8G,UAAY9G,EAAK8G,SAASC,gBAAkBhE,EAAKgE,eAI9DrF,KAAM,SAAU0C,EAAKzC,EAAUC,GAC9B,GAAIoF,GACH5E,EAAI,EACJjC,EAASiE,EAAIjE,OACbiD,EAAU6D,EAAa7C,EAExB,IAAKxC,GACJ,GAAKwB,GACJ,KAAYjD,EAAJiC,EAAYA,IAGnB,GAFA4E,EAAQrF,EAASI,MAAOqC,EAAKhC,GAAKR,GAE7BoF,KAAU,EACd,UAIF,KAAM5E,IAAKgC,GAGV,GAFA4C,EAAQrF,EAASI,MAAOqC,EAAKhC,GAAKR,GAE7BoF,KAAU,EACd,UAOH,IAAK5D,GACJ,KAAYjD,EAAJiC,EAAYA,IAGnB,GAFA4E,EAAQrF,EAASR,KAAMiD,EAAKhC,GAAKA,EAAGgC,EAAKhC,IAEpC4E,KAAU,EACd,UAIF,KAAM5E,IAAKgC,GAGV,GAFA4C,EAAQrF,EAASR,KAAMiD,EAAKhC,GAAKA,EAAGgC,EAAKhC,IAEpC4E,KAAU,EACd,KAMJ,OAAO5C,IAIRtG,KAAMD,IAAcA,EAAUsD,KAAK,gBAClC,SAAU+F,GACT,MAAe,OAARA,EACN,GACArJ,EAAUsD,KAAM+F,IAIlB,SAAUA,GACT,MAAe,OAARA,EACN,IACEA,EAAO,IAAK1D,QAASlF,EAAO,KAIjC2C,UAAW,SAAUkG,EAAKC,GACzB,GAAI5F,GAAM4F,KAaV,OAXY,OAAPD,IACCF,EAAaI,OAAOF,IACxBxK,EAAO2D,MAAOkB,EACE,gBAAR2F,IACLA,GAAQA,GAGXhK,EAAUgE,KAAMK,EAAK2F,IAIhB3F,GAGR8F,QAAS,SAAUtH,EAAMmH,EAAK/E,GAC7B,GAAIC,EAEJ,IAAK8E,EAAM,CACV,GAAK5J,EACJ,MAAOA,GAAa4D,KAAMgG,EAAKnH,EAAMoC,EAMtC,KAHAC,EAAM8E,EAAIhH,OACViC,EAAIA,EAAQ,EAAJA,EAAQkB,KAAKiE,IAAK,EAAGlF,EAAMD,GAAMA,EAAI,EAEjCC,EAAJD,EAASA,IAEhB,GAAKA,IAAK+E,IAAOA,EAAK/E,KAAQpC,EAC7B,MAAOoC,GAKV,MAAO,IAGR9B,MAAO,SAAU2B,EAAOuF,GACvB,GAAIC,GAAID,EAAOrH,OACdiC,EAAIH,EAAM9B,OACVmC,EAAI,CAEL,IAAkB,gBAANmF,GACX,KAAYA,EAAJnF,EAAOA,IACdL,EAAOG,KAAQoF,EAAQlF,OAGxB,OAAQkF,EAAOlF,KAAOpG,EACrB+F,EAAOG,KAAQoF,EAAQlF,IAMzB,OAFAL,GAAM9B,OAASiC,EAERH,GAGRyF,KAAM,SAAUnG,EAAOI,EAAUgG,GAChC,GAAIC,GACHpG,KACAY,EAAI,EACJjC,EAASoB,EAAMpB,MAKhB,KAJAwH,IAAQA,EAIIxH,EAAJiC,EAAYA,IACnBwF,IAAWjG,EAAUJ,EAAOa,GAAKA,GAC5BuF,IAAQC,GACZpG,EAAIpE,KAAMmE,EAAOa,GAInB,OAAOZ,IAIRe,IAAK,SAAUhB,EAAOI,EAAUkG,GAC/B,GAAIb,GACH5E,EAAI,EACJjC,EAASoB,EAAMpB,OACfiD,EAAU6D,EAAa1F,GACvBC,IAGD,IAAK4B,EACJ,KAAYjD,EAAJiC,EAAYA,IACnB4E,EAAQrF,EAAUJ,EAAOa,GAAKA,EAAGyF,GAEnB,MAATb,IACJxF,EAAKA,EAAIrB,QAAW6G,OAMtB,KAAM5E,IAAKb,GACVyF,EAAQrF,EAAUJ,EAAOa,GAAKA,EAAGyF,GAEnB,MAATb,IACJxF,EAAKA,EAAIrB,QAAW6G,EAMvB,OAAO/J,GAAY8E,SAAWP,IAI/BsG,KAAM,EAINC,MAAO,SAAU9J,EAAID,GACpB,GAAI4D,GAAMmG,EAAO7B,CAUjB,OARwB,gBAAZlI,KACXkI,EAAMjI,EAAID,GACVA,EAAUC,EACVA,EAAKiI,GAKAvJ,EAAOiE,WAAY3C,IAKzB2D,EAAOvE,EAAW8D,KAAMa,UAAW,GACnC+F,EAAQ,WACP,MAAO9J,GAAG8D,MAAO/D,GAAWiC,KAAM2B,EAAK1E,OAAQG,EAAW8D,KAAMa,cAIjE+F,EAAMD,KAAO7J,EAAG6J,KAAO7J,EAAG6J,MAAQnL,EAAOmL,OAElCC,GAZC7L,GAiBT8L,OAAQ,SAAUzG,EAAOtD,EAAI2G,EAAKoC,EAAOiB,EAAWC,EAAUC,GAC7D,GAAI/F,GAAI,EACPjC,EAASoB,EAAMpB,OACfiI,EAAc,MAAPxD,CAGR,IAA4B,WAAvBjI,EAAO2C,KAAMsF,GAAqB,CACtCqD,GAAY,CACZ,KAAM7F,IAAKwC,GACVjI,EAAOqL,OAAQzG,EAAOtD,EAAImE,EAAGwC,EAAIxC,IAAI,EAAM8F,EAAUC,OAIhD,IAAKnB,IAAU9K,IACrB+L,GAAY,EAENtL,EAAOiE,WAAYoG,KACxBmB,GAAM,GAGFC,IAECD,GACJlK,EAAGkD,KAAMI,EAAOyF,GAChB/I,EAAK,OAILmK,EAAOnK,EACPA,EAAK,SAAU+B,EAAM4E,EAAKoC,GACzB,MAAOoB,GAAKjH,KAAMxE,EAAQqD,GAAQgH,MAKhC/I,GACJ,KAAYkC,EAAJiC,EAAYA,IACnBnE,EAAIsD,EAAMa,GAAIwC,EAAKuD,EAAMnB,EAAQA,EAAM7F,KAAMI,EAAMa,GAAIA,EAAGnE,EAAIsD,EAAMa,GAAIwC,IAK3E,OAAOqD,GACN1G,EAGA6G,EACCnK,EAAGkD,KAAMI,GACTpB,EAASlC,EAAIsD,EAAM,GAAIqD,GAAQsD,GAGlCG,IAAK,WACJ,OAAO,GAAMC,OAASC,WAMvBC,KAAM,SAAUxI,EAAMgD,EAASrB,EAAUC,GACxC,GAAIJ,GAAKuB,EACR0F,IAGD,KAAM1F,IAAQC,GACbyF,EAAK1F,GAAS/C,EAAK0I,MAAO3F,GAC1B/C,EAAK0I,MAAO3F,GAASC,EAASD,EAG/BvB,GAAMG,EAASI,MAAO/B,EAAM4B,MAG5B,KAAMmB,IAAQC,GACbhD,EAAK0I,MAAO3F,GAAS0F,EAAK1F,EAG3B,OAAOvB,MAIT7E,EAAO8C,MAAMoC,QAAU,SAAUuC,GAChC,IAAMjI,EAOL,GALAA,EAAYQ,EAAOgM,WAKU,aAAxBpM,EAASgD,WAEbyE,WAAYrH,EAAO8C,WAGb,IAAKlD,EAAS8C,iBAEpB9C,EAAS8C,iBAAkB,mBAAoBF,GAAW,GAG1DlD,EAAOoD,iBAAkB,OAAQF,GAAW,OAGtC,CAEN5C,EAASqM,YAAa,qBAAsBzJ,GAG5ClD,EAAO2M,YAAa,SAAUzJ,EAI9B,IAAI0J,IAAM,CAEV,KACCA,EAA6B,MAAvB5M,EAAO6M,cAAwBvM,EAASE,gBAC7C,MAAMoI,IAEHgE,GAAOA,EAAIE,UACf,QAAUC,KACT,IAAMrM,EAAO+G,QAAU,CAEtB,IAGCmF,EAAIE,SAAS,QACZ,MAAMlE,GACP,MAAOb,YAAYgF,EAAe,IAInCxJ,IAGA7C,EAAO8C,YAMZ,MAAOtD,GAAU0F,QAASuC,IAI3BzH,EAAO+E,KAAK,gEAAgEuH,MAAM,KAAM,SAAS7G,EAAGW,GACnGjG,EAAY,WAAaiG,EAAO,KAAQA,EAAKgE,eAG9C,SAASE,GAAa7C,GACrB,GAAIjE,GAASiE,EAAIjE,OAChBb,EAAO3C,EAAO2C,KAAM8E,EAErB,OAAKzH,GAAO2H,SAAUF,IACd,EAGc,IAAjBA,EAAI5D,UAAkBL,GACnB,EAGQ,UAATb,GAA6B,aAATA,IACb,IAAXa,GACgB,gBAAXA,IAAuBA,EAAS,GAAOA,EAAS,IAAOiE,IAIhEhI,EAAaO,EAAOJ,GAWpB,SAAWN,EAAQC,GAEnB,GAAIkG,GACH0C,EACAoE,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,EAGAC,EACAlN,EACAC,EACAkN,EACAC,EACAC,EACAC,EACAC,EAGAzG,EAAU,UAAY,GAAKiF,MAC3ByB,EAAe9N,EAAOM,SACtByN,EAAU,EACVlI,EAAO,EACPmI,EAAaC,KACbC,EAAaD,KACbE,EAAgBF,KAChBG,GAAe,EACfC,EAAY,SAAUC,EAAGC,GACxB,MAAKD,KAAMC,GACVH,GAAe,EACR,GAED,GAIRI,QAAsBvO,GACtBwO,EAAe,GAAK,GAGpBC,KAAc/M,eACduJ,KACAyD,EAAMzD,EAAIyD,IACVC,EAAc1D,EAAI/J,KAClBA,EAAO+J,EAAI/J,KACXE,EAAQ6J,EAAI7J,MAEZE,EAAU2J,EAAI3J,SAAW,SAAUwC,GAClC,GAAIoC,GAAI,EACPC,EAAMpC,KAAKE,MACZ,MAAYkC,EAAJD,EAASA,IAChB,GAAKnC,KAAKmC,KAAOpC,EAChB,MAAOoC,EAGT,OAAO,IAGR0I,EAAW,6HAKXC,EAAa,sBAEbC,EAAoB,mCAKpBC,EAAaD,EAAkBxH,QAAS,IAAK,MAG7C0H,EAAa,MAAQH,EAAa,KAAOC,EAAoB,IAAMD,EAClE,mBAAqBA,EAAa,wCAA0CE,EAAa,QAAUF,EAAa,OAQjHI,EAAU,KAAOH,EAAoB,mEAAqEE,EAAW1H,QAAS,EAAG,GAAM,eAGvIlF,EAAY8M,OAAQ,IAAML,EAAa,8BAAgCA,EAAa,KAAM,KAE1FM,EAAaD,OAAQ,IAAML,EAAa,KAAOA,EAAa,KAC5DO,EAAmBF,OAAQ,IAAML,EAAa,WAAaA,EAAa,IAAMA,EAAa,KAE3FQ,EAAeH,OAAQL,EAAa,SACpCS,EAAuBJ,OAAQ,IAAML,EAAa,gBAAkBA,EAAa,OAAQ,KAEzFU,EAAcL,OAAQD,GACtBO,EAAkBN,OAAQ,IAAMH,EAAa,KAE7CU,GACCC,GAAUR,OAAQ,MAAQJ,EAAoB,KAC9Ca,MAAaT,OAAQ,QAAUJ,EAAoB,KACnDc,IAAWV,OAAQ,KAAOJ,EAAkBxH,QAAS,IAAK,MAAS,KACnEuI,KAAYX,OAAQ,IAAMF,GAC1Bc,OAAcZ,OAAQ,IAAMD,GAC5Bc,MAAab,OAAQ,yDAA2DL,EAC/E,+BAAiCA,EAAa,cAAgBA,EAC9D,aAAeA,EAAa,SAAU,KACvCmB,KAAYd,OAAQ,OAASN,EAAW,KAAM,KAG9CqB,aAAoBf,OAAQ,IAAML,EAAa,mDAC9CA,EAAa,mBAAqBA,EAAa,mBAAoB,MAGrEqB,EAAU,yBAGV7N,EAAa,mCAEb8N,GAAU,sCACVC,GAAU,SAEVC,GAAU,QAGVC,GAAgBpB,OAAQ,qBAAuBL,EAAa,MAAQA,EAAa,OAAQ,MACzF0B,GAAY,SAAUC,EAAGC,EAASC,GACjC,GAAIC,GAAO,KAAOF,EAAU,KAI5B,OAAOE,KAASA,GAAQD,EACvBD,EAEO,EAAPE,EACClI,OAAOmI,aAAcD,EAAO,OAE5BlI,OAAOmI,aAA2B,MAAbD,GAAQ,GAA4B,MAAR,KAAPA,GAI9C,KACCzP,EAAK2E,MACHoF,EAAM7J,EAAM6D,KAAM4I,EAAapE,YAChCoE,EAAapE,YAIdwB,EAAK4C,EAAapE,WAAWxF,QAASK,SACrC,MAAQqE,IACTzH,GAAS2E,MAAOoF,EAAIhH,OAGnB,SAAU+C,EAAQ6J,GACjBlC,EAAY9I,MAAOmB,EAAQ5F,EAAM6D,KAAK4L,KAKvC,SAAU7J,EAAQ6J,GACjB,GAAIzK,GAAIY,EAAO/C,OACdiC,EAAI,CAEL,OAASc,EAAOZ,KAAOyK,EAAI3K,MAC3Bc,EAAO/C,OAASmC,EAAI,IAKvB,QAAS0K,IAAQjP,EAAUC,EAASoJ,EAAS6F,GAC5C,GAAIlN,GAAOC,EAAMkN,EAAG1M,EAEnB4B,EAAG+K,EAAQ1E,EAAK2E,EAAKC,EAAYC,CASlC,KAPOtP,EAAUA,EAAQyC,eAAiBzC,EAAU+L,KAAmBxN,GACtEkN,EAAazL,GAGdA,EAAUA,GAAWzB,EACrB6K,EAAUA,OAEJrJ,GAAgC,gBAAbA,GACxB,MAAOqJ,EAGR,IAAuC,KAAjC5G,EAAWxC,EAAQwC,WAAgC,IAAbA,EAC3C,QAGD,IAAKkJ,IAAmBuD,EAAO,CAG9B,GAAMlN,EAAQxB,EAAW6B,KAAMrC,GAE9B,GAAMmP,EAAInN,EAAM,IACf,GAAkB,IAAbS,EAAiB,CAIrB,GAHAR,EAAOhC,EAAQ8C,eAAgBoM,IAG1BlN,IAAQA,EAAKe,WAQjB,MAAOqG,EALP,IAAKpH,EAAKgB,KAAOkM,EAEhB,MADA9F,GAAQhK,KAAM4C,GACPoH,MAOT,IAAKpJ,EAAQyC,gBAAkBT,EAAOhC,EAAQyC,cAAcK,eAAgBoM,KAC3EpD,EAAU9L,EAASgC,IAAUA,EAAKgB,KAAOkM,EAEzC,MADA9F,GAAQhK,KAAM4C,GACPoH,MAKH,CAAA,GAAKrH,EAAM,GAEjB,MADA3C,GAAK2E,MAAOqF,EAASpJ,EAAQwI,qBAAsBzI,IAC5CqJ,CAGD,KAAM8F,EAAInN,EAAM,KAAO+E,EAAQyI,wBAA0BvP,EAAQuP,uBAEvE,MADAnQ,GAAK2E,MAAOqF,EAASpJ,EAAQuP,uBAAwBL,IAC9C9F,EAKT,GAAKtC,EAAQ0I,OAAS7D,IAAcA,EAAUjJ,KAAM3C,IAAc,CASjE,GARAqP,EAAM3E,EAAMpF,EACZgK,EAAarP,EACbsP,EAA2B,IAAb9M,GAAkBzC,EAMd,IAAbyC,GAAqD,WAAnCxC,EAAQ8I,SAASC,cAA6B,CACpEoG,EAASM,GAAU1P,IAEb0K,EAAMzK,EAAQ0P,aAAa,OAChCN,EAAM3E,EAAIjF,QAAS+I,GAAS,QAE5BvO,EAAQ2P,aAAc,KAAMP,GAE7BA,EAAM,QAAUA,EAAM,MAEtBhL,EAAI+K,EAAOhN,MACX,OAAQiC,IACP+K,EAAO/K,GAAKgL,EAAMQ,GAAYT,EAAO/K,GAEtCiL,GAAa9B,EAAS7K,KAAM3C,IAAcC,EAAQ+C,YAAc/C,EAChEsP,EAAcH,EAAOU,KAAK,KAG3B,GAAKP,EACJ,IAIC,MAHAlQ,GAAK2E,MAAOqF,EACXiG,EAAWS,iBAAkBR,IAEvBlG,EACN,MAAM2G,IACN,QACKtF,GACLzK,EAAQgQ,gBAAgB,QAQ7B,MAAOC,IAAQlQ,EAASyF,QAASlF,EAAO,MAAQN,EAASoJ,EAAS6F,GASnE,QAAS/C,MACR,GAAIgE,KAEJ,SAASC,GAAOvJ,EAAKoC,GAMpB,MAJKkH,GAAK9Q,KAAMwH,GAAO,KAAQuE,EAAKiF,mBAE5BD,GAAOD,EAAKG,SAEZF,EAAOvJ,GAAQoC,EAExB,MAAOmH,GAOR,QAASG,IAAcrQ,GAEtB,MADAA,GAAIoF,IAAY,EACTpF,EAOR,QAASsQ,IAAQtQ,GAChB,GAAIuQ,GAAMjS,EAASiJ,cAAc,MAEjC,KACC,QAASvH,EAAIuQ,GACZ,MAAO3J,GACR,OAAO,EACN,QAEI2J,EAAIzN,YACRyN,EAAIzN,WAAW0N,YAAaD,GAG7BA,EAAM,MASR,QAASE,IAAWC,EAAOC,GAC1B,GAAIzH,GAAMwH,EAAM1F,MAAM,KACrB7G,EAAIuM,EAAMxO,MAEX,OAAQiC,IACP+G,EAAK0F,WAAY1H,EAAI/E,IAAOwM,EAU9B,QAASE,IAAcvE,EAAGC,GACzB,GAAIuE,GAAMvE,GAAKD,EACdyE,EAAOD,GAAsB,IAAfxE,EAAE/J,UAAiC,IAAfgK,EAAEhK,YAChCgK,EAAEyE,aAAevE,KACjBH,EAAE0E,aAAevE,EAGtB,IAAKsE,EACJ,MAAOA,EAIR,IAAKD,EACJ,MAASA,EAAMA,EAAIG,YAClB,GAAKH,IAAQvE,EACZ,MAAO,EAKV,OAAOD,GAAI,EAAI,GAOhB,QAAS4E,IAAmB7P,GAC3B,MAAO,UAAUU,GAChB,GAAI+C,GAAO/C,EAAK8G,SAASC,aACzB,OAAgB,UAAThE,GAAoB/C,EAAKV,OAASA,GAQ3C,QAAS8P,IAAoB9P,GAC5B,MAAO,UAAUU,GAChB,GAAI+C,GAAO/C,EAAK8G,SAASC,aACzB,QAAiB,UAAThE,GAA6B,WAATA,IAAsB/C,EAAKV,OAASA,GAQlE,QAAS+P,IAAwBpR,GAChC,MAAOqQ,IAAa,SAAUgB,GAE7B,MADAA,IAAYA,EACLhB,GAAa,SAAUrB,EAAMpD,GACnC,GAAIvH,GACHiN,EAAetR,KAAQgP,EAAK9M,OAAQmP,GACpClN,EAAImN,EAAapP,MAGlB,OAAQiC,IACF6K,EAAO3K,EAAIiN,EAAanN,MAC5B6K,EAAK3K,KAAOuH,EAAQvH,GAAK2K,EAAK3K,SAWnC+G,EAAQ2D,GAAO3D,MAAQ,SAAUrJ,GAGhC,GAAIvD,GAAkBuD,IAASA,EAAKS,eAAiBT,GAAMvD,eAC3D,OAAOA,GAA+C,SAA7BA,EAAgBqK,UAAsB,GAIhEhC,EAAUkI,GAAOlI,WAOjB2E,EAAcuD,GAAOvD,YAAc,SAAU+F,GAC5C,GAAIC,GAAMD,EAAOA,EAAK/O,eAAiB+O,EAAOzF,EAC7C2F,EAASD,EAAIE,WAGd,OAAKF,KAAQlT,GAA6B,IAAjBkT,EAAIjP,UAAmBiP,EAAIhT,iBAKpDF,EAAWkT,EACXjT,EAAUiT,EAAIhT,gBAGdiN,GAAkBL,EAAOoG,GAMpBC,GAAUA,EAAO9G,aAAe8G,IAAWA,EAAO7G,KACtD6G,EAAO9G,YAAa,iBAAkB,WACrCa,MASF3E,EAAQoG,WAAaqD,GAAO,SAAUC,GAErC,MADAA,GAAIoB,UAAY,KACRpB,EAAId,aAAa,eAO1B5I,EAAQ0B,qBAAuB+H,GAAO,SAAUC,GAE/C,MADAA,GAAIqB,YAAaJ,EAAIK,cAAc,MAC3BtB,EAAIhI,qBAAqB,KAAKrG,SAIvC2E,EAAQyI,uBAAyBgB,GAAO,SAAUC,GAQjD,MAPAA,GAAIuB,UAAY,+CAIhBvB,EAAIwB,WAAWJ,UAAY,IAGuB,IAA3CpB,EAAIjB,uBAAuB,KAAKpN,SAOxC2E,EAAQmL,QAAU1B,GAAO,SAAUC,GAElC,MADAhS,GAAQqT,YAAarB,GAAMxN,GAAKqC,GACxBoM,EAAIS,oBAAsBT,EAAIS,kBAAmB7M,GAAUlD,SAI/D2E,EAAQmL,SACZ9G,EAAK9I,KAAS,GAAI,SAAUW,EAAIhD,GAC/B,SAAYA,GAAQ8C,iBAAmB2J,GAAgBf,EAAiB,CACvE,GAAIwD,GAAIlP,EAAQ8C,eAAgBE,EAGhC,OAAOkM,IAAKA,EAAEnM,YAAcmM,QAG9B/D,EAAKgH,OAAW,GAAI,SAAUnP,GAC7B,GAAIoP,GAASpP,EAAGwC,QAASgJ,GAAWC,GACpC,OAAO,UAAUzM,GAChB,MAAOA,GAAK0N,aAAa,QAAU0C,YAM9BjH,GAAK9I,KAAS,GAErB8I,EAAKgH,OAAW,GAAK,SAAUnP,GAC9B,GAAIoP,GAASpP,EAAGwC,QAASgJ,GAAWC,GACpC,OAAO,UAAUzM,GAChB,GAAIwP,SAAcxP,GAAKqQ,mBAAqB5F,GAAgBzK,EAAKqQ,iBAAiB,KAClF,OAAOb,IAAQA,EAAKxI,QAAUoJ,KAMjCjH,EAAK9I,KAAU,IAAIyE,EAAQ0B,qBAC1B,SAAU8J,EAAKtS,GACd,aAAYA,GAAQwI,uBAAyBiE,EACrCzM,EAAQwI,qBAAsB8J,GADtC,GAID,SAAUA,EAAKtS,GACd,GAAIgC,GACHkG,KACA9D,EAAI,EACJgF,EAAUpJ,EAAQwI,qBAAsB8J,EAGzC,IAAa,MAARA,EAAc,CAClB,MAAStQ,EAAOoH,EAAQhF,KACA,IAAlBpC,EAAKQ,UACT0F,EAAI9I,KAAM4C,EAIZ,OAAOkG,GAER,MAAOkB,IAIT+B,EAAK9I,KAAY,MAAIyE,EAAQyI,wBAA0B,SAAUqC,EAAW5R,GAC3E,aAAYA,GAAQuP,yBAA2B9C,GAAgBf,EACvD1L,EAAQuP,uBAAwBqC,GADxC,GAWDhG,KAOAD,MAEM7E,EAAQ0I,IAAMpB,EAAQ1L,KAAM+O,EAAI3B,qBAGrCS,GAAO,SAAUC,GAMhBA,EAAIuB,UAAY,iDAIVvB,EAAIV,iBAAiB,cAAc3N,QACxCwJ,EAAUvM,KAAM,MAAQ2N,EAAa,aAAeD,EAAW,KAM1D0D,EAAIV,iBAAiB,YAAY3N,QACtCwJ,EAAUvM,KAAK,cAIjBmR,GAAO,SAAUC,GAOhB,GAAI+B,GAAQd,EAAIjK,cAAc,QAC9B+K,GAAM5C,aAAc,OAAQ,UAC5Ba,EAAIqB,YAAaU,GAAQ5C,aAAc,IAAK,IAEvCa,EAAIV,iBAAiB,WAAW3N,QACpCwJ,EAAUvM,KAAM,SAAW2N,EAAa,gBAKnCyD,EAAIV,iBAAiB,YAAY3N,QACtCwJ,EAAUvM,KAAM,WAAY,aAI7BoR,EAAIV,iBAAiB,QACrBnE,EAAUvM,KAAK,YAIX0H,EAAQ0L,gBAAkBpE,EAAQ1L,KAAOmJ,EAAUrN,EAAQiU,uBAChEjU,EAAQkU,oBACRlU,EAAQmU,kBACRnU,EAAQoU,qBAERrC,GAAO,SAAUC,GAGhB1J,EAAQ+L,kBAAoBhH,EAAQ1I,KAAMqN,EAAK,OAI/C3E,EAAQ1I,KAAMqN,EAAK,aACnB5E,EAAcxM,KAAM,KAAM+N,KAI5BxB,EAAYA,EAAUxJ,QAAciL,OAAQzB,EAAUkE,KAAK,MAC3DjE,EAAgBA,EAAczJ,QAAciL,OAAQxB,EAAciE,KAAK,MAQvE/D,EAAWsC,EAAQ1L,KAAMlE,EAAQsN,WAActN,EAAQsU,wBACtD,SAAUvG,EAAGC,GACZ,GAAIuG,GAAuB,IAAfxG,EAAE/J,SAAiB+J,EAAE9N,gBAAkB8N,EAClDyG,EAAMxG,GAAKA,EAAEzJ,UACd,OAAOwJ,KAAMyG,MAAWA,GAAwB,IAAjBA,EAAIxQ,YAClCuQ,EAAMjH,SACLiH,EAAMjH,SAAUkH,GAChBzG,EAAEuG,yBAA8D,GAAnCvG,EAAEuG,wBAAyBE,MAG3D,SAAUzG,EAAGC,GACZ,GAAKA,EACJ,MAASA,EAAIA,EAAEzJ,WACd,GAAKyJ,IAAMD,EACV,OAAO,CAIV,QAAO,GAOTD,EAAY9N,EAAQsU,wBACpB,SAAUvG,EAAGC,GAGZ,GAAKD,IAAMC,EAEV,MADAH,IAAe,EACR,CAGR,IAAI4G,GAAUzG,EAAEsG,yBAA2BvG,EAAEuG,yBAA2BvG,EAAEuG,wBAAyBtG,EAEnG,OAAKyG,GAEW,EAAVA,IACFnM,EAAQoM,cAAgB1G,EAAEsG,wBAAyBvG,KAAQ0G,EAGxD1G,IAAMkF,GAAO3F,EAASC,EAAcQ,GACjC,GAEHC,IAAMiF,GAAO3F,EAASC,EAAcS,GACjC,EAIDhB,EACJhM,EAAQ2D,KAAMqI,EAAWe,GAAM/M,EAAQ2D,KAAMqI,EAAWgB,GAC1D,EAGe,EAAVyG,EAAc,GAAK,EAIpB1G,EAAEuG,wBAA0B,GAAK,GAEzC,SAAUvG,EAAGC,GACZ,GAAIuE,GACH3M,EAAI,EACJ+O,EAAM5G,EAAExJ,WACRiQ,EAAMxG,EAAEzJ,WACRqQ,GAAO7G,GACP8G,GAAO7G,EAGR,IAAKD,IAAMC,EAEV,MADAH,IAAe,EACR,CAGD,KAAM8G,IAAQH,EACpB,MAAOzG,KAAMkF,EAAM,GAClBjF,IAAMiF,EAAM,EACZ0B,EAAM,GACNH,EAAM,EACNxH,EACEhM,EAAQ2D,KAAMqI,EAAWe,GAAM/M,EAAQ2D,KAAMqI,EAAWgB,GAC1D,CAGK,IAAK2G,IAAQH,EACnB,MAAOlC,IAAcvE,EAAGC,EAIzBuE,GAAMxE,CACN,OAASwE,EAAMA,EAAIhO,WAClBqQ,EAAGE,QAASvC,EAEbA,GAAMvE,CACN,OAASuE,EAAMA,EAAIhO,WAClBsQ,EAAGC,QAASvC,EAIb,OAAQqC,EAAGhP,KAAOiP,EAAGjP,GACpBA,GAGD,OAAOA,GAEN0M,GAAcsC,EAAGhP,GAAIiP,EAAGjP,IAGxBgP,EAAGhP,KAAO2H,EAAe,GACzBsH,EAAGjP,KAAO2H,EAAe,EACzB,GAGK0F,GA1UClT,GA6UTyQ,GAAOnD,QAAU,SAAU0H,EAAMC,GAChC,MAAOxE,IAAQuE,EAAM,KAAM,KAAMC,IAGlCxE,GAAOwD,gBAAkB,SAAUxQ,EAAMuR,GASxC,IAPOvR,EAAKS,eAAiBT,KAAWzD,GACvCkN,EAAazJ,GAIduR,EAAOA,EAAK/N,QAASgI,EAAkB,aAElC1G,EAAQ0L,kBAAmB9G,GAC5BE,GAAkBA,EAAclJ,KAAM6Q,IACtC5H,GAAkBA,EAAUjJ,KAAM6Q,IAErC,IACC,GAAI/P,GAAMqI,EAAQ1I,KAAMnB,EAAMuR,EAG9B,IAAK/P,GAAOsD,EAAQ+L,mBAGlB7Q,EAAKzD,UAAuC,KAA3ByD,EAAKzD,SAASiE,SAChC,MAAOgB,GAEP,MAAMqD,IAGT,MAAOmI,IAAQuE,EAAMhV,EAAU,MAAOyD,IAAQG,OAAS,GAGxD6M,GAAOlD,SAAW,SAAU9L,EAASgC,GAKpC,OAHOhC,EAAQyC,eAAiBzC,KAAczB,GAC7CkN,EAAazL,GAEP8L,EAAU9L,EAASgC,IAG3BgN,GAAOnM,KAAO,SAAUb,EAAM+C,IAEtB/C,EAAKS,eAAiBT,KAAWzD,GACvCkN,EAAazJ,EAGd,IAAI/B,GAAKkL,EAAK0F,WAAY9L,EAAKgE,eAE9B0K,EAAMxT,GAAM0M,EAAOxJ,KAAMgI,EAAK0F,WAAY9L,EAAKgE,eAC9C9I,EAAI+B,EAAM+C,GAAO2G,GACjBxN,CAEF,OAAOuV,KAAQvV,EACd4I,EAAQoG,aAAexB,EACtB1J,EAAK0N,aAAc3K,IAClB0O,EAAMzR,EAAKqQ,iBAAiBtN,KAAU0O,EAAIC,UAC1CD,EAAIzK,MACJ,KACFyK,GAGFzE,GAAO/H,MAAQ,SAAUC,GACxB,KAAUC,OAAO,0CAA4CD,IAO9D8H,GAAO2E,WAAa,SAAUvK,GAC7B,GAAIpH,GACH4R,KACAtP,EAAI,EACJF,EAAI,CAOL,IAJAiI,GAAgBvF,EAAQ+M,iBACxBrI,GAAa1E,EAAQgN,YAAc1K,EAAQ9J,MAAO,GAClD8J,EAAQ3E,KAAM6H,GAETD,EAAe,CACnB,MAASrK,EAAOoH,EAAQhF,KAClBpC,IAASoH,EAAShF,KACtBE,EAAIsP,EAAWxU,KAAMgF,GAGvB,OAAQE,IACP8E,EAAQ1E,OAAQkP,EAAYtP,GAAK,GAInC,MAAO8E,IAORgC,EAAU4D,GAAO5D,QAAU,SAAUpJ,GACpC,GAAIwP,GACHhO,EAAM,GACNY,EAAI,EACJ5B,EAAWR,EAAKQ,QAEjB,IAAMA,GAMC,GAAkB,IAAbA,GAA+B,IAAbA,GAA+B,KAAbA,EAAkB,CAGjE,GAAiC,gBAArBR,GAAK+R,YAChB,MAAO/R,GAAK+R,WAGZ,KAAM/R,EAAOA,EAAKgQ,WAAYhQ,EAAMA,EAAOA,EAAKkP,YAC/C1N,GAAO4H,EAASpJ,OAGZ,IAAkB,IAAbQ,GAA+B,IAAbA,EAC7B,MAAOR,GAAKgS,cAhBZ,MAASxC,EAAOxP,EAAKoC,GAAKA,IAEzBZ,GAAO4H,EAASoG,EAkBlB,OAAOhO,IAGR2H,EAAO6D,GAAOiF,WAGb7D,YAAa,GAEb8D,aAAc5D,GAEdvO,MAAO4L,EAEPkD,cAEAxO,QAEA8R,UACCC,KAAOC,IAAK,aAAcpQ,OAAO,GACjCqQ,KAAOD,IAAK,cACZE,KAAOF,IAAK,kBAAmBpQ,OAAO,GACtCuQ,KAAOH,IAAK,oBAGbI,WACC1G,KAAQ,SAAUhM,GAUjB,MATAA,GAAM,GAAKA,EAAM,GAAGyD,QAASgJ,GAAWC,IAGxC1M,EAAM,IAAOA,EAAM,IAAMA,EAAM,IAAM,IAAKyD,QAASgJ,GAAWC,IAE5C,OAAb1M,EAAM,KACVA,EAAM,GAAK,IAAMA,EAAM,GAAK,KAGtBA,EAAMzC,MAAO,EAAG,IAGxB2O,MAAS,SAAUlM,GA6BlB,MAlBAA,GAAM,GAAKA,EAAM,GAAGgH,cAEY,QAA3BhH,EAAM,GAAGzC,MAAO,EAAG,IAEjByC,EAAM,IACXiN,GAAO/H,MAAOlF,EAAM,IAKrBA,EAAM,KAAQA,EAAM,GAAKA,EAAM,IAAMA,EAAM,IAAM,GAAK,GAAmB,SAAbA,EAAM,IAA8B,QAAbA,EAAM,KACzFA,EAAM,KAAUA,EAAM,GAAKA,EAAM,IAAqB,QAAbA,EAAM,KAGpCA,EAAM,IACjBiN,GAAO/H,MAAOlF,EAAM,IAGdA,GAGRiM,OAAU,SAAUjM,GACnB,GAAI2S,GACHC,GAAY5S,EAAM,IAAMA,EAAM,EAE/B,OAAK4L,GAAiB,MAAEjL,KAAMX,EAAM,IAC5B,MAIHA,EAAM,IAAMA,EAAM,KAAO7D,EAC7B6D,EAAM,GAAKA,EAAM,GAGN4S,GAAYlH,EAAQ/K,KAAMiS,KAEpCD,EAASjF,GAAUkF,GAAU,MAE7BD,EAASC,EAASnV,QAAS,IAAKmV,EAASxS,OAASuS,GAAWC,EAASxS,UAGvEJ,EAAM,GAAKA,EAAM,GAAGzC,MAAO,EAAGoV,GAC9B3S,EAAM,GAAK4S,EAASrV,MAAO,EAAGoV,IAIxB3S,EAAMzC,MAAO,EAAG,MAIzB6S,QAECrE,IAAO,SAAU8G,GAChB,GAAI9L,GAAW8L,EAAiBpP,QAASgJ,GAAWC,IAAY1F,aAChE,OAA4B,MAArB6L,EACN,WAAa,OAAO,GACpB,SAAU5S,GACT,MAAOA,GAAK8G,UAAY9G,EAAK8G,SAASC,gBAAkBD,IAI3D+E,MAAS,SAAU+D,GAClB,GAAIiD,GAAU5I,EAAY2F,EAAY,IAEtC,OAAOiD,KACLA,EAAczH,OAAQ,MAAQL,EAAa,IAAM6E,EAAY,IAAM7E,EAAa,SACjFd,EAAY2F,EAAW,SAAU5P,GAChC,MAAO6S,GAAQnS,KAAgC,gBAAnBV,GAAK4P,WAA0B5P,EAAK4P,iBAAoB5P,GAAK0N,eAAiBjD,GAAgBzK,EAAK0N,aAAa,UAAY,OAI3J3B,KAAQ,SAAUhJ,EAAM+P,EAAUC,GACjC,MAAO,UAAU/S,GAChB,GAAIgT,GAAShG,GAAOnM,KAAMb,EAAM+C,EAEhC,OAAe,OAAViQ,EACgB,OAAbF,EAEFA,GAINE,GAAU,GAEU,MAAbF,EAAmBE,IAAWD,EACvB,OAAbD,EAAoBE,IAAWD,EAClB,OAAbD,EAAoBC,GAAqC,IAA5BC,EAAOxV,QAASuV,GAChC,OAAbD,EAAoBC,GAASC,EAAOxV,QAASuV,GAAU,GAC1C,OAAbD,EAAoBC,GAASC,EAAO1V,OAAQyV,EAAM5S,UAAa4S,EAClD,OAAbD,GAAsB,IAAME,EAAS,KAAMxV,QAASuV,GAAU,GACjD,OAAbD,EAAoBE,IAAWD,GAASC,EAAO1V,MAAO,EAAGyV,EAAM5S,OAAS,KAAQ4S,EAAQ,KACxF,IAZO,IAgBV9G,MAAS,SAAU3M,EAAM2T,EAAM3D,EAAUrN,EAAOE,GAC/C,GAAI+Q,GAAgC,QAAvB5T,EAAKhC,MAAO,EAAG,GAC3B6V,EAA+B,SAArB7T,EAAKhC,MAAO,IACtB8V,EAAkB,YAATH,CAEV,OAAiB,KAAVhR,GAAwB,IAATE,EAGrB,SAAUnC,GACT,QAASA,EAAKe,YAGf,SAAUf,EAAMhC,EAASiI,GACxB,GAAIkI,GAAOkF,EAAY7D,EAAMR,EAAMsE,EAAWC,EAC7ClB,EAAMa,IAAWC,EAAU,cAAgB,kBAC3CzD,EAAS1P,EAAKe,WACdgC,EAAOqQ,GAAUpT,EAAK8G,SAASC,cAC/ByM,GAAYvN,IAAQmN,CAErB,IAAK1D,EAAS,CAGb,GAAKwD,EAAS,CACb,MAAQb,EAAM,CACb7C,EAAOxP,CACP,OAASwP,EAAOA,EAAM6C,GACrB,GAAKe,EAAS5D,EAAK1I,SAASC,gBAAkBhE,EAAyB,IAAlByM,EAAKhP,SACzD,OAAO,CAIT+S,GAAQlB,EAAe,SAAT/S,IAAoBiU,GAAS,cAE5C,OAAO,EAMR,GAHAA,GAAUJ,EAAUzD,EAAOM,WAAaN,EAAO+D,WAG1CN,GAAWK,EAAW,CAE1BH,EAAa3D,EAAQrM,KAAcqM,EAAQrM,OAC3C8K,EAAQkF,EAAY/T,OACpBgU,EAAYnF,EAAM,KAAOnE,GAAWmE,EAAM,GAC1Ca,EAAOb,EAAM,KAAOnE,GAAWmE,EAAM,GACrCqB,EAAO8D,GAAa5D,EAAO/J,WAAY2N,EAEvC,OAAS9D,IAAS8D,GAAa9D,GAAQA,EAAM6C,KAG3CrD,EAAOsE,EAAY,IAAMC,EAAM3I,MAGhC,GAAuB,IAAlB4E,EAAKhP,YAAoBwO,GAAQQ,IAASxP,EAAO,CACrDqT,EAAY/T,IAAW0K,EAASsJ,EAAWtE,EAC3C,YAKI,IAAKwE,IAAarF,GAASnO,EAAMqD,KAAcrD,EAAMqD,QAAkB/D,KAAW6O,EAAM,KAAOnE,EACrGgF,EAAOb,EAAM,OAKb,OAASqB,IAAS8D,GAAa9D,GAAQA,EAAM6C,KAC3CrD,EAAOsE,EAAY,IAAMC,EAAM3I,MAEhC,IAAOwI,EAAS5D,EAAK1I,SAASC,gBAAkBhE,EAAyB,IAAlByM,EAAKhP,aAAsBwO,IAE5EwE,KACHhE,EAAMnM,KAAcmM,EAAMnM,QAAkB/D,IAAW0K,EAASgF,IAG7DQ,IAASxP,GACb,KAQJ,OADAgP,IAAQ7M,EACD6M,IAAS/M,GAA4B,IAAjB+M,EAAO/M,GAAe+M,EAAO/M,GAAS,KAKrE+J,OAAU,SAAU0H,EAAQpE,GAK3B,GAAI1N,GACH3D,EAAKkL,EAAKgC,QAASuI,IAAYvK,EAAKwK,WAAYD,EAAO3M,gBACtDiG,GAAO/H,MAAO,uBAAyByO,EAKzC,OAAKzV,GAAIoF,GACDpF,EAAIqR,GAIPrR,EAAGkC,OAAS,GAChByB,GAAS8R,EAAQA,EAAQ,GAAIpE,GACtBnG,EAAKwK,WAAW/V,eAAgB8V,EAAO3M,eAC7CuH,GAAa,SAAUrB,EAAMpD,GAC5B,GAAI+J,GACHC,EAAU5V,EAAIgP,EAAMqC,GACpBlN,EAAIyR,EAAQ1T,MACb,OAAQiC,IACPwR,EAAMpW,EAAQ2D,KAAM8L,EAAM4G,EAAQzR,IAClC6K,EAAM2G,KAAW/J,EAAS+J,GAAQC,EAAQzR,MAG5C,SAAUpC,GACT,MAAO/B,GAAI+B,EAAM,EAAG4B,KAIhB3D,IAITkN,SAEC2I,IAAOxF,GAAa,SAAUvQ,GAI7B,GAAIwS,MACHnJ,KACA2M,EAAUzK,EAASvL,EAASyF,QAASlF,EAAO,MAE7C,OAAOyV,GAAS1Q,GACfiL,GAAa,SAAUrB,EAAMpD,EAAS7L,EAASiI,GAC9C,GAAIjG,GACHgU,EAAYD,EAAS9G,EAAM,KAAMhH,MACjC7D,EAAI6K,EAAK9M,MAGV,OAAQiC,KACDpC,EAAOgU,EAAU5R,MACtB6K,EAAK7K,KAAOyH,EAAQzH,GAAKpC,MAI5B,SAAUA,EAAMhC,EAASiI,GAGxB,MAFAsK,GAAM,GAAKvQ,EACX+T,EAASxD,EAAO,KAAMtK,EAAKmB,IACnBA,EAAQwD,SAInBqJ,IAAO3F,GAAa,SAAUvQ,GAC7B,MAAO,UAAUiC,GAChB,MAAOgN,IAAQjP,EAAUiC,GAAOG,OAAS,KAI3C2J,SAAYwE,GAAa,SAAUpH,GAClC,MAAO,UAAUlH,GAChB,OAASA,EAAK+R,aAAe/R,EAAKkU,WAAa9K,EAASpJ,IAASxC,QAAS0J,GAAS,MAWrFiN,KAAQ7F,GAAc,SAAU6F,GAM/B,MAJMzI,GAAYhL,KAAKyT,GAAQ,KAC9BnH,GAAO/H,MAAO,qBAAuBkP,GAEtCA,EAAOA,EAAK3Q,QAASgJ,GAAWC,IAAY1F,cACrC,SAAU/G,GAChB,GAAIoU,EACJ,GACC,IAAMA,EAAW1K,EAChB1J,EAAKmU,KACLnU,EAAK0N,aAAa,aAAe1N,EAAK0N,aAAa,QAGnD,MADA0G,GAAWA,EAASrN,cACbqN,IAAaD,GAA2C,IAAnCC,EAAS5W,QAAS2W,EAAO,YAE5CnU,EAAOA,EAAKe,aAAiC,IAAlBf,EAAKQ,SAC3C,QAAO,KAKT0C,OAAU,SAAUlD,GACnB,GAAIqU,GAAOpY,EAAOK,UAAYL,EAAOK,SAAS+X,IAC9C,OAAOA,IAAQA,EAAK/W,MAAO,KAAQ0C,EAAKgB,IAGzCsT,KAAQ,SAAUtU,GACjB,MAAOA,KAASxD,GAGjB+X,MAAS,SAAUvU,GAClB,MAAOA,KAASzD,EAASiY,iBAAmBjY,EAASkY,UAAYlY,EAASkY,gBAAkBzU,EAAKV,MAAQU,EAAK0U,OAAS1U,EAAK2U,WAI7HC,QAAW,SAAU5U,GACpB,MAAOA,GAAK6U,YAAa,GAG1BA,SAAY,SAAU7U,GACrB,MAAOA,GAAK6U,YAAa,GAG1BC,QAAW,SAAU9U,GAGpB,GAAI8G,GAAW9G,EAAK8G,SAASC,aAC7B,OAAqB,UAAbD,KAA0B9G,EAAK8U,SAA0B,WAAbhO,KAA2B9G,EAAK+U,UAGrFA,SAAY,SAAU/U,GAOrB,MAJKA,GAAKe,YACTf,EAAKe,WAAWiU,cAGVhV,EAAK+U,YAAa,GAI1BE,MAAS,SAAUjV,GAMlB,IAAMA,EAAOA,EAAKgQ,WAAYhQ,EAAMA,EAAOA,EAAKkP,YAC/C,GAAKlP,EAAK8G,SAAW,KAAyB,IAAlB9G,EAAKQ,UAAoC,IAAlBR,EAAKQ,SACvD,OAAO,CAGT,QAAO,GAGRkP,OAAU,SAAU1P,GACnB,OAAQmJ,EAAKgC,QAAe,MAAGnL,IAIhCkV,OAAU,SAAUlV,GACnB,MAAOsM,IAAQ5L,KAAMV,EAAK8G,WAG3ByJ,MAAS,SAAUvQ,GAClB,MAAOqM,IAAQ3L,KAAMV,EAAK8G,WAG3BqO,OAAU,SAAUnV,GACnB,GAAI+C,GAAO/C,EAAK8G,SAASC,aACzB,OAAgB,UAAThE,GAAkC,WAAd/C,EAAKV,MAA8B,WAATyD,GAGtDmE,KAAQ,SAAUlH,GACjB,GAAIa,EAGJ,OAAuC,UAAhCb,EAAK8G,SAASC,eACN,SAAd/G,EAAKV,OACmC,OAArCuB,EAAOb,EAAK0N,aAAa,UAAoB7M,EAAKkG,gBAAkB/G,EAAKV,OAI9E2C,MAASoN,GAAuB,WAC/B,OAAS,KAGVlN,KAAQkN,GAAuB,SAAUE,EAAcpP,GACtD,OAASA,EAAS,KAGnB+B,GAAMmN,GAAuB,SAAUE,EAAcpP,EAAQmP,GAC5D,OAAoB,EAAXA,EAAeA,EAAWnP,EAASmP,KAG7C8F,KAAQ/F,GAAuB,SAAUE,EAAcpP,GACtD,GAAIiC,GAAI,CACR,MAAYjC,EAAJiC,EAAYA,GAAK,EACxBmN,EAAanS,KAAMgF,EAEpB,OAAOmN,KAGR8F,IAAOhG,GAAuB,SAAUE,EAAcpP,GACrD,GAAIiC,GAAI,CACR,MAAYjC,EAAJiC,EAAYA,GAAK,EACxBmN,EAAanS,KAAMgF,EAEpB,OAAOmN,KAGR+F,GAAMjG,GAAuB,SAAUE,EAAcpP,EAAQmP,GAC5D,GAAIlN,GAAe,EAAXkN,EAAeA,EAAWnP,EAASmP,CAC3C,QAAUlN,GAAK,GACdmN,EAAanS,KAAMgF,EAEpB,OAAOmN,KAGRgG,GAAMlG,GAAuB,SAAUE,EAAcpP,EAAQmP,GAC5D,GAAIlN,GAAe,EAAXkN,EAAeA,EAAWnP,EAASmP,CAC3C,MAAcnP,IAAJiC,GACTmN,EAAanS,KAAMgF,EAEpB,OAAOmN,OAKVpG,EAAKgC,QAAa,IAAIhC,EAAKgC,QAAY,EAGvC,KAAM/I,KAAOoT,OAAO,EAAMC,UAAU,EAAMC,MAAM,EAAMC,UAAU,EAAMC,OAAO,GAC5EzM,EAAKgC,QAAS/I,GAAM+M,GAAmB/M,EAExC,KAAMA,KAAOyT,QAAQ,EAAMC,OAAO,GACjC3M,EAAKgC,QAAS/I,GAAMgN,GAAoBhN,EAIzC,SAASuR,OACTA,GAAW/T,UAAYuJ,EAAK4M,QAAU5M,EAAKgC,QAC3ChC,EAAKwK,WAAa,GAAIA,GAEtB,SAASlG,IAAU1P,EAAUiY,GAC5B,GAAInC,GAAS9T,EAAOkW,EAAQ3W,EAC3B4W,EAAO/I,EAAQgJ,EACfC,EAASjM,EAAYpM,EAAW,IAEjC,IAAKqY,EACJ,MAAOJ,GAAY,EAAII,EAAO9Y,MAAO,EAGtC4Y,GAAQnY,EACRoP,KACAgJ,EAAahN,EAAKsJ,SAElB,OAAQyD,EAAQ,GAGTrC,IAAY9T,EAAQsL,EAAOjL,KAAM8V,OACjCnW,IAEJmW,EAAQA,EAAM5Y,MAAOyC,EAAM,GAAGI,SAAY+V,GAE3C/I,EAAO/P,KAAM6Y,OAGdpC,GAAU,GAGJ9T,EAAQuL,EAAalL,KAAM8V,MAChCrC,EAAU9T,EAAMsO,QAChB4H,EAAO7Y,MACN4J,MAAO6M,EAEPvU,KAAMS,EAAM,GAAGyD,QAASlF,EAAO,OAEhC4X,EAAQA,EAAM5Y,MAAOuW,EAAQ1T,QAI9B,KAAMb,IAAQ6J,GAAKgH,SACZpQ,EAAQ4L,EAAWrM,GAAOc,KAAM8V,KAAcC,EAAY7W,MAC9DS,EAAQoW,EAAY7W,GAAQS,MAC7B8T,EAAU9T,EAAMsO,QAChB4H,EAAO7Y,MACN4J,MAAO6M,EACPvU,KAAMA,EACNuK,QAAS9J,IAEVmW,EAAQA,EAAM5Y,MAAOuW,EAAQ1T,QAI/B,KAAM0T,EACL,MAOF,MAAOmC,GACNE,EAAM/V,OACN+V,EACClJ,GAAO/H,MAAOlH,GAEdoM,EAAYpM,EAAUoP,GAAS7P,MAAO,GAGzC,QAASsQ,IAAYqI,GACpB,GAAI7T,GAAI,EACPC,EAAM4T,EAAO9V,OACbpC,EAAW,EACZ,MAAYsE,EAAJD,EAASA,IAChBrE,GAAYkY,EAAO7T,GAAG4E,KAEvB,OAAOjJ,GAGR,QAASsY,IAAetC,EAASuC,EAAYC,GAC5C,GAAIlE,GAAMiE,EAAWjE,IACpBmE,EAAmBD,GAAgB,eAARlE,EAC3BoE,EAAW3U,GAEZ,OAAOwU,GAAWrU,MAEjB,SAAUjC,EAAMhC,EAASiI,GACxB,MAASjG,EAAOA,EAAMqS,GACrB,GAAuB,IAAlBrS,EAAKQ,UAAkBgW,EAC3B,MAAOzC,GAAS/T,EAAMhC,EAASiI,IAMlC,SAAUjG,EAAMhC,EAASiI,GACxB,GAAIb,GAAM+I,EAAOkF,EAChBqD,EAAS1M,EAAU,IAAMyM,CAG1B,IAAKxQ,GACJ,MAASjG,EAAOA,EAAMqS,GACrB,IAAuB,IAAlBrS,EAAKQ,UAAkBgW,IACtBzC,EAAS/T,EAAMhC,EAASiI,GAC5B,OAAO,MAKV,OAASjG,EAAOA,EAAMqS,GACrB,GAAuB,IAAlBrS,EAAKQ,UAAkBgW,EAE3B,GADAnD,EAAarT,EAAMqD,KAAcrD,EAAMqD,QACjC8K,EAAQkF,EAAYhB,KAAUlE,EAAM,KAAOuI,GAChD,IAAMtR,EAAO+I,EAAM,OAAQ,GAAQ/I,IAAS8D,EAC3C,MAAO9D,MAAS,MAKjB,IAFA+I,EAAQkF,EAAYhB,IAAUqE,GAC9BvI,EAAM,GAAK4F,EAAS/T,EAAMhC,EAASiI,IAASiD,EACvCiF,EAAM,MAAO,EACjB,OAAO,GASf,QAASwI,IAAgBC,GACxB,MAAOA,GAASzW,OAAS,EACxB,SAAUH,EAAMhC,EAASiI,GACxB,GAAI7D,GAAIwU,EAASzW,MACjB,OAAQiC,IACP,IAAMwU,EAASxU,GAAIpC,EAAMhC,EAASiI,GACjC,OAAO,CAGT,QAAO,GAER2Q,EAAS,GAGX,QAASC,IAAU7C,EAAWzR,EAAK4N,EAAQnS,EAASiI,GACnD,GAAIjG,GACH8W,KACA1U,EAAI,EACJC,EAAM2R,EAAU7T,OAChB4W,EAAgB,MAAPxU,CAEV,MAAYF,EAAJD,EAASA,KACVpC,EAAOgU,EAAU5R,OAChB+N,GAAUA,EAAQnQ,EAAMhC,EAASiI,MACtC6Q,EAAa1Z,KAAM4C,GACd+W,GACJxU,EAAInF,KAAMgF,GAMd,OAAO0U,GAGR,QAASE,IAAYvE,EAAW1U,EAAUgW,EAASkD,EAAYC,EAAYC,GAO1E,MANKF,KAAeA,EAAY5T,KAC/B4T,EAAaD,GAAYC,IAErBC,IAAeA,EAAY7T,KAC/B6T,EAAaF,GAAYE,EAAYC,IAE/B7I,GAAa,SAAUrB,EAAM7F,EAASpJ,EAASiI,GACrD,GAAImR,GAAMhV,EAAGpC,EACZqX,KACAC,KACAC,EAAcnQ,EAAQjH,OAGtBoB,EAAQ0L,GAAQuK,GAAkBzZ,GAAY,IAAKC,EAAQwC,UAAaxC,GAAYA,MAGpFyZ,GAAYhF,IAAexF,GAASlP,EAEnCwD,EADAsV,GAAUtV,EAAO8V,EAAQ5E,EAAWzU,EAASiI,GAG9CyR,EAAa3D,EAEZmD,IAAgBjK,EAAOwF,EAAY8E,GAAeN,MAMjD7P,EACDqQ,CAQF,IALK1D,GACJA,EAAS0D,EAAWC,EAAY1Z,EAASiI,GAIrCgR,EAAa,CACjBG,EAAOP,GAAUa,EAAYJ,GAC7BL,EAAYG,KAAUpZ,EAASiI,GAG/B7D,EAAIgV,EAAKjX,MACT,OAAQiC,KACDpC,EAAOoX,EAAKhV,MACjBsV,EAAYJ,EAAQlV,MAASqV,EAAWH,EAAQlV,IAAOpC,IAK1D,GAAKiN,GACJ,GAAKiK,GAAczE,EAAY,CAC9B,GAAKyE,EAAa,CAEjBE,KACAhV,EAAIsV,EAAWvX,MACf,OAAQiC,KACDpC,EAAO0X,EAAWtV,KAEvBgV,EAAKha,KAAOqa,EAAUrV,GAAKpC,EAG7BkX,GAAY,KAAOQ,KAAkBN,EAAMnR,GAI5C7D,EAAIsV,EAAWvX,MACf,OAAQiC,KACDpC,EAAO0X,EAAWtV,MACtBgV,EAAOF,EAAa1Z,EAAQ2D,KAAM8L,EAAMjN,GAASqX,EAAOjV,IAAM,KAE/D6K,EAAKmK,KAAUhQ,EAAQgQ,GAAQpX,SAOlC0X,GAAab,GACZa,IAAetQ,EACdsQ,EAAWhV,OAAQ6U,EAAaG,EAAWvX,QAC3CuX,GAEGR,EACJA,EAAY,KAAM9P,EAASsQ,EAAYzR,GAEvC7I,EAAK2E,MAAOqF,EAASsQ,KAMzB,QAASC,IAAmB1B,GAC3B,GAAI2B,GAAc7D,EAASzR,EAC1BD,EAAM4T,EAAO9V,OACb0X,EAAkB1O,EAAKgJ,SAAU8D,EAAO,GAAG3W,MAC3CwY,EAAmBD,GAAmB1O,EAAKgJ,SAAS,KACpD/P,EAAIyV,EAAkB,EAAI,EAG1BE,EAAe1B,GAAe,SAAUrW,GACvC,MAAOA,KAAS4X,GACdE,GAAkB,GACrBE,EAAkB3B,GAAe,SAAUrW,GAC1C,MAAOxC,GAAQ2D,KAAMyW,EAAc5X,GAAS,IAC1C8X,GAAkB,GACrBlB,GAAa,SAAU5W,EAAMhC,EAASiI,GACrC,OAAU4R,IAAqB5R,GAAOjI,IAAYuL,MAChDqO,EAAe5Z,GAASwC,SACxBuX,EAAc/X,EAAMhC,EAASiI,GAC7B+R,EAAiBhY,EAAMhC,EAASiI,KAGpC,MAAY5D,EAAJD,EAASA,IAChB,GAAM2R,EAAU5K,EAAKgJ,SAAU8D,EAAO7T,GAAG9C,MACxCsX,GAAaP,GAAcM,GAAgBC,GAAY7C,QACjD,CAIN,GAHAA,EAAU5K,EAAKgH,OAAQ8F,EAAO7T,GAAG9C,MAAOyC,MAAO,KAAMkU,EAAO7T,GAAGyH,SAG1DkK,EAAS1Q,GAAY,CAGzB,IADAf,IAAMF,EACMC,EAAJC,EAASA,IAChB,GAAK6G,EAAKgJ,SAAU8D,EAAO3T,GAAGhD,MAC7B,KAGF,OAAO0X,IACN5U,EAAI,GAAKuU,GAAgBC,GACzBxU,EAAI,GAAKwL,GAERqI,EAAO3Y,MAAO,EAAG8E,EAAI,GAAIlF,QAAS8J,MAAgC,MAAzBiP,EAAQ7T,EAAI,GAAI9C,KAAe,IAAM,MAC7EkE,QAASlF,EAAO,MAClByV,EACIzR,EAAJF,GAASuV,GAAmB1B,EAAO3Y,MAAO8E,EAAGE,IACzCD,EAAJC,GAAWqV,GAAoB1B,EAASA,EAAO3Y,MAAOgF,IAClDD,EAAJC,GAAWsL,GAAYqI,IAGzBW,EAASxZ,KAAM2W,GAIjB,MAAO4C,IAAgBC,GAGxB,QAASqB,IAA0BC,EAAiBC,GAEnD,GAAIC,GAAoB,EACvBC,EAAQF,EAAYhY,OAAS,EAC7BmY,EAAYJ,EAAgB/X,OAAS,EACrCoY,EAAe,SAAUtL,EAAMjP,EAASiI,EAAKmB,EAASoR,GACrD,GAAIxY,GAAMsC,EAAGyR,EACZ0E,KACAC,EAAe,EACftW,EAAI,IACJ4R,EAAY/G,MACZ0L,EAA6B,MAAjBH,EACZI,EAAgBrP,EAEhBhI,EAAQ0L,GAAQqL,GAAanP,EAAK9I,KAAU,IAAG,IAAKmY,GAAiBxa,EAAQ+C,YAAc/C,GAE3F6a,EAAiB7O,GAA4B,MAAjB4O,EAAwB,EAAItV,KAAKC,UAAY,EAS1E,KAPKoV,IACJpP,EAAmBvL,IAAYzB,GAAYyB,EAC3CkL,EAAakP,GAKe,OAApBpY,EAAOuB,EAAMa,IAAaA,IAAM,CACxC,GAAKkW,GAAatY,EAAO,CACxBsC,EAAI,CACJ,OAASyR,EAAUmE,EAAgB5V,KAClC,GAAKyR,EAAS/T,EAAMhC,EAASiI,GAAQ,CACpCmB,EAAQhK,KAAM4C,EACd,OAGG2Y,IACJ3O,EAAU6O,EACV3P,IAAekP,GAKZC,KAEErY,GAAQ+T,GAAW/T,IACxB0Y,IAIIzL,GACJ+G,EAAU5W,KAAM4C,IAOnB,GADA0Y,GAAgBtW,EACXiW,GAASjW,IAAMsW,EAAe,CAClCpW,EAAI,CACJ,OAASyR,EAAUoE,EAAY7V,KAC9ByR,EAASC,EAAWyE,EAAYza,EAASiI,EAG1C,IAAKgH,EAAO,CAEX,GAAKyL,EAAe,EACnB,MAAQtW,IACA4R,EAAU5R,IAAMqW,EAAWrW,KACjCqW,EAAWrW,GAAKwI,EAAIzJ,KAAMiG,GAM7BqR,GAAa5B,GAAU4B,GAIxBrb,EAAK2E,MAAOqF,EAASqR,GAGhBE,IAAc1L,GAAQwL,EAAWtY,OAAS,GAC5CuY,EAAeP,EAAYhY,OAAW,GAExC6M,GAAO2E,WAAYvK,GAUrB,MALKuR,KACJ3O,EAAU6O,EACVtP,EAAmBqP,GAGb5E,EAGT,OAAOqE,GACN/J,GAAciK,GACdA,EAGFjP,EAAU0D,GAAO1D,QAAU,SAAUvL,EAAU+a,GAC9C,GAAI1W,GACH+V,KACAD,KACA9B,EAAShM,EAAerM,EAAW,IAEpC,KAAMqY,EAAS,CAER0C,IACLA,EAAQrL,GAAU1P,IAEnBqE,EAAI0W,EAAM3Y,MACV,OAAQiC,IACPgU,EAASuB,GAAmBmB,EAAM1W,IAC7BgU,EAAQ/S,GACZ8U,EAAY/a,KAAMgZ,GAElB8B,EAAgB9a,KAAMgZ,EAKxBA,GAAShM,EAAerM,EAAUka,GAA0BC,EAAiBC,IAE9E,MAAO/B,GAGR,SAASoB,IAAkBzZ,EAAUgb,EAAU3R,GAC9C,GAAIhF,GAAI,EACPC,EAAM0W,EAAS5Y,MAChB,MAAYkC,EAAJD,EAASA,IAChB4K,GAAQjP,EAAUgb,EAAS3W,GAAIgF,EAEhC,OAAOA,GAGR,QAAS6G,IAAQlQ,EAAUC,EAASoJ,EAAS6F,GAC5C,GAAI7K,GAAG6T,EAAQ+C,EAAO1Z,EAAMe,EAC3BN,EAAQ0N,GAAU1P,EAEnB,KAAMkP,GAEiB,IAAjBlN,EAAMI,OAAe,CAIzB,GADA8V,EAASlW,EAAM,GAAKA,EAAM,GAAGzC,MAAO,GAC/B2Y,EAAO9V,OAAS,GAAkC,QAA5B6Y,EAAQ/C,EAAO,IAAI3W,MAC5CwF,EAAQmL,SAAgC,IAArBjS,EAAQwC,UAAkBkJ,GAC7CP,EAAKgJ,SAAU8D,EAAO,GAAG3W,MAAS,CAGnC,GADAtB,GAAYmL,EAAK9I,KAAS,GAAG2Y,EAAMnP,QAAQ,GAAGrG,QAAQgJ,GAAWC,IAAYzO,QAAkB,IACzFA,EACL,MAAOoJ,EAERrJ,GAAWA,EAAST,MAAO2Y,EAAO5H,QAAQrH,MAAM7G,QAIjDiC,EAAIuJ,EAAwB,aAAEjL,KAAM3C,GAAa,EAAIkY,EAAO9V,MAC5D,OAAQiC,IAAM,CAIb,GAHA4W,EAAQ/C,EAAO7T,GAGV+G,EAAKgJ,SAAW7S,EAAO0Z,EAAM1Z,MACjC,KAED,KAAMe,EAAO8I,EAAK9I,KAAMf,MAEjB2N,EAAO5M,EACZ2Y,EAAMnP,QAAQ,GAAGrG,QAASgJ,GAAWC,IACrClB,EAAS7K,KAAMuV,EAAO,GAAG3W,OAAUtB,EAAQ+C,YAAc/C,IACrD,CAKJ,GAFAiY,EAAOvT,OAAQN,EAAG,GAClBrE,EAAWkP,EAAK9M,QAAUyN,GAAYqI,IAChClY,EAEL,MADAX,GAAK2E,MAAOqF,EAAS6F,GACd7F,CAGR,SAgBL,MAPAkC,GAASvL,EAAUgC,GAClBkN,EACAjP,GACC0L,EACDtC,EACAmE,EAAS7K,KAAM3C,IAETqJ,EAMRtC,EAAQgN,WAAazO,EAAQ4F,MAAM,IAAIxG,KAAM6H,GAAYuD,KAAK,MAAQxK,EAItEyB,EAAQ+M,iBAAmBxH,EAG3BZ,IAIA3E,EAAQoM,aAAe3C,GAAO,SAAU0K,GAEvC,MAAuE,GAAhEA,EAAKnI,wBAAyBvU,EAASiJ,cAAc,UAMvD+I,GAAO,SAAUC,GAEtB,MADAA,GAAIuB,UAAY,mBAC+B,MAAxCvB,EAAIwB,WAAWtC,aAAa,WAEnCgB,GAAW,yBAA0B,SAAU1O,EAAM+C,EAAMsG,GAC1D,MAAMA,GAAN,EACQrJ,EAAK0N,aAAc3K,EAA6B,SAAvBA,EAAKgE,cAA2B,EAAI,KAOjEjC,EAAQoG,YAAeqD,GAAO,SAAUC,GAG7C,MAFAA,GAAIuB,UAAY,WAChBvB,EAAIwB,WAAWrC,aAAc,QAAS,IACY,KAA3Ca,EAAIwB,WAAWtC,aAAc,YAEpCgB,GAAW,QAAS,SAAU1O,EAAM+C,EAAMsG,GACzC,MAAMA,IAAyC,UAAhCrJ,EAAK8G,SAASC,cAA7B,EACQ/G,EAAKkZ,eAOT3K,GAAO,SAAUC,GACtB,MAAuC,OAAhCA,EAAId,aAAa,eAExBgB,GAAW5D,EAAU,SAAU9K,EAAM+C,EAAMsG,GAC1C,GAAIoI,EACJ,OAAMpI,GAAN,GACSoI,EAAMzR,EAAKqQ,iBAAkBtN,KAAW0O,EAAIC,UACnDD,EAAIzK,MACJhH,EAAM+C,MAAW,EAAOA,EAAKgE,cAAgB,OAKjDpK,EAAO0D,KAAO2M,GACdrQ,EAAO4U,KAAOvE,GAAOiF,UACrBtV,EAAO4U,KAAK,KAAO5U,EAAO4U,KAAKpG,QAC/BxO,EAAOwc,OAASnM,GAAO2E,WACvBhV,EAAOuK,KAAO8F,GAAO5D,QACrBzM,EAAOyc,SAAWpM,GAAO3D,MACzB1M,EAAOmN,SAAWkD,GAAOlD,UAGrB7N,EAEJ,IAAIod,KAGJ,SAASC,GAAetW,GACvB,GAAIuW,GAASF,EAAcrW,KAI3B,OAHArG,GAAO+E,KAAMsB,EAAQjD,MAAO1B,OAAwB,SAAUqO,EAAG8M,GAChED,EAAQC,IAAS,IAEXD,EAyBR5c,EAAO8c,UAAY,SAAUzW,GAI5BA,EAA6B,gBAAZA,GACdqW,EAAcrW,IAAasW,EAAetW,GAC5CrG,EAAOgG,UAAYK,EAEpB,IACC0W,GAEAC,EAEAC,EAEAC,EAEAC,EAEAC,EAEAC,KAEAC,GAASjX,EAAQkX,SAEjBC,EAAO,SAAU/U,GAOhB,IANAuU,EAAS3W,EAAQ2W,QAAUvU,EAC3BwU,GAAQ,EACRE,EAAcC,GAAe,EAC7BA,EAAc,EACdF,EAAeG,EAAK7Z,OACpBuZ,GAAS,EACDM,GAAsBH,EAAdC,EAA4BA,IAC3C,GAAKE,EAAMF,GAAc/X,MAAOqD,EAAM,GAAKA,EAAM,OAAU,GAASpC,EAAQoX,YAAc,CACzFT,GAAS,CACT,OAGFD,GAAS,EACJM,IACCC,EACCA,EAAM9Z,QACVga,EAAMF,EAAM5L,SAEFsL,EACXK,KAEAK,EAAKC,YAKRD,GAECE,IAAK,WACJ,GAAKP,EAAO,CAEX,GAAIzG,GAAQyG,EAAK7Z,QACjB,QAAUoa,GAAK3Y,GACdjF,EAAO+E,KAAME,EAAM,SAAU8K,EAAG7E,GAC/B,GAAIvI,GAAO3C,EAAO2C,KAAMuI,EACV,cAATvI,EACE0D,EAAQmW,QAAWkB,EAAKpG,IAAKpM,IAClCmS,EAAK5c,KAAMyK,GAEDA,GAAOA,EAAI1H,QAAmB,WAATb,GAEhCib,EAAK1S,OAGJ7F,WAGC0X,EACJG,EAAeG,EAAK7Z,OAGTwZ,IACXI,EAAcxG,EACd4G,EAAMR,IAGR,MAAO1Z,OAGRyF,OAAQ,WAkBP,MAjBKsU,IACJrd,EAAO+E,KAAMM,UAAW,SAAU0K,EAAG7E,GACpC,GAAI2S,EACJ,QAASA,EAAQ7d,EAAO2K,QAASO,EAAKmS,EAAMQ,IAAY,GACvDR,EAAKtX,OAAQ8X,EAAO,GAEfd,IACUG,GAATW,GACJX,IAEaC,GAATU,GACJV,OAME7Z,MAIRgU,IAAK,SAAUhW,GACd,MAAOA,GAAKtB,EAAO2K,QAASrJ,EAAI+b,GAAS,MAASA,IAAQA,EAAK7Z,SAGhE8U,MAAO,WAGN,MAFA+E,MACAH,EAAe,EACR5Z,MAGRqa,QAAS,WAER,MADAN,GAAOC,EAAQN,EAASzd,EACjB+D,MAGR4U,SAAU,WACT,OAAQmF,GAGTS,KAAM,WAKL,MAJAR,GAAQ/d,EACFyd,GACLU,EAAKC,UAECra,MAGRya,OAAQ,WACP,OAAQT,GAGTU,SAAU,SAAU3c,EAAS4D,GAU5B,OATKoY,GAAWJ,IAASK,IACxBrY,EAAOA,MACPA,GAAS5D,EAAS4D,EAAKtE,MAAQsE,EAAKtE,QAAUsE,GACzC8X,EACJO,EAAM7c,KAAMwE,GAEZuY,EAAMvY,IAGD3B,MAGRka,KAAM,WAEL,MADAE,GAAKM,SAAU1a,KAAM+B,WACd/B,MAGR2Z,MAAO,WACN,QAASA,GAIZ,OAAOS,IAER1d,EAAOgG,QAENgG,SAAU,SAAUiS,GACnB,GAAIC,KAEA,UAAW,OAAQle,EAAO8c,UAAU,eAAgB,aACpD,SAAU,OAAQ9c,EAAO8c,UAAU,eAAgB,aACnD,SAAU,WAAY9c,EAAO8c,UAAU,YAE1CqB,EAAQ,UACRjZ,GACCiZ,MAAO,WACN,MAAOA,IAERC,OAAQ,WAEP,MADAC,GAASlZ,KAAME,WAAYiZ,KAAMjZ,WAC1B/B,MAERib,KAAM,WACL,GAAIC,GAAMnZ,SACV,OAAOrF,GAAOgM,SAAS,SAAUyS,GAChCze,EAAO+E,KAAMmZ,EAAQ,SAAUzY,EAAGiZ,GACjC,GAAIC,GAASD,EAAO,GACnBpd,EAAKtB,EAAOiE,WAAYua,EAAK/Y,KAAS+Y,EAAK/Y,EAE5C4Y,GAAUK,EAAM,IAAK,WACpB,GAAIE,GAAWtd,GAAMA,EAAG8D,MAAO9B,KAAM+B,UAChCuZ,IAAY5e,EAAOiE,WAAY2a,EAAS1Z,SAC5C0Z,EAAS1Z,UACPC,KAAMsZ,EAASI,SACfP,KAAMG,EAASK,QACfC,SAAUN,EAASO,QAErBP,EAAUE,EAAS,QAAUrb,OAAS4B,EAAUuZ,EAASvZ,UAAY5B,KAAMhC,GAAOsd,GAAavZ,eAIlGmZ,EAAM,OACJtZ,WAIJA,QAAS,SAAUuC,GAClB,MAAc,OAAPA,EAAczH,EAAOgG,OAAQyB,EAAKvC,GAAYA,IAGvDmZ,IAwCD,OArCAnZ,GAAQ+Z,KAAO/Z,EAAQqZ,KAGvBve,EAAO+E,KAAMmZ,EAAQ,SAAUzY,EAAGiZ,GACjC,GAAIrB,GAAOqB,EAAO,GACjBQ,EAAcR,EAAO,EAGtBxZ,GAASwZ,EAAM,IAAOrB,EAAKO,IAGtBsB,GACJ7B,EAAKO,IAAI,WAERO,EAAQe,GAGNhB,EAAY,EAAJzY,GAAS,GAAIkY,QAASO,EAAQ,GAAK,GAAIJ,MAInDO,EAAUK,EAAM,IAAO,WAEtB,MADAL,GAAUK,EAAM,GAAK,QAAUpb,OAAS+a,EAAWnZ,EAAU5B,KAAM+B,WAC5D/B,MAER+a,EAAUK,EAAM,GAAK,QAAWrB,EAAKW,WAItC9Y,EAAQA,QAASmZ,GAGZJ,GACJA,EAAKzZ,KAAM6Z,EAAUA,GAIfA,GAIRc,KAAM,SAAUC,GACf,GAAI3Z,GAAI,EACP4Z,EAAgB3e,EAAW8D,KAAMa,WACjC7B,EAAS6b,EAAc7b,OAGvB8b,EAAuB,IAAX9b,GAAkB4b,GAAepf,EAAOiE,WAAYmb,EAAYla,SAAc1B,EAAS,EAGnG6a,EAAyB,IAAdiB,EAAkBF,EAAcpf,EAAOgM,WAGlDuT,EAAa,SAAU9Z,EAAG2W,EAAUoD,GACnC,MAAO,UAAUnV,GAChB+R,EAAU3W,GAAMnC,KAChBkc,EAAQ/Z,GAAMJ,UAAU7B,OAAS,EAAI9C,EAAW8D,KAAMa,WAAcgF,EAChEmV,IAAWC,EACdpB,EAASqB,WAAYtD,EAAUoD,KACfF,GAChBjB,EAAS/W,YAAa8U,EAAUoD,KAKnCC,EAAgBE,EAAkBC,CAGnC,IAAKpc,EAAS,EAIb,IAHAic,EAAqB/X,MAAOlE,GAC5Bmc,EAAuBjY,MAAOlE,GAC9Boc,EAAsBlY,MAAOlE,GACjBA,EAAJiC,EAAYA,IACd4Z,EAAe5Z,IAAOzF,EAAOiE,WAAYob,EAAe5Z,GAAIP,SAChEma,EAAe5Z,GAAIP,UACjBC,KAAMoa,EAAY9Z,EAAGma,EAAiBP,IACtCf,KAAMD,EAASS,QACfC,SAAUQ,EAAY9Z,EAAGka,EAAkBF,MAE3CH,CAUL,OAJMA,IACLjB,EAAS/W,YAAasY,EAAiBP,GAGjChB,EAASnZ,aAGlBlF,EAAOmI,QAAU,SAAWA,GAE3B,GAAI9F,GAAKuL,EAAGgG,EAAOtC,EAAQuO,EAAUC,EAAKC,EAAWC,EAAava,EACjEoM,EAAMjS,EAASiJ,cAAc,MAS9B,IANAgJ,EAAIb,aAAc,YAAa,KAC/Ba,EAAIuB,UAAY,qEAGhB/Q,EAAMwP,EAAIhI,qBAAqB,SAC/B+D,EAAIiE,EAAIhI,qBAAqB,KAAM,IAC7B+D,IAAMA,EAAE7B,QAAU1J,EAAImB,OAC3B,MAAO2E,EAIRmJ,GAAS1R,EAASiJ,cAAc,UAChCiX,EAAMxO,EAAO4B,YAAatT,EAASiJ,cAAc,WACjD+K,EAAQ/B,EAAIhI,qBAAqB,SAAU,GAE3C+D,EAAE7B,MAAMkU,QAAU,gCAGlB9X,EAAQ+X,gBAAoC,MAAlBrO,EAAIoB,UAG9B9K,EAAQgY,kBAAgD,IAA5BtO,EAAIwB,WAAWxP,SAI3CsE,EAAQiY,OAASvO,EAAIhI,qBAAqB,SAASrG,OAInD2E,EAAQkY,gBAAkBxO,EAAIhI,qBAAqB,QAAQrG,OAI3D2E,EAAQ4D,MAAQ,MAAMhI,KAAM6J,EAAEmD,aAAa,UAI3C5I,EAAQmY,eAA4C,OAA3B1S,EAAEmD,aAAa,QAKxC5I,EAAQoY,QAAU,OAAOxc,KAAM6J,EAAE7B,MAAMwU,SAIvCpY,EAAQqY,WAAa5S,EAAE7B,MAAMyU,SAG7BrY,EAAQsY,UAAY7M,EAAMvJ,MAI1BlC,EAAQuY,YAAcZ,EAAI1H,SAG1BjQ,EAAQwY,UAAY/gB,EAASiJ,cAAc,QAAQ8X,QAInDxY,EAAQyY,WAA2E,kBAA9DhhB,EAASiJ,cAAc,OAAOgY,WAAW,GAAOC,UAGrE3Y,EAAQ4Y,wBAAyB,EACjC5Y,EAAQ6Y,kBAAmB,EAC3B7Y,EAAQ8Y,eAAgB,EACxB9Y,EAAQ+Y,eAAgB,EACxB/Y,EAAQgZ,cAAe,EACvBhZ,EAAQiZ,qBAAsB,EAC9BjZ,EAAQkZ,mBAAoB,EAG5BzN,EAAMuE,SAAU,EAChBhQ,EAAQmZ,eAAiB1N,EAAMiN,WAAW,GAAO1I,QAIjD7G,EAAO4G,UAAW,EAClB/P,EAAQoZ,aAAezB,EAAI5H,QAG3B,WACQrG,GAAI9N,KACV,MAAOmE,GACRC,EAAQ+Y,eAAgB,EAIzBtN,EAAQhU,EAASiJ,cAAc,SAC/B+K,EAAM5C,aAAc,QAAS,IAC7B7I,EAAQyL,MAA0C,KAAlCA,EAAM7C,aAAc,SAGpC6C,EAAMvJ,MAAQ,IACduJ,EAAM5C,aAAc,OAAQ,SAC5B7I,EAAQqZ,WAA6B,MAAhB5N,EAAMvJ,MAG3BuJ,EAAM5C,aAAc,UAAW,KAC/B4C,EAAM5C,aAAc,OAAQ,KAE5B6O,EAAWjgB,EAAS6hB,yBACpB5B,EAAS3M,YAAaU,GAItBzL,EAAQuZ,cAAgB9N,EAAMuE,QAG9BhQ,EAAQwZ,WAAa9B,EAASgB,WAAW,GAAOA,WAAW,GAAO/J,UAAUqB,QAKvEtG,EAAI5F,cACR4F,EAAI5F,YAAa,UAAW,WAC3B9D,EAAQgZ,cAAe,IAGxBtP,EAAIgP,WAAW,GAAOe,QAKvB,KAAMnc,KAAOyT,QAAQ,EAAM2I,QAAQ,EAAMC,SAAS,GACjDjQ,EAAIb,aAAc+O,EAAY,KAAOta,EAAG,KAExC0C,EAAS1C,EAAI,WAAcsa,IAAazgB,IAAUuS,EAAItD,WAAYwR,GAAYrZ,WAAY,CAG3FmL,GAAI9F,MAAMgW,eAAiB,cAC3BlQ,EAAIgP,WAAW,GAAO9U,MAAMgW,eAAiB,GAC7C5Z,EAAQ6Z,gBAA+C,gBAA7BnQ,EAAI9F,MAAMgW,cAIpC,KAAMtc,IAAKzF,GAAQmI,GAClB,KAoGD,OAlGAA,GAAQC,QAAgB,MAAN3C,EAGlBzF,EAAO,WACN,GAAIiiB,GAAWC,EAAWC,EACzBC,EAAW,+HACXhb,EAAOxH,EAASiK,qBAAqB,QAAQ,EAExCzC,KAKN6a,EAAYriB,EAASiJ,cAAc,OACnCoZ,EAAUlW,MAAMkU,QAAU,gFAE1B7Y,EAAK8L,YAAa+O,GAAY/O,YAAarB,GAS3CA,EAAIuB,UAAY,8CAChB+O,EAAMtQ,EAAIhI,qBAAqB,MAC/BsY,EAAK,GAAIpW,MAAMkU,QAAU,2CACzBD,EAA0C,IAA1BmC,EAAK,GAAIE,aAEzBF,EAAK,GAAIpW,MAAMuW,QAAU,GACzBH,EAAK,GAAIpW,MAAMuW,QAAU,OAIzBna,EAAQoa,sBAAwBvC,GAA2C,IAA1BmC,EAAK,GAAIE,aAG1DxQ,EAAIuB,UAAY,GAChBvB,EAAI9F,MAAMkU,QAAU,wKAIpBjgB,EAAO6L,KAAMzE,EAAyB,MAAnBA,EAAK2E,MAAMyW,MAAiBA,KAAM,MAAU,WAC9Dra,EAAQsa,UAAgC,IAApB5Q,EAAI6Q,cAIpBpjB,EAAOqjB,mBACXxa,EAAQ8Y,cAAuE,QAArD3hB,EAAOqjB,iBAAkB9Q,EAAK,WAAe3F,IACvE/D,EAAQkZ,kBAA2F,SAArE/hB,EAAOqjB,iBAAkB9Q,EAAK,QAAY+Q,MAAO,QAAUA,MAMzFV,EAAYrQ,EAAIqB,YAAatT,EAASiJ,cAAc,QACpDqZ,EAAUnW,MAAMkU,QAAUpO,EAAI9F,MAAMkU,QAAUmC,EAC9CF,EAAUnW,MAAM8W,YAAcX,EAAUnW,MAAM6W,MAAQ,IACtD/Q,EAAI9F,MAAM6W,MAAQ,MAElBza,EAAQiZ,qBACNtZ,YAAcxI,EAAOqjB,iBAAkBT,EAAW,WAAeW,oBAGxDhR,GAAI9F,MAAMyW,OAAS9iB,IAK9BmS,EAAIuB,UAAY,GAChBvB,EAAI9F,MAAMkU,QAAUmC,EAAW,8CAC/Bja,EAAQ4Y,uBAA+C,IAApBlP,EAAI6Q,YAIvC7Q,EAAI9F,MAAMuW,QAAU,QACpBzQ,EAAIuB,UAAY,cAChBvB,EAAIwB,WAAWtH,MAAM6W,MAAQ,MAC7Bza,EAAQ6Y,iBAAyC,IAApBnP,EAAI6Q,YAE5Bva,EAAQ4Y,yBAIZ3Z,EAAK2E,MAAMyW,KAAO,IAIpBpb,EAAK0K,YAAamQ,GAGlBA,EAAYpQ,EAAMsQ,EAAMD,EAAY,QAIrC7f,EAAMiP,EAASuO,EAAWC,EAAMlS,EAAIgG,EAAQ,KAErCzL;KAGR,IAAI2a,GAAS,+BACZC,EAAa,UAEd,SAASC,GAAc3f,EAAM+C,EAAMqC,EAAMwa,GACxC,GAAMjjB,EAAOkjB,WAAY7f,GAAzB,CAIA,GAAIwB,GAAKse,EACRC,EAAcpjB,EAAO0G,QAIrB2c,EAAShgB,EAAKQ,SAId2N,EAAQ6R,EAASrjB,EAAOwR,MAAQnO,EAIhCgB,EAAKgf,EAAShgB,EAAM+f,GAAgB/f,EAAM+f,IAAiBA,CAI5D,IAAO/e,GAAOmN,EAAMnN,KAAS4e,GAAQzR,EAAMnN,GAAIoE,OAAUA,IAASlJ,GAA6B,gBAAT6G,GAgEtF,MA5DM/B,KAIJA,EADIgf,EACChgB,EAAM+f,GAAgBhjB,EAAgB6N,OAASjO,EAAOmL,OAEtDiY,GAID5R,EAAOnN,KAGZmN,EAAOnN,GAAOgf,MAAgBC,OAAQtjB,EAAO8J,QAKzB,gBAAT1D,IAAqC,kBAATA,MAClC6c,EACJzR,EAAOnN,GAAOrE,EAAOgG,OAAQwL,EAAOnN,GAAM+B,GAE1CoL,EAAOnN,GAAKoE,KAAOzI,EAAOgG,OAAQwL,EAAOnN,GAAKoE,KAAMrC,IAItD+c,EAAY3R,EAAOnN,GAKb4e,IACCE,EAAU1a,OACf0a,EAAU1a,SAGX0a,EAAYA,EAAU1a,MAGlBA,IAASlJ,IACb4jB,EAAWnjB,EAAOiK,UAAW7D,IAAWqC,GAKpB,gBAATrC,IAGXvB,EAAMse,EAAW/c,GAGL,MAAPvB,IAGJA,EAAMse,EAAWnjB,EAAOiK,UAAW7D,MAGpCvB,EAAMse,EAGAte,GAGR,QAAS0e,GAAoBlgB,EAAM+C,EAAM6c,GACxC,GAAMjjB,EAAOkjB,WAAY7f,GAAzB,CAIA,GAAI8f,GAAW1d,EACd4d,EAAShgB,EAAKQ,SAGd2N,EAAQ6R,EAASrjB,EAAOwR,MAAQnO,EAChCgB,EAAKgf,EAAShgB,EAAMrD,EAAO0G,SAAY1G,EAAO0G,OAI/C,IAAM8K,EAAOnN,GAAb,CAIA,GAAK+B,IAEJ+c,EAAYF,EAAMzR,EAAOnN,GAAOmN,EAAOnN,GAAKoE,MAE3B,CAGVzI,EAAOyG,QAASL,GAsBrBA,EAAOA,EAAK7F,OAAQP,EAAO4F,IAAKQ,EAAMpG,EAAOiK,YAnBxC7D,IAAQ+c,GACZ/c,GAASA,IAITA,EAAOpG,EAAOiK,UAAW7D,GAExBA,EADIA,IAAQ+c,IACH/c,GAEFA,EAAKkG,MAAM,MAarB7G,EAAIW,EAAK5C,MACT,OAAQiC,UACA0d,GAAW/c,EAAKX,GAKxB,IAAKwd,GAAOO,EAAkBL,IAAcnjB,EAAOqI,cAAc8a,GAChE,QAMGF,UACEzR,GAAOnN,GAAKoE,KAIb+a,EAAmBhS,EAAOnN,QAM5Bgf,EACJrjB,EAAOyjB,WAAapgB,IAAQ,GAIjBrD,EAAOmI,QAAQ+Y,eAAiB1P,GAASA,EAAMlS,aAEnDkS,GAAOnN,GAIdmN,EAAOnN,GAAO,QAIhBrE,EAAOgG,QACNwL,SAIAkS,QACCC,QAAU,EACVC,OAAS,EAEThH,OAAU,8CAGXiH,QAAS,SAAUxgB,GAElB,MADAA,GAAOA,EAAKQ,SAAW7D,EAAOwR,MAAOnO,EAAKrD,EAAO0G,UAAarD,EAAMrD,EAAO0G,WAClErD,IAASmgB,EAAmBngB,IAGtCoF,KAAM,SAAUpF,EAAM+C,EAAMqC,GAC3B,MAAOua,GAAc3f,EAAM+C,EAAMqC,IAGlCqb,WAAY,SAAUzgB,EAAM+C,GAC3B,MAAOmd,GAAoBlgB,EAAM+C,IAIlC2d,MAAO,SAAU1gB,EAAM+C,EAAMqC,GAC5B,MAAOua,GAAc3f,EAAM+C,EAAMqC,GAAM,IAGxCub,YAAa,SAAU3gB,EAAM+C,GAC5B,MAAOmd,GAAoBlgB,EAAM+C,GAAM,IAIxC8c,WAAY,SAAU7f,GAErB,GAAKA,EAAKQ,UAA8B,IAAlBR,EAAKQ,UAAoC,IAAlBR,EAAKQ,SACjD,OAAO,CAGR,IAAI6f,GAASrgB,EAAK8G,UAAYnK,EAAO0jB,OAAQrgB,EAAK8G,SAASC,cAG3D,QAAQsZ,GAAUA,KAAW,GAAQrgB,EAAK0N,aAAa,aAAe2S,KAIxE1jB,EAAOsB,GAAG0E,QACTyC,KAAM,SAAUR,EAAKoC,GACpB,GAAI2H,GAAO5L,EACVqC,EAAO,KACPhD,EAAI,EACJpC,EAAOC,KAAK,EAMb,IAAK2E,IAAQ1I,EAAY,CACxB,GAAK+D,KAAKE,SACTiF,EAAOzI,EAAOyI,KAAMpF,GAEG,IAAlBA,EAAKQ,WAAmB7D,EAAO+jB,MAAO1gB,EAAM,gBAAkB,CAElE,IADA2O,EAAQ3O,EAAKkL,WACDyD,EAAMxO,OAAViC,EAAkBA,IACzBW,EAAO4L,EAAMvM,GAAGW,KAEe,IAA1BA,EAAKvF,QAAQ,WACjBuF,EAAOpG,EAAOiK,UAAW7D,EAAKzF,MAAM,IAEpCsjB,EAAU5gB,EAAM+C,EAAMqC,EAAMrC,IAG9BpG,GAAO+jB,MAAO1gB,EAAM,eAAe,GAIrC,MAAOoF,GAIR,MAAoB,gBAARR,GACJ3E,KAAKyB,KAAK,WAChB/E,EAAOyI,KAAMnF,KAAM2E,KAId5C,UAAU7B,OAAS,EAGzBF,KAAKyB,KAAK,WACT/E,EAAOyI,KAAMnF,KAAM2E,EAAKoC,KAKzBhH,EAAO4gB,EAAU5gB,EAAM4E,EAAKjI,EAAOyI,KAAMpF,EAAM4E,IAAU,MAG3D6b,WAAY,SAAU7b,GACrB,MAAO3E,MAAKyB,KAAK,WAChB/E,EAAO8jB,WAAYxgB,KAAM2E,OAK5B,SAASgc,GAAU5gB,EAAM4E,EAAKQ,GAG7B,GAAKA,IAASlJ,GAA+B,IAAlB8D,EAAKQ,SAAiB,CAEhD,GAAIuC,GAAO,QAAU6B,EAAIpB,QAASkc,EAAY,OAAQ3Y,aAItD,IAFA3B,EAAOpF,EAAK0N,aAAc3K,GAEL,gBAATqC,GAAoB,CAC/B,IACCA,EAAgB,SAATA,GAAkB,EACf,UAATA,GAAmB,EACV,SAATA,EAAkB,MAEjBA,EAAO,KAAOA,GAAQA,EACvBqa,EAAO/e,KAAM0E,GAASzI,EAAOiJ,UAAWR,GACvCA,EACD,MAAOP,IAGTlI,EAAOyI,KAAMpF,EAAM4E,EAAKQ,OAGxBA,GAAOlJ,EAIT,MAAOkJ,GAIR,QAAS+a,GAAmB/b,GAC3B,GAAIrB,EACJ,KAAMA,IAAQqB,GAGb,IAAc,SAATrB,IAAmBpG,EAAOqI,cAAeZ,EAAIrB,MAGpC,WAATA,EACJ,OAAO,CAIT,QAAO,EAERpG,EAAOgG,QACNke,MAAO,SAAU7gB,EAAMV,EAAM8F,GAC5B,GAAIyb,EAEJ,OAAK7gB,IACJV,GAASA,GAAQ,MAAS,QAC1BuhB,EAAQlkB,EAAO+jB,MAAO1gB,EAAMV,GAGvB8F,KACEyb,GAASlkB,EAAOyG,QAAQgC,GAC7Byb,EAAQlkB,EAAO+jB,MAAO1gB,EAAMV,EAAM3C,EAAOsE,UAAUmE,IAEnDyb,EAAMzjB,KAAMgI,IAGPyb,OAZR,GAgBDC,QAAS,SAAU9gB,EAAMV,GACxBA,EAAOA,GAAQ,IAEf,IAAIuhB,GAAQlkB,EAAOkkB,MAAO7gB,EAAMV,GAC/ByhB,EAAcF,EAAM1gB,OACpBlC,EAAK4iB,EAAMxS,QACX2S,EAAQrkB,EAAOskB,YAAajhB,EAAMV,GAClC4hB,EAAO,WACNvkB,EAAOmkB,QAAS9gB,EAAMV,GAIZ,gBAAPrB,IACJA,EAAK4iB,EAAMxS,QACX0S,KAGI9iB,IAIU,OAATqB,GACJuhB,EAAMvP,QAAS,oBAIT0P,GAAMG,KACbljB,EAAGkD,KAAMnB,EAAMkhB,EAAMF,KAGhBD,GAAeC,GACpBA,EAAM/L,MAAMkF,QAKd8G,YAAa,SAAUjhB,EAAMV,GAC5B,GAAIsF,GAAMtF,EAAO,YACjB,OAAO3C,GAAO+jB,MAAO1gB,EAAM4E,IAASjI,EAAO+jB,MAAO1gB,EAAM4E,GACvDqQ,MAAOtY,EAAO8c,UAAU,eAAec,IAAI,WAC1C5d,EAAOgkB,YAAa3gB,EAAMV,EAAO,SACjC3C,EAAOgkB,YAAa3gB,EAAM4E,UAM9BjI,EAAOsB,GAAG0E,QACTke,MAAO,SAAUvhB,EAAM8F,GACtB,GAAIgc,GAAS,CAQb,OANqB,gBAAT9hB,KACX8F,EAAO9F,EACPA,EAAO,KACP8hB,KAGuBA,EAAnBpf,UAAU7B,OACPxD,EAAOkkB,MAAO5gB,KAAK,GAAIX,GAGxB8F,IAASlJ,EACf+D,KACAA,KAAKyB,KAAK,WACT,GAAImf,GAAQlkB,EAAOkkB,MAAO5gB,KAAMX,EAAM8F,EAGtCzI,GAAOskB,YAAahhB,KAAMX,GAEZ,OAATA,GAA8B,eAAbuhB,EAAM,IAC3BlkB,EAAOmkB,QAAS7gB,KAAMX,MAI1BwhB,QAAS,SAAUxhB,GAClB,MAAOW,MAAKyB,KAAK,WAChB/E,EAAOmkB,QAAS7gB,KAAMX,MAKxB+hB,MAAO,SAAUC,EAAMhiB,GAItB,MAHAgiB,GAAO3kB,EAAO4kB,GAAK5kB,EAAO4kB,GAAGC,OAAQF,IAAUA,EAAOA,EACtDhiB,EAAOA,GAAQ,KAERW,KAAK4gB,MAAOvhB,EAAM,SAAU4hB,EAAMF,GACxC,GAAIS,GAAUzd,WAAYkd,EAAMI,EAChCN,GAAMG,KAAO,WACZO,aAAcD,OAIjBE,WAAY,SAAUriB,GACrB,MAAOW,MAAK4gB,MAAOvhB,GAAQ,UAI5BuC,QAAS,SAAUvC,EAAM8E,GACxB,GAAI8B,GACH0b,EAAQ,EACRC,EAAQllB,EAAOgM,WACf6I,EAAWvR,KACXmC,EAAInC,KAAKE,OACTqb,EAAU,aACCoG,GACTC,EAAM5d,YAAauN,GAAYA,IAIb,iBAATlS,KACX8E,EAAM9E,EACNA,EAAOpD,GAERoD,EAAOA,GAAQ,IAEf,OAAO8C,IACN8D,EAAMvJ,EAAO+jB,MAAOlP,EAAUpP,GAAK9C,EAAO,cACrC4G,GAAOA,EAAI+O,QACf2M,IACA1b,EAAI+O,MAAMsF,IAAKiB,GAIjB,OADAA,KACOqG,EAAMhgB,QAASuC,KAGxB,IAAI0d,GAAUC,EACbC,EAAS,cACTC,EAAU,MACVC,EAAa,6CACbC,EAAa,gBACbC,EAAc,0BACdvF,EAAkBlgB,EAAOmI,QAAQ+X,gBACjCwF,EAAc1lB,EAAOmI,QAAQyL,KAE9B5T,GAAOsB,GAAG0E,QACT9B,KAAM,SAAUkC,EAAMiE,GACrB,MAAOrK,GAAOqL,OAAQ/H,KAAMtD,EAAOkE,KAAMkC,EAAMiE,EAAOhF,UAAU7B,OAAS,IAG1EmiB,WAAY,SAAUvf,GACrB,MAAO9C,MAAKyB,KAAK,WAChB/E,EAAO2lB,WAAYriB,KAAM8C,MAI3Bwf,KAAM,SAAUxf,EAAMiE,GACrB,MAAOrK,GAAOqL,OAAQ/H,KAAMtD,EAAO4lB,KAAMxf,EAAMiE,EAAOhF,UAAU7B,OAAS,IAG1EqiB,WAAY,SAAUzf,GAErB,MADAA,GAAOpG,EAAO8lB,QAAS1f,IAAUA,EAC1B9C,KAAKyB,KAAK,WAEhB,IACCzB,KAAM8C,GAAS7G,QACR+D,MAAM8C,GACZ,MAAO8B,QAIX6d,SAAU,SAAU1b,GACnB,GAAI2b,GAAS3iB,EAAM+O,EAAK6T,EAAOtgB,EAC9BF,EAAI,EACJC,EAAMpC,KAAKE,OACX0iB,EAA2B,gBAAV7b,IAAsBA,CAExC,IAAKrK,EAAOiE,WAAYoG,GACvB,MAAO/G,MAAKyB,KAAK,SAAUY,GAC1B3F,EAAQsD,MAAOyiB,SAAU1b,EAAM7F,KAAMlB,KAAMqC,EAAGrC,KAAK2P,aAIrD,IAAKiT,EAIJ,IAFAF,GAAY3b,GAAS,IAAKjH,MAAO1B,OAErBgE,EAAJD,EAASA,IAOhB,GANApC,EAAOC,KAAMmC,GACb2M,EAAwB,IAAlB/O,EAAKQ,WAAoBR,EAAK4P,WACjC,IAAM5P,EAAK4P,UAAY,KAAMpM,QAASwe,EAAQ,KAChD,KAGU,CACV1f,EAAI,CACJ,OAASsgB,EAAQD,EAAQrgB,KACgB,EAAnCyM,EAAIvR,QAAS,IAAMolB,EAAQ,OAC/B7T,GAAO6T,EAAQ,IAGjB5iB,GAAK4P,UAAYjT,EAAOmB,KAAMiR,GAMjC,MAAO9O,OAGR6iB,YAAa,SAAU9b,GACtB,GAAI2b,GAAS3iB,EAAM+O,EAAK6T,EAAOtgB,EAC9BF,EAAI,EACJC,EAAMpC,KAAKE,OACX0iB,EAA+B,IAArB7gB,UAAU7B,QAAiC,gBAAV6G,IAAsBA,CAElE,IAAKrK,EAAOiE,WAAYoG,GACvB,MAAO/G,MAAKyB,KAAK,SAAUY,GAC1B3F,EAAQsD,MAAO6iB,YAAa9b,EAAM7F,KAAMlB,KAAMqC,EAAGrC,KAAK2P,aAGxD,IAAKiT,EAGJ,IAFAF,GAAY3b,GAAS,IAAKjH,MAAO1B,OAErBgE,EAAJD,EAASA,IAQhB,GAPApC,EAAOC,KAAMmC,GAEb2M,EAAwB,IAAlB/O,EAAKQ,WAAoBR,EAAK4P,WACjC,IAAM5P,EAAK4P,UAAY,KAAMpM,QAASwe,EAAQ,KAChD,IAGU,CACV1f,EAAI,CACJ,OAASsgB,EAAQD,EAAQrgB,KAExB,MAAQyM,EAAIvR,QAAS,IAAMolB,EAAQ,MAAS,EAC3C7T,EAAMA,EAAIvL,QAAS,IAAMof,EAAQ,IAAK,IAGxC5iB,GAAK4P,UAAY5I,EAAQrK,EAAOmB,KAAMiR,GAAQ,GAKjD,MAAO9O,OAGR8iB,YAAa,SAAU/b,EAAOgc,GAC7B,GAAI1jB,SAAc0H,EAElB,OAAyB,iBAAbgc,IAAmC,WAAT1jB,EAC9B0jB,EAAW/iB,KAAKyiB,SAAU1b,GAAU/G,KAAK6iB,YAAa9b,GAGzDrK,EAAOiE,WAAYoG,GAChB/G,KAAKyB,KAAK,SAAUU,GAC1BzF,EAAQsD,MAAO8iB,YAAa/b,EAAM7F,KAAKlB,KAAMmC,EAAGnC,KAAK2P,UAAWoT,GAAWA,KAItE/iB,KAAKyB,KAAK,WAChB,GAAc,WAATpC,EAAoB,CAExB,GAAIsQ,GACHxN,EAAI,EACJiY,EAAO1d,EAAQsD,MACfgjB,EAAajc,EAAMjH,MAAO1B,MAE3B,OAASuR,EAAYqT,EAAY7gB,KAE3BiY,EAAK6I,SAAUtT,GACnByK,EAAKyI,YAAalT,GAElByK,EAAKqI,SAAU9S,QAKNtQ,IAASjD,GAA8B,YAATiD,KACpCW,KAAK2P,WAETjT,EAAO+jB,MAAOzgB,KAAM,gBAAiBA,KAAK2P,WAO3C3P,KAAK2P,UAAY3P,KAAK2P,WAAa5I,KAAU,EAAQ,GAAKrK,EAAO+jB,MAAOzgB,KAAM,kBAAqB,OAKtGijB,SAAU,SAAUnlB,GACnB,GAAI6R,GAAY,IAAM7R,EAAW,IAChCqE,EAAI,EACJqF,EAAIxH,KAAKE,MACV,MAAYsH,EAAJrF,EAAOA,IACd,GAA0B,IAArBnC,KAAKmC,GAAG5B,WAAmB,IAAMP,KAAKmC,GAAGwN,UAAY,KAAKpM,QAAQwe,EAAQ,KAAKxkB,QAASoS,IAAe,EAC3G,OAAO,CAIT,QAAO,GAGR6B,IAAK,SAAUzK,GACd,GAAIxF,GAAKwf,EAAOpgB,EACfZ,EAAOC,KAAK,EAEb,EAAA,GAAM+B,UAAU7B,OAsBhB,MAFAS,GAAajE,EAAOiE,WAAYoG,GAEzB/G,KAAKyB,KAAK,SAAUU,GAC1B,GAAIqP,EAEmB,KAAlBxR,KAAKO,WAKTiR,EADI7Q,EACEoG,EAAM7F,KAAMlB,KAAMmC,EAAGzF,EAAQsD,MAAOwR,OAEpCzK,EAIK,MAAPyK,EACJA,EAAM,GACoB,gBAARA,GAClBA,GAAO,GACI9U,EAAOyG,QAASqO,KAC3BA,EAAM9U,EAAO4F,IAAIkP,EAAK,SAAWzK,GAChC,MAAgB,OAATA,EAAgB,GAAKA,EAAQ,MAItCga,EAAQrkB,EAAOwmB,SAAUljB,KAAKX,OAAU3C,EAAOwmB,SAAUljB,KAAK6G,SAASC,eAGjEia,GAAW,OAASA,IAAUA,EAAMoC,IAAKnjB,KAAMwR,EAAK,WAAcvV,IACvE+D,KAAK+G,MAAQyK,KAjDd,IAAKzR,EAGJ,MAFAghB,GAAQrkB,EAAOwmB,SAAUnjB,EAAKV,OAAU3C,EAAOwmB,SAAUnjB,EAAK8G,SAASC,eAElEia,GAAS,OAASA,KAAUxf,EAAMwf,EAAM5f,IAAKpB,EAAM,YAAe9D,EAC/DsF,GAGRA,EAAMxB,EAAKgH,MAEW,gBAARxF,GAEbA,EAAIgC,QAAQye,EAAS,IAEd,MAAPzgB,EAAc,GAAKA,OA0CxB7E,EAAOgG,QACNwgB,UACCE,QACCjiB,IAAK,SAAUpB,GAEd,GAAIyR,GAAM9U,EAAO0D,KAAKQ,KAAMb,EAAM,QAClC,OAAc,OAAPyR,EACNA,EACAzR,EAAKkH,OAGR+G,QACC7M,IAAK,SAAUpB,GACd,GAAIgH,GAAOqc,EACVrgB,EAAUhD,EAAKgD,QACfwX,EAAQxa,EAAKgV,cACbsO,EAAoB,eAAdtjB,EAAKV,MAAiC,EAARkb,EACpC2B,EAASmH,EAAM,QACf/b,EAAM+b,EAAM9I,EAAQ,EAAIxX,EAAQ7C,OAChCiC,EAAY,EAARoY,EACHjT,EACA+b,EAAM9I,EAAQ,CAGhB,MAAYjT,EAAJnF,EAASA,IAIhB,GAHAihB,EAASrgB,EAASZ,MAGXihB,EAAOtO,UAAY3S,IAAMoY,IAE5B7d,EAAOmI,QAAQoZ,YAAemF,EAAOxO,SAA+C,OAApCwO,EAAO3V,aAAa,cACnE2V,EAAOtiB,WAAW8T,UAAalY,EAAOmK,SAAUuc,EAAOtiB,WAAY,aAAiB,CAMxF,GAHAiG,EAAQrK,EAAQ0mB,GAAS5R,MAGpB6R,EACJ,MAAOtc,EAIRmV,GAAO/e,KAAM4J,GAIf,MAAOmV,IAGRiH,IAAK,SAAUpjB,EAAMgH,GACpB,GAAIuc,GAAWF,EACdrgB,EAAUhD,EAAKgD,QACfmZ,EAASxf,EAAOsE,UAAW+F,GAC3B5E,EAAIY,EAAQ7C,MAEb,OAAQiC,IACPihB,EAASrgB,EAASZ,IACZihB,EAAOtO,SAAWpY,EAAO2K,QAAS3K,EAAO0mB,GAAQ5R,MAAO0K,IAAY,KACzEoH,GAAY,EAQd,OAHMA,KACLvjB,EAAKgV,cAAgB,IAEfmH,KAKVtb,KAAM,SAAUb,EAAM+C,EAAMiE,GAC3B,GAAIga,GAAOxf,EACVgiB,EAAQxjB,EAAKQ,QAGd,IAAMR,GAAkB,IAAVwjB,GAAyB,IAAVA,GAAyB,IAAVA,EAK5C,aAAYxjB,GAAK0N,eAAiBrR,EAC1BM,EAAO4lB,KAAMviB,EAAM+C,EAAMiE,IAKlB,IAAVwc,GAAgB7mB,EAAOyc,SAAUpZ,KACrC+C,EAAOA,EAAKgE,cACZia,EAAQrkB,EAAO8mB,UAAW1gB,KACvBpG,EAAO4U,KAAKxR,MAAMmM,KAAKxL,KAAMqC,GAASgf,EAAWD,IAGhD9a,IAAU9K,EAaH8kB,GAAS,OAASA,IAA6C,QAAnCxf,EAAMwf,EAAM5f,IAAKpB,EAAM+C,IACvDvB,GAGPA,EAAM7E,EAAO0D,KAAKQ,KAAMb,EAAM+C,GAGhB,MAAPvB,EACNtF,EACAsF,GApBc,OAAVwF,EAGOga,GAAS,OAASA,KAAUxf,EAAMwf,EAAMoC,IAAKpjB,EAAMgH,EAAOjE,MAAY7G,EAC1EsF,GAGPxB,EAAK2N,aAAc5K,EAAMiE,EAAQ,IAC1BA,IAPPrK,EAAO2lB,WAAYtiB,EAAM+C,GAAzBpG,KAuBH2lB,WAAY,SAAUtiB,EAAMgH,GAC3B,GAAIjE,GAAM2gB,EACTthB,EAAI,EACJuhB,EAAY3c,GAASA,EAAMjH,MAAO1B,EAEnC,IAAKslB,GAA+B,IAAlB3jB,EAAKQ,SACtB,MAASuC,EAAO4gB,EAAUvhB,KACzBshB,EAAW/mB,EAAO8lB,QAAS1f,IAAUA,EAGhCpG,EAAO4U,KAAKxR,MAAMmM,KAAKxL,KAAMqC,GAE5Bsf,GAAexF,IAAoBuF,EAAY1hB,KAAMqC,GACzD/C,EAAM0jB,IAAa,EAInB1jB,EAAMrD,EAAOiK,UAAW,WAAa7D,IACpC/C,EAAM0jB,IAAa,EAKrB/mB,EAAOkE,KAAMb,EAAM+C,EAAM,IAG1B/C,EAAKgO,gBAAiB6O,EAAkB9Z,EAAO2gB,IAKlDD,WACCnkB,MACC8jB,IAAK,SAAUpjB,EAAMgH,GACpB,IAAMrK,EAAOmI,QAAQqZ,YAAwB,UAAVnX,GAAqBrK,EAAOmK,SAAS9G,EAAM,SAAW,CAGxF,GAAIyR,GAAMzR,EAAKgH,KAKf,OAJAhH,GAAK2N,aAAc,OAAQ3G,GACtByK,IACJzR,EAAKgH,MAAQyK,GAEPzK,MAMXyb,SACCmB,MAAO,UACPC,QAAS,aAGVtB,KAAM,SAAUviB,EAAM+C,EAAMiE,GAC3B,GAAIxF,GAAKwf,EAAO8C,EACfN,EAAQxjB,EAAKQ,QAGd,IAAMR,GAAkB,IAAVwjB,GAAyB,IAAVA,GAAyB,IAAVA,EAY5C,MARAM,GAAmB,IAAVN,IAAgB7mB,EAAOyc,SAAUpZ,GAErC8jB,IAEJ/gB,EAAOpG,EAAO8lB,QAAS1f,IAAUA,EACjCie,EAAQrkB,EAAOonB,UAAWhhB,IAGtBiE,IAAU9K,EACP8kB,GAAS,OAASA,KAAUxf,EAAMwf,EAAMoC,IAAKpjB,EAAMgH,EAAOjE,MAAY7G,EAC5EsF,EACExB,EAAM+C,GAASiE,EAGXga,GAAS,OAASA,IAA6C,QAAnCxf,EAAMwf,EAAM5f,IAAKpB,EAAM+C,IACzDvB,EACAxB,EAAM+C,IAITghB,WACCpP,UACCvT,IAAK,SAAUpB,GAId,GAAIgkB,GAAWrnB,EAAO0D,KAAKQ,KAAMb,EAAM,WAEvC,OAAOgkB,GACNC,SAAUD,EAAU,IACpB9B,EAAWxhB,KAAMV,EAAK8G,WAAcqb,EAAWzhB,KAAMV,EAAK8G,WAAc9G,EAAK0U,KAC5E,EACA,QAONqN,GACCqB,IAAK,SAAUpjB,EAAMgH,EAAOjE,GAa3B,MAZKiE,MAAU,EAEdrK,EAAO2lB,WAAYtiB,EAAM+C,GACdsf,GAAexF,IAAoBuF,EAAY1hB,KAAMqC,GAEhE/C,EAAK2N,cAAekP,GAAmBlgB,EAAO8lB,QAAS1f,IAAUA,EAAMA,GAIvE/C,EAAMrD,EAAOiK,UAAW,WAAa7D,IAAW/C,EAAM+C,IAAS,EAGzDA,IAGTpG,EAAO+E,KAAM/E,EAAO4U,KAAKxR,MAAMmM,KAAK9N,OAAO2B,MAAO,QAAU,SAAUqC,EAAGW,GACxE,GAAImhB,GAASvnB,EAAO4U,KAAK1C,WAAY9L,IAAUpG,EAAO0D,KAAKQ,IAE3DlE,GAAO4U,KAAK1C,WAAY9L,GAASsf,GAAexF,IAAoBuF,EAAY1hB,KAAMqC,GACrF,SAAU/C,EAAM+C,EAAMsG,GACrB,GAAIpL,GAAKtB,EAAO4U,KAAK1C,WAAY9L,GAChCvB,EAAM6H,EACLnN,GAECS,EAAO4U,KAAK1C,WAAY9L,GAAS7G,IACjCgoB,EAAQlkB,EAAM+C,EAAMsG,GAEpBtG,EAAKgE,cACL,IAEH,OADApK,GAAO4U,KAAK1C,WAAY9L,GAAS9E,EAC1BuD,GAER,SAAUxB,EAAM+C,EAAMsG,GACrB,MAAOA,GACNnN,EACA8D,EAAMrD,EAAOiK,UAAW,WAAa7D,IACpCA,EAAKgE,cACL,QAKCsb,GAAgBxF,IACrBlgB,EAAO8mB,UAAUzc,OAChBoc,IAAK,SAAUpjB,EAAMgH,EAAOjE,GAC3B,MAAKpG,GAAOmK,SAAU9G,EAAM,UAE3BA,EAAKkZ,aAAelS,EAApBhH,GAGO8hB,GAAYA,EAASsB,IAAKpjB,EAAMgH,EAAOjE,MAO5C8Z,IAILiF,GACCsB,IAAK,SAAUpjB,EAAMgH,EAAOjE,GAE3B,GAAIvB,GAAMxB,EAAKqQ,iBAAkBtN,EAUjC,OATMvB,IACLxB,EAAKmkB,iBACH3iB,EAAMxB,EAAKS,cAAc2jB,gBAAiBrhB,IAI7CvB,EAAIwF,MAAQA,GAAS,GAGL,UAATjE,GAAoBiE,IAAUhH,EAAK0N,aAAc3K,GACvDiE,EACA9K,IAGHS,EAAO4U,KAAK1C,WAAW7N,GAAKrE,EAAO4U,KAAK1C,WAAW9L,KAAOpG,EAAO4U,KAAK1C,WAAWwV,OAEhF,SAAUrkB,EAAM+C,EAAMsG,GACrB,GAAI7H,EACJ,OAAO6H,GACNnN,GACCsF,EAAMxB,EAAKqQ,iBAAkBtN,KAAyB,KAAdvB,EAAIwF,MAC5CxF,EAAIwF,MACJ,MAEJrK,EAAOwmB,SAAShO,QACf/T,IAAK,SAAUpB,EAAM+C,GACpB,GAAIvB,GAAMxB,EAAKqQ,iBAAkBtN,EACjC,OAAOvB,IAAOA,EAAIkQ,UACjBlQ,EAAIwF,MACJ9K,GAEFknB,IAAKtB,EAASsB,KAKfzmB,EAAO8mB,UAAUa,iBAChBlB,IAAK,SAAUpjB,EAAMgH,EAAOjE,GAC3B+e,EAASsB,IAAKpjB,EAAgB,KAAVgH,GAAe,EAAQA,EAAOjE,KAMpDpG,EAAO+E,MAAO,QAAS,UAAY,SAAUU,EAAGW,GAC/CpG,EAAO8mB,UAAW1gB,IACjBqgB,IAAK,SAAUpjB,EAAMgH,GACpB,MAAe,KAAVA,GACJhH,EAAK2N,aAAc5K,EAAM,QAClBiE,GAFR,OAYErK,EAAOmI,QAAQmY,gBAEpBtgB,EAAO+E,MAAO,OAAQ,OAAS,SAAUU,EAAGW,GAC3CpG,EAAOonB,UAAWhhB,IACjB3B,IAAK,SAAUpB,GACd,MAAOA,GAAK0N,aAAc3K,EAAM,OAM9BpG,EAAOmI,QAAQ4D,QACpB/L,EAAO8mB,UAAU/a,OAChBtH,IAAK,SAAUpB,GAId,MAAOA,GAAK0I,MAAMkU,SAAW1gB,GAE9BknB,IAAK,SAAUpjB,EAAMgH,GACpB,MAAShH,GAAK0I,MAAMkU,QAAU5V,EAAQ,MAOnCrK,EAAOmI,QAAQuY,cACpB1gB,EAAOonB,UAAUhP,UAChB3T,IAAK,SAAUpB,GACd,GAAI0P,GAAS1P,EAAKe,UAUlB,OARK2O,KACJA,EAAOsF,cAGFtF,EAAO3O,YACX2O,EAAO3O,WAAWiU,eAGb,QAKVrY,EAAO+E,MACN,WACA,WACA,YACA,cACA,cACA,UACA,UACA,SACA,cACA,mBACE,WACF/E,EAAO8lB,QAASxiB,KAAK8G,eAAkB9G,OAIlCtD,EAAOmI,QAAQwY,UACpB3gB,EAAO8lB,QAAQnF,QAAU,YAI1B3gB,EAAO+E,MAAO,QAAS,YAAc,WACpC/E,EAAOwmB,SAAUljB,OAChBmjB,IAAK,SAAUpjB,EAAMgH,GACpB,MAAKrK,GAAOyG,QAAS4D,GACXhH,EAAK8U,QAAUnY,EAAO2K,QAAS3K,EAAOqD,GAAMyR,MAAOzK,IAAW,EADxE,IAKIrK,EAAOmI,QAAQsY,UACpBzgB,EAAOwmB,SAAUljB,MAAOmB,IAAM,SAAUpB,GAGvC,MAAsC,QAA/BA,EAAK0N,aAAa,SAAoB,KAAO1N,EAAKgH,SAI5D,IAAIud,GAAa,+BAChBC,GAAY,OACZC,GAAc,+BACdC,GAAc,kCACdC,GAAiB,sBAElB,SAASC,MACR,OAAO,EAGR,QAASC,MACR,OAAO,EAGR,QAASC,MACR,IACC,MAAOvoB,GAASiY,cACf,MAAQuQ,KAOXpoB,EAAOyC,OAEN4lB,UAEAzK,IAAK,SAAUva,EAAMilB,EAAOrW,EAASxJ,EAAMrH,GAC1C,GAAImI,GAAKgf,EAAQC,EAAGC,EACnBC,EAASC,EAAaC,EACtBC,EAAUlmB,EAAMmmB,EAAYC,EAC5BC,EAAWhpB,EAAO+jB,MAAO1gB,EAG1B,IAAM2lB,EAAN,CAKK/W,EAAQA,UACZwW,EAAcxW,EACdA,EAAUwW,EAAYxW,QACtB7Q,EAAWqnB,EAAYrnB,UAIlB6Q,EAAQ9G,OACb8G,EAAQ9G,KAAOnL,EAAOmL,SAIhBod,EAASS,EAAST,UACxBA,EAASS,EAAST,YAEZI,EAAcK,EAASC,UAC7BN,EAAcK,EAASC,OAAS,SAAU/gB,GAGzC,aAAclI,KAAWN,GAAuBwI,GAAKlI,EAAOyC,MAAMymB,YAAchhB,EAAEvF,KAEjFpD,EADAS,EAAOyC,MAAM0mB,SAAS/jB,MAAOujB,EAAYtlB,KAAMgC,YAIjDsjB,EAAYtlB,KAAOA,GAIpBilB,GAAUA,GAAS,IAAKllB,MAAO1B,KAAqB,IACpD8mB,EAAIF,EAAM9kB,MACV,OAAQglB,IACPjf,EAAMye,GAAevkB,KAAM6kB,EAAME,QACjC7lB,EAAOomB,EAAWxf,EAAI,GACtBuf,GAAevf,EAAI,IAAM,IAAK+C,MAAO,KAAMxG,OAGrCnD,IAKN+lB,EAAU1oB,EAAOyC,MAAMimB,QAAS/lB,OAGhCA,GAASvB,EAAWsnB,EAAQU,aAAeV,EAAQW,WAAc1mB,EAGjE+lB,EAAU1oB,EAAOyC,MAAMimB,QAAS/lB,OAGhCimB,EAAY5oB,EAAOgG,QAClBrD,KAAMA,EACNomB,SAAUA,EACVtgB,KAAMA,EACNwJ,QAASA,EACT9G,KAAM8G,EAAQ9G,KACd/J,SAAUA,EACVoO,aAAcpO,GAAYpB,EAAO4U,KAAKxR,MAAMoM,aAAazL,KAAM3C,GAC/DkoB,UAAWR,EAAW5X,KAAK,MACzBuX,IAGII,EAAWN,EAAQ5lB,MACzBkmB,EAAWN,EAAQ5lB,MACnBkmB,EAASU,cAAgB,EAGnBb,EAAQc,OAASd,EAAQc,MAAMhlB,KAAMnB,EAAMoF,EAAMqgB,EAAYH,MAAkB,IAE/EtlB,EAAKX,iBACTW,EAAKX,iBAAkBC,EAAMgmB,GAAa,GAE/BtlB,EAAK4I,aAChB5I,EAAK4I,YAAa,KAAOtJ,EAAMgmB,KAK7BD,EAAQ9K,MACZ8K,EAAQ9K,IAAIpZ,KAAMnB,EAAMulB,GAElBA,EAAU3W,QAAQ9G,OACvByd,EAAU3W,QAAQ9G,KAAO8G,EAAQ9G,OAK9B/J,EACJynB,EAAS9iB,OAAQ8iB,EAASU,gBAAiB,EAAGX,GAE9CC,EAASpoB,KAAMmoB,GAIhB5oB,EAAOyC,MAAM4lB,OAAQ1lB,IAAS,EAI/BU,GAAO,OAIR0F,OAAQ,SAAU1F,EAAMilB,EAAOrW,EAAS7Q,EAAUqoB,GACjD,GAAI9jB,GAAGijB,EAAWrf,EACjBmgB,EAAWlB,EAAGD,EACdG,EAASG,EAAUlmB,EACnBmmB,EAAYC,EACZC,EAAWhpB,EAAO6jB,QAASxgB,IAAUrD,EAAO+jB,MAAO1gB,EAEpD,IAAM2lB,IAAcT,EAASS,EAAST,QAAtC,CAKAD,GAAUA,GAAS,IAAKllB,MAAO1B,KAAqB,IACpD8mB,EAAIF,EAAM9kB,MACV,OAAQglB,IAMP,GALAjf,EAAMye,GAAevkB,KAAM6kB,EAAME,QACjC7lB,EAAOomB,EAAWxf,EAAI,GACtBuf,GAAevf,EAAI,IAAM,IAAK+C,MAAO,KAAMxG,OAGrCnD,EAAN,CAOA+lB,EAAU1oB,EAAOyC,MAAMimB,QAAS/lB,OAChCA,GAASvB,EAAWsnB,EAAQU,aAAeV,EAAQW,WAAc1mB,EACjEkmB,EAAWN,EAAQ5lB,OACnB4G,EAAMA,EAAI,IAAUkF,OAAQ,UAAYqa,EAAW5X,KAAK,iBAAmB,WAG3EwY,EAAY/jB,EAAIkjB,EAASrlB,MACzB,OAAQmC,IACPijB,EAAYC,EAAUljB,IAEf8jB,GAAeV,IAAaH,EAAUG,UACzC9W,GAAWA,EAAQ9G,OAASyd,EAAUzd,MACtC5B,IAAOA,EAAIxF,KAAM6kB,EAAUU,YAC3BloB,GAAYA,IAAawnB,EAAUxnB,WAAyB,OAAbA,IAAqBwnB,EAAUxnB,YACjFynB,EAAS9iB,OAAQJ,EAAG,GAEfijB,EAAUxnB,UACdynB,EAASU,gBAELb,EAAQ3f,QACZ2f,EAAQ3f,OAAOvE,KAAMnB,EAAMulB,GAOzBc,KAAcb,EAASrlB,SACrBklB,EAAQiB,UAAYjB,EAAQiB,SAASnlB,KAAMnB,EAAMylB,EAAYE,EAASC,WAAa,GACxFjpB,EAAO4pB,YAAavmB,EAAMV,EAAMqmB,EAASC,cAGnCV,GAAQ5lB,QAtCf,KAAMA,IAAQ4lB,GACbvoB,EAAOyC,MAAMsG,OAAQ1F,EAAMV,EAAO2lB,EAAOE,GAAKvW,EAAS7Q,GAAU,EA0C/DpB,GAAOqI,cAAekgB,WACnBS,GAASC,OAIhBjpB,EAAOgkB,YAAa3gB,EAAM,aAI5BkE,QAAS,SAAU9E,EAAOgG,EAAMpF,EAAMwmB,GACrC,GAAIZ,GAAQa,EAAQ1X,EACnB2X,EAAYrB,EAASnf,EAAK9D,EAC1BukB,GAAc3mB,GAAQzD,GACtB+C,EAAO3B,EAAYwD,KAAM/B,EAAO,QAAWA,EAAME,KAAOF,EACxDqmB,EAAa9nB,EAAYwD,KAAM/B,EAAO,aAAgBA,EAAM6mB,UAAUhd,MAAM,OAK7E,IAHA8F,EAAM7I,EAAMlG,EAAOA,GAAQzD,EAGJ,IAAlByD,EAAKQ,UAAoC,IAAlBR,EAAKQ,WAK5BkkB,GAAYhkB,KAAMpB,EAAO3C,EAAOyC,MAAMymB,aAItCvmB,EAAK9B,QAAQ,MAAQ,IAEzBioB,EAAanmB,EAAK2J,MAAM,KACxB3J,EAAOmmB,EAAWpX,QAClBoX,EAAWhjB,QAEZgkB,EAA6B,EAApBnnB,EAAK9B,QAAQ,MAAY,KAAO8B,EAGzCF,EAAQA,EAAOzC,EAAO0G,SACrBjE,EACA,GAAIzC,GAAOiqB,MAAOtnB,EAAuB,gBAAVF,IAAsBA,GAGtDA,EAAMynB,UAAYL,EAAe,EAAI,EACrCpnB,EAAM6mB,UAAYR,EAAW5X,KAAK,KAClCzO,EAAM0nB,aAAe1nB,EAAM6mB,UACtB7a,OAAQ,UAAYqa,EAAW5X,KAAK,iBAAmB,WAC3D,KAGDzO,EAAM4T,OAAS9W,EACTkD,EAAM8D,SACX9D,EAAM8D,OAASlD,GAIhBoF,EAAe,MAARA,GACJhG,GACFzC,EAAOsE,UAAWmE,GAAQhG,IAG3BimB,EAAU1oB,EAAOyC,MAAMimB,QAAS/lB,OAC1BknB,IAAgBnB,EAAQnhB,SAAWmhB,EAAQnhB,QAAQnC,MAAO/B,EAAMoF,MAAW,GAAjF,CAMA,IAAMohB,IAAiBnB,EAAQ0B,WAAapqB,EAAO2H,SAAUtE,GAAS,CAMrE,IAJA0mB,EAAarB,EAAQU,cAAgBzmB,EAC/BolB,GAAYhkB,KAAMgmB,EAAapnB,KACpCyP,EAAMA,EAAIhO,YAEHgO,EAAKA,EAAMA,EAAIhO,WACtB4lB,EAAUvpB,KAAM2R,GAChB7I,EAAM6I,CAIF7I,MAASlG,EAAKS,eAAiBlE,IACnCoqB,EAAUvpB,KAAM8I,EAAIyJ,aAAezJ,EAAI8gB,cAAgB/qB,GAKzDmG,EAAI,CACJ,QAAS2M,EAAM4X,EAAUvkB,QAAUhD,EAAM6nB,uBAExC7nB,EAAME,KAAO8C,EAAI,EAChBskB,EACArB,EAAQW,UAAY1mB,EAGrBsmB,GAAWjpB,EAAO+jB,MAAO3R,EAAK,eAAoB3P,EAAME,OAAU3C,EAAO+jB,MAAO3R,EAAK,UAChF6W,GACJA,EAAO7jB,MAAOgN,EAAK3J,GAIpBwgB,EAASa,GAAU1X,EAAK0X,GACnBb,GAAUjpB,EAAOkjB,WAAY9Q,IAAS6W,EAAO7jB,OAAS6jB,EAAO7jB,MAAOgN,EAAK3J,MAAW,GACxFhG,EAAM8nB,gBAMR,IAHA9nB,EAAME,KAAOA,GAGPknB,IAAiBpnB,EAAM+nB,wBAErB9B,EAAQ+B,UAAY/B,EAAQ+B,SAASrlB,MAAO4kB,EAAU/b,MAAOxF,MAAW,IAC9EzI,EAAOkjB,WAAY7f,IAKdymB,GAAUzmB,EAAMV,KAAW3C,EAAO2H,SAAUtE,GAAS,CAGzDkG,EAAMlG,EAAMymB,GAEPvgB,IACJlG,EAAMymB,GAAW,MAIlB9pB,EAAOyC,MAAMymB,UAAYvmB,CACzB,KACCU,EAAMV,KACL,MAAQuF,IAIVlI,EAAOyC,MAAMymB,UAAY3pB,EAEpBgK,IACJlG,EAAMymB,GAAWvgB,GAMrB,MAAO9G,GAAM4T,SAGd8S,SAAU,SAAU1mB,GAGnBA,EAAQzC,EAAOyC,MAAMioB,IAAKjoB,EAE1B,IAAIgD,GAAGZ,EAAK+jB,EAAW1R,EAASvR,EAC/BglB,KACA1lB,EAAOvE,EAAW8D,KAAMa,WACxBwjB,GAAa7oB,EAAO+jB,MAAOzgB,KAAM,eAAoBb,EAAME,UAC3D+lB,EAAU1oB,EAAOyC,MAAMimB,QAASjmB,EAAME,SAOvC,IAJAsC,EAAK,GAAKxC,EACVA,EAAMmoB,eAAiBtnB,MAGlBolB,EAAQmC,aAAenC,EAAQmC,YAAYrmB,KAAMlB,KAAMb,MAAY,EAAxE,CAKAkoB,EAAe3qB,EAAOyC,MAAMomB,SAASrkB,KAAMlB,KAAMb,EAAOomB,GAGxDpjB,EAAI,CACJ,QAASyR,EAAUyT,EAAcllB,QAAWhD,EAAM6nB,uBAAyB,CAC1E7nB,EAAMqoB,cAAgB5T,EAAQ7T,KAE9BsC,EAAI,CACJ,QAASijB,EAAY1R,EAAQ2R,SAAUljB,QAAWlD,EAAMsoB,kCAIjDtoB,EAAM0nB,cAAgB1nB,EAAM0nB,aAAapmB,KAAM6kB,EAAUU,cAE9D7mB,EAAMmmB,UAAYA,EAClBnmB,EAAMgG,KAAOmgB,EAAUngB,KAEvB5D,IAAS7E,EAAOyC,MAAMimB,QAASE,EAAUG,eAAkBE,QAAUL,EAAU3W,SAC5E7M,MAAO8R,EAAQ7T,KAAM4B,GAEnBJ,IAAQtF,IACNkD,EAAM4T,OAASxR,MAAS,IAC7BpC,EAAM8nB,iBACN9nB,EAAMuoB,oBAYX,MAJKtC,GAAQuC,cACZvC,EAAQuC,aAAazmB,KAAMlB,KAAMb,GAG3BA,EAAM4T,SAGdwS,SAAU,SAAUpmB,EAAOomB,GAC1B,GAAIqC,GAAKtC,EAAW1b,EAASzH,EAC5BklB,KACApB,EAAgBV,EAASU,cACzBnX,EAAM3P,EAAM8D,MAKb,IAAKgjB,GAAiBnX,EAAIvO,YAAcpB,EAAM+V,QAAyB,UAAf/V,EAAME,MAG7D,KAAQyP,GAAO9O,KAAM8O,EAAMA,EAAIhO,YAAcd,KAK5C,GAAsB,IAAjB8O,EAAIvO,WAAmBuO,EAAI8F,YAAa,GAAuB,UAAfzV,EAAME,MAAoB,CAE9E,IADAuK,KACMzH,EAAI,EAAO8jB,EAAJ9jB,EAAmBA,IAC/BmjB,EAAYC,EAAUpjB,GAGtBylB,EAAMtC,EAAUxnB,SAAW,IAEtB8L,EAASge,KAAU3rB,IACvB2N,EAASge,GAAQtC,EAAUpZ,aAC1BxP,EAAQkrB,EAAK5nB,MAAOua,MAAOzL,IAAS,EACpCpS,EAAO0D,KAAMwnB,EAAK5nB,KAAM,MAAQ8O,IAAQ5O,QAErC0J,EAASge,IACbhe,EAAQzM,KAAMmoB,EAGX1b,GAAQ1J,QACZmnB,EAAalqB,MAAO4C,KAAM+O,EAAKyW,SAAU3b,IAW7C,MAJqB2b,GAASrlB,OAAzB+lB,GACJoB,EAAalqB,MAAO4C,KAAMC,KAAMulB,SAAUA,EAASloB,MAAO4oB,KAGpDoB,GAGRD,IAAK,SAAUjoB,GACd,GAAKA,EAAOzC,EAAO0G,SAClB,MAAOjE,EAIR,IAAIgD,GAAGmgB,EAAMzf,EACZxD,EAAOF,EAAME,KACbwoB,EAAgB1oB,EAChB2oB,EAAU9nB,KAAK+nB,SAAU1oB,EAEpByoB,KACL9nB,KAAK+nB,SAAU1oB,GAASyoB,EACvBtD,GAAY/jB,KAAMpB,GAASW,KAAKgoB,WAChCzD,GAAU9jB,KAAMpB,GAASW,KAAKioB,aAGhCplB,EAAOilB,EAAQI,MAAQloB,KAAKkoB,MAAMjrB,OAAQ6qB,EAAQI,OAAUloB,KAAKkoB,MAEjE/oB,EAAQ,GAAIzC,GAAOiqB,MAAOkB,GAE1B1lB,EAAIU,EAAK3C,MACT,OAAQiC,IACPmgB,EAAOzf,EAAMV,GACbhD,EAAOmjB,GAASuF,EAAevF,EAmBhC,OAdMnjB,GAAM8D,SACX9D,EAAM8D,OAAS4kB,EAAcM,YAAc7rB,GAKb,IAA1B6C,EAAM8D,OAAO1C,WACjBpB,EAAM8D,OAAS9D,EAAM8D,OAAOnC,YAK7B3B,EAAMipB,UAAYjpB,EAAMipB,QAEjBN,EAAQ5X,OAAS4X,EAAQ5X,OAAQ/Q,EAAO0oB,GAAkB1oB,GAIlE+oB,MAAO,wHAAwHlf,MAAM,KAErI+e,YAEAE,UACCC,MAAO,4BAA4Blf,MAAM,KACzCkH,OAAQ,SAAU/Q,EAAOkpB,GAOxB,MAJoB,OAAflpB,EAAMmpB,QACVnpB,EAAMmpB,MAA6B,MAArBD,EAASE,SAAmBF,EAASE,SAAWF,EAASG,SAGjErpB,IAIT6oB,YACCE,MAAO,mGAAmGlf,MAAM,KAChHkH,OAAQ,SAAU/Q,EAAOkpB,GACxB,GAAIvkB,GAAM2kB,EAAUjZ,EACnB0F,EAASmT,EAASnT,OAClBwT,EAAcL,EAASK,WAuBxB,OApBoB,OAAfvpB,EAAMwpB,OAAqC,MAApBN,EAASO,UACpCH,EAAWtpB,EAAM8D,OAAOzC,eAAiBlE,EACzCkT,EAAMiZ,EAASjsB,gBACfsH,EAAO2kB,EAAS3kB,KAEhB3E,EAAMwpB,MAAQN,EAASO,SAAYpZ,GAAOA,EAAIqZ,YAAc/kB,GAAQA,EAAK+kB,YAAc,IAAQrZ,GAAOA,EAAIsZ,YAAchlB,GAAQA,EAAKglB,YAAc,GACnJ3pB,EAAM4pB,MAAQV,EAASW,SAAYxZ,GAAOA,EAAIyZ,WAAcnlB,GAAQA,EAAKmlB,WAAc,IAAQzZ,GAAOA,EAAI0Z,WAAcplB,GAAQA,EAAKolB,WAAc,KAI9I/pB,EAAMgqB,eAAiBT,IAC5BvpB,EAAMgqB,cAAgBT,IAAgBvpB,EAAM8D,OAASolB,EAASe,UAAYV,GAKrEvpB,EAAMmpB,OAASpT,IAAWjZ,IAC/BkD,EAAMmpB,MAAmB,EAATpT,EAAa,EAAe,EAATA,EAAa,EAAe,EAATA,EAAa,EAAI,GAGjE/V,IAITimB,SACCiE,MAECvC,UAAU,GAEXxS,OAECrQ,QAAS,WACR,GAAKjE,OAAS6kB,MAAuB7kB,KAAKsU,MACzC,IAEC,MADAtU,MAAKsU,SACE,EACN,MAAQ1P,MAOZkhB,aAAc,WAEfwD,MACCrlB,QAAS,WACR,MAAKjE,QAAS6kB,MAAuB7kB,KAAKspB,MACzCtpB,KAAKspB,QACE,GAFR,GAKDxD,aAAc,YAEfxH,OAECra,QAAS,WACR,MAAKvH,GAAOmK,SAAU7G,KAAM,UAA2B,aAAdA,KAAKX,MAAuBW,KAAKse,OACzEte,KAAKse,SACE,GAFR,GAOD6I,SAAU,SAAUhoB,GACnB,MAAOzC,GAAOmK,SAAU1H,EAAM8D,OAAQ,OAIxCsmB,cACC5B,aAAc,SAAUxoB,GAGlBA,EAAM4T,SAAW9W,IACrBkD,EAAM0oB,cAAc2B,YAAcrqB,EAAM4T,WAM5C0W,SAAU,SAAUpqB,EAAMU,EAAMZ,EAAOuqB,GAItC,GAAI9kB,GAAIlI,EAAOgG,OACd,GAAIhG,GAAOiqB,MACXxnB,GAECE,KAAMA,EACNsqB,aAAa,EACb9B,kBAGG6B,GACJhtB,EAAOyC,MAAM8E,QAASW,EAAG,KAAM7E,GAE/BrD,EAAOyC,MAAM0mB,SAAS3kB,KAAMnB,EAAM6E,GAE9BA,EAAEsiB,sBACN/nB,EAAM8nB,mBAKTvqB,EAAO4pB,YAAchqB,EAASmD,oBAC7B,SAAUM,EAAMV,EAAMsmB,GAChB5lB,EAAKN,qBACTM,EAAKN,oBAAqBJ,EAAMsmB,GAAQ,IAG1C,SAAU5lB,EAAMV,EAAMsmB,GACrB,GAAI7iB,GAAO,KAAOzD,CAEbU,GAAKL,oBAIGK,GAAM+C,KAAW1G,IAC5B2D,EAAM+C,GAAS,MAGhB/C,EAAKL,YAAaoD,EAAM6iB,KAI3BjpB,EAAOiqB,MAAQ,SAAUhkB,EAAKulB,GAE7B,MAAOloB,gBAAgBtD,GAAOiqB,OAKzBhkB,GAAOA,EAAItD,MACfW,KAAK6nB,cAAgBllB,EACrB3C,KAAKX,KAAOsD,EAAItD,KAIhBW,KAAKknB,mBAAuBvkB,EAAIinB,kBAAoBjnB,EAAI6mB,eAAgB,GACvE7mB,EAAIknB,mBAAqBlnB,EAAIknB,oBAAwBlF,GAAaC,IAInE5kB,KAAKX,KAAOsD,EAIRulB,GACJxrB,EAAOgG,OAAQ1C,KAAMkoB,GAItBloB,KAAK8pB,UAAYnnB,GAAOA,EAAImnB,WAAaptB,EAAO0L,MAGhDpI,KAAMtD,EAAO0G,UAAY,EAvBzB,GAJQ,GAAI1G,GAAOiqB,MAAOhkB,EAAKulB,IAgChCxrB,EAAOiqB,MAAMhnB,WACZunB,mBAAoBtC,GACpBoC,qBAAsBpC,GACtB6C,8BAA+B7C,GAE/BqC,eAAgB,WACf,GAAIriB,GAAI5E,KAAK6nB,aAEb7nB,MAAKknB,mBAAqBvC,GACpB/f,IAKDA,EAAEqiB,eACNriB,EAAEqiB,iBAKFriB,EAAE4kB,aAAc,IAGlB9B,gBAAiB,WAChB,GAAI9iB,GAAI5E,KAAK6nB,aAEb7nB,MAAKgnB,qBAAuBrC,GACtB/f,IAIDA,EAAE8iB,iBACN9iB,EAAE8iB,kBAKH9iB,EAAEmlB,cAAe,IAElBC,yBAA0B,WACzBhqB,KAAKynB,8BAAgC9C,GACrC3kB,KAAK0nB,oBAKPhrB,EAAO+E,MACNwoB,WAAY,YACZC,WAAY,YACV,SAAUC,EAAM/C,GAClB1qB,EAAOyC,MAAMimB,QAAS+E,IACrBrE,aAAcsB,EACdrB,SAAUqB,EAEVzB,OAAQ,SAAUxmB,GACjB,GAAIoC,GACH0B,EAASjD,KACToqB,EAAUjrB,EAAMgqB,cAChB7D,EAAYnmB,EAAMmmB,SASnB,SALM8E,GAAYA,IAAYnnB,IAAWvG,EAAOmN,SAAU5G,EAAQmnB,MACjEjrB,EAAME,KAAOimB,EAAUG,SACvBlkB,EAAM+jB,EAAU3W,QAAQ7M,MAAO9B,KAAM+B,WACrC5C,EAAME,KAAO+nB,GAEP7lB,MAMJ7E,EAAOmI,QAAQwlB,gBAEpB3tB,EAAOyC,MAAMimB,QAAQxP,QACpBsQ,MAAO,WAEN,MAAKxpB,GAAOmK,SAAU7G,KAAM,SACpB,GAIRtD,EAAOyC,MAAMmb,IAAKta,KAAM,iCAAkC,SAAU4E,GAEnE,GAAI7E,GAAO6E,EAAE3B,OACZqnB,EAAO5tB,EAAOmK,SAAU9G,EAAM,UAAarD,EAAOmK,SAAU9G,EAAM,UAAaA,EAAKuqB,KAAOruB,CACvFquB,KAAS5tB,EAAO+jB,MAAO6J,EAAM,mBACjC5tB,EAAOyC,MAAMmb,IAAKgQ,EAAM,iBAAkB,SAAUnrB,GACnDA,EAAMorB,gBAAiB,IAExB7tB,EAAO+jB,MAAO6J,EAAM,iBAAiB,MARvC5tB,IAcDirB,aAAc,SAAUxoB,GAElBA,EAAMorB,uBACHprB,GAAMorB,eACRvqB,KAAKc,aAAe3B,EAAMynB,WAC9BlqB,EAAOyC,MAAMsqB,SAAU,SAAUzpB,KAAKc,WAAY3B,GAAO,KAK5DknB,SAAU,WAET,MAAK3pB,GAAOmK,SAAU7G,KAAM,SACpB,GAIRtD,EAAOyC,MAAMsG,OAAQzF,KAAM,YAA3BtD,MAMGA,EAAOmI,QAAQ2lB,gBAEpB9tB,EAAOyC,MAAMimB,QAAQ7G,QAEpB2H,MAAO,WAEN,MAAK5B,GAAW7jB,KAAMT,KAAK6G,YAIP,aAAd7G,KAAKX,MAAqC,UAAdW,KAAKX,QACrC3C,EAAOyC,MAAMmb,IAAKta,KAAM,yBAA0B,SAAUb,GACjB,YAArCA,EAAM0oB,cAAc4C,eACxBzqB,KAAK0qB,eAAgB,KAGvBhuB,EAAOyC,MAAMmb,IAAKta,KAAM,gBAAiB,SAAUb,GAC7Ca,KAAK0qB,gBAAkBvrB,EAAMynB,YACjC5mB,KAAK0qB,eAAgB,GAGtBhuB,EAAOyC,MAAMsqB,SAAU,SAAUzpB,KAAMb,GAAO,OAGzC,IAGRzC,EAAOyC,MAAMmb,IAAKta,KAAM,yBAA0B,SAAU4E,GAC3D,GAAI7E,GAAO6E,EAAE3B,MAERqhB,GAAW7jB,KAAMV,EAAK8G,YAAenK,EAAO+jB,MAAO1gB,EAAM,mBAC7DrD,EAAOyC,MAAMmb,IAAKva,EAAM,iBAAkB,SAAUZ,IAC9Ca,KAAKc,YAAe3B,EAAMwqB,aAAgBxqB,EAAMynB,WACpDlqB,EAAOyC,MAAMsqB,SAAU,SAAUzpB,KAAKc,WAAY3B,GAAO,KAG3DzC,EAAO+jB,MAAO1gB,EAAM,iBAAiB,MATvCrD,IAcDipB,OAAQ,SAAUxmB,GACjB,GAAIY,GAAOZ,EAAM8D,MAGjB,OAAKjD,QAASD,GAAQZ,EAAMwqB,aAAexqB,EAAMynB,WAA4B,UAAd7mB,EAAKV,MAAkC,aAAdU,EAAKV,KACrFF,EAAMmmB,UAAU3W,QAAQ7M,MAAO9B,KAAM+B,WAD7C,GAKDskB,SAAU,WAGT,MAFA3pB,GAAOyC,MAAMsG,OAAQzF,KAAM,aAEnBskB,EAAW7jB,KAAMT,KAAK6G,aAM3BnK,EAAOmI,QAAQ8lB,gBACpBjuB,EAAO+E,MAAO6S,MAAO,UAAWgV,KAAM,YAAc,SAAUa,EAAM/C,GAGnE,GAAIwD,GAAW,EACdjc,EAAU,SAAUxP,GACnBzC,EAAOyC,MAAMsqB,SAAUrC,EAAKjoB,EAAM8D,OAAQvG,EAAOyC,MAAMioB,IAAKjoB,IAAS,GAGvEzC,GAAOyC,MAAMimB,QAASgC,IACrBlB,MAAO,WACc,IAAf0E,KACJtuB,EAAS8C,iBAAkB+qB,EAAMxb,GAAS,IAG5C0X,SAAU,WACW,MAAbuE,GACNtuB,EAASmD,oBAAqB0qB,EAAMxb,GAAS,OAOlDjS,EAAOsB,GAAG0E,QAETmoB,GAAI,SAAU7F,EAAOlnB,EAAUqH,EAAMnH,EAAiBqlB,GACrD,GAAIhkB,GAAMyrB,CAGV,IAAsB,gBAAV9F,GAAqB,CAEP,gBAAblnB,KAEXqH,EAAOA,GAAQrH,EACfA,EAAW7B,EAEZ,KAAMoD,IAAQ2lB,GACbhlB,KAAK6qB,GAAIxrB,EAAMvB,EAAUqH,EAAM6f,EAAO3lB,GAAQgkB,EAE/C,OAAOrjB,MAmBR,GAhBa,MAARmF,GAAsB,MAANnH,GAEpBA,EAAKF,EACLqH,EAAOrH,EAAW7B,GACD,MAAN+B,IACc,gBAAbF,IAEXE,EAAKmH,EACLA,EAAOlJ,IAGP+B,EAAKmH,EACLA,EAAOrH,EACPA,EAAW7B,IAGR+B,KAAO,EACXA,EAAK4mB,OACC,KAAM5mB,EACZ,MAAOgC,KAaR,OAVa,KAARqjB,IACJyH,EAAS9sB,EACTA,EAAK,SAAUmB,GAGd,MADAzC,KAASwH,IAAK/E,GACP2rB,EAAOhpB,MAAO9B,KAAM+B,YAG5B/D,EAAG6J,KAAOijB,EAAOjjB,OAAUijB,EAAOjjB,KAAOnL,EAAOmL,SAE1C7H,KAAKyB,KAAM,WACjB/E,EAAOyC,MAAMmb,IAAKta,KAAMglB,EAAOhnB,EAAImH,EAAMrH,MAG3CulB,IAAK,SAAU2B,EAAOlnB,EAAUqH,EAAMnH,GACrC,MAAOgC,MAAK6qB,GAAI7F,EAAOlnB,EAAUqH,EAAMnH,EAAI,IAE5CkG,IAAK,SAAU8gB,EAAOlnB,EAAUE,GAC/B,GAAIsnB,GAAWjmB,CACf,IAAK2lB,GAASA,EAAMiC,gBAAkBjC,EAAMM,UAQ3C,MANAA,GAAYN,EAAMM,UAClB5oB,EAAQsoB,EAAMsC,gBAAiBpjB,IAC9BohB,EAAUU,UAAYV,EAAUG,SAAW,IAAMH,EAAUU,UAAYV,EAAUG,SACjFH,EAAUxnB,SACVwnB,EAAU3W,SAEJ3O,IAER,IAAsB,gBAAVglB,GAAqB,CAEhC,IAAM3lB,IAAQ2lB,GACbhlB,KAAKkE,IAAK7E,EAAMvB,EAAUknB,EAAO3lB,GAElC,OAAOW,MAUR,OARKlC,KAAa,GAA6B,kBAAbA,MAEjCE,EAAKF,EACLA,EAAW7B,GAEP+B,KAAO,IACXA,EAAK4mB,IAEC5kB,KAAKyB,KAAK,WAChB/E,EAAOyC,MAAMsG,OAAQzF,KAAMglB,EAAOhnB,EAAIF,MAIxCmG,QAAS,SAAU5E,EAAM8F,GACxB,MAAOnF,MAAKyB,KAAK,WAChB/E,EAAOyC,MAAM8E,QAAS5E,EAAM8F,EAAMnF,SAGpC+qB,eAAgB,SAAU1rB,EAAM8F,GAC/B,GAAIpF,GAAOC,KAAK,EAChB,OAAKD,GACGrD,EAAOyC,MAAM8E,QAAS5E,EAAM8F,EAAMpF,GAAM,GADhD,IAKF,IAAIirB,IAAW,iBACdC,GAAe,iCACfC,GAAgBxuB,EAAO4U,KAAKxR,MAAMoM,aAElCif,IACCC,UAAU,EACVC,UAAU,EACVpK,MAAM,EACNqK,MAAM,EAGR5uB,GAAOsB,GAAG0E,QACTtC,KAAM,SAAUtC,GACf,GAAIqE,GACHZ,KACA6Y,EAAOpa,KACPoC,EAAMgY,EAAKla,MAEZ,IAAyB,gBAAbpC,GACX,MAAOkC,MAAKqB,UAAW3E,EAAQoB,GAAWoS,OAAO,WAChD,IAAM/N,EAAI,EAAOC,EAAJD,EAASA,IACrB,GAAKzF,EAAOmN,SAAUuQ,EAAMjY,GAAKnC,MAChC,OAAO,IAMX,KAAMmC,EAAI,EAAOC,EAAJD,EAASA,IACrBzF,EAAO0D,KAAMtC,EAAUsc,EAAMjY,GAAKZ,EAMnC,OAFAA,GAAMvB,KAAKqB,UAAWe,EAAM,EAAI1F,EAAOwc,OAAQ3X,GAAQA,GACvDA,EAAIzD,SAAWkC,KAAKlC,SAAWkC,KAAKlC,SAAW,IAAMA,EAAWA,EACzDyD,GAGRyS,IAAK,SAAU/Q,GACd,GAAId,GACHopB,EAAU7uB,EAAQuG,EAAQjD,MAC1BoC,EAAMmpB,EAAQrrB,MAEf,OAAOF,MAAKkQ,OAAO,WAClB,IAAM/N,EAAI,EAAOC,EAAJD,EAASA,IACrB,GAAKzF,EAAOmN,SAAU7J,KAAMurB,EAAQppB,IACnC,OAAO,KAMX0R,IAAK,SAAU/V,GACd,MAAOkC,MAAKqB,UAAWmqB,GAAOxrB,KAAMlC,OAAgB,KAGrDoS,OAAQ,SAAUpS,GACjB,MAAOkC,MAAKqB,UAAWmqB,GAAOxrB,KAAMlC,OAAgB,KAGrD2tB,GAAI,SAAU3tB,GACb,QAAS0tB,GACRxrB,KAIoB,gBAAblC,IAAyBotB,GAAczqB,KAAM3C,GACnDpB,EAAQoB,GACRA,OACD,GACCoC,QAGHwrB,QAAS,SAAU1Z,EAAWjU,GAC7B,GAAI+Q,GACH3M,EAAI,EACJqF,EAAIxH,KAAKE,OACTqB,KACAoqB,EAAMT,GAAczqB,KAAMuR,IAAoC,gBAAdA,GAC/CtV,EAAQsV,EAAWjU,GAAWiC,KAAKjC,SACnC,CAEF,MAAYyJ,EAAJrF,EAAOA,IACd,IAAM2M,EAAM9O,KAAKmC,GAAI2M,GAAOA,IAAQ/Q,EAAS+Q,EAAMA,EAAIhO,WAEtD,GAAoB,GAAfgO,EAAIvO,WAAkBorB,EAC1BA,EAAIpR,MAAMzL,GAAO,GAGA,IAAjBA,EAAIvO,UACH7D,EAAO0D,KAAKmQ,gBAAgBzB,EAAKkD,IAAc,CAEhDlD,EAAMvN,EAAIpE,KAAM2R,EAChB,OAKH,MAAO9O,MAAKqB,UAAWE,EAAIrB,OAAS,EAAIxD,EAAOwc,OAAQ3X,GAAQA,IAKhEgZ,MAAO,SAAUxa,GAGhB,MAAMA,GAKe,gBAATA,GACJrD,EAAO2K,QAASrH,KAAK,GAAItD,EAAQqD,IAIlCrD,EAAO2K,QAEbtH,EAAKH,OAASG,EAAK,GAAKA,EAAMC,MAXrBA,KAAK,IAAMA,KAAK,GAAGc,WAAed,KAAKgC,QAAQ4pB,UAAU1rB,OAAS,IAc7Eoa,IAAK,SAAUxc,EAAUC,GACxB,GAAIolB,GAA0B,gBAAbrlB,GACfpB,EAAQoB,EAAUC,GAClBrB,EAAOsE,UAAWlD,GAAYA,EAASyC,UAAazC,GAAaA,GAClEiB,EAAMrC,EAAO2D,MAAOL,KAAKmB,MAAOgiB,EAEjC,OAAOnjB,MAAKqB,UAAW3E,EAAOwc,OAAOna,KAGtC8sB,QAAS,SAAU/tB,GAClB,MAAOkC,MAAKsa,IAAiB,MAAZxc,EAChBkC,KAAKwB,WAAaxB,KAAKwB,WAAW0O,OAAOpS,MAK5C,SAASguB,IAAShd,EAAKsD,GACtB,EACCtD,GAAMA,EAAKsD,SACFtD,GAAwB,IAAjBA,EAAIvO,SAErB,OAAOuO,GAGRpS,EAAO+E,MACNgO,OAAQ,SAAU1P,GACjB,GAAI0P,GAAS1P,EAAKe,UAClB,OAAO2O,IAA8B,KAApBA,EAAOlP,SAAkBkP,EAAS,MAEpDsc,QAAS,SAAUhsB,GAClB,MAAOrD,GAAO0V,IAAKrS,EAAM,eAE1BisB,aAAc,SAAUjsB,EAAMoC,EAAG8pB,GAChC,MAAOvvB,GAAO0V,IAAKrS,EAAM,aAAcksB,IAExChL,KAAM,SAAUlhB,GACf,MAAO+rB,IAAS/rB,EAAM,gBAEvBurB,KAAM,SAAUvrB,GACf,MAAO+rB,IAAS/rB,EAAM,oBAEvBmsB,QAAS,SAAUnsB,GAClB,MAAOrD,GAAO0V,IAAKrS,EAAM,gBAE1B6rB,QAAS,SAAU7rB,GAClB,MAAOrD,GAAO0V,IAAKrS,EAAM,oBAE1BosB,UAAW,SAAUpsB,EAAMoC,EAAG8pB,GAC7B,MAAOvvB,GAAO0V,IAAKrS,EAAM,cAAeksB,IAEzCG,UAAW,SAAUrsB,EAAMoC,EAAG8pB,GAC7B,MAAOvvB,GAAO0V,IAAKrS,EAAM,kBAAmBksB,IAE7CI,SAAU,SAAUtsB,GACnB,MAAOrD,GAAOovB,SAAW/rB,EAAKe,gBAAmBiP,WAAYhQ,IAE9DqrB,SAAU,SAAUrrB,GACnB,MAAOrD,GAAOovB,QAAS/rB,EAAKgQ,aAE7Bsb,SAAU,SAAUtrB,GACnB,MAAOrD,GAAOmK,SAAU9G,EAAM,UAC7BA,EAAKusB,iBAAmBvsB,EAAKwsB,cAAcjwB,SAC3CI,EAAO2D,SAAWN,EAAK2F,cAEvB,SAAU5C,EAAM9E,GAClBtB,EAAOsB,GAAI8E,GAAS,SAAUmpB,EAAOnuB,GACpC,GAAIyD,GAAM7E,EAAO4F,IAAKtC,KAAMhC,EAAIiuB,EAsBhC,OApB0B,UAArBnpB,EAAKzF,MAAO,MAChBS,EAAWmuB,GAGPnuB,GAAgC,gBAAbA,KACvByD,EAAM7E,EAAOwT,OAAQpS,EAAUyD,IAG3BvB,KAAKE,OAAS,IAEZirB,GAAkBroB,KACvBvB,EAAM7E,EAAOwc,OAAQ3X,IAIjB0pB,GAAaxqB,KAAMqC,KACvBvB,EAAMA,EAAIirB,YAILxsB,KAAKqB,UAAWE,MAIzB7E,EAAOgG,QACNwN,OAAQ,SAAUoB,EAAMhQ,EAAOuS,GAC9B,GAAI9T,GAAOuB,EAAO,EAMlB,OAJKuS,KACJvC,EAAO,QAAUA,EAAO,KAGD,IAAjBhQ,EAAMpB,QAAkC,IAAlBH,EAAKQ,SACjC7D,EAAO0D,KAAKmQ,gBAAiBxQ,EAAMuR,IAAWvR,MAC9CrD,EAAO0D,KAAKwJ,QAAS0H,EAAM5U,EAAO+K,KAAMnG,EAAO,SAAUvB,GACxD,MAAyB,KAAlBA,EAAKQ,aAIf6R,IAAK,SAAUrS,EAAMqS,EAAK6Z,GACzB,GAAIrY,MACH9E,EAAM/O,EAAMqS,EAEb,OAAQtD,GAAwB,IAAjBA,EAAIvO,WAAmB0rB,IAAUhwB,GAA8B,IAAjB6S,EAAIvO,WAAmB7D,EAAQoS,GAAM2c,GAAIQ,IAC/E,IAAjBnd,EAAIvO,UACRqT,EAAQzW,KAAM2R,GAEfA,EAAMA,EAAIsD,EAEX,OAAOwB,IAGRkY,QAAS,SAAUW,EAAG1sB,GACrB,GAAI2sB,KAEJ,MAAQD,EAAGA,EAAIA,EAAExd,YACI,IAAfwd,EAAElsB,UAAkBksB,IAAM1sB,GAC9B2sB,EAAEvvB,KAAMsvB,EAIV,OAAOC,KAKT,SAASlB,IAAQja,EAAUob,EAAW9Y,GACrC,GAAKnX,EAAOiE,WAAYgsB,GACvB,MAAOjwB,GAAO+K,KAAM8J,EAAU,SAAUxR,EAAMoC,GAE7C,QAASwqB,EAAUzrB,KAAMnB,EAAMoC,EAAGpC,KAAW8T,GAK/C,IAAK8Y,EAAUpsB,SACd,MAAO7D,GAAO+K,KAAM8J,EAAU,SAAUxR,GACvC,MAASA,KAAS4sB,IAAgB9Y,GAKpC,IAA0B,gBAAd8Y,GAAyB,CACpC,GAAK3B,GAASvqB,KAAMksB,GACnB,MAAOjwB,GAAOwT,OAAQyc,EAAWpb,EAAUsC,EAG5C8Y,GAAYjwB,EAAOwT,OAAQyc,EAAWpb,GAGvC,MAAO7U,GAAO+K,KAAM8J,EAAU,SAAUxR,GACvC,MAASrD,GAAO2K,QAAStH,EAAM4sB,IAAe,IAAQ9Y,IAGxD,QAAS+Y,IAAoBtwB,GAC5B,GAAIyd,GAAO8S,GAAU7jB,MAAO,KAC3B8jB,EAAWxwB,EAAS6hB,wBAErB,IAAK2O,EAASvnB,cACb,MAAQwU,EAAK7Z,OACZ4sB,EAASvnB,cACRwU,EAAKpP,MAIR,OAAOmiB,GAGR,GAAID,IAAY,6JAEfE,GAAgB,6BAChBC,GAAmB7hB,OAAO,OAAS0hB,GAAY,WAAY,KAC3DI,GAAqB,OACrBC,GAAY,0EACZC,GAAW,YACXC,GAAS,UACTC,GAAQ,YACRC,GAAe,0BACfC,GAA8B,wBAE9BC,GAAW,oCACXC,GAAc,4BACdC,GAAoB,cACpBC,GAAe,2CAGfC,IACCxK,QAAU,EAAG,+BAAgC,aAC7CyK,QAAU,EAAG,aAAc,eAC3BC,MAAQ,EAAG,QAAS,UACpBC,OAAS,EAAG,WAAY,aACxBC,OAAS,EAAG,UAAW,YACvBC,IAAM,EAAG,iBAAkB,oBAC3BC,KAAO,EAAG,mCAAoC,uBAC9CC,IAAM,EAAG,qBAAsB,yBAI/BhH,SAAUzqB,EAAOmI,QAAQkY,eAAkB,EAAG,GAAI,KAAS,EAAG,SAAU,WAEzEqR,GAAexB,GAAoBtwB,GACnC+xB,GAAcD,GAAaxe,YAAatT,EAASiJ,cAAc,OAEhEqoB,IAAQU,SAAWV,GAAQxK,OAC3BwK,GAAQ9Q,MAAQ8Q,GAAQW,MAAQX,GAAQY,SAAWZ,GAAQa,QAAUb,GAAQI,MAC7EJ,GAAQc,GAAKd,GAAQO,GAErBzxB,EAAOsB,GAAG0E,QACTuE,KAAM,SAAUF,GACf,MAAOrK,GAAOqL,OAAQ/H,KAAM,SAAU+G,GACrC,MAAOA,KAAU9K,EAChBS,EAAOuK,KAAMjH,MACbA,KAAKgV,QAAQ2Z,QAAU3uB,KAAK,IAAMA,KAAK,GAAGQ,eAAiBlE,GAAWsyB,eAAgB7nB,KACrF,KAAMA,EAAOhF,UAAU7B,SAG3ByuB,OAAQ,WACP,MAAO3uB,MAAK6uB,SAAU9sB,UAAW,SAAUhC,GAC1C,GAAuB,IAAlBC,KAAKO,UAAoC,KAAlBP,KAAKO,UAAqC,IAAlBP,KAAKO,SAAiB,CACzE,GAAI0C,GAAS6rB,GAAoB9uB,KAAMD,EACvCkD,GAAO2M,YAAa7P,OAKvBgvB,QAAS,WACR,MAAO/uB,MAAK6uB,SAAU9sB,UAAW,SAAUhC,GAC1C,GAAuB,IAAlBC,KAAKO,UAAoC,KAAlBP,KAAKO,UAAqC,IAAlBP,KAAKO,SAAiB,CACzE,GAAI0C,GAAS6rB,GAAoB9uB,KAAMD,EACvCkD,GAAO+rB,aAAcjvB,EAAMkD,EAAO8M,gBAKrCkf,OAAQ,WACP,MAAOjvB,MAAK6uB,SAAU9sB,UAAW,SAAUhC,GACrCC,KAAKc,YACTd,KAAKc,WAAWkuB,aAAcjvB,EAAMC,SAKvCkvB,MAAO,WACN,MAAOlvB,MAAK6uB,SAAU9sB,UAAW,SAAUhC,GACrCC,KAAKc,YACTd,KAAKc,WAAWkuB,aAAcjvB,EAAMC,KAAKiP,gBAM5CxJ,OAAQ,SAAU3H,EAAUqxB,GAC3B,GAAIpvB,GACHuB,EAAQxD,EAAWpB,EAAOwT,OAAQpS,EAAUkC,MAASA,KACrDmC,EAAI,CAEL,MAA6B,OAApBpC,EAAOuB,EAAMa,IAAaA,IAE5BgtB,GAA8B,IAAlBpvB,EAAKQ,UACtB7D,EAAOyjB,UAAWiP,GAAQrvB,IAGtBA,EAAKe,aACJquB,GAAYzyB,EAAOmN,SAAU9J,EAAKS,cAAeT,IACrDsvB,GAAeD,GAAQrvB,EAAM,WAE9BA,EAAKe,WAAW0N,YAAazO,GAI/B,OAAOC,OAGRgV,MAAO,WACN,GAAIjV,GACHoC,EAAI,CAEL,MAA4B,OAAnBpC,EAAOC,KAAKmC,IAAaA,IAAM,CAEhB,IAAlBpC,EAAKQ,UACT7D,EAAOyjB,UAAWiP,GAAQrvB,GAAM,GAIjC,OAAQA,EAAKgQ,WACZhQ,EAAKyO,YAAazO,EAAKgQ,WAKnBhQ,GAAKgD,SAAWrG,EAAOmK,SAAU9G,EAAM,YAC3CA,EAAKgD,QAAQ7C,OAAS,GAIxB,MAAOF,OAGRgD,MAAO,SAAUssB,EAAeC,GAI/B,MAHAD,GAAiC,MAAjBA,GAAwB,EAAQA,EAChDC,EAAyC,MAArBA,EAA4BD,EAAgBC,EAEzDvvB,KAAKsC,IAAK,WAChB,MAAO5F,GAAOsG,MAAOhD,KAAMsvB,EAAeC,MAI5CC,KAAM,SAAUzoB,GACf,MAAOrK,GAAOqL,OAAQ/H,KAAM,SAAU+G,GACrC,GAAIhH,GAAOC,KAAK,OACfmC,EAAI,EACJqF,EAAIxH,KAAKE,MAEV,IAAK6G,IAAU9K,EACd,MAAyB,KAAlB8D,EAAKQ,SACXR,EAAK+P,UAAUvM,QAASwpB,GAAe,IACvC9wB,CAIF,MAAsB,gBAAV8K,IAAuBumB,GAAa7sB,KAAMsG,KACnDrK,EAAOmI,QAAQkY,eAAkBiQ,GAAavsB,KAAMsG,KACpDrK,EAAOmI,QAAQgY,mBAAsBoQ,GAAmBxsB,KAAMsG,IAC/D6mB,IAAWT,GAAShtB,KAAM4G,KAAY,GAAI,KAAM,GAAGD,gBAAkB,CAEtEC,EAAQA,EAAMxD,QAAS2pB,GAAW,YAElC,KACC,KAAW1lB,EAAJrF,EAAOA,IAEbpC,EAAOC,KAAKmC,OACW,IAAlBpC,EAAKQ,WACT7D,EAAOyjB,UAAWiP,GAAQrvB,GAAM,IAChCA,EAAK+P,UAAY/I,EAInBhH,GAAO,EAGN,MAAM6E,KAGJ7E,GACJC,KAAKgV,QAAQ2Z,OAAQ5nB,IAEpB,KAAMA,EAAOhF,UAAU7B,SAG3BuvB,YAAa,WACZ,GAEC9tB,GAAOjF,EAAO4F,IAAKtC,KAAM,SAAUD,GAClC,OAASA,EAAKkP,YAAalP,EAAKe,cAEjCqB,EAAI,CAmBL,OAhBAnC,MAAK6uB,SAAU9sB,UAAW,SAAUhC,GACnC,GAAIkhB,GAAOtf,EAAMQ,KAChBsN,EAAS9N,EAAMQ,IAEXsN,KAECwR,GAAQA,EAAKngB,aAAe2O,IAChCwR,EAAOjhB,KAAKiP,aAEbvS,EAAQsD,MAAOyF,SACfgK,EAAOuf,aAAcjvB,EAAMkhB,MAG1B,GAGI9e,EAAInC,KAAOA,KAAKyF,UAGxBlG,OAAQ,SAAUzB,GACjB,MAAOkC,MAAKyF,OAAQ3H,GAAU,IAG/B+wB,SAAU,SAAUltB,EAAMD,EAAUguB,GAGnC/tB,EAAO3E,EAAY8E,SAAWH,EAE9B,IAAIK,GAAOuN,EAAMogB,EAChBrqB,EAASkK,EAAK+M,EACdpa,EAAI,EACJqF,EAAIxH,KAAKE,OACTijB,EAAMnjB,KACN4vB,EAAWpoB,EAAI,EACfT,EAAQpF,EAAK,GACbhB,EAAajE,EAAOiE,WAAYoG,EAGjC,IAAKpG,KAAsB,GAAL6G,GAA2B,gBAAVT,IAAsBrK,EAAOmI,QAAQwZ,aAAemP,GAAS/sB,KAAMsG,GACzG,MAAO/G,MAAKyB,KAAK,SAAU8Y,GAC1B,GAAIH,GAAO+I,EAAIlhB,GAAIsY,EACd5Z,KACJgB,EAAK,GAAKoF,EAAM7F,KAAMlB,KAAMua,EAAOH,EAAKoV,SAEzCpV,EAAKyU,SAAUltB,EAAMD,EAAUguB,IAIjC,IAAKloB,IACJ+U,EAAW7f,EAAO8I,cAAe7D,EAAM3B,KAAM,GAAIQ,eAAe,GAAQkvB,GAAqB1vB,MAC7FgC,EAAQua,EAASxM,WAEmB,IAA/BwM,EAAS7W,WAAWxF,SACxBqc,EAAWva,GAGPA,GAAQ,CAMZ,IALAsD,EAAU5I,EAAO4F,IAAK8sB,GAAQ7S,EAAU,UAAYsT,IACpDF,EAAarqB,EAAQpF,OAITsH,EAAJrF,EAAOA,IACdoN,EAAOgN,EAEFpa,IAAMytB,IACVrgB,EAAO7S,EAAOsG,MAAOuM,GAAM,GAAM,GAG5BogB,GACJjzB,EAAO2D,MAAOiF,EAAS8pB,GAAQ7f,EAAM,YAIvC7N,EAASR,KAAMlB,KAAKmC,GAAIoN,EAAMpN,EAG/B,IAAKwtB,EAOJ,IANAngB,EAAMlK,EAASA,EAAQpF,OAAS,GAAIM,cAGpC9D,EAAO4F,IAAKgD,EAASwqB,IAGf3tB,EAAI,EAAOwtB,EAAJxtB,EAAgBA,IAC5BoN,EAAOjK,EAASnD,GACXsrB,GAAYhtB,KAAM8O,EAAKlQ,MAAQ,MAClC3C,EAAO+jB,MAAOlR,EAAM,eAAkB7S,EAAOmN,SAAU2F,EAAKD,KAExDA,EAAK5M,IAETjG,EAAOqzB,SAAUxgB,EAAK5M,KAEtBjG,EAAO+J,YAAc8I,EAAKtI,MAAQsI,EAAKuC,aAAevC,EAAKO,WAAa,IAAKvM,QAASoqB,GAAc,KAOxGpR,GAAWva,EAAQ,KAIrB,MAAOhC,QAMT,SAAS8uB,IAAoB/uB,EAAMiwB,GAClC,MAAOtzB,GAAOmK,SAAU9G,EAAM,UAC7BrD,EAAOmK,SAA+B,IAArBmpB,EAAQzvB,SAAiByvB,EAAUA,EAAQjgB,WAAY,MAExEhQ,EAAKwG,qBAAqB,SAAS,IAClCxG,EAAK6P,YAAa7P,EAAKS,cAAc+E,cAAc,UACpDxF,EAIF,QAAS8vB,IAAe9vB,GAEvB,MADAA,GAAKV,MAA6C,OAArC3C,EAAO0D,KAAKQ,KAAMb,EAAM,SAAqB,IAAMA,EAAKV,KAC9DU,EAER,QAAS+vB,IAAe/vB,GACvB,GAAID,GAAQ4tB,GAAkBvtB,KAAMJ,EAAKV,KAMzC,OALKS,GACJC,EAAKV,KAAOS,EAAM,GAElBC,EAAKgO,gBAAgB,QAEfhO,EAIR,QAASsvB,IAAe/tB,EAAO2uB,GAC9B,GAAIlwB,GACHoC,EAAI,CACL,MAA6B,OAApBpC,EAAOuB,EAAMa,IAAaA,IAClCzF,EAAO+jB,MAAO1gB,EAAM,cAAekwB,GAAevzB,EAAO+jB,MAAOwP,EAAY9tB,GAAI,eAIlF,QAAS+tB,IAAgBvtB,EAAKwtB,GAE7B,GAAuB,IAAlBA,EAAK5vB,UAAmB7D,EAAO6jB,QAAS5d,GAA7C,CAIA,GAAItD,GAAM8C,EAAGqF,EACZ4oB,EAAU1zB,EAAO+jB,MAAO9d,GACxB0tB,EAAU3zB,EAAO+jB,MAAO0P,EAAMC,GAC9BnL,EAASmL,EAAQnL,MAElB,IAAKA,EAAS,OACNoL,GAAQ1K,OACf0K,EAAQpL,SAER,KAAM5lB,IAAQ4lB,GACb,IAAM9iB,EAAI,EAAGqF,EAAIyd,EAAQ5lB,GAAOa,OAAYsH,EAAJrF,EAAOA,IAC9CzF,EAAOyC,MAAMmb,IAAK6V,EAAM9wB,EAAM4lB,EAAQ5lB,GAAQ8C,IAM5CkuB,EAAQlrB,OACZkrB,EAAQlrB,KAAOzI,EAAOgG,UAAY2tB,EAAQlrB,QAI5C,QAASmrB,IAAoB3tB,EAAKwtB,GACjC,GAAItpB,GAAUjC,EAAGO,CAGjB,IAAuB,IAAlBgrB,EAAK5vB,SAAV,CAOA,GAHAsG,EAAWspB,EAAKtpB,SAASC,eAGnBpK,EAAOmI,QAAQgZ,cAAgBsS,EAAMzzB,EAAO0G,SAAY,CAC7D+B,EAAOzI,EAAO+jB,MAAO0P,EAErB,KAAMvrB,IAAKO,GAAK8f,OACfvoB,EAAO4pB,YAAa6J,EAAMvrB,EAAGO,EAAKwgB,OAInCwK,GAAKpiB,gBAAiBrR,EAAO0G,SAIZ,WAAbyD,GAAyBspB,EAAKlpB,OAAStE,EAAIsE,MAC/C4oB,GAAeM,GAAOlpB,KAAOtE,EAAIsE,KACjC6oB,GAAeK,IAIS,WAAbtpB,GACNspB,EAAKrvB,aACTqvB,EAAK3S,UAAY7a,EAAI6a,WAOjB9gB,EAAOmI,QAAQyY,YAAgB3a,EAAImN,YAAcpT,EAAOmB,KAAKsyB,EAAKrgB,aACtEqgB,EAAKrgB,UAAYnN,EAAImN,YAGE,UAAbjJ,GAAwB0mB,GAA4B9sB,KAAMkC,EAAItD,OAKzE8wB,EAAKI,eAAiBJ,EAAKtb,QAAUlS,EAAIkS,QAIpCsb,EAAKppB,QAAUpE,EAAIoE,QACvBopB,EAAKppB,MAAQpE,EAAIoE,QAKM,WAAbF,EACXspB,EAAKK,gBAAkBL,EAAKrb,SAAWnS,EAAI6tB,iBAInB,UAAb3pB,GAAqC,aAAbA,KACnCspB,EAAKlX,aAAetW,EAAIsW,eAI1Bvc,EAAO+E,MACNgvB,SAAU,SACVC,UAAW,UACX1B,aAAc,SACd2B,YAAa,QACbC,WAAY,eACV,SAAU9tB,EAAMulB,GAClB3rB,EAAOsB,GAAI8E,GAAS,SAAUhF,GAC7B,GAAIwD,GACHa,EAAI,EACJZ,KACAsvB,EAASn0B,EAAQoB,GACjBoE,EAAO2uB,EAAO3wB,OAAS,CAExB,MAAagC,GAALC,EAAWA,IAClBb,EAAQa,IAAMD,EAAOlC,KAAOA,KAAKgD,OAAM,GACvCtG,EAAQm0B,EAAO1uB,IAAMkmB,GAAY/mB,GAGjCpE,EAAU4E,MAAOP,EAAKD,EAAMH,MAG7B,OAAOnB,MAAKqB,UAAWE,KAIzB,SAAS6tB,IAAQrxB,EAASsS,GACzB,GAAI/O,GAAOvB,EACVoC,EAAI,EACJ2uB,QAAe/yB,GAAQwI,uBAAyBnK,EAAoB2B,EAAQwI,qBAAsB8J,GAAO,WACjGtS,GAAQ8P,mBAAqBzR,EAAoB2B,EAAQ8P,iBAAkBwC,GAAO,KACzFpU,CAEF,KAAM60B,EACL,IAAMA,KAAYxvB,EAAQvD,EAAQ2H,YAAc3H,EAA8B,OAApBgC,EAAOuB,EAAMa,IAAaA,KAC7EkO,GAAO3T,EAAOmK,SAAU9G,EAAMsQ,GACnCygB,EAAM3zB,KAAM4C,GAEZrD,EAAO2D,MAAOywB,EAAO1B,GAAQrvB,EAAMsQ,GAKtC,OAAOA,KAAQpU,GAAaoU,GAAO3T,EAAOmK,SAAU9I,EAASsS,GAC5D3T,EAAO2D,OAAStC,GAAW+yB,GAC3BA,EAIF,QAASC,IAAmBhxB,GACtBwtB,GAA4B9sB,KAAMV,EAAKV,QAC3CU,EAAKwwB,eAAiBxwB,EAAK8U,SAI7BnY,EAAOgG,QACNM,MAAO,SAAUjD,EAAMuvB,EAAeC,GACrC,GAAIyB,GAAczhB,EAAMvM,EAAOb,EAAG8uB,EACjCC,EAASx0B,EAAOmN,SAAU9J,EAAKS,cAAeT,EAW/C,IATKrD,EAAOmI,QAAQyY,YAAc5gB,EAAOyc,SAASpZ,KAAUitB,GAAavsB,KAAM,IAAMV,EAAK8G,SAAW,KACpG7D,EAAQjD,EAAKwd,WAAW,IAIxB8Q,GAAYve,UAAY/P,EAAKyd,UAC7B6Q,GAAY7f,YAAaxL,EAAQqrB,GAAYte,eAGvCrT,EAAOmI,QAAQgZ,cAAiBnhB,EAAOmI,QAAQmZ,gBACjC,IAAlBje,EAAKQ,UAAoC,KAAlBR,EAAKQ,UAAqB7D,EAAOyc,SAASpZ,IAOnE,IAJAixB,EAAe5B,GAAQpsB,GACvBiuB,EAAc7B,GAAQrvB,GAGhBoC,EAAI,EAA8B,OAA1BoN,EAAO0hB,EAAY9uB,MAAeA,EAE1C6uB,EAAa7uB,IACjBmuB,GAAoB/gB,EAAMyhB,EAAa7uB,GAM1C,IAAKmtB,EACJ,GAAKC,EAIJ,IAHA0B,EAAcA,GAAe7B,GAAQrvB,GACrCixB,EAAeA,GAAgB5B,GAAQpsB,GAEjCb,EAAI,EAA8B,OAA1BoN,EAAO0hB,EAAY9uB,IAAaA,IAC7C+tB,GAAgB3gB,EAAMyhB,EAAa7uB,QAGpC+tB,IAAgBnwB,EAAMiD,EAaxB,OARAguB,GAAe5B,GAAQpsB,EAAO,UACzBguB,EAAa9wB,OAAS,GAC1BmvB,GAAe2B,GAAeE,GAAU9B,GAAQrvB,EAAM,WAGvDixB,EAAeC,EAAc1hB,EAAO,KAG7BvM,GAGRwC,cAAe,SAAUlE,EAAOvD,EAASuH,EAAS6rB,GACjD,GAAI9uB,GAAGtC,EAAM8J,EACZ5D,EAAKoK,EAAKyM,EAAOsU,EACjB5pB,EAAIlG,EAAMpB,OAGVmxB,EAAOzE,GAAoB7uB,GAE3BuzB,KACAnvB,EAAI,CAEL,MAAYqF,EAAJrF,EAAOA,IAGd,GAFApC,EAAOuB,EAAOa,GAETpC,GAAiB,IAATA,EAGZ,GAA6B,WAAxBrD,EAAO2C,KAAMU,GACjBrD,EAAO2D,MAAOixB,EAAOvxB,EAAKQ,UAAaR,GAASA,OAG1C,IAAMstB,GAAM5sB,KAAMV,GAIlB,CACNkG,EAAMA,GAAOorB,EAAKzhB,YAAa7R,EAAQwH,cAAc,QAGrD8K,GAAQ8c,GAAShtB,KAAMJ,KAAW,GAAI,KAAM,GAAG+G,cAC/CsqB,EAAOxD,GAASvd,IAASud,GAAQzG,SAEjClhB,EAAI6J,UAAYshB,EAAK,GAAKrxB,EAAKwD,QAAS2pB,GAAW,aAAgBkE,EAAK,GAGxE/uB,EAAI+uB,EAAK,EACT,OAAQ/uB,IACP4D,EAAMA,EAAIuN,SASX,KALM9W,EAAOmI,QAAQgY,mBAAqBoQ,GAAmBxsB,KAAMV,IAClEuxB,EAAMn0B,KAAMY,EAAQ6wB,eAAgB3B,GAAmB9sB,KAAMJ,GAAO,MAI/DrD,EAAOmI,QAAQiY,MAAQ,CAG5B/c,EAAe,UAARsQ,GAAoB+c,GAAO3sB,KAAMV,GAI3B,YAAZqxB,EAAK,IAAqBhE,GAAO3sB,KAAMV,GAEtC,EADAkG,EAJDA,EAAI8J,WAOL1N,EAAItC,GAAQA,EAAK2F,WAAWxF,MAC5B,OAAQmC,IACF3F,EAAOmK,SAAWiW,EAAQ/c,EAAK2F,WAAWrD,GAAK,WAAcya,EAAMpX,WAAWxF,QAClFH,EAAKyO,YAAasO,GAKrBpgB,EAAO2D,MAAOixB,EAAOrrB,EAAIP,YAGzBO,EAAI6L,YAAc,EAGlB,OAAQ7L,EAAI8J,WACX9J,EAAIuI,YAAavI,EAAI8J,WAItB9J,GAAMorB,EAAK7d,cAtDX8d,GAAMn0B,KAAMY,EAAQ6wB,eAAgB7uB,GA4DlCkG,IACJorB,EAAK7iB,YAAavI,GAKbvJ,EAAOmI,QAAQuZ,eACpB1hB,EAAO+K,KAAM2nB,GAAQkC,EAAO,SAAWP,IAGxC5uB,EAAI,CACJ,OAASpC,EAAOuxB,EAAOnvB,KAItB,KAAKgvB,GAAmD,KAAtCz0B,EAAO2K,QAAStH,EAAMoxB,MAIxCtnB,EAAWnN,EAAOmN,SAAU9J,EAAKS,cAAeT,GAGhDkG,EAAMmpB,GAAQiC,EAAKzhB,YAAa7P,GAAQ,UAGnC8J,GACJwlB,GAAeppB,GAIXX,GAAU,CACdjD,EAAI,CACJ,OAAStC,EAAOkG,EAAK5D,KACforB,GAAYhtB,KAAMV,EAAKV,MAAQ,KACnCiG,EAAQnI,KAAM4C,GAQlB,MAFAkG,GAAM,KAECorB,GAGRlR,UAAW,SAAU7e,EAAsBse,GAC1C,GAAI7f,GAAMV,EAAM0B,EAAIoE,EACnBhD,EAAI,EACJ2d,EAAcpjB,EAAO0G,QACrB8K,EAAQxR,EAAOwR,MACf0P,EAAgBlhB,EAAOmI,QAAQ+Y,cAC/BwH,EAAU1oB,EAAOyC,MAAMimB,OAExB,MAA6B,OAApBrlB,EAAOuB,EAAMa,IAAaA,IAElC,IAAKyd,GAAcljB,EAAOkjB,WAAY7f,MAErCgB,EAAKhB,EAAM+f,GACX3a,EAAOpE,GAAMmN,EAAOnN,IAER,CACX,GAAKoE,EAAK8f,OACT,IAAM5lB,IAAQ8F,GAAK8f,OACbG,EAAS/lB,GACb3C,EAAOyC,MAAMsG,OAAQ1F,EAAMV,GAI3B3C,EAAO4pB,YAAavmB,EAAMV,EAAM8F,EAAKwgB,OAMnCzX;EAAOnN,WAEJmN,GAAOnN,GAKT6c,QACG7d,GAAM+f,SAEK/f,GAAKgO,kBAAoB3R,EAC3C2D,EAAKgO,gBAAiB+R,GAGtB/f,EAAM+f,GAAgB,KAGvBhjB,EAAgBK,KAAM4D,MAO3BgvB,SAAU,SAAUwB,GACnB,MAAO70B,GAAO80B,MACbD,IAAKA,EACLlyB,KAAM,MACNoyB,SAAU,SACVprB,OAAO,EACP0e,QAAQ,EACR2M,UAAU,OAIbh1B,EAAOsB,GAAG0E,QACTivB,QAAS,SAAUnC,GAClB,GAAK9yB,EAAOiE,WAAY6uB,GACvB,MAAOxvB,MAAKyB,KAAK,SAASU,GACzBzF,EAAOsD,MAAM2xB,QAASnC,EAAKtuB,KAAKlB,KAAMmC,KAIxC,IAAKnC,KAAK,GAAK,CAEd,GAAIoxB,GAAO10B,EAAQ8yB,EAAMxvB,KAAK,GAAGQ,eAAgByB,GAAG,GAAGe,OAAM,EAExDhD,MAAK,GAAGc,YACZswB,EAAKpC,aAAchvB,KAAK,IAGzBoxB,EAAK9uB,IAAI,WACR,GAAIvC,GAAOC,IAEX,OAAQD,EAAKgQ,YAA2C,IAA7BhQ,EAAKgQ,WAAWxP,SAC1CR,EAAOA,EAAKgQ,UAGb,OAAOhQ,KACL4uB,OAAQ3uB,MAGZ,MAAOA,OAGR4xB,UAAW,SAAUpC,GACpB,MAAK9yB,GAAOiE,WAAY6uB,GAChBxvB,KAAKyB,KAAK,SAASU,GACzBzF,EAAOsD,MAAM4xB,UAAWpC,EAAKtuB,KAAKlB,KAAMmC,MAInCnC,KAAKyB,KAAK,WAChB,GAAI2Y,GAAO1d,EAAQsD,MAClBqrB,EAAWjR,EAAKiR,UAEZA,GAASnrB,OACbmrB,EAASsG,QAASnC,GAGlBpV,EAAKuU,OAAQa,MAKhB4B,KAAM,SAAU5B,GACf,GAAI7uB,GAAajE,EAAOiE,WAAY6uB,EAEpC,OAAOxvB,MAAKyB,KAAK,SAASU,GACzBzF,EAAQsD,MAAO2xB,QAAShxB,EAAa6uB,EAAKtuB,KAAKlB,KAAMmC,GAAKqtB,MAI5DqC,OAAQ,WACP,MAAO7xB,MAAKyP,SAAShO,KAAK,WACnB/E,EAAOmK,SAAU7G,KAAM,SAC5BtD,EAAQsD,MAAOyvB,YAAazvB,KAAK0F,cAEhCnD,QAGL,IAAIuvB,IAAQC,GAAWC,GACtBC,GAAS,kBACTC,GAAW,wBACXC,GAAY,4BAGZC,GAAe,4BACfC,GAAU,UACVC,GAAgBnnB,OAAQ,KAAOjN,EAAY,SAAU,KACrDq0B,GAAgBpnB,OAAQ,KAAOjN,EAAY,kBAAmB,KAC9Ds0B,GAAcrnB,OAAQ,YAAcjN,EAAY,IAAK,KACrDu0B,IAAgBC,KAAM,SAEtBC,IAAYC,SAAU,WAAYC,WAAY,SAAU7T,QAAS,SACjE8T,IACCC,cAAe,EACfC,WAAY,KAGbC,IAAc,MAAO,QAAS,SAAU,QACxCC,IAAgB,SAAU,IAAK,MAAO,KAGvC,SAASC,IAAgB1qB,EAAO3F,GAG/B,GAAKA,IAAQ2F,GACZ,MAAO3F,EAIR,IAAIswB,GAAUtwB,EAAK7C,OAAO,GAAGhB,cAAgB6D,EAAKzF,MAAM,GACvDg2B,EAAWvwB,EACXX,EAAI+wB,GAAYhzB,MAEjB,OAAQiC,IAEP,GADAW,EAAOowB,GAAa/wB,GAAMixB,EACrBtwB,IAAQ2F,GACZ,MAAO3F,EAIT,OAAOuwB,GAGR,QAASC,IAAUvzB,EAAMwzB,GAIxB,MADAxzB,GAAOwzB,GAAMxzB,EAC4B,SAAlCrD,EAAO82B,IAAKzzB,EAAM,aAA2BrD,EAAOmN,SAAU9J,EAAKS,cAAeT,GAG1F,QAAS0zB,IAAUliB,EAAUmiB,GAC5B,GAAI1U,GAASjf,EAAM4zB,EAClBzX,KACA3B,EAAQ,EACRra,EAASqR,EAASrR,MAEnB,MAAgBA,EAARqa,EAAgBA,IACvBxa,EAAOwR,EAAUgJ,GACXxa,EAAK0I,QAIXyT,EAAQ3B,GAAU7d,EAAO+jB,MAAO1gB,EAAM,cACtCif,EAAUjf,EAAK0I,MAAMuW,QAChB0U,GAGExX,EAAQ3B,IAAuB,SAAZyE,IACxBjf,EAAK0I,MAAMuW,QAAU,IAMM,KAAvBjf,EAAK0I,MAAMuW,SAAkBsU,GAAUvzB,KAC3Cmc,EAAQ3B,GAAU7d,EAAO+jB,MAAO1gB,EAAM,aAAc6zB,GAAmB7zB,EAAK8G,aAIvEqV,EAAQ3B,KACboZ,EAASL,GAAUvzB,IAEdif,GAAuB,SAAZA,IAAuB2U,IACtCj3B,EAAO+jB,MAAO1gB,EAAM,aAAc4zB,EAAS3U,EAAUtiB,EAAO82B,IAAKzzB,EAAM,aAQ3E,KAAMwa,EAAQ,EAAWra,EAARqa,EAAgBA,IAChCxa,EAAOwR,EAAUgJ,GACXxa,EAAK0I,QAGLirB,GAA+B,SAAvB3zB,EAAK0I,MAAMuW,SAA6C,KAAvBjf,EAAK0I,MAAMuW,UACzDjf,EAAK0I,MAAMuW,QAAU0U,EAAOxX,EAAQ3B,IAAW,GAAK,QAItD,OAAOhJ,GAGR7U,EAAOsB,GAAG0E,QACT8wB,IAAK,SAAU1wB,EAAMiE,GACpB,MAAOrK,GAAOqL,OAAQ/H,KAAM,SAAUD,EAAM+C,EAAMiE,GACjD,GAAI3E,GAAKyxB,EACRvxB,KACAH,EAAI,CAEL,IAAKzF,EAAOyG,QAASL,GAAS,CAI7B,IAHA+wB,EAAS9B,GAAWhyB,GACpBqC,EAAMU,EAAK5C,OAECkC,EAAJD,EAASA,IAChBG,EAAKQ,EAAMX,IAAQzF,EAAO82B,IAAKzzB,EAAM+C,EAAMX,IAAK,EAAO0xB,EAGxD,OAAOvxB,GAGR,MAAOyE,KAAU9K,EAChBS,EAAO+L,MAAO1I,EAAM+C,EAAMiE,GAC1BrK,EAAO82B,IAAKzzB,EAAM+C,IACjBA,EAAMiE,EAAOhF,UAAU7B,OAAS,IAEpCwzB,KAAM,WACL,MAAOD,IAAUzzB,MAAM,IAExB8zB,KAAM,WACL,MAAOL,IAAUzzB,OAElB+zB,OAAQ,SAAUlZ,GACjB,MAAsB,iBAAVA,GACJA,EAAQ7a,KAAK0zB,OAAS1zB,KAAK8zB,OAG5B9zB,KAAKyB,KAAK,WACX6xB,GAAUtzB,MACdtD,EAAQsD,MAAO0zB,OAEfh3B,EAAQsD,MAAO8zB,YAMnBp3B,EAAOgG,QAGNsxB,UACC/W,SACC9b,IAAK,SAAUpB,EAAMk0B,GACpB,GAAKA,EAAW,CAEf,GAAI1yB,GAAMywB,GAAQjyB,EAAM,UACxB,OAAe,KAARwB,EAAa,IAAMA,MAO9B2yB,WACCC,aAAe,EACfC,aAAe,EACfpB,YAAc,EACdqB,YAAc,EACdpX,SAAW,EACXqX,OAAS,EACTC,SAAW,EACXC,QAAU,EACVC,QAAU,EACVvV,MAAQ,GAKTwV,UAECC,QAASj4B,EAAOmI,QAAQqY,SAAW,WAAa,cAIjDzU,MAAO,SAAU1I,EAAM+C,EAAMiE,EAAO6tB,GAEnC,GAAM70B,GAA0B,IAAlBA,EAAKQ,UAAoC,IAAlBR,EAAKQ,UAAmBR,EAAK0I,MAAlE,CAKA,GAAIlH,GAAKlC,EAAM0hB,EACdsS,EAAW32B,EAAOiK,UAAW7D,GAC7B2F,EAAQ1I,EAAK0I,KASd,IAPA3F,EAAOpG,EAAOg4B,SAAUrB,KAAgB32B,EAAOg4B,SAAUrB,GAAaF,GAAgB1qB,EAAO4qB,IAI7FtS,EAAQrkB,EAAOs3B,SAAUlxB,IAAUpG,EAAOs3B,SAAUX,GAG/CtsB,IAAU9K,EAsCd,MAAK8kB,IAAS,OAASA,KAAUxf,EAAMwf,EAAM5f,IAAKpB,GAAM,EAAO60B,MAAa34B,EACpEsF,EAIDkH,EAAO3F,EAhCd,IAVAzD,QAAc0H,GAGA,WAAT1H,IAAsBkC,EAAMixB,GAAQryB,KAAM4G,MAC9CA,GAAUxF,EAAI,GAAK,GAAMA,EAAI,GAAKiD,WAAY9H,EAAO82B,IAAKzzB,EAAM+C,IAEhEzD,EAAO,YAIM,MAAT0H,GAA0B,WAAT1H,GAAqBkF,MAAOwC,KAKpC,WAAT1H,GAAsB3C,EAAOw3B,UAAWb,KAC5CtsB,GAAS,MAKJrK,EAAOmI,QAAQ6Z,iBAA6B,KAAV3X,GAA+C,IAA/BjE,EAAKvF,QAAQ,gBACpEkL,EAAO3F,GAAS,WAIXie,GAAW,OAASA,KAAWha,EAAQga,EAAMoC,IAAKpjB,EAAMgH,EAAO6tB,MAAa34B,IAIjF,IACCwM,EAAO3F,GAASiE,EACf,MAAMnC,OAcX4uB,IAAK,SAAUzzB,EAAM+C,EAAM8xB,EAAOf,GACjC,GAAIzyB,GAAKoQ,EAAKuP,EACbsS,EAAW32B,EAAOiK,UAAW7D,EAyB9B,OAtBAA,GAAOpG,EAAOg4B,SAAUrB,KAAgB32B,EAAOg4B,SAAUrB,GAAaF,GAAgBpzB,EAAK0I,MAAO4qB,IAIlGtS,EAAQrkB,EAAOs3B,SAAUlxB,IAAUpG,EAAOs3B,SAAUX,GAG/CtS,GAAS,OAASA,KACtBvP,EAAMuP,EAAM5f,IAAKpB,GAAM,EAAM60B,IAIzBpjB,IAAQvV,IACZuV,EAAMwgB,GAAQjyB,EAAM+C,EAAM+wB,IAId,WAARriB,GAAoB1O,IAAQgwB,MAChCthB,EAAMshB,GAAoBhwB,IAIZ,KAAV8xB,GAAgBA,GACpBxzB,EAAMoD,WAAYgN,GACXojB,KAAU,GAAQl4B,EAAO4H,UAAWlD,GAAQA,GAAO,EAAIoQ,GAExDA,KAMJxV,EAAOqjB,kBACX0S,GAAY,SAAUhyB,GACrB,MAAO/D,GAAOqjB,iBAAkBtf,EAAM,OAGvCiyB,GAAS,SAAUjyB,EAAM+C,EAAM+xB,GAC9B,GAAIvV,GAAOwV,EAAUC,EACpBd,EAAWY,GAAa9C,GAAWhyB,GAGnCwB,EAAM0yB,EAAWA,EAASe,iBAAkBlyB,IAAUmxB,EAAUnxB,GAAS7G,EACzEwM,EAAQ1I,EAAK0I,KA8Bd,OA5BKwrB,KAES,KAAR1yB,GAAe7E,EAAOmN,SAAU9J,EAAKS,cAAeT,KACxDwB,EAAM7E,EAAO+L,MAAO1I,EAAM+C,IAOtByvB,GAAU9xB,KAAMc,IAAS8wB,GAAQ5xB,KAAMqC,KAG3Cwc,EAAQ7W,EAAM6W,MACdwV,EAAWrsB,EAAMqsB,SACjBC,EAAWtsB,EAAMssB,SAGjBtsB,EAAMqsB,SAAWrsB,EAAMssB,SAAWtsB,EAAM6W,MAAQ/d,EAChDA,EAAM0yB,EAAS3U,MAGf7W,EAAM6W,MAAQA,EACd7W,EAAMqsB,SAAWA,EACjBrsB,EAAMssB,SAAWA,IAIZxzB,IAEGjF,EAASE,gBAAgBy4B,eACpClD,GAAY,SAAUhyB,GACrB,MAAOA,GAAKk1B,cAGbjD,GAAS,SAAUjyB,EAAM+C,EAAM+xB,GAC9B,GAAIK,GAAMC,EAAIC,EACbnB,EAAWY,GAAa9C,GAAWhyB,GACnCwB,EAAM0yB,EAAWA,EAAUnxB,GAAS7G,EACpCwM,EAAQ1I,EAAK0I,KAoCd,OAhCY,OAAPlH,GAAekH,GAASA,EAAO3F,KACnCvB,EAAMkH,EAAO3F,IAUTyvB,GAAU9xB,KAAMc,KAAU4wB,GAAU1xB,KAAMqC,KAG9CoyB,EAAOzsB,EAAMysB,KACbC,EAAKp1B,EAAKs1B,aACVD,EAASD,GAAMA,EAAGD,KAGbE,IACJD,EAAGD,KAAOn1B,EAAKk1B,aAAaC,MAE7BzsB,EAAMysB,KAAgB,aAATpyB,EAAsB,MAAQvB,EAC3CA,EAAMkH,EAAM6sB,UAAY,KAGxB7sB,EAAMysB,KAAOA,EACRE,IACJD,EAAGD,KAAOE,IAIG,KAAR7zB,EAAa,OAASA,GAI/B,SAASg0B,IAAmBx1B,EAAMgH,EAAOyuB,GACxC,GAAI5rB,GAAU0oB,GAAUnyB,KAAM4G,EAC9B,OAAO6C,GAENvG,KAAKiE,IAAK,EAAGsC,EAAS,IAAQ4rB,GAAY,KAAU5rB,EAAS,IAAO,MACpE7C,EAGF,QAAS0uB,IAAsB11B,EAAM+C,EAAM8xB,EAAOc,EAAa7B,GAC9D,GAAI1xB,GAAIyyB,KAAYc,EAAc,SAAW,WAE5C,EAES,UAAT5yB,EAAmB,EAAI,EAEvB0O,EAAM,CAEP,MAAY,EAAJrP,EAAOA,GAAK,EAEJ,WAAVyyB,IACJpjB,GAAO9U,EAAO82B,IAAKzzB,EAAM60B,EAAQ3B,GAAW9wB,IAAK,EAAM0xB,IAGnD6B,GAEW,YAAVd,IACJpjB,GAAO9U,EAAO82B,IAAKzzB,EAAM,UAAYkzB,GAAW9wB,IAAK,EAAM0xB,IAI7C,WAAVe,IACJpjB,GAAO9U,EAAO82B,IAAKzzB,EAAM,SAAWkzB,GAAW9wB,GAAM,SAAS,EAAM0xB,MAIrEriB,GAAO9U,EAAO82B,IAAKzzB,EAAM,UAAYkzB,GAAW9wB,IAAK,EAAM0xB,GAG5C,YAAVe,IACJpjB,GAAO9U,EAAO82B,IAAKzzB,EAAM,SAAWkzB,GAAW9wB,GAAM,SAAS,EAAM0xB,IAKvE,OAAOriB,GAGR,QAASmkB,IAAkB51B,EAAM+C,EAAM8xB,GAGtC,GAAIgB,IAAmB,EACtBpkB,EAAe,UAAT1O,EAAmB/C,EAAKqf,YAAcrf,EAAKgf,aACjD8U,EAAS9B,GAAWhyB,GACpB21B,EAAch5B,EAAOmI,QAAQsa,WAAgE,eAAnDziB,EAAO82B,IAAKzzB,EAAM,aAAa,EAAO8zB,EAKjF,IAAY,GAAPriB,GAAmB,MAAPA,EAAc,CAQ9B,GANAA,EAAMwgB,GAAQjyB,EAAM+C,EAAM+wB,IACf,EAANriB,GAAkB,MAAPA,KACfA,EAAMzR,EAAK0I,MAAO3F,IAIdyvB,GAAU9xB,KAAK+Q,GACnB,MAAOA,EAKRokB,GAAmBF,IAAiBh5B,EAAOmI,QAAQkZ,mBAAqBvM,IAAQzR,EAAK0I,MAAO3F,IAG5F0O,EAAMhN,WAAYgN,IAAS,EAI5B,MAASA,GACRikB,GACC11B,EACA+C,EACA8xB,IAAWc,EAAc,SAAW,WACpCE,EACA/B,GAEE,KAIL,QAASD,IAAoB/sB,GAC5B,GAAI2I,GAAMlT,EACT0iB,EAAUyT,GAAa5rB,EA0BxB,OAxBMmY,KACLA,EAAU6W,GAAehvB,EAAU2I,GAGlB,SAAZwP,GAAuBA,IAE3B8S,IAAWA,IACVp1B,EAAO,kDACN82B,IAAK,UAAW,6BAChB/C,SAAUjhB,EAAIhT,iBAGhBgT,GAAQsiB,GAAO,GAAGvF,eAAiBuF,GAAO,GAAGxF,iBAAkBhwB,SAC/DkT,EAAIsmB,MAAM,+BACVtmB,EAAIumB,QAEJ/W,EAAU6W,GAAehvB,EAAU2I,GACnCsiB,GAAOvyB,UAIRkzB,GAAa5rB,GAAamY,GAGpBA,EAIR,QAAS6W,IAAe/yB,EAAM0M,GAC7B,GAAIzP,GAAOrD,EAAQ8S,EAAIjK,cAAezC,IAAS2tB,SAAUjhB,EAAI1L,MAC5Dkb,EAAUtiB,EAAO82B,IAAKzzB,EAAK,GAAI,UAEhC,OADAA,GAAK0F,SACEuZ,EAGRtiB,EAAO+E,MAAO,SAAU,SAAW,SAAUU,EAAGW,GAC/CpG,EAAOs3B,SAAUlxB,IAChB3B,IAAK,SAAUpB,EAAMk0B,EAAUW,GAC9B,MAAKX,GAGwB,IAArBl0B,EAAKqf,aAAqBgT,GAAa3xB,KAAM/D,EAAO82B,IAAKzzB,EAAM,YACrErD,EAAO6L,KAAMxI,EAAM4yB,GAAS,WAC3B,MAAOgD,IAAkB51B,EAAM+C,EAAM8xB,KAEtCe,GAAkB51B,EAAM+C,EAAM8xB,GAPhC,GAWDzR,IAAK,SAAUpjB,EAAMgH,EAAO6tB,GAC3B,GAAIf,GAASe,GAAS7C,GAAWhyB,EACjC,OAAOw1B,IAAmBx1B,EAAMgH,EAAO6tB,EACtCa,GACC11B,EACA+C,EACA8xB,EACAl4B,EAAOmI,QAAQsa,WAAgE,eAAnDziB,EAAO82B,IAAKzzB,EAAM,aAAa,EAAO8zB,GAClEA,GACG,OAMFn3B,EAAOmI,QAAQoY,UACpBvgB,EAAOs3B,SAAS/W,SACf9b,IAAK,SAAUpB,EAAMk0B,GAEpB,MAAO/B,IAASzxB,MAAOwzB,GAAYl0B,EAAKk1B,aAAel1B,EAAKk1B,aAAa/kB,OAASnQ,EAAK0I,MAAMyH,SAAW,IACrG,IAAO1L,WAAY2G,OAAO6qB,IAAS,GACrC/B,EAAW,IAAM,IAGnB9Q,IAAK,SAAUpjB,EAAMgH,GACpB,GAAI0B,GAAQ1I,EAAK0I,MAChBwsB,EAAel1B,EAAKk1B,aACpBhY,EAAUvgB,EAAO4H,UAAWyC,GAAU,iBAA2B,IAARA,EAAc,IAAM,GAC7EmJ,EAAS+kB,GAAgBA,EAAa/kB,QAAUzH,EAAMyH,QAAU,EAIjEzH,GAAMyW,KAAO,GAINnY,GAAS,GAAe,KAAVA,IAC6B,KAAhDrK,EAAOmB,KAAMqS,EAAO3M,QAAS0uB,GAAQ,MACrCxpB,EAAMsF,kBAKPtF,EAAMsF,gBAAiB,UAGR,KAAVhH,GAAgBkuB,IAAiBA,EAAa/kB,UAMpDzH,EAAMyH,OAAS+hB,GAAOxxB,KAAMyP,GAC3BA,EAAO3M,QAAS0uB,GAAQhV,GACxB/M,EAAS,IAAM+M,MAOnBvgB,EAAO,WACAA,EAAOmI,QAAQiZ,sBACpBphB,EAAOs3B,SAASzU,aACfpe,IAAK,SAAUpB,EAAMk0B,GACpB,MAAKA,GAGGv3B,EAAO6L,KAAMxI,GAAQif,QAAW,gBACtCgT,IAAUjyB,EAAM,gBAJlB,MAaGrD,EAAOmI,QAAQ8Y,eAAiBjhB,EAAOsB,GAAG40B,UAC/Cl2B,EAAO+E,MAAQ,MAAO,QAAU,SAAUU,EAAGmgB,GAC5C5lB,EAAOs3B,SAAU1R,IAChBnhB,IAAK,SAAUpB,EAAMk0B,GACpB,MAAKA,IACJA,EAAWjC,GAAQjyB,EAAMuiB,GAElBiQ,GAAU9xB,KAAMwzB,GACtBv3B,EAAQqD,GAAO6yB,WAAYtQ,GAAS,KACpC2R,GALF,QAcAv3B,EAAO4U,MAAQ5U,EAAO4U,KAAKwE,UAC/BpZ,EAAO4U,KAAKwE,QAAQ6d,OAAS,SAAU5zB,GAGtC,MAA2B,IAApBA,EAAKqf,aAAyC,GAArBrf,EAAKgf,eAClCriB,EAAOmI,QAAQoa,uBAAmG,UAAxElf,EAAK0I,OAAS1I,EAAK0I,MAAMuW,SAAYtiB,EAAO82B,IAAKzzB,EAAM,aAGrGrD,EAAO4U,KAAKwE,QAAQmgB,QAAU,SAAUl2B,GACvC,OAAQrD,EAAO4U,KAAKwE,QAAQ6d,OAAQ5zB,KAKtCrD,EAAO+E,MACNy0B,OAAQ,GACRC,QAAS,GACTC,OAAQ,SACN,SAAUC,EAAQC,GACpB55B,EAAOs3B,SAAUqC,EAASC,IACzBC,OAAQ,SAAUxvB,GACjB,GAAI5E,GAAI,EACPq0B,KAGAC,EAAyB,gBAAV1vB,GAAqBA,EAAMiC,MAAM,MAASjC,EAE1D,MAAY,EAAJ5E,EAAOA,IACdq0B,EAAUH,EAASpD,GAAW9wB,GAAMm0B,GACnCG,EAAOt0B,IAAOs0B,EAAOt0B,EAAI,IAAOs0B,EAAO,EAGzC,OAAOD,KAIHnE,GAAQ5xB,KAAM41B,KACnB35B,EAAOs3B,SAAUqC,EAASC,GAASnT,IAAMoS,KAG3C,IAAImB,IAAM,OACTC,GAAW,QACXC,GAAQ,SACRC,GAAkB,wCAClBC,GAAe,oCAEhBp6B,GAAOsB,GAAG0E,QACTq0B,UAAW,WACV,MAAOr6B,GAAOqxB,MAAO/tB,KAAKg3B,mBAE3BA,eAAgB,WACf,MAAOh3B,MAAKsC,IAAI,WAEf,GAAIiP,GAAW7U,EAAO4lB,KAAMtiB,KAAM,WAClC,OAAOuR,GAAW7U,EAAOsE,UAAWuQ,GAAavR,OAEjDkQ,OAAO,WACP,GAAI7Q,GAAOW,KAAKX,IAEhB,OAAOW,MAAK8C,OAASpG,EAAQsD,MAAOyrB,GAAI,cACvCqL,GAAar2B,KAAMT,KAAK6G,YAAegwB,GAAgBp2B,KAAMpB,KAC3DW,KAAK6U,UAAY0Y,GAA4B9sB,KAAMpB,MAEtDiD,IAAI,SAAUH,EAAGpC,GACjB,GAAIyR,GAAM9U,EAAQsD,MAAOwR,KAEzB,OAAc,OAAPA,EACN,KACA9U,EAAOyG,QAASqO,GACf9U,EAAO4F,IAAKkP,EAAK,SAAUA,GAC1B,OAAS1O,KAAM/C,EAAK+C,KAAMiE,MAAOyK,EAAIjO,QAASqzB,GAAO,YAEpD9zB,KAAM/C,EAAK+C,KAAMiE,MAAOyK,EAAIjO,QAASqzB,GAAO,WAC9Cz1B,SAMLzE,EAAOqxB,MAAQ,SAAUzjB,EAAG2sB,GAC3B,GAAIZ,GACHa,KACA5c,EAAM,SAAU3V,EAAKoC,GAEpBA,EAAQrK,EAAOiE,WAAYoG,GAAUA,IAAqB,MAATA,EAAgB,GAAKA,EACtEmwB,EAAGA,EAAEh3B,QAAWi3B,mBAAoBxyB,GAAQ,IAAMwyB,mBAAoBpwB,GASxE,IALKkwB,IAAgBh7B,IACpBg7B,EAAcv6B,EAAO06B,cAAgB16B,EAAO06B,aAAaH,aAIrDv6B,EAAOyG,QAASmH,IAASA,EAAE1K,SAAWlD,EAAOgE,cAAe4J,GAEhE5N,EAAO+E,KAAM6I,EAAG,WACfgQ,EAAKta,KAAK8C,KAAM9C,KAAK+G,aAMtB,KAAMsvB,IAAU/rB,GACf+sB,GAAahB,EAAQ/rB,EAAG+rB,GAAUY,EAAa3c,EAKjD,OAAO4c,GAAEtpB,KAAM,KAAMrK,QAASmzB,GAAK,KAGpC,SAASW,IAAahB,EAAQlyB,EAAK8yB,EAAa3c,GAC/C,GAAIxX,EAEJ,IAAKpG,EAAOyG,QAASgB,GAEpBzH,EAAO+E,KAAM0C,EAAK,SAAUhC,EAAGm1B,GACzBL,GAAeN,GAASl2B,KAAM41B,GAElC/b,EAAK+b,EAAQiB,GAIbD,GAAahB,EAAS,KAAqB,gBAANiB,GAAiBn1B,EAAI,IAAO,IAAKm1B,EAAGL,EAAa3c,SAIlF,IAAM2c,GAAsC,WAAvBv6B,EAAO2C,KAAM8E,GAQxCmW,EAAK+b,EAAQlyB,OANb,KAAMrB,IAAQqB,GACbkzB,GAAahB,EAAS,IAAMvzB,EAAO,IAAKqB,EAAKrB,GAAQm0B,EAAa3c,GAQrE5d,EAAO+E,KAAM,0MAEqDuH,MAAM,KAAM,SAAU7G,EAAGW,GAG1FpG,EAAOsB,GAAI8E,GAAS,SAAUqC,EAAMnH,GACnC,MAAO+D,WAAU7B,OAAS,EACzBF,KAAK6qB,GAAI/nB,EAAM,KAAMqC,EAAMnH,GAC3BgC,KAAKiE,QAASnB,MAIjBpG,EAAOsB,GAAG0E,QACT60B,MAAO,SAAUC,EAAQC,GACxB,MAAOz3B,MAAKiqB,WAAYuN,GAAStN,WAAYuN,GAASD,IAGvDE,KAAM,SAAU1S,EAAO7f,EAAMnH,GAC5B,MAAOgC,MAAK6qB,GAAI7F,EAAO,KAAM7f,EAAMnH,IAEpC25B,OAAQ,SAAU3S,EAAOhnB,GACxB,MAAOgC,MAAKkE,IAAK8gB,EAAO,KAAMhnB,IAG/B45B,SAAU,SAAU95B,EAAUknB,EAAO7f,EAAMnH,GAC1C,MAAOgC,MAAK6qB,GAAI7F,EAAOlnB,EAAUqH,EAAMnH,IAExC65B,WAAY,SAAU/5B,EAAUknB,EAAOhnB,GAEtC,MAA4B,KAArB+D,UAAU7B,OAAeF,KAAKkE,IAAKpG,EAAU,MAASkC,KAAKkE,IAAK8gB,EAAOlnB,GAAY,KAAME,KAGlG,IAEC85B,IACAC,GACAC,GAAat7B,EAAO0L,MAEpB6vB,GAAc,KACdC,GAAQ,OACRC,GAAM,gBACNC,GAAW,gCAEXC,GAAiB,4DACjBC,GAAa,iBACbC,GAAY,QACZC,GAAO,8CAGPC,GAAQ/7B,EAAOsB,GAAGqrB,KAWlBqP,MAOAC,MAGAC,GAAW,KAAK37B,OAAO,IAIxB,KACC86B,GAAe17B,EAASoY,KACvB,MAAO7P,IAGRmzB,GAAez7B,EAASiJ,cAAe,KACvCwyB,GAAatjB,KAAO,GACpBsjB,GAAeA,GAAatjB,KAI7BqjB,GAAeU,GAAKr4B,KAAM43B,GAAajxB,kBAGvC,SAAS+xB,IAA6BC,GAGrC,MAAO,UAAUC,EAAoBpe,GAED,gBAAvBoe,KACXpe,EAAOoe,EACPA,EAAqB,IAGtB,IAAItH,GACHtvB,EAAI,EACJ62B,EAAYD,EAAmBjyB,cAAchH,MAAO1B,MAErD,IAAK1B,EAAOiE,WAAYga,GAEvB,MAAS8W,EAAWuH,EAAU72B,KAER,MAAhBsvB,EAAS,IACbA,EAAWA,EAASp0B,MAAO,IAAO,KACjCy7B,EAAWrH,GAAaqH,EAAWrH,QAAkBpgB,QAASsJ,KAI9Dme,EAAWrH,GAAaqH,EAAWrH,QAAkBt0B,KAAMwd,IAQjE,QAASse,IAA+BH,EAAW/1B,EAASm2B,EAAiBC,GAE5E,GAAIC,MACHC,EAAqBP,IAAcH,EAEpC,SAASW,GAAS7H,GACjB,GAAI3c,EAYJ,OAXAskB,GAAW3H,IAAa,EACxB/0B,EAAO+E,KAAMq3B,EAAWrH,OAAkB,SAAUhlB,EAAG8sB,GACtD,GAAIC,GAAsBD,EAAoBx2B,EAASm2B,EAAiBC,EACxE,OAAmC,gBAAxBK,IAAqCH,GAAqBD,EAAWI,GAIpEH,IACDvkB,EAAW0kB,GADf,GAHNz2B,EAAQi2B,UAAU3nB,QAASmoB,GAC3BF,EAASE,IACF,KAKF1kB,EAGR,MAAOwkB,GAASv2B,EAAQi2B,UAAW,MAAUI,EAAW,MAASE,EAAS,KAM3E,QAASG,IAAYx2B,EAAQN,GAC5B,GAAIO,GAAMyB,EACT+0B,EAAch9B,EAAO06B,aAAasC,eAEnC,KAAM/0B,IAAOhC,GACPA,EAAKgC,KAAU1I,KACjBy9B,EAAa/0B,GAAQ1B,EAAWC,IAASA,OAAgByB,GAAQhC,EAAKgC,GAO1E,OAJKzB,IACJxG,EAAOgG,QAAQ,EAAMO,EAAQC,GAGvBD,EAGRvG,EAAOsB,GAAGqrB,KAAO,SAAUkI,EAAKoI,EAAQj4B,GACvC,GAAoB,gBAAR6vB,IAAoBkH,GAC/B,MAAOA,IAAM32B,MAAO9B,KAAM+B,UAG3B,IAAIjE,GAAU87B,EAAUv6B,EACvB+a,EAAOpa,KACPkE,EAAMqtB,EAAIh0B,QAAQ,IA+CnB,OA7CK2G,IAAO,IACXpG,EAAWyzB,EAAIl0B,MAAO6G,EAAKqtB,EAAIrxB,QAC/BqxB,EAAMA,EAAIl0B,MAAO,EAAG6G,IAIhBxH,EAAOiE,WAAYg5B,IAGvBj4B,EAAWi4B,EACXA,EAAS19B,GAGE09B,GAA4B,gBAAXA,KAC5Bt6B,EAAO,QAIH+a,EAAKla,OAAS,GAClBxD,EAAO80B,MACND,IAAKA,EAGLlyB,KAAMA,EACNoyB,SAAU,OACVtsB,KAAMw0B,IACJ93B,KAAK,SAAUg4B,GAGjBD,EAAW73B,UAEXqY,EAAKoV,KAAM1xB,EAIVpB,EAAO,SAASiyB,OAAQjyB,EAAO4D,UAAWu5B,IAAiBz5B,KAAMtC,GAGjE+7B,KAECC,SAAUp4B,GAAY,SAAUy3B,EAAOY,GACzC3f,EAAK3Y,KAAMC,EAAUk4B,IAAcT,EAAMU,aAAcE,EAAQZ,MAI1Dn5B,MAIRtD,EAAO+E,MAAQ,YAAa,WAAY,eAAgB,YAAa,cAAe,YAAc,SAAUU,EAAG9C,GAC9G3C,EAAOsB,GAAIqB,GAAS,SAAUrB,GAC7B,MAAOgC,MAAK6qB,GAAIxrB,EAAMrB,MAIxBtB,EAAOgG,QAGNs3B,OAAQ,EAGRC,gBACAC,QAEA9C,cACC7F,IAAKwG,GACL14B,KAAM,MACN86B,QAAS9B,GAAe53B,KAAMq3B,GAAc,IAC5C/S,QAAQ,EACRqV,aAAa,EACb/zB,OAAO,EACPg0B,YAAa,mDAabC,SACCC,IAAK3B,GACL3xB,KAAM,aACNuoB,KAAM,YACNxpB,IAAK,4BACLw0B,KAAM,qCAGPnP,UACCrlB,IAAK,MACLwpB,KAAM,OACNgL,KAAM,QAGPC,gBACCz0B,IAAK,cACLiB,KAAM,eACNuzB,KAAM,gBAKPE,YAGCC,SAAUj2B,OAGVk2B,aAAa,EAGbC,YAAan+B,EAAOiJ,UAGpBm1B,WAAYp+B,EAAOqJ,UAOpB2zB,aACCnI,KAAK,EACLxzB,SAAS,IAOXg9B,UAAW,SAAU93B,EAAQ+3B,GAC5B,MAAOA,GAGNvB,GAAYA,GAAYx2B,EAAQvG,EAAO06B,cAAgB4D,GAGvDvB,GAAY/8B,EAAO06B,aAAcn0B,IAGnCg4B,cAAepC,GAA6BH,IAC5CwC,cAAerC,GAA6BF,IAG5CnH,KAAM,SAAUD,EAAKxuB,GAGA,gBAARwuB,KACXxuB,EAAUwuB,EACVA,EAAMt1B,GAIP8G,EAAUA,KAEV,IACC0zB,GAEAt0B,EAEAg5B,EAEAC,EAEAC,EAGAC,EAEAC,EAEAC,EAEAtE,EAAIx6B,EAAOq+B,aAAeh4B,GAE1B04B,EAAkBvE,EAAEn5B,SAAWm5B,EAE/BwE,EAAqBxE,EAAEn5B,UAAa09B,EAAgBl7B,UAAYk7B,EAAgB77B,QAC/ElD,EAAQ++B,GACR/+B,EAAOyC,MAER4b,EAAWre,EAAOgM,WAClBizB,EAAmBj/B,EAAO8c,UAAU,eAEpCoiB,EAAa1E,EAAE0E,eAEfC,KACAC,KAEAjhB,EAAQ,EAERkhB,EAAW,WAEX5C,GACC75B,WAAY,EAGZ08B,kBAAmB,SAAUr3B,GAC5B,GAAI7E,EACJ,IAAe,IAAV+a,EAAc,CAClB,IAAM2gB,EAAkB,CACvBA,IACA,OAAS17B,EAAQs4B,GAASj4B,KAAMi7B,GAC/BI,EAAiB17B,EAAM,GAAGgH,eAAkBhH,EAAO,GAGrDA,EAAQ07B,EAAiB72B,EAAImC,eAE9B,MAAgB,OAAThH,EAAgB,KAAOA,GAI/Bm8B,sBAAuB,WACtB,MAAiB,KAAVphB,EAAcugB,EAAwB,MAI9Cc,iBAAkB,SAAUp5B,EAAMiE,GACjC,GAAIo1B,GAAQr5B,EAAKgE,aAKjB,OAJM+T,KACL/X,EAAOg5B,EAAqBK,GAAUL,EAAqBK,IAAWr5B,EACtE+4B,EAAgB/4B,GAASiE,GAEnB/G,MAIRo8B,iBAAkB,SAAU/8B,GAI3B,MAHMwb,KACLqc,EAAEmF,SAAWh9B,GAEPW,MAIR47B,WAAY,SAAUt5B,GACrB,GAAIg6B,EACJ,IAAKh6B,EACJ,GAAa,EAARuY,EACJ,IAAMyhB,IAAQh6B,GAEbs5B,EAAYU,IAAWV,EAAYU,GAAQh6B,EAAKg6B,QAIjDnD,GAAMre,OAAQxY,EAAK62B,EAAMY,QAG3B,OAAO/5B,OAIRu8B,MAAO,SAAUC,GAChB,GAAIC,GAAYD,GAAcT,CAK9B,OAJKR,IACJA,EAAUgB,MAAOE,GAElB56B,EAAM,EAAG46B,GACFz8B,MAwCV,IAnCA+a,EAASnZ,QAASu3B,GAAQW,SAAW6B,EAAiBrhB,IACtD6e,EAAMuD,QAAUvD,EAAMt3B,KACtBs3B,EAAMn0B,MAAQm0B,EAAMne,KAMpBkc,EAAE3F,MAAUA,GAAO2F,EAAE3F,KAAOwG,IAAiB,IAAKx0B,QAAS20B,GAAO,IAAK30B,QAASg1B,GAAWT,GAAc,GAAM,MAG/GZ,EAAE73B,KAAO0D,EAAQ45B,QAAU55B,EAAQ1D,MAAQ63B,EAAEyF,QAAUzF,EAAE73B,KAGzD63B,EAAE8B,UAAYt8B,EAAOmB,KAAMq5B,EAAEzF,UAAY,KAAM3qB,cAAchH,MAAO1B,KAAqB,IAGnE,MAAjB84B,EAAE0F,cACNnG,EAAQ+B,GAAKr4B,KAAM+2B,EAAE3F,IAAIzqB,eACzBowB,EAAE0F,eAAkBnG,GACjBA,EAAO,KAAQqB,GAAc,IAAOrB,EAAO,KAAQqB,GAAc,KAChErB,EAAO,KAAwB,UAAfA,EAAO,GAAkB,KAAO,WAC/CqB,GAAc,KAA+B,UAAtBA,GAAc,GAAkB,KAAO,UAK/DZ,EAAE/xB,MAAQ+xB,EAAEkD,aAAiC,gBAAXlD,GAAE/xB,OACxC+xB,EAAE/xB,KAAOzI,EAAOqxB,MAAOmJ,EAAE/xB,KAAM+xB,EAAED,cAIlCgC,GAA+BP,GAAYxB,EAAGn0B,EAASo2B,GAGxC,IAAVte,EACJ,MAAOse,EAIRmC,GAAcpE,EAAEnS,OAGXuW,GAAmC,IAApB5+B,EAAOs9B,UAC1Bt9B,EAAOyC,MAAM8E,QAAQ,aAItBizB,EAAE73B,KAAO63B,EAAE73B,KAAKJ,cAGhBi4B,EAAE2F,YAAcvE,GAAW73B,KAAMy2B,EAAE73B,MAInC87B,EAAWjE,EAAE3F,IAGP2F,EAAE2F,aAGF3F,EAAE/xB,OACNg2B,EAAajE,EAAE3F,MAAS0G,GAAYx3B,KAAM06B,GAAa,IAAM,KAAQjE,EAAE/xB,WAEhE+xB,GAAE/xB,MAIL+xB,EAAEhpB,SAAU,IAChBgpB,EAAE3F,IAAM4G,GAAI13B,KAAM06B,GAGjBA,EAAS53B,QAAS40B,GAAK,OAASH,MAGhCmD,GAAalD,GAAYx3B,KAAM06B,GAAa,IAAM,KAAQ,KAAOnD,OAK/Dd,EAAE4F,aACDpgC,EAAOu9B,aAAckB,IACzBhC,EAAM+C,iBAAkB,oBAAqBx/B,EAAOu9B,aAAckB,IAE9Dz+B,EAAOw9B,KAAMiB,IACjBhC,EAAM+C,iBAAkB,gBAAiBx/B,EAAOw9B,KAAMiB,MAKnDjE,EAAE/xB,MAAQ+xB,EAAE2F,YAAc3F,EAAEmD,eAAgB,GAASt3B,EAAQs3B,cACjElB,EAAM+C,iBAAkB,eAAgBhF,EAAEmD,aAI3ClB,EAAM+C,iBACL,SACAhF,EAAE8B,UAAW,IAAO9B,EAAEoD,QAASpD,EAAE8B,UAAU,IAC1C9B,EAAEoD,QAASpD,EAAE8B,UAAU,KAA8B,MAArB9B,EAAE8B,UAAW,GAAc,KAAOJ,GAAW,WAAa,IAC1F1B,EAAEoD,QAAS,KAIb,KAAMn4B,IAAK+0B,GAAE6F,QACZ5D,EAAM+C,iBAAkB/5B,EAAG+0B,EAAE6F,QAAS56B,GAIvC,IAAK+0B,EAAE8F,aAAgB9F,EAAE8F,WAAW97B,KAAMu6B,EAAiBtC,EAAOjC,MAAQ,GAAmB,IAAVrc,GAElF,MAAOse,GAAMoD,OAIdR,GAAW,OAGX,KAAM55B,KAAOu6B,QAAS,EAAG13B,MAAO,EAAG80B,SAAU,GAC5CX,EAAOh3B,GAAK+0B,EAAG/0B,GAOhB,IAHAo5B,EAAYtC,GAA+BN,GAAYzB,EAAGn0B,EAASo2B,GAK5D,CACNA,EAAM75B,WAAa,EAGdg8B,GACJI,EAAmBz3B,QAAS,YAAck1B,EAAOjC,IAG7CA,EAAE7wB,OAAS6wB,EAAE1V,QAAU,IAC3B6Z,EAAet3B,WAAW,WACzBo1B,EAAMoD,MAAM,YACVrF,EAAE1V,SAGN,KACC3G,EAAQ,EACR0gB,EAAU0B,KAAMpB,EAAgBh6B,GAC/B,MAAQ+C,GAET,KAAa,EAARiW,GAIJ,KAAMjW,EAHN/C,GAAM,GAAI+C,QArBZ/C,GAAM,GAAI,eA8BX,SAASA,GAAMk4B,EAAQmD,EAAkBC,EAAWJ,GACnD,GAAIK,GAAWV,EAAS13B,EAAO40B,EAAUyD,EACxCb,EAAaU,CAGC,KAAVriB,IAKLA,EAAQ,EAGHwgB,GACJ5Z,aAAc4Z,GAKfE,EAAYt/B,EAGZm/B,EAAwB2B,GAAW,GAGnC5D,EAAM75B,WAAay6B,EAAS,EAAI,EAAI,EAGpCqD,EAAYrD,GAAU,KAAgB,IAATA,GAA2B,MAAXA,EAGxCoD,IACJvD,EAAW0D,GAAqBpG,EAAGiC,EAAOgE,IAI3CvD,EAAW2D,GAAarG,EAAG0C,EAAUT,EAAOiE,GAGvCA,GAGClG,EAAE4F,aACNO,EAAWlE,EAAM6C,kBAAkB,iBAC9BqB,IACJ3gC,EAAOu9B,aAAckB,GAAakC,GAEnCA,EAAWlE,EAAM6C,kBAAkB,QAC9BqB,IACJ3gC,EAAOw9B,KAAMiB,GAAakC,IAKZ,MAAXtD,GAA6B,SAAX7C,EAAE73B,KACxBm9B,EAAa,YAGS,MAAXzC,EACXyC,EAAa,eAIbA,EAAa5C,EAAS/e,MACtB6hB,EAAU9C,EAASz0B,KACnBH,EAAQ40B,EAAS50B,MACjBo4B,GAAap4B,KAKdA,EAAQw3B,GACHzC,IAAWyC,KACfA,EAAa,QACC,EAATzC,IACJA,EAAS,KAMZZ,EAAMY,OAASA,EACfZ,EAAMqD,YAAeU,GAAoBV,GAAe,GAGnDY,EACJriB,EAAS/W,YAAay3B,GAAmBiB,EAASF,EAAYrD,IAE9Dpe,EAASyiB,WAAY/B,GAAmBtC,EAAOqD,EAAYx3B,IAI5Dm0B,EAAMyC,WAAYA,GAClBA,EAAa3/B,EAERq/B,GACJI,EAAmBz3B,QAASm5B,EAAY,cAAgB,aACrDjE,EAAOjC,EAAGkG,EAAYV,EAAU13B,IAIpC22B,EAAiBjhB,SAAU+gB,GAAmBtC,EAAOqD,IAEhDlB,IACJI,EAAmBz3B,QAAS,gBAAkBk1B,EAAOjC,MAE3Cx6B,EAAOs9B,QAChBt9B,EAAOyC,MAAM8E,QAAQ,cAKxB,MAAOk1B,IAGRsE,QAAS,SAAUlM,EAAKpsB,EAAMzD,GAC7B,MAAOhF,GAAOyE,IAAKowB,EAAKpsB,EAAMzD,EAAU,SAGzCg8B,UAAW,SAAUnM,EAAK7vB,GACzB,MAAOhF,GAAOyE,IAAKowB,EAAKt1B,EAAWyF,EAAU,aAI/ChF,EAAO+E,MAAQ,MAAO,QAAU,SAAUU,EAAGw6B,GAC5CjgC,EAAQigC,GAAW,SAAUpL,EAAKpsB,EAAMzD,EAAUrC,GAQjD,MANK3C,GAAOiE,WAAYwE,KACvB9F,EAAOA,GAAQqC,EACfA,EAAWyD,EACXA,EAAOlJ,GAGDS,EAAO80B,MACbD,IAAKA,EACLlyB,KAAMs9B,EACNlL,SAAUpyB,EACV8F,KAAMA,EACNu3B,QAASh7B,MASZ,SAAS47B,IAAqBpG,EAAGiC,EAAOgE,GACvC,GAAIQ,GAAeC,EAAIC,EAAex+B,EACrCgsB,EAAW6L,EAAE7L,SACb2N,EAAY9B,EAAE8B,SAGf,OAA0B,MAAnBA,EAAW,GACjBA,EAAU5qB,QACLwvB,IAAO3hC,IACX2hC,EAAK1G,EAAEmF,UAAYlD,EAAM6C,kBAAkB,gBAK7C,IAAK4B,EACJ,IAAMv+B,IAAQgsB,GACb,GAAKA,EAAUhsB,IAAUgsB,EAAUhsB,GAAOoB,KAAMm9B,GAAO,CACtD5E,EAAU3nB,QAAShS,EACnB,OAMH,GAAK25B,EAAW,IAAOmE,GACtBU,EAAgB7E,EAAW,OACrB,CAEN,IAAM35B,IAAQ89B,GAAY,CACzB,IAAMnE,EAAW,IAAO9B,EAAEwD,WAAYr7B,EAAO,IAAM25B,EAAU,IAAO,CACnE6E,EAAgBx+B,CAChB,OAEKs+B,IACLA,EAAgBt+B,GAIlBw+B,EAAgBA,GAAiBF,EAMlC,MAAKE,IACCA,IAAkB7E,EAAW,IACjCA,EAAU3nB,QAASwsB,GAEbV,EAAWU,IAJnB,EAWD,QAASN,IAAarG,EAAG0C,EAAUT,EAAOiE,GACzC,GAAIU,GAAOC,EAASC,EAAM/3B,EAAKqlB,EAC9BoP,KAEA1B,EAAY9B,EAAE8B,UAAU37B,OAGzB,IAAK27B,EAAW,GACf,IAAMgF,IAAQ9G,GAAEwD,WACfA,EAAYsD,EAAKl3B,eAAkBowB,EAAEwD,WAAYsD,EAInDD,GAAU/E,EAAU5qB,OAGpB,OAAQ2vB,EAcP,GAZK7G,EAAEuD,eAAgBsD,KACtB5E,EAAOjC,EAAEuD,eAAgBsD,IAAcnE,IAIlCtO,GAAQ8R,GAAalG,EAAE+G,aAC5BrE,EAAW1C,EAAE+G,WAAYrE,EAAU1C,EAAEzF,WAGtCnG,EAAOyS,EACPA,EAAU/E,EAAU5qB,QAKnB,GAAiB,MAAZ2vB,EAEJA,EAAUzS,MAGJ,IAAc,MAATA,GAAgBA,IAASyS,EAAU,CAM9C,GAHAC,EAAOtD,EAAYpP,EAAO,IAAMyS,IAAarD,EAAY,KAAOqD,IAG1DC,EACL,IAAMF,IAASpD,GAId,GADAz0B,EAAM63B,EAAM90B,MAAO,KACd/C,EAAK,KAAQ83B,IAGjBC,EAAOtD,EAAYpP,EAAO,IAAMrlB,EAAK,KACpCy0B,EAAY,KAAOz0B,EAAK,KACb,CAEN+3B,KAAS,EACbA,EAAOtD,EAAYoD,GAGRpD,EAAYoD,MAAY,IACnCC,EAAU93B,EAAK,GACf+yB,EAAU3nB,QAASpL,EAAK,IAEzB,OAOJ,GAAK+3B,KAAS,EAGb,GAAKA,GAAQ9G,EAAG,UACf0C,EAAWoE,EAAMpE,OAEjB,KACCA,EAAWoE,EAAMpE,GAChB,MAAQh1B,GACT,OAASiW,MAAO,cAAe7V,MAAOg5B,EAAOp5B,EAAI,sBAAwB0mB,EAAO,OAASyS,IAQ/F,OAASljB,MAAO,UAAW1V,KAAMy0B,GAGlCl9B,EAAOq+B,WACNT,SACC4D,OAAQ,6FAET7S,UACC6S,OAAQ,uBAETxD,YACCyD,cAAe,SAAUl3B,GAExB,MADAvK,GAAO+J,WAAYQ,GACZA,MAMVvK,EAAOu+B,cAAe,SAAU,SAAU/D,GACpCA,EAAEhpB,QAAUjS,IAChBi7B,EAAEhpB,OAAQ,GAENgpB,EAAE0F,cACN1F,EAAE73B,KAAO,MACT63B,EAAEnS,QAAS,KAKbroB,EAAOw+B,cAAe,SAAU,SAAShE,GAGxC,GAAKA,EAAE0F,YAAc,CAEpB,GAAIsB,GACHE,EAAO9hC,EAAS8hC,MAAQ1hC,EAAO,QAAQ,IAAMJ,EAASE,eAEvD,QAECygC,KAAM,SAAUxwB,EAAG/K,GAElBw8B,EAAS5hC,EAASiJ,cAAc,UAEhC24B,EAAO73B,OAAQ,EAEV6wB,EAAEmH,gBACNH,EAAOI,QAAUpH,EAAEmH,eAGpBH,EAAOv7B,IAAMu0B,EAAE3F,IAGf2M,EAAOK,OAASL,EAAOM,mBAAqB,SAAU/xB,EAAGgyB,IAEnDA,IAAYP,EAAO5+B,YAAc,kBAAkBmB,KAAMy9B,EAAO5+B,eAGpE4+B,EAAOK,OAASL,EAAOM,mBAAqB,KAGvCN,EAAOp9B,YACXo9B,EAAOp9B,WAAW0N,YAAa0vB,GAIhCA,EAAS,KAGHO,GACL/8B,EAAU,IAAK,aAOlB08B,EAAKpP,aAAckP,EAAQE,EAAKruB,aAGjCwsB,MAAO,WACD2B,GACJA,EAAOK,OAAQtiC,GAAW,OAM/B,IAAIyiC,OACHC,GAAS,mBAGVjiC,GAAOq+B,WACN6D,MAAO,WACPC,cAAe,WACd,GAAIn9B,GAAWg9B,GAAa/zB,OAAWjO,EAAO0G,QAAU,IAAQ40B,IAEhE,OADAh4B,MAAM0B,IAAa,EACZA,KAKThF,EAAOu+B,cAAe,aAAc,SAAU/D,EAAG4H,EAAkB3F,GAElE,GAAI4F,GAAcC,EAAaC,EAC9BC,EAAWhI,EAAE0H,SAAU,IAAWD,GAAOl+B,KAAMy2B,EAAE3F,KAChD,MACkB,gBAAX2F,GAAE/xB,QAAwB+xB,EAAEmD,aAAe,IAAK98B,QAAQ,sCAAwCohC,GAAOl+B,KAAMy2B,EAAE/xB,OAAU,OAIlI,OAAK+5B,IAAiC,UAArBhI,EAAE8B,UAAW,IAG7B+F,EAAe7H,EAAE2H,cAAgBniC,EAAOiE,WAAYu2B,EAAE2H,eACrD3H,EAAE2H,gBACF3H,EAAE2H,cAGEK,EACJhI,EAAGgI,GAAahI,EAAGgI,GAAW37B,QAASo7B,GAAQ,KAAOI,GAC3C7H,EAAE0H,SAAU,IACvB1H,EAAE3F,MAAS0G,GAAYx3B,KAAMy2B,EAAE3F,KAAQ,IAAM,KAAQ2F,EAAE0H,MAAQ,IAAMG,GAItE7H,EAAEwD,WAAW,eAAiB,WAI7B,MAHMuE,IACLviC,EAAOsI,MAAO+5B,EAAe,mBAEvBE,EAAmB,IAI3B/H,EAAE8B,UAAW,GAAM,OAGnBgG,EAAchjC,EAAQ+iC,GACtB/iC,EAAQ+iC,GAAiB,WACxBE,EAAoBl9B,WAIrBo3B,EAAMre,OAAO,WAEZ9e,EAAQ+iC,GAAiBC,EAGpB9H,EAAG6H,KAEP7H,EAAE2H,cAAgBC,EAAiBD,cAGnCH,GAAavhC,KAAM4hC,IAIfE,GAAqBviC,EAAOiE,WAAYq+B,IAC5CA,EAAaC,EAAmB,IAGjCA,EAAoBD,EAAc/iC,IAI5B,UAtDR,GAyDD,IAAIkjC,IAAcC,GACjBC,GAAQ,EAERC,GAAmBtjC,EAAOoK,eAAiB,WAE1C,GAAIzB,EACJ,KAAMA,IAAOw6B,IACZA,GAAcx6B,GAAO1I,GAAW,GAKnC,SAASsjC,MACR,IACC,MAAO,IAAIvjC,GAAOwjC,eACjB,MAAO56B,KAGV,QAAS66B,MACR,IACC,MAAO,IAAIzjC,GAAOoK,cAAc,qBAC/B,MAAOxB,KAKVlI,EAAO06B,aAAasI,IAAM1jC,EAAOoK,cAOhC,WACC,OAAQpG,KAAKm6B,SAAWoF,MAAuBE,MAGhDF,GAGDH,GAAe1iC,EAAO06B,aAAasI,MACnChjC,EAAOmI,QAAQ86B,OAASP,IAAkB,mBAAqBA,IAC/DA,GAAe1iC,EAAOmI,QAAQ2sB,OAAS4N,GAGlCA,IAEJ1iC,EAAOw+B,cAAc,SAAUhE,GAE9B,IAAMA,EAAE0F,aAAelgC,EAAOmI,QAAQ86B,KAAO,CAE5C,GAAIj+B,EAEJ,QACCu7B,KAAM,SAAUF,EAASjD,GAGxB,GAAInU,GAAQxjB,EACXu9B,EAAMxI,EAAEwI,KAWT,IAPKxI,EAAE0I,SACNF,EAAIG,KAAM3I,EAAE73B,KAAM63B,EAAE3F,IAAK2F,EAAE7wB,MAAO6wB,EAAE0I,SAAU1I,EAAExhB,UAEhDgqB,EAAIG,KAAM3I,EAAE73B,KAAM63B,EAAE3F,IAAK2F,EAAE7wB,OAIvB6wB,EAAE4I,UACN,IAAM39B,IAAK+0B,GAAE4I,UACZJ,EAAKv9B,GAAM+0B,EAAE4I,UAAW39B,EAKrB+0B,GAAEmF,UAAYqD,EAAItD,kBACtBsD,EAAItD,iBAAkBlF,EAAEmF,UAQnBnF,EAAE0F,aAAgBG,EAAQ,sBAC/BA,EAAQ,oBAAsB,iBAI/B,KACC,IAAM56B,IAAK46B,GACV2C,EAAIxD,iBAAkB/5B,EAAG46B,EAAS56B,IAElC,MAAO2iB,IAKT4a,EAAIzC,KAAQ/F,EAAE2F,YAAc3F,EAAE/xB,MAAU,MAGxCzD,EAAW,SAAU+K,EAAGgyB,GACvB,GAAI1E,GAAQyB,EAAiBgB,EAAYW,CAKzC,KAGC,GAAKz7B,IAAc+8B,GAA8B,IAAnBiB,EAAIpgC,YAcjC,GAXAoC,EAAWzF,EAGN0pB,IACJ+Z,EAAIlB,mBAAqB9hC,EAAO8J,KAC3B84B,UACGH,IAAcxZ,IAKlB8Y,EAEoB,IAAnBiB,EAAIpgC,YACRogC,EAAInD,YAEC,CACNY,KACApD,EAAS2F,EAAI3F,OACbyB,EAAkBkE,EAAIzD,wBAIW,gBAArByD,GAAI7F,eACfsD,EAAUl2B,KAAOy4B,EAAI7F,aAKtB,KACC2C,EAAakD,EAAIlD,WAChB,MAAO53B,GAER43B,EAAa,GAQRzC,IAAU7C,EAAEiD,SAAYjD,EAAE0F,YAGT,OAAX7C,IACXA,EAAS,KAHTA,EAASoD,EAAUl2B,KAAO,IAAM,KAOlC,MAAO84B,GACFtB,GACL3E,EAAU,GAAIiG,GAKX5C,GACJrD,EAAUC,EAAQyC,EAAYW,EAAW3B,IAIrCtE,EAAE7wB,MAGuB,IAAnBq5B,EAAIpgC,WAGfyE,WAAYrC,IAEZikB,IAAW0Z,GACNC,KAGEH,KACLA,MACAziC,EAAQV,GAASgkC,OAAQV,KAG1BH,GAAcxZ,GAAWjkB,GAE1Bg+B,EAAIlB,mBAAqB98B,GAjBzBA,KAqBF66B,MAAO,WACD76B,GACJA,EAAUzF,GAAW,OAO3B,IAAIgkC,IAAOC,GACVC,GAAW,yBACXC,GAAaj1B,OAAQ,iBAAmBjN,EAAY,cAAe,KACnEmiC,GAAO,cACPC,IAAwBC,IACxBC,IACCjG,KAAM,SAAUjY,EAAMvb,GACrB,GAAI05B,GAAQzgC,KAAK0gC,YAAape,EAAMvb,GACnC9D,EAASw9B,EAAM3xB,MACf2nB,EAAQ2J,GAAOjgC,KAAM4G,GACrB45B,EAAOlK,GAASA,EAAO,KAAS/5B,EAAOw3B,UAAW5R,GAAS,GAAK,MAGhEhP,GAAU5W,EAAOw3B,UAAW5R,IAAmB,OAATqe,IAAkB19B,IACvDm9B,GAAOjgC,KAAMzD,EAAO82B,IAAKiN,EAAM1gC,KAAMuiB,IACtCse,EAAQ,EACRC,EAAgB,EAEjB,IAAKvtB,GAASA,EAAO,KAAQqtB,EAAO,CAEnCA,EAAOA,GAAQrtB,EAAO,GAGtBmjB,EAAQA,MAGRnjB,GAASrQ,GAAU,CAEnB,GAGC29B,GAAQA,GAAS,KAGjBttB,GAAgBstB,EAChBlkC,EAAO+L,MAAOg4B,EAAM1gC,KAAMuiB,EAAMhP,EAAQqtB,SAI/BC,KAAWA,EAAQH,EAAM3xB,MAAQ7L,IAAqB,IAAV29B,KAAiBC,GAaxE,MATKpK,KACJnjB,EAAQmtB,EAAMntB,OAASA,IAAUrQ,GAAU,EAC3Cw9B,EAAME,KAAOA,EAEbF,EAAMl+B,IAAMk0B,EAAO,GAClBnjB,GAAUmjB,EAAO,GAAM,GAAMA,EAAO,IACnCA,EAAO,IAGHgK,IAKV,SAASK,MAIR,MAHA/8B,YAAW,WACVk8B,GAAQhkC,IAEAgkC,GAAQvjC,EAAO0L,MAGzB,QAASs4B,IAAa35B,EAAOub,EAAMye,GAClC,GAAIN,GACHO,GAAeR,GAAUle,QAAerlB,OAAQujC,GAAU,MAC1DjmB,EAAQ,EACRra,EAAS8gC,EAAW9gC,MACrB,MAAgBA,EAARqa,EAAgBA,IACvB,GAAMkmB,EAAQO,EAAYzmB,GAAQrZ,KAAM6/B,EAAWze,EAAMvb,GAGxD,MAAO05B,GAKV,QAASQ,IAAWlhC,EAAMmhC,EAAYn+B,GACrC,GAAIgQ,GACHouB,EACA5mB,EAAQ,EACRra,EAASogC,GAAoBpgC,OAC7B6a,EAAWre,EAAOgM,WAAWoS,OAAQ,iBAE7BsmB,GAAKrhC,OAEbqhC,EAAO,WACN,GAAKD,EACJ,OAAO,CAER,IAAIE,GAAcpB,IAASa,KAC1B9kB,EAAY3Y,KAAKiE,IAAK,EAAGy5B,EAAUO,UAAYP,EAAUQ,SAAWF,GAEpElqB,EAAO6E,EAAY+kB,EAAUQ,UAAY,EACzCC,EAAU,EAAIrqB,EACdoD,EAAQ,EACRra,EAAS6gC,EAAUU,OAAOvhC,MAE3B,MAAgBA,EAARqa,EAAiBA,IACxBwmB,EAAUU,OAAQlnB,GAAQmnB,IAAKF,EAKhC,OAFAzmB,GAASqB,WAAYrc,GAAQghC,EAAWS,EAASxlB,IAElC,EAAVwlB,GAAethC,EACZ8b,GAEPjB,EAAS/W,YAAajE,GAAQghC,KACvB,IAGTA,EAAYhmB,EAASnZ,SACpB7B,KAAMA,EACNmoB,MAAOxrB,EAAOgG,UAAYw+B,GAC1BS,KAAMjlC,EAAOgG,QAAQ,GAAQk/B,kBAAqB7+B,GAClD8+B,mBAAoBX,EACpBhI,gBAAiBn2B,EACjBu+B,UAAWrB,IAASa,KACpBS,SAAUx+B,EAAQw+B,SAClBE,UACAf,YAAa,SAAUpe,EAAM/f,GAC5B,GAAIk+B,GAAQ/jC,EAAOolC,MAAO/hC,EAAMghC,EAAUY,KAAMrf,EAAM/f,EACpDw+B,EAAUY,KAAKC,cAAetf,IAAUye,EAAUY,KAAKI,OAEzD,OADAhB,GAAUU,OAAOtkC,KAAMsjC,GAChBA,GAERvf,KAAM,SAAU8gB,GACf,GAAIznB,GAAQ,EAGXra,EAAS8hC,EAAUjB,EAAUU,OAAOvhC,OAAS,CAC9C,IAAKihC,EACJ,MAAOnhC,KAGR,KADAmhC,GAAU,EACMjhC,EAARqa,EAAiBA,IACxBwmB,EAAUU,OAAQlnB,GAAQmnB,IAAK,EAUhC,OALKM,GACJjnB,EAAS/W,YAAajE,GAAQghC,EAAWiB,IAEzCjnB,EAASyiB,WAAYz9B,GAAQghC,EAAWiB,IAElChiC,QAGTkoB,EAAQ6Y,EAAU7Y,KAInB,KAFA+Z,GAAY/Z,EAAO6Y,EAAUY,KAAKC,eAElB1hC,EAARqa,EAAiBA,IAExB,GADAxH,EAASutB,GAAqB/lB,GAAQrZ,KAAM6/B,EAAWhhC,EAAMmoB,EAAO6Y,EAAUY,MAE7E,MAAO5uB,EAmBT,OAfArW,GAAO4F,IAAK4lB,EAAOwY,GAAaK,GAE3BrkC,EAAOiE,WAAYogC,EAAUY,KAAKruB,QACtCytB,EAAUY,KAAKruB,MAAMpS,KAAMnB,EAAMghC,GAGlCrkC,EAAO4kB,GAAG4gB,MACTxlC,EAAOgG,OAAQ0+B,GACdrhC,KAAMA,EACNoiC,KAAMpB,EACNngB,MAAOmgB,EAAUY,KAAK/gB,SAKjBmgB,EAAUtlB,SAAUslB,EAAUY,KAAKlmB,UACxC5Z,KAAMk/B,EAAUY,KAAK9/B,KAAMk/B,EAAUY,KAAK7H,UAC1C9e,KAAM+lB,EAAUY,KAAK3mB,MACrBF,OAAQimB,EAAUY,KAAK7mB,QAG1B,QAASmnB,IAAY/Z,EAAO0Z,GAC3B,GAAIrnB,GAAOzX,EAAMi/B,EAAQh7B,EAAOga,CAGhC,KAAMxG,IAAS2N,GAed,GAdAplB,EAAOpG,EAAOiK,UAAW4T,GACzBwnB,EAASH,EAAe9+B,GACxBiE,EAAQmhB,EAAO3N,GACV7d,EAAOyG,QAAS4D,KACpBg7B,EAASh7B,EAAO,GAChBA,EAAQmhB,EAAO3N,GAAUxT,EAAO,IAG5BwT,IAAUzX,IACdolB,EAAOplB,GAASiE,QACTmhB,GAAO3N,IAGfwG,EAAQrkB,EAAOs3B,SAAUlxB,GACpBie,GAAS,UAAYA,GAAQ,CACjCha,EAAQga,EAAMwV,OAAQxvB,SACfmhB,GAAOplB,EAId,KAAMyX,IAASxT,GACNwT,IAAS2N,KAChBA,EAAO3N,GAAUxT,EAAOwT,GACxBqnB,EAAernB,GAAUwnB,OAI3BH,GAAe9+B,GAASi/B,EAK3BrlC,EAAOukC,UAAYvkC,EAAOgG,OAAQu+B,IAEjCmB,QAAS,SAAUla,EAAOxmB,GACpBhF,EAAOiE,WAAYunB,IACvBxmB,EAAWwmB,EACXA,GAAU,MAEVA,EAAQA,EAAMlf,MAAM,IAGrB,IAAIsZ,GACH/H,EAAQ,EACRra,EAASgoB,EAAMhoB,MAEhB,MAAgBA,EAARqa,EAAiBA,IACxB+H,EAAO4F,EAAO3N,GACdimB,GAAUle,GAASke,GAAUle,OAC7Bke,GAAUle,GAAOjR,QAAS3P,IAI5B2gC,UAAW,SAAU3gC,EAAUqtB,GACzBA,EACJuR,GAAoBjvB,QAAS3P,GAE7B4+B,GAAoBnjC,KAAMuE,KAK7B,SAAS6+B,IAAkBxgC,EAAMmoB,EAAOyZ,GAEvC,GAAIrf,GAAMvb,EAAOgtB,EAAQ0M,EAAO1f,EAAOuhB,EACtCH,EAAOniC,KACPmqB,KACA1hB,EAAQ1I,EAAK0I,MACbkrB,EAAS5zB,EAAKQ,UAAY+yB,GAAUvzB,GACpCwiC,EAAW7lC,EAAO+jB,MAAO1gB,EAAM,SAG1B4hC,GAAK/gB,QACVG,EAAQrkB,EAAOskB,YAAajhB,EAAM,MACX,MAAlBghB,EAAMyhB,WACVzhB,EAAMyhB,SAAW,EACjBF,EAAUvhB,EAAM/L,MAAMkF,KACtB6G,EAAM/L,MAAMkF,KAAO,WACZ6G,EAAMyhB,UACXF,MAIHvhB,EAAMyhB,WAENL,EAAKrnB,OAAO,WAGXqnB,EAAKrnB,OAAO,WACXiG,EAAMyhB,WACA9lC,EAAOkkB,MAAO7gB,EAAM,MAAOG,QAChC6gB,EAAM/L,MAAMkF,YAOO,IAAlBna,EAAKQ,WAAoB,UAAY2nB,IAAS,SAAWA,MAK7DyZ,EAAKc,UAAah6B,EAAMg6B,SAAUh6B,EAAMi6B,UAAWj6B,EAAMk6B,WAIlB,WAAlCjmC,EAAO82B,IAAKzzB,EAAM,YACW,SAAhCrD,EAAO82B,IAAKzzB,EAAM,WAIbrD,EAAOmI,QAAQ4Y,wBAAkE,WAAxCmW,GAAoB7zB,EAAK8G,UAIvE4B,EAAMyW,KAAO,EAHbzW,EAAMuW,QAAU,iBAQd2iB,EAAKc,WACTh6B,EAAMg6B,SAAW,SACX/lC,EAAOmI,QAAQ6Y,kBACpBykB,EAAKrnB,OAAO,WACXrS,EAAMg6B,SAAWd,EAAKc,SAAU,GAChCh6B,EAAMi6B,UAAYf,EAAKc,SAAU,GACjCh6B,EAAMk6B,UAAYhB,EAAKc,SAAU,KAOpC,KAAMngB,IAAQ4F,GAEb,GADAnhB,EAAQmhB,EAAO5F,GACV6d,GAAShgC,KAAM4G,GAAU,CAG7B,SAFOmhB,GAAO5F,GACdyR,EAASA,GAAoB,WAAVhtB,EACdA,KAAY4sB,EAAS,OAAS,QAClC,QAEDxJ,GAAM7H,GAASigB,GAAYA,EAAUjgB,IAAU5lB,EAAO+L,MAAO1I,EAAMuiB,GAIrE,IAAM5lB,EAAOqI,cAAeolB,GAAS,CAC/BoY,EACC,UAAYA,KAChB5O,EAAS4O,EAAS5O,QAGnB4O,EAAW7lC,EAAO+jB,MAAO1gB,EAAM,aAI3Bg0B,IACJwO,EAAS5O,QAAUA,GAEfA,EACJj3B,EAAQqD,GAAO2zB,OAEfyO,EAAKtgC,KAAK,WACTnF,EAAQqD,GAAO+zB,SAGjBqO,EAAKtgC,KAAK,WACT,GAAIygB,EACJ5lB,GAAOgkB,YAAa3gB,EAAM,SAC1B,KAAMuiB,IAAQ6H,GACbztB,EAAO+L,MAAO1I,EAAMuiB,EAAM6H,EAAM7H,KAGlC,KAAMA,IAAQ6H,GACbsW,EAAQC,GAAa/M,EAAS4O,EAAUjgB,GAAS,EAAGA,EAAM6f,GAElD7f,IAAQigB,KACfA,EAAUjgB,GAASme,EAAMntB,MACpBqgB,IACJ8M,EAAMl+B,IAAMk+B,EAAMntB,MAClBmtB,EAAMntB,MAAiB,UAATgP,GAA6B,WAATA,EAAoB,EAAI,KAO/D,QAASwf,IAAO/hC,EAAMgD,EAASuf,EAAM/f,EAAKw/B,GACzC,MAAO,IAAID,IAAMniC,UAAU1B,KAAM8B,EAAMgD,EAASuf,EAAM/f,EAAKw/B,GAE5DrlC,EAAOolC,MAAQA,GAEfA,GAAMniC,WACLE,YAAaiiC,GACb7jC,KAAM,SAAU8B,EAAMgD,EAASuf,EAAM/f,EAAKw/B,EAAQpB,GACjD3gC,KAAKD,KAAOA,EACZC,KAAKsiB,KAAOA,EACZtiB,KAAK+hC,OAASA,GAAU,QACxB/hC,KAAK+C,QAAUA,EACf/C,KAAKsT,MAAQtT,KAAKoI,IAAMpI,KAAK8O,MAC7B9O,KAAKuC,IAAMA,EACXvC,KAAK2gC,KAAOA,IAAUjkC,EAAOw3B,UAAW5R,GAAS,GAAK,OAEvDxT,IAAK,WACJ,GAAIiS,GAAQ+gB,GAAMhe,UAAW9jB,KAAKsiB,KAElC,OAAOvB,IAASA,EAAM5f,IACrB4f,EAAM5f,IAAKnB,MACX8hC,GAAMhe,UAAUqD,SAAShmB,IAAKnB,OAEhC0hC,IAAK,SAAUF,GACd,GAAIoB,GACH7hB,EAAQ+gB,GAAMhe,UAAW9jB,KAAKsiB,KAoB/B,OAjBCtiB,MAAK2rB,IAAMiX,EADP5iC,KAAK+C,QAAQw+B,SACE7kC,EAAOqlC,OAAQ/hC,KAAK+hC,QACtCP,EAASxhC,KAAK+C,QAAQw+B,SAAWC,EAAS,EAAG,EAAGxhC,KAAK+C,QAAQw+B,UAG3CC,EAEpBxhC,KAAKoI,KAAQpI,KAAKuC,IAAMvC,KAAKsT,OAAUsvB,EAAQ5iC,KAAKsT,MAE/CtT,KAAK+C,QAAQ8/B,MACjB7iC,KAAK+C,QAAQ8/B,KAAK3hC,KAAMlB,KAAKD,KAAMC,KAAKoI,IAAKpI,MAGzC+gB,GAASA,EAAMoC,IACnBpC,EAAMoC,IAAKnjB,MAEX8hC,GAAMhe,UAAUqD,SAAShE,IAAKnjB,MAExBA,OAIT8hC,GAAMniC,UAAU1B,KAAK0B,UAAYmiC,GAAMniC,UAEvCmiC,GAAMhe,WACLqD,UACChmB,IAAK,SAAUs/B,GACd,GAAI1tB,EAEJ,OAAiC,OAA5B0tB,EAAM1gC,KAAM0gC,EAAMne,OACpBme,EAAM1gC,KAAK0I,OAA2C,MAAlCg4B,EAAM1gC,KAAK0I,MAAOg4B,EAAMne,OAQ/CvP,EAASrW,EAAO82B,IAAKiN,EAAM1gC,KAAM0gC,EAAMne,KAAM,IAErCvP,GAAqB,SAAXA,EAAwBA,EAAJ,GAT9B0tB,EAAM1gC,KAAM0gC,EAAMne,OAW3Ba,IAAK,SAAUsd,GAGT/jC,EAAO4kB,GAAGuhB,KAAMpC,EAAMne,MAC1B5lB,EAAO4kB,GAAGuhB,KAAMpC,EAAMne,MAAQme,GACnBA,EAAM1gC,KAAK0I,QAAgE,MAArDg4B,EAAM1gC,KAAK0I,MAAO/L,EAAOg4B,SAAU+L,EAAMne,QAAoB5lB,EAAOs3B,SAAUyM,EAAMne,OACrH5lB,EAAO+L,MAAOg4B,EAAM1gC,KAAM0gC,EAAMne,KAAMme,EAAMr4B,IAAMq4B,EAAME,MAExDF,EAAM1gC,KAAM0gC,EAAMne,MAASme,EAAMr4B,OASrC05B,GAAMhe,UAAUmF,UAAY6Y,GAAMhe,UAAU+E,YAC3C1F,IAAK,SAAUsd,GACTA,EAAM1gC,KAAKQ,UAAYkgC,EAAM1gC,KAAKe,aACtC2/B,EAAM1gC,KAAM0gC,EAAMne,MAASme,EAAMr4B,OAKpC1L,EAAO+E,MAAO,SAAU,OAAQ,QAAU,SAAUU,EAAGW,GACtD,GAAIggC,GAAQpmC,EAAOsB,GAAI8E,EACvBpG,GAAOsB,GAAI8E,GAAS,SAAUigC,EAAOhB,EAAQrgC,GAC5C,MAAgB,OAATqhC,GAAkC,iBAAVA,GAC9BD,EAAMhhC,MAAO9B,KAAM+B,WACnB/B,KAAKgjC,QAASC,GAAOngC,GAAM,GAAQigC,EAAOhB,EAAQrgC,MAIrDhF,EAAOsB,GAAG0E,QACTwgC,OAAQ,SAAUH,EAAOI,EAAIpB,EAAQrgC,GAGpC,MAAO1B,MAAKkQ,OAAQojB,IAAWE,IAAK,UAAW,GAAIE,OAGjDnxB,MAAMygC,SAAU/lB,QAASkmB,GAAMJ,EAAOhB,EAAQrgC,IAEjDshC,QAAS,SAAU1gB,EAAMygB,EAAOhB,EAAQrgC,GACvC,GAAIsT,GAAQtY,EAAOqI,cAAeud,GACjC8gB,EAAS1mC,EAAOqmC,MAAOA,EAAOhB,EAAQrgC,GACtC2hC,EAAc,WAEb,GAAIlB,GAAOlB,GAAWjhC,KAAMtD,EAAOgG,UAAY4f,GAAQ8gB,IAGlDpuB,GAAStY,EAAO+jB,MAAOzgB,KAAM,YACjCmiC,EAAKjhB,MAAM,GAKd,OAFCmiB,GAAYC,OAASD,EAEfruB,GAASouB,EAAOxiB,SAAU,EAChC5gB,KAAKyB,KAAM4hC,GACXrjC,KAAK4gB,MAAOwiB,EAAOxiB,MAAOyiB,IAE5BniB,KAAM,SAAU7hB,EAAMqiB,EAAYsgB,GACjC,GAAIuB,GAAY,SAAUxiB,GACzB,GAAIG,GAAOH,EAAMG,WACVH,GAAMG,KACbA,EAAM8gB,GAYP,OATqB,gBAAT3iC,KACX2iC,EAAUtgB,EACVA,EAAariB,EACbA,EAAOpD,GAEHylB,GAAcriB,KAAS,GAC3BW,KAAK4gB,MAAOvhB,GAAQ,SAGdW,KAAKyB,KAAK,WAChB,GAAIof,IAAU,EACbtG,EAAgB,MAARlb,GAAgBA,EAAO,aAC/BmkC,EAAS9mC,EAAO8mC,OAChBr+B,EAAOzI,EAAO+jB,MAAOzgB,KAEtB,IAAKua,EACCpV,EAAMoV,IAAWpV,EAAMoV,GAAQ2G,MACnCqiB,EAAWp+B,EAAMoV,QAGlB,KAAMA,IAASpV,GACTA,EAAMoV,IAAWpV,EAAMoV,GAAQ2G,MAAQmf,GAAK5/B,KAAM8Z,IACtDgpB,EAAWp+B,EAAMoV,GAKpB,KAAMA,EAAQipB,EAAOtjC,OAAQqa,KACvBipB,EAAQjpB,GAAQxa,OAASC,MAAiB,MAARX,GAAgBmkC,EAAQjpB,GAAQqG,QAAUvhB,IAChFmkC,EAAQjpB,GAAQ4nB,KAAKjhB,KAAM8gB,GAC3BnhB,GAAU,EACV2iB,EAAO/gC,OAAQ8X,EAAO,KAOnBsG,IAAYmhB,IAChBtlC,EAAOmkB,QAAS7gB,KAAMX,MAIzBikC,OAAQ,SAAUjkC,GAIjB,MAHKA,MAAS,IACbA,EAAOA,GAAQ,MAETW,KAAKyB,KAAK,WAChB,GAAI8Y,GACHpV,EAAOzI,EAAO+jB,MAAOzgB,MACrB4gB,EAAQzb,EAAM9F,EAAO,SACrB0hB,EAAQ5b,EAAM9F,EAAO,cACrBmkC,EAAS9mC,EAAO8mC,OAChBtjC,EAAS0gB,EAAQA,EAAM1gB,OAAS,CAajC,KAVAiF,EAAKm+B,QAAS,EAGd5mC,EAAOkkB,MAAO5gB,KAAMX,MAEf0hB,GAASA,EAAMG,MACnBH,EAAMG,KAAKhgB,KAAMlB,MAAM,GAIlBua,EAAQipB,EAAOtjC,OAAQqa,KACvBipB,EAAQjpB,GAAQxa,OAASC,MAAQwjC,EAAQjpB,GAAQqG,QAAUvhB,IAC/DmkC,EAAQjpB,GAAQ4nB,KAAKjhB,MAAM,GAC3BsiB,EAAO/gC,OAAQ8X,EAAO,GAKxB,KAAMA,EAAQ,EAAWra,EAARqa,EAAgBA,IAC3BqG,EAAOrG,IAAWqG,EAAOrG,GAAQ+oB,QACrC1iB,EAAOrG,GAAQ+oB,OAAOpiC,KAAMlB,YAKvBmF,GAAKm+B,WAMf,SAASL,IAAO5jC,EAAMokC,GACrB,GAAInb,GACH5Z,GAAUg1B,OAAQrkC,GAClB8C,EAAI,CAKL,KADAshC,EAAeA,EAAc,EAAI,EACtB,EAAJthC,EAAQA,GAAK,EAAIshC,EACvBnb,EAAQ2K,GAAW9wB,GACnBuM,EAAO,SAAW4Z,GAAU5Z,EAAO,UAAY4Z,GAAUjpB,CAO1D,OAJKokC,KACJ/0B,EAAMuO,QAAUvO,EAAM4Q,MAAQjgB,GAGxBqP,EAIRhS,EAAO+E,MACNkiC,UAAWV,GAAM,QACjBW,QAASX,GAAM,QACfY,YAAaZ,GAAM,UACnBa,QAAU7mB,QAAS,QACnB8mB,SAAW9mB,QAAS,QACpB+mB,YAAc/mB,QAAS,WACrB,SAAUna,EAAMolB,GAClBxrB,EAAOsB,GAAI8E,GAAS,SAAUigC,EAAOhB,EAAQrgC,GAC5C,MAAO1B,MAAKgjC,QAAS9a,EAAO6a,EAAOhB,EAAQrgC,MAI7ChF,EAAOqmC,MAAQ,SAAUA,EAAOhB,EAAQ/jC,GACvC,GAAIwe,GAAMumB,GAA0B,gBAAVA,GAAqBrmC,EAAOgG,UAAYqgC,IACjEjJ,SAAU97B,IAAOA,GAAM+jC,GACtBrlC,EAAOiE,WAAYoiC,IAAWA,EAC/BxB,SAAUwB,EACVhB,OAAQ/jC,GAAM+jC,GAAUA,IAAWrlC,EAAOiE,WAAYohC,IAAYA,EAwBnE,OArBAvlB,GAAI+kB,SAAW7kC,EAAO4kB,GAAGpd,IAAM,EAA4B,gBAAjBsY,GAAI+kB,SAAwB/kB,EAAI+kB,SACzE/kB,EAAI+kB,WAAY7kC,GAAO4kB,GAAGC,OAAS7kB,EAAO4kB,GAAGC,OAAQ/E,EAAI+kB,UAAa7kC,EAAO4kB,GAAGC,OAAO4F,UAGtE,MAAb3K,EAAIoE,OAAiBpE,EAAIoE,SAAU,KACvCpE,EAAIoE,MAAQ,MAIbpE,EAAIhU,IAAMgU,EAAIsd,SAEdtd,EAAIsd,SAAW,WACTp9B,EAAOiE,WAAY6b,EAAIhU,MAC3BgU,EAAIhU,IAAItH,KAAMlB,MAGVwc,EAAIoE,OACRlkB,EAAOmkB,QAAS7gB,KAAMwc,EAAIoE,QAIrBpE,GAGR9f,EAAOqlC,QACNkC,OAAQ,SAAUC,GACjB,MAAOA,IAERC,MAAO,SAAUD,GAChB,MAAO,GAAM7gC,KAAK+gC,IAAKF,EAAE7gC,KAAKghC,IAAO,IAIvC3nC,EAAO8mC,UACP9mC,EAAO4kB,GAAKwgB,GAAMniC,UAAU1B,KAC5BvB,EAAO4kB,GAAG8f,KAAO,WAChB,GAAIc,GACHsB,EAAS9mC,EAAO8mC,OAChBrhC,EAAI,CAIL,KAFA89B,GAAQvjC,EAAO0L,MAEHo7B,EAAOtjC,OAAXiC,EAAmBA,IAC1B+/B,EAAQsB,EAAQrhC,GAEV+/B,KAAWsB,EAAQrhC,KAAQ+/B,GAChCsB,EAAO/gC,OAAQN,IAAK,EAIhBqhC,GAAOtjC,QACZxD,EAAO4kB,GAAGJ,OAEX+e,GAAQhkC,GAGTS,EAAO4kB,GAAG4gB,MAAQ,SAAUA,GACtBA,KAAWxlC,EAAO8mC,OAAOrmC,KAAM+kC,IACnCxlC,EAAO4kB,GAAGhO,SAIZ5W,EAAO4kB,GAAGgjB,SAAW,GAErB5nC,EAAO4kB,GAAGhO,MAAQ,WACX4sB,KACLA,GAAUqE,YAAa7nC,EAAO4kB,GAAG8f,KAAM1kC,EAAO4kB,GAAGgjB,YAInD5nC,EAAO4kB,GAAGJ,KAAO,WAChBsjB,cAAetE,IACfA,GAAU,MAGXxjC,EAAO4kB,GAAGC,QACTkjB,KAAM,IACNC,KAAM,IAENvd,SAAU,KAIXzqB,EAAO4kB,GAAGuhB,QAELnmC,EAAO4U,MAAQ5U,EAAO4U,KAAKwE,UAC/BpZ,EAAO4U,KAAKwE,QAAQ6uB,SAAW,SAAU5kC,GACxC,MAAOrD,GAAO+K,KAAK/K,EAAO8mC,OAAQ,SAAUxlC,GAC3C,MAAO+B,KAAS/B,EAAG+B,OACjBG,SAGLxD,EAAOsB,GAAG4mC,OAAS,SAAU7hC,GAC5B,GAAKhB,UAAU7B,OACd,MAAO6C,KAAY9G,EAClB+D,KACAA,KAAKyB,KAAK,SAAUU,GACnBzF,EAAOkoC,OAAOC,UAAW7kC,KAAM+C,EAASZ,IAI3C,IAAI5F,GAASuoC,EACZC,GAAQn8B,IAAK,EAAGssB,KAAM,GACtBn1B,EAAOC,KAAM,GACbwP,EAAMzP,GAAQA,EAAKS,aAEpB,IAAMgP,EAON,MAHAjT,GAAUiT,EAAIhT,gBAGRE,EAAOmN,SAAUtN,EAASwD,UAMpBA,GAAKilC,wBAA0B5oC,IAC1C2oC,EAAMhlC,EAAKilC,yBAEZF,EAAMG,GAAWz1B,IAEhB5G,IAAKm8B,EAAIn8B,KAASk8B,EAAII,aAAe3oC,EAAQ0sB,YAAiB1sB,EAAQ2sB,WAAc,GACpFgM,KAAM6P,EAAI7P,MAAS4P,EAAIK,aAAe5oC,EAAQssB,aAAiBtsB,EAAQusB,YAAc,KAX9Eic,GAeTroC,EAAOkoC,QAENC,UAAW,SAAU9kC,EAAMgD,EAASZ,GACnC,GAAIywB,GAAWl2B,EAAO82B,IAAKzzB,EAAM,WAGf,YAAb6yB,IACJ7yB,EAAK0I,MAAMmqB,SAAW,WAGvB,IAAIwS,GAAU1oC,EAAQqD,GACrBslC,EAAYD,EAAQR,SACpBU,EAAY5oC,EAAO82B,IAAKzzB,EAAM,OAC9BwlC,EAAa7oC,EAAO82B,IAAKzzB,EAAM,QAC/BylC,GAAmC,aAAb5S,GAAwC,UAAbA,IAA0Bl2B,EAAO2K,QAAQ,QAASi+B,EAAWC,IAAe,GAC7Hrd,KAAYud,KAAkBC,EAAQC,CAGlCH,IACJC,EAAcL,EAAQxS,WACtB8S,EAASD,EAAY78B,IACrB+8B,EAAUF,EAAYvQ,OAEtBwQ,EAASlhC,WAAY8gC,IAAe,EACpCK,EAAUnhC,WAAY+gC,IAAgB,GAGlC7oC,EAAOiE,WAAYoC,KACvBA,EAAUA,EAAQ7B,KAAMnB,EAAMoC,EAAGkjC,IAGd,MAAftiC,EAAQ6F,MACZsf,EAAMtf,IAAQ7F,EAAQ6F,IAAMy8B,EAAUz8B,IAAQ88B,GAE1B,MAAhB3iC,EAAQmyB,OACZhN,EAAMgN,KAASnyB,EAAQmyB,KAAOmQ,EAAUnQ,KAASyQ,GAG7C,SAAW5iC,GACfA,EAAQ6iC,MAAM1kC,KAAMnB,EAAMmoB,GAE1Bkd,EAAQ5R,IAAKtL,KAMhBxrB,EAAOsB,GAAG0E,QAETkwB,SAAU,WACT,GAAM5yB,KAAM,GAAZ,CAIA,GAAI6lC,GAAcjB,EACjBkB,GAAiBl9B,IAAK,EAAGssB,KAAM,GAC/Bn1B,EAAOC,KAAM,EAwBd,OArBwC,UAAnCtD,EAAO82B,IAAKzzB,EAAM,YAEtB6kC,EAAS7kC,EAAKilC,yBAGda,EAAe7lC,KAAK6lC,eAGpBjB,EAAS5kC,KAAK4kC,SACRloC,EAAOmK,SAAUg/B,EAAc,GAAK,UACzCC,EAAeD,EAAajB,UAI7BkB,EAAal9B,KAAQlM,EAAO82B,IAAKqS,EAAc,GAAK,kBAAkB,GACtEC,EAAa5Q,MAAQx4B,EAAO82B,IAAKqS,EAAc,GAAK,mBAAmB,KAOvEj9B,IAAMg8B,EAAOh8B,IAAOk9B,EAAal9B,IAAMlM,EAAO82B,IAAKzzB,EAAM,aAAa,GACtEm1B,KAAM0P,EAAO1P,KAAO4Q,EAAa5Q,KAAOx4B,EAAO82B,IAAKzzB,EAAM,cAAc,MAI1E8lC,aAAc,WACb,MAAO7lC,MAAKsC,IAAI,WACf,GAAIujC,GAAe7lC,KAAK6lC,cAAgBtpC,CACxC,OAAQspC,IAAmBnpC,EAAOmK,SAAUg/B,EAAc,SAAsD,WAA1CnpC,EAAO82B,IAAKqS,EAAc,YAC/FA,EAAeA,EAAaA,YAE7B,OAAOA,IAAgBtpC,OAO1BG,EAAO+E,MAAOonB,WAAY,cAAeI,UAAW,eAAgB,SAAU0T,EAAQra,GACrF,GAAI1Z,GAAM,IAAInI,KAAM6hB,EAEpB5lB,GAAOsB,GAAI2+B,GAAW,SAAUnrB,GAC/B,MAAO9U,GAAOqL,OAAQ/H,KAAM,SAAUD,EAAM48B,EAAQnrB,GACnD,GAAIszB,GAAMG,GAAWllC,EAErB,OAAKyR,KAAQvV,EACL6oC,EAAOxiB,IAAQwiB,GAAOA,EAAKxiB,GACjCwiB,EAAIxoC,SAASE,gBAAiBmgC,GAC9B58B,EAAM48B,IAGHmI,EACJA,EAAIiB,SACFn9B,EAAYlM,EAAQooC,GAAMjc,aAApBrX,EACP5I,EAAM4I,EAAM9U,EAAQooC,GAAM7b,aAI3BlpB,EAAM48B,GAAWnrB,EAPlB,IASEmrB,EAAQnrB,EAAKzP,UAAU7B,OAAQ,QAIpC,SAAS+kC,IAAWllC,GACnB,MAAOrD,GAAO2H,SAAUtE,GACvBA,EACkB,IAAlBA,EAAKQ,SACJR,EAAK2P,aAAe3P,EAAKgnB,cACzB,EAGHrqB,EAAO+E,MAAQukC,OAAQ,SAAUC,MAAO,SAAW,SAAUnjC,EAAMzD,GAClE3C,EAAO+E,MAAQ00B,QAAS,QAAUrzB,EAAMktB,QAAS3wB,EAAM,GAAI,QAAUyD,GAAQ,SAAUojC,EAAcC,GAEpGzpC,EAAOsB,GAAImoC,GAAa,SAAUjQ,EAAQnvB,GACzC,GAAIiB,GAAYjG,UAAU7B,SAAYgmC,GAAkC,iBAAXhQ,IAC5DtB,EAAQsR,IAAkBhQ,KAAW,GAAQnvB,KAAU,EAAO,SAAW,SAE1E,OAAOrK,GAAOqL,OAAQ/H,KAAM,SAAUD,EAAMV,EAAM0H,GACjD,GAAIyI,EAEJ,OAAK9S,GAAO2H,SAAUtE,GAIdA,EAAKzD,SAASE,gBAAiB,SAAWsG,GAI3B,IAAlB/C,EAAKQ,UACTiP,EAAMzP,EAAKvD,gBAIJ6G,KAAKiE,IACXvH,EAAK+D,KAAM,SAAWhB,GAAQ0M,EAAK,SAAW1M,GAC9C/C,EAAK+D,KAAM,SAAWhB,GAAQ0M,EAAK,SAAW1M,GAC9C0M,EAAK,SAAW1M,KAIXiE,IAAU9K,EAEhBS,EAAO82B,IAAKzzB,EAAMV,EAAMu1B,GAGxBl4B,EAAO+L,MAAO1I,EAAMV,EAAM0H,EAAO6tB,IAChCv1B,EAAM2I,EAAYkuB,EAASj6B,EAAW+L,EAAW,WAQvDtL,EAAOsB,GAAGooC,KAAO,WAChB,MAAOpmC,MAAKE,QAGbxD,EAAOsB,GAAGqoC,QAAU3pC,EAAOsB,GAAG6tB,QAGP,gBAAXya,SAAuBA,QAAoC,gBAAnBA,QAAOC,QAK1DD,OAAOC,QAAU7pC,GAGjBV,EAAOU,OAASV,EAAOY,EAAIF,EASJ,kBAAX8pC,SAAyBA,OAAOC,KAC3CD,OAAQ,YAAc,WAAc,MAAO9pC,QAIzCV"}
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate-vsdoc.js b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate-vsdoc.js
new file mode 100644
index 000000000..fd9125705
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate-vsdoc.js
@@ -0,0 +1,1302 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*
+* This file has been commented to support Visual Studio Intellisense.
+* You should not use this file at runtime inside the browser--it is only
+* intended to be used only for design-time IntelliSense. Please use the
+* standard jQuery library for all production use.
+*
+* Comment version: 1.11.1
+*/
+
+/*
+* Note: While Microsoft is not the author of this file, Microsoft is
+* offering you a license subject to the terms of the Microsoft Software
+* License Terms for Microsoft ASP.NET Model View Controller 3.
+* Microsoft reserves all other rights. The notices below are provided
+* for informational purposes only and are not the license terms under
+* which Microsoft distributed this file.
+*
+* jQuery Validation Plugin - v1.11.1 - 2/4/2013
+* https://github.com/jzaefferer/jquery-validation
+* Copyright (c) 2013 Jörn Zaefferer; Licensed MIT
+*
+*/
+
+(function($) {
+
+$.extend($.fn, {
+ // http://docs.jquery.com/Plugins/Validation/validate
+ validate: function( options ) {
+ ///
+ /// Validates the selected form. This method sets up event handlers for submit, focus,
+ /// keyup, blur and click to trigger validation of the entire form or individual
+ /// elements. Each one can be disabled, see the onxxx options (onsubmit, onfocusout,
+ /// onkeyup, onclick). focusInvalid focuses elements when submitting a invalid form.
+ ///
+ ///
+ /// A set of key/value pairs that configure the validate. All options are optional.
+ ///
+
+ // if nothing is selected, return nothing; can't chain anyway
+ if (!this.length) {
+ options && options.debug && window.console && console.warn( "nothing selected, can't validate, returning nothing" );
+ return;
+ }
+
+ // check if a validator for this form was already created
+ var validator = $.data(this[0], 'validator');
+ if ( validator ) {
+ return validator;
+ }
+
+ validator = new $.validator( options, this[0] );
+ $.data(this[0], 'validator', validator);
+
+ if ( validator.settings.onsubmit ) {
+
+ // allow suppresing validation by adding a cancel class to the submit button
+ this.find("input, button").filter(".cancel").click(function() {
+ validator.cancelSubmit = true;
+ });
+
+ // when a submitHandler is used, capture the submitting button
+ if (validator.settings.submitHandler) {
+ this.find("input, button").filter(":submit").click(function() {
+ validator.submitButton = this;
+ });
+ }
+
+ // validate the form on submit
+ this.submit( function( event ) {
+ if ( validator.settings.debug )
+ // prevent form submit to be able to see console output
+ event.preventDefault();
+
+ function handle() {
+ if ( validator.settings.submitHandler ) {
+ if (validator.submitButton) {
+ // insert a hidden input as a replacement for the missing submit button
+ var hidden = $("
").attr("name", validator.submitButton.name).val(validator.submitButton.value).appendTo(validator.currentForm);
+ }
+ validator.settings.submitHandler.call( validator, validator.currentForm );
+ if (validator.submitButton) {
+ // and clean up afterwards; thanks to no-block-scope, hidden can be referenced
+ hidden.remove();
+ }
+ return false;
+ }
+ return true;
+ }
+
+ // prevent submit for invalid forms or custom submit handlers
+ if ( validator.cancelSubmit ) {
+ validator.cancelSubmit = false;
+ return handle();
+ }
+ if ( validator.form() ) {
+ if ( validator.pendingRequest ) {
+ validator.formSubmitted = true;
+ return false;
+ }
+ return handle();
+ } else {
+ validator.focusInvalid();
+ return false;
+ }
+ });
+ }
+
+ return validator;
+ },
+ // http://docs.jquery.com/Plugins/Validation/valid
+ valid: function() {
+ ///
+ /// Checks if the selected form is valid or if all selected elements are valid.
+ /// validate() needs to be called on the form before checking it using this method.
+ ///
+ ///
+
+ if ( $(this[0]).is('form')) {
+ return this.validate().form();
+ } else {
+ var valid = true;
+ var validator = $(this[0].form).validate();
+ this.each(function() {
+ valid &= validator.element(this);
+ });
+ return valid;
+ }
+ },
+ // attributes: space seperated list of attributes to retrieve and remove
+ removeAttrs: function(attributes) {
+ ///
+ /// Remove the specified attributes from the first matched element and return them.
+ ///
+ ///
+ /// A space-seperated list of attribute names to remove.
+ ///
+
+ var result = {},
+ $element = this;
+ $.each(attributes.split(/\s/), function(index, value) {
+ result[value] = $element.attr(value);
+ $element.removeAttr(value);
+ });
+ return result;
+ },
+ // http://docs.jquery.com/Plugins/Validation/rules
+ rules: function(command, argument) {
+ ///
+ /// Return the validations rules for the first selected element.
+ ///
+ ///
+ /// Can be either "add" or "remove".
+ ///
+ ///
+ /// A list of rules to add or remove.
+ ///
+
+ var element = this[0];
+
+ if (command) {
+ var settings = $.data(element.form, 'validator').settings;
+ var staticRules = settings.rules;
+ var existingRules = $.validator.staticRules(element);
+ switch(command) {
+ case "add":
+ $.extend(existingRules, $.validator.normalizeRule(argument));
+ staticRules[element.name] = existingRules;
+ if (argument.messages)
+ settings.messages[element.name] = $.extend( settings.messages[element.name], argument.messages );
+ break;
+ case "remove":
+ if (!argument) {
+ delete staticRules[element.name];
+ return existingRules;
+ }
+ var filtered = {};
+ $.each(argument.split(/\s/), function(index, method) {
+ filtered[method] = existingRules[method];
+ delete existingRules[method];
+ });
+ return filtered;
+ }
+ }
+
+ var data = $.validator.normalizeRules(
+ $.extend(
+ {},
+ $.validator.metadataRules(element),
+ $.validator.classRules(element),
+ $.validator.attributeRules(element),
+ $.validator.staticRules(element)
+ ), element);
+
+ // make sure required is at front
+ if (data.required) {
+ var param = data.required;
+ delete data.required;
+ data = $.extend({required: param}, data);
+ }
+
+ return data;
+ }
+});
+
+// Custom selectors
+$.extend($.expr[":"], {
+ // http://docs.jquery.com/Plugins/Validation/blank
+ blank: function(a) {return !$.trim("" + a.value);},
+ // http://docs.jquery.com/Plugins/Validation/filled
+ filled: function(a) {return !!$.trim("" + a.value);},
+ // http://docs.jquery.com/Plugins/Validation/unchecked
+ unchecked: function(a) {return !a.checked;}
+});
+
+// constructor for validator
+$.validator = function( options, form ) {
+ this.settings = $.extend( true, {}, $.validator.defaults, options );
+ this.currentForm = form;
+ this.init();
+};
+
+$.validator.format = function(source, params) {
+ ///
+ /// Replaces {n} placeholders with arguments.
+ /// One or more arguments can be passed, in addition to the string template itself, to insert
+ /// into the string.
+ ///
+ ///
+ /// The string to format.
+ ///
+ ///
+ /// The first argument to insert, or an array of Strings to insert
+ ///
+ ///
+
+ if ( arguments.length == 1 )
+ return function() {
+ var args = $.makeArray(arguments);
+ args.unshift(source);
+ return $.validator.format.apply( this, args );
+ };
+ if ( arguments.length > 2 && params.constructor != Array ) {
+ params = $.makeArray(arguments).slice(1);
+ }
+ if ( params.constructor != Array ) {
+ params = [ params ];
+ }
+ $.each(params, function(i, n) {
+ source = source.replace(new RegExp("\\{" + i + "\\}", "g"), n);
+ });
+ return source;
+};
+
+$.extend($.validator, {
+
+ defaults: {
+ messages: {},
+ groups: {},
+ rules: {},
+ errorClass: "error",
+ validClass: "valid",
+ errorElement: "label",
+ focusInvalid: true,
+ errorContainer: $( [] ),
+ errorLabelContainer: $( [] ),
+ onsubmit: true,
+ ignore: [],
+ ignoreTitle: false,
+ onfocusin: function(element) {
+ this.lastActive = element;
+
+ // hide error label and remove error class on focus if enabled
+ if ( this.settings.focusCleanup && !this.blockFocusCleanup ) {
+ this.settings.unhighlight && this.settings.unhighlight.call( this, element, this.settings.errorClass, this.settings.validClass );
+ this.addWrapper(this.errorsFor(element)).hide();
+ }
+ },
+ onfocusout: function(element) {
+ if ( !this.checkable(element) && (element.name in this.submitted || !this.optional(element)) ) {
+ this.element(element);
+ }
+ },
+ onkeyup: function(element) {
+ if ( element.name in this.submitted || element == this.lastElement ) {
+ this.element(element);
+ }
+ },
+ onclick: function(element) {
+ // click on selects, radiobuttons and checkboxes
+ if ( element.name in this.submitted )
+ this.element(element);
+ // or option elements, check parent select in that case
+ else if (element.parentNode.name in this.submitted)
+ this.element(element.parentNode);
+ },
+ highlight: function( element, errorClass, validClass ) {
+ $(element).addClass(errorClass).removeClass(validClass);
+ },
+ unhighlight: function( element, errorClass, validClass ) {
+ $(element).removeClass(errorClass).addClass(validClass);
+ }
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/setDefaults
+ setDefaults: function(settings) {
+ ///
+ /// Modify default settings for validation.
+ /// Accepts everything that Plugins/Validation/validate accepts.
+ ///
+ ///
+ /// Options to set as default.
+ ///
+
+ $.extend( $.validator.defaults, settings );
+ },
+
+ messages: {
+ required: "This field is required.",
+ remote: "Please fix this field.",
+ email: "Please enter a valid email address.",
+ url: "Please enter a valid URL.",
+ date: "Please enter a valid date.",
+ dateISO: "Please enter a valid date (ISO).",
+ number: "Please enter a valid number.",
+ digits: "Please enter only digits.",
+ creditcard: "Please enter a valid credit card number.",
+ equalTo: "Please enter the same value again.",
+ accept: "Please enter a value with a valid extension.",
+ maxlength: $.validator.format("Please enter no more than {0} characters."),
+ minlength: $.validator.format("Please enter at least {0} characters."),
+ rangelength: $.validator.format("Please enter a value between {0} and {1} characters long."),
+ range: $.validator.format("Please enter a value between {0} and {1}."),
+ max: $.validator.format("Please enter a value less than or equal to {0}."),
+ min: $.validator.format("Please enter a value greater than or equal to {0}.")
+ },
+
+ autoCreateRanges: false,
+
+ prototype: {
+
+ init: function() {
+ this.labelContainer = $(this.settings.errorLabelContainer);
+ this.errorContext = this.labelContainer.length && this.labelContainer || $(this.currentForm);
+ this.containers = $(this.settings.errorContainer).add( this.settings.errorLabelContainer );
+ this.submitted = {};
+ this.valueCache = {};
+ this.pendingRequest = 0;
+ this.pending = {};
+ this.invalid = {};
+ this.reset();
+
+ var groups = (this.groups = {});
+ $.each(this.settings.groups, function(key, value) {
+ $.each(value.split(/\s/), function(index, name) {
+ groups[name] = key;
+ });
+ });
+ var rules = this.settings.rules;
+ $.each(rules, function(key, value) {
+ rules[key] = $.validator.normalizeRule(value);
+ });
+
+ function delegate(event) {
+ var validator = $.data(this[0].form, "validator"),
+ eventType = "on" + event.type.replace(/^validate/, "");
+ validator.settings[eventType] && validator.settings[eventType].call(validator, this[0] );
+ }
+ $(this.currentForm)
+ .validateDelegate(":text, :password, :file, select, textarea", "focusin focusout keyup", delegate)
+ .validateDelegate(":radio, :checkbox, select, option", "click", delegate);
+
+ if (this.settings.invalidHandler)
+ $(this.currentForm).bind("invalid-form.validate", this.settings.invalidHandler);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/form
+ form: function() {
+ ///
+ /// Validates the form, returns true if it is valid, false otherwise.
+ /// This behaves as a normal submit event, but returns the result.
+ ///
+ ///
+
+ this.checkForm();
+ $.extend(this.submitted, this.errorMap);
+ this.invalid = $.extend({}, this.errorMap);
+ if (!this.valid())
+ $(this.currentForm).triggerHandler("invalid-form", [this]);
+ this.showErrors();
+ return this.valid();
+ },
+
+ checkForm: function() {
+ this.prepareForm();
+ for ( var i = 0, elements = (this.currentElements = this.elements()); elements[i]; i++ ) {
+ this.check( elements[i] );
+ }
+ return this.valid();
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/element
+ element: function( element ) {
+ ///
+ /// Validates a single element, returns true if it is valid, false otherwise.
+ /// This behaves as validation on blur or keyup, but returns the result.
+ ///
+ ///
+ /// An element to validate, must be inside the validated form.
+ ///
+ ///
+
+ element = this.clean( element );
+ this.lastElement = element;
+ this.prepareElement( element );
+ this.currentElements = $(element);
+ var result = this.check( element );
+ if ( result ) {
+ delete this.invalid[element.name];
+ } else {
+ this.invalid[element.name] = true;
+ }
+ if ( !this.numberOfInvalids() ) {
+ // Hide error containers on last error
+ this.toHide = this.toHide.add( this.containers );
+ }
+ this.showErrors();
+ return result;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/showErrors
+ showErrors: function(errors) {
+ ///
+ /// Show the specified messages.
+ /// Keys have to refer to the names of elements, values are displayed for those elements, using the configured error placement.
+ ///
+ ///
+ /// One or more key/value pairs of input names and messages.
+ ///
+
+ if(errors) {
+ // add items to error list and map
+ $.extend( this.errorMap, errors );
+ this.errorList = [];
+ for ( var name in errors ) {
+ this.errorList.push({
+ message: errors[name],
+ element: this.findByName(name)[0]
+ });
+ }
+ // remove items from success list
+ this.successList = $.grep( this.successList, function(element) {
+ return !(element.name in errors);
+ });
+ }
+ this.settings.showErrors
+ ? this.settings.showErrors.call( this, this.errorMap, this.errorList )
+ : this.defaultShowErrors();
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/resetForm
+ resetForm: function() {
+ ///
+ /// Resets the controlled form.
+ /// Resets input fields to their original value (requires form plugin), removes classes
+ /// indicating invalid elements and hides error messages.
+ ///
+
+ if ( $.fn.resetForm )
+ $( this.currentForm ).resetForm();
+ this.submitted = {};
+ this.prepareForm();
+ this.hideErrors();
+ this.elements().removeClass( this.settings.errorClass );
+ },
+
+ numberOfInvalids: function() {
+ ///
+ /// Returns the number of invalid fields.
+ /// This depends on the internal validator state. It covers all fields only after
+ /// validating the complete form (on submit or via $("form").valid()). After validating
+ /// a single element, only that element is counted. Most useful in combination with the
+ /// invalidHandler-option.
+ ///
+ ///
+
+ return this.objectLength(this.invalid);
+ },
+
+ objectLength: function( obj ) {
+ var count = 0;
+ for ( var i in obj )
+ count++;
+ return count;
+ },
+
+ hideErrors: function() {
+ this.addWrapper( this.toHide ).hide();
+ },
+
+ valid: function() {
+ return this.size() == 0;
+ },
+
+ size: function() {
+ return this.errorList.length;
+ },
+
+ focusInvalid: function() {
+ if( this.settings.focusInvalid ) {
+ try {
+ $(this.findLastActive() || this.errorList.length && this.errorList[0].element || [])
+ .filter(":visible")
+ .focus()
+ // manually trigger focusin event; without it, focusin handler isn't called, findLastActive won't have anything to find
+ .trigger("focusin");
+ } catch(e) {
+ // ignore IE throwing errors when focusing hidden elements
+ }
+ }
+ },
+
+ findLastActive: function() {
+ var lastActive = this.lastActive;
+ return lastActive && $.grep(this.errorList, function(n) {
+ return n.element.name == lastActive.name;
+ }).length == 1 && lastActive;
+ },
+
+ elements: function() {
+ var validator = this,
+ rulesCache = {};
+
+ // select all valid inputs inside the form (no submit or reset buttons)
+ // workaround $Query([]).add until http://dev.jquery.com/ticket/2114 is solved
+ return $([]).add(this.currentForm.elements)
+ .filter(":input")
+ .not(":submit, :reset, :image, [disabled]")
+ .not( this.settings.ignore )
+ .filter(function() {
+ !this.name && validator.settings.debug && window.console && console.error( "%o has no name assigned", this);
+
+ // select only the first element for each name, and only those with rules specified
+ if ( this.name in rulesCache || !validator.objectLength($(this).rules()) )
+ return false;
+
+ rulesCache[this.name] = true;
+ return true;
+ });
+ },
+
+ clean: function( selector ) {
+ return $( selector )[0];
+ },
+
+ errors: function() {
+ return $( this.settings.errorElement + "." + this.settings.errorClass, this.errorContext );
+ },
+
+ reset: function() {
+ this.successList = [];
+ this.errorList = [];
+ this.errorMap = {};
+ this.toShow = $([]);
+ this.toHide = $([]);
+ this.currentElements = $([]);
+ },
+
+ prepareForm: function() {
+ this.reset();
+ this.toHide = this.errors().add( this.containers );
+ },
+
+ prepareElement: function( element ) {
+ this.reset();
+ this.toHide = this.errorsFor(element);
+ },
+
+ check: function( element ) {
+ element = this.clean( element );
+
+ // if radio/checkbox, validate first element in group instead
+ if (this.checkable(element)) {
+ element = this.findByName(element.name).not(this.settings.ignore)[0];
+ }
+
+ var rules = $(element).rules();
+ var dependencyMismatch = false;
+ for (var method in rules) {
+ var rule = { method: method, parameters: rules[method] };
+ try {
+ var result = $.validator.methods[method].call( this, element.value.replace(/\r/g, ""), element, rule.parameters );
+
+ // if a method indicates that the field is optional and therefore valid,
+ // don't mark it as valid when there are no other rules
+ if ( result == "dependency-mismatch" ) {
+ dependencyMismatch = true;
+ continue;
+ }
+ dependencyMismatch = false;
+
+ if ( result == "pending" ) {
+ this.toHide = this.toHide.not( this.errorsFor(element) );
+ return;
+ }
+
+ if( !result ) {
+ this.formatAndAdd( element, rule );
+ return false;
+ }
+ } catch(e) {
+ this.settings.debug && window.console && console.log("exception occured when checking element " + element.id
+ + ", check the '" + rule.method + "' method", e);
+ throw e;
+ }
+ }
+ if (dependencyMismatch)
+ return;
+ if ( this.objectLength(rules) )
+ this.successList.push(element);
+ return true;
+ },
+
+ // return the custom message for the given element and validation method
+ // specified in the element's "messages" metadata
+ customMetaMessage: function(element, method) {
+ if (!$.metadata)
+ return;
+
+ var meta = this.settings.meta
+ ? $(element).metadata()[this.settings.meta]
+ : $(element).metadata();
+
+ return meta && meta.messages && meta.messages[method];
+ },
+
+ // return the custom message for the given element name and validation method
+ customMessage: function( name, method ) {
+ var m = this.settings.messages[name];
+ return m && (m.constructor == String
+ ? m
+ : m[method]);
+ },
+
+ // return the first defined argument, allowing empty strings
+ findDefined: function() {
+ for(var i = 0; i < arguments.length; i++) {
+ if (arguments[i] !== undefined)
+ return arguments[i];
+ }
+ return undefined;
+ },
+
+ defaultMessage: function( element, method) {
+ return this.findDefined(
+ this.customMessage( element.name, method ),
+ this.customMetaMessage( element, method ),
+ // title is never undefined, so handle empty string as undefined
+ !this.settings.ignoreTitle && element.title || undefined,
+ $.validator.messages[method],
+ "
Warning: No message defined for " + element.name + ""
+ );
+ },
+
+ formatAndAdd: function( element, rule ) {
+ var message = this.defaultMessage( element, rule.method ),
+ theregex = /\$?\{(\d+)\}/g;
+ if ( typeof message == "function" ) {
+ message = message.call(this, rule.parameters, element);
+ } else if (theregex.test(message)) {
+ message = jQuery.format(message.replace(theregex, '{$1}'), rule.parameters);
+ }
+ this.errorList.push({
+ message: message,
+ element: element
+ });
+
+ this.errorMap[element.name] = message;
+ this.submitted[element.name] = message;
+ },
+
+ addWrapper: function(toToggle) {
+ if ( this.settings.wrapper )
+ toToggle = toToggle.add( toToggle.parent( this.settings.wrapper ) );
+ return toToggle;
+ },
+
+ defaultShowErrors: function() {
+ for ( var i = 0; this.errorList[i]; i++ ) {
+ var error = this.errorList[i];
+ this.settings.highlight && this.settings.highlight.call( this, error.element, this.settings.errorClass, this.settings.validClass );
+ this.showLabel( error.element, error.message );
+ }
+ if( this.errorList.length ) {
+ this.toShow = this.toShow.add( this.containers );
+ }
+ if (this.settings.success) {
+ for ( var i = 0; this.successList[i]; i++ ) {
+ this.showLabel( this.successList[i] );
+ }
+ }
+ if (this.settings.unhighlight) {
+ for ( var i = 0, elements = this.validElements(); elements[i]; i++ ) {
+ this.settings.unhighlight.call( this, elements[i], this.settings.errorClass, this.settings.validClass );
+ }
+ }
+ this.toHide = this.toHide.not( this.toShow );
+ this.hideErrors();
+ this.addWrapper( this.toShow ).show();
+ },
+
+ validElements: function() {
+ return this.currentElements.not(this.invalidElements());
+ },
+
+ invalidElements: function() {
+ return $(this.errorList).map(function() {
+ return this.element;
+ });
+ },
+
+ showLabel: function(element, message) {
+ var label = this.errorsFor( element );
+ if ( label.length ) {
+ // refresh error/success class
+ label.removeClass().addClass( this.settings.errorClass );
+
+ // check if we have a generated label, replace the message then
+ label.attr("generated") && label.html(message);
+ } else {
+ // create label
+ label = $("<" + this.settings.errorElement + "/>")
+ .attr({"for": this.idOrName(element), generated: true})
+ .addClass(this.settings.errorClass)
+ .html(message || "");
+ if ( this.settings.wrapper ) {
+ // make sure the element is visible, even in IE
+ // actually showing the wrapped element is handled elsewhere
+ label = label.hide().show().wrap("<" + this.settings.wrapper + "/>").parent();
+ }
+ if ( !this.labelContainer.append(label).length )
+ this.settings.errorPlacement
+ ? this.settings.errorPlacement(label, $(element) )
+ : label.insertAfter(element);
+ }
+ if ( !message && this.settings.success ) {
+ label.text("");
+ typeof this.settings.success == "string"
+ ? label.addClass( this.settings.success )
+ : this.settings.success( label );
+ }
+ this.toShow = this.toShow.add(label);
+ },
+
+ errorsFor: function(element) {
+ var name = this.idOrName(element);
+ return this.errors().filter(function() {
+ return $(this).attr('for') == name;
+ });
+ },
+
+ idOrName: function(element) {
+ return this.groups[element.name] || (this.checkable(element) ? element.name : element.id || element.name);
+ },
+
+ checkable: function( element ) {
+ return /radio|checkbox/i.test(element.type);
+ },
+
+ findByName: function( name ) {
+ // select by name and filter by form for performance over form.find("[name=...]")
+ var form = this.currentForm;
+ return $(document.getElementsByName(name)).map(function(index, element) {
+ return element.form == form && element.name == name && element || null;
+ });
+ },
+
+ getLength: function(value, element) {
+ switch( element.nodeName.toLowerCase() ) {
+ case 'select':
+ return $("option:selected", element).length;
+ case 'input':
+ if( this.checkable( element) )
+ return this.findByName(element.name).filter(':checked').length;
+ }
+ return value.length;
+ },
+
+ depend: function(param, element) {
+ return this.dependTypes[typeof param]
+ ? this.dependTypes[typeof param](param, element)
+ : true;
+ },
+
+ dependTypes: {
+ "boolean": function(param, element) {
+ return param;
+ },
+ "string": function(param, element) {
+ return !!$(param, element.form).length;
+ },
+ "function": function(param, element) {
+ return param(element);
+ }
+ },
+
+ optional: function(element) {
+ return !$.validator.methods.required.call(this, $.trim(element.value), element) && "dependency-mismatch";
+ },
+
+ startRequest: function(element) {
+ if (!this.pending[element.name]) {
+ this.pendingRequest++;
+ this.pending[element.name] = true;
+ }
+ },
+
+ stopRequest: function(element, valid) {
+ this.pendingRequest--;
+ // sometimes synchronization fails, make sure pendingRequest is never < 0
+ if (this.pendingRequest < 0)
+ this.pendingRequest = 0;
+ delete this.pending[element.name];
+ if ( valid && this.pendingRequest == 0 && this.formSubmitted && this.form() ) {
+ $(this.currentForm).submit();
+ this.formSubmitted = false;
+ } else if (!valid && this.pendingRequest == 0 && this.formSubmitted) {
+ $(this.currentForm).triggerHandler("invalid-form", [this]);
+ this.formSubmitted = false;
+ }
+ },
+
+ previousValue: function(element) {
+ return $.data(element, "previousValue") || $.data(element, "previousValue", {
+ old: null,
+ valid: true,
+ message: this.defaultMessage( element, "remote" )
+ });
+ }
+
+ },
+
+ classRuleSettings: {
+ required: {required: true},
+ email: {email: true},
+ url: {url: true},
+ date: {date: true},
+ dateISO: {dateISO: true},
+ dateDE: {dateDE: true},
+ number: {number: true},
+ numberDE: {numberDE: true},
+ digits: {digits: true},
+ creditcard: {creditcard: true}
+ },
+
+ addClassRules: function(className, rules) {
+ ///
+ /// Add a compound class method - useful to refactor common combinations of rules into a single
+ /// class.
+ ///
+ ///
+ /// The name of the class rule to add
+ ///
+ ///
+ /// The compound rules
+ ///
+
+ className.constructor == String ?
+ this.classRuleSettings[className] = rules :
+ $.extend(this.classRuleSettings, className);
+ },
+
+ classRules: function(element) {
+ var rules = {};
+ var classes = $(element).attr('class');
+ classes && $.each(classes.split(' '), function() {
+ if (this in $.validator.classRuleSettings) {
+ $.extend(rules, $.validator.classRuleSettings[this]);
+ }
+ });
+ return rules;
+ },
+
+ attributeRules: function(element) {
+ var rules = {};
+ var $element = $(element);
+
+ for (var method in $.validator.methods) {
+ var value = $element.attr(method);
+ if (value) {
+ rules[method] = value;
+ }
+ }
+
+ // maxlength may be returned as -1, 2147483647 (IE) and 524288 (safari) for text inputs
+ if (rules.maxlength && /-1|2147483647|524288/.test(rules.maxlength)) {
+ delete rules.maxlength;
+ }
+
+ return rules;
+ },
+
+ metadataRules: function(element) {
+ if (!$.metadata) return {};
+
+ var meta = $.data(element.form, 'validator').settings.meta;
+ return meta ?
+ $(element).metadata()[meta] :
+ $(element).metadata();
+ },
+
+ staticRules: function(element) {
+ var rules = {};
+ var validator = $.data(element.form, 'validator');
+ if (validator.settings.rules) {
+ rules = $.validator.normalizeRule(validator.settings.rules[element.name]) || {};
+ }
+ return rules;
+ },
+
+ normalizeRules: function(rules, element) {
+ // handle dependency check
+ $.each(rules, function(prop, val) {
+ // ignore rule when param is explicitly false, eg. required:false
+ if (val === false) {
+ delete rules[prop];
+ return;
+ }
+ if (val.param || val.depends) {
+ var keepRule = true;
+ switch (typeof val.depends) {
+ case "string":
+ keepRule = !!$(val.depends, element.form).length;
+ break;
+ case "function":
+ keepRule = val.depends.call(element, element);
+ break;
+ }
+ if (keepRule) {
+ rules[prop] = val.param !== undefined ? val.param : true;
+ } else {
+ delete rules[prop];
+ }
+ }
+ });
+
+ // evaluate parameters
+ $.each(rules, function(rule, parameter) {
+ rules[rule] = $.isFunction(parameter) ? parameter(element) : parameter;
+ });
+
+ // clean number parameters
+ $.each(['minlength', 'maxlength', 'min', 'max'], function() {
+ if (rules[this]) {
+ rules[this] = Number(rules[this]);
+ }
+ });
+ $.each(['rangelength', 'range'], function() {
+ if (rules[this]) {
+ rules[this] = [Number(rules[this][0]), Number(rules[this][1])];
+ }
+ });
+
+ if ($.validator.autoCreateRanges) {
+ // auto-create ranges
+ if (rules.min && rules.max) {
+ rules.range = [rules.min, rules.max];
+ delete rules.min;
+ delete rules.max;
+ }
+ if (rules.minlength && rules.maxlength) {
+ rules.rangelength = [rules.minlength, rules.maxlength];
+ delete rules.minlength;
+ delete rules.maxlength;
+ }
+ }
+
+ // To support custom messages in metadata ignore rule methods titled "messages"
+ if (rules.messages) {
+ delete rules.messages;
+ }
+
+ return rules;
+ },
+
+ // Converts a simple string to a {string: true} rule, e.g., "required" to {required:true}
+ normalizeRule: function(data) {
+ if( typeof data == "string" ) {
+ var transformed = {};
+ $.each(data.split(/\s/), function() {
+ transformed[this] = true;
+ });
+ data = transformed;
+ }
+ return data;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/addMethod
+ addMethod: function(name, method, message) {
+ ///
+ /// Add a custom validation method. It must consist of a name (must be a legal javascript
+ /// identifier), a javascript based function and a default string message.
+ ///
+ ///
+ /// The name of the method, used to identify and referencing it, must be a valid javascript
+ /// identifier
+ ///
+ ///
+ /// The actual method implementation, returning true if an element is valid
+ ///
+ ///
+ /// (Optional) The default message to display for this method. Can be a function created by
+ /// jQuery.validator.format(value). When undefined, an already existing message is used
+ /// (handy for localization), otherwise the field-specific messages have to be defined.
+ ///
+
+ $.validator.methods[name] = method;
+ $.validator.messages[name] = message != undefined ? message : $.validator.messages[name];
+ if (method.length < 3) {
+ $.validator.addClassRules(name, $.validator.normalizeRule(name));
+ }
+ },
+
+ methods: {
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/required
+ required: function(value, element, param) {
+ // check if dependency is met
+ if ( !this.depend(param, element) )
+ return "dependency-mismatch";
+ switch( element.nodeName.toLowerCase() ) {
+ case 'select':
+ // could be an array for select-multiple or a string, both are fine this way
+ var val = $(element).val();
+ return val && val.length > 0;
+ case 'input':
+ if ( this.checkable(element) )
+ return this.getLength(value, element) > 0;
+ default:
+ return $.trim(value).length > 0;
+ }
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/remote
+ remote: function(value, element, param) {
+ if ( this.optional(element) )
+ return "dependency-mismatch";
+
+ var previous = this.previousValue(element);
+ if (!this.settings.messages[element.name] )
+ this.settings.messages[element.name] = {};
+ previous.originalMessage = this.settings.messages[element.name].remote;
+ this.settings.messages[element.name].remote = previous.message;
+
+ param = typeof param == "string" && {url:param} || param;
+
+ if ( this.pending[element.name] ) {
+ return "pending";
+ }
+ if ( previous.old === value ) {
+ return previous.valid;
+ }
+
+ previous.old = value;
+ var validator = this;
+ this.startRequest(element);
+ var data = {};
+ data[element.name] = value;
+ $.ajax($.extend(true, {
+ url: param,
+ mode: "abort",
+ port: "validate" + element.name,
+ dataType: "json",
+ data: data,
+ success: function(response) {
+ validator.settings.messages[element.name].remote = previous.originalMessage;
+ var valid = response === true;
+ if ( valid ) {
+ var submitted = validator.formSubmitted;
+ validator.prepareElement(element);
+ validator.formSubmitted = submitted;
+ validator.successList.push(element);
+ validator.showErrors();
+ } else {
+ var errors = {};
+ var message = response || validator.defaultMessage(element, "remote");
+ errors[element.name] = previous.message = $.isFunction(message) ? message(value) : message;
+ validator.showErrors(errors);
+ }
+ previous.valid = valid;
+ validator.stopRequest(element, valid);
+ }
+ }, param));
+ return "pending";
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/minlength
+ minlength: function(value, element, param) {
+ return this.optional(element) || this.getLength($.trim(value), element) >= param;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/maxlength
+ maxlength: function(value, element, param) {
+ return this.optional(element) || this.getLength($.trim(value), element) <= param;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/rangelength
+ rangelength: function(value, element, param) {
+ var length = this.getLength($.trim(value), element);
+ return this.optional(element) || ( length >= param[0] && length <= param[1] );
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/min
+ min: function( value, element, param ) {
+ return this.optional(element) || value >= param;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/max
+ max: function( value, element, param ) {
+ return this.optional(element) || value <= param;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/range
+ range: function( value, element, param ) {
+ return this.optional(element) || ( value >= param[0] && value <= param[1] );
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/email
+ email: function(value, element) {
+ // contributed by Scott Gonzalez: http://projects.scottsplayground.com/email_address_validation/
+ return this.optional(element) || /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/url
+ url: function(value, element) {
+ // contributed by Scott Gonzalez: http://projects.scottsplayground.com/iri/
+ return this.optional(element) || /^(https?|ftp):\/\/(((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/i.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/date
+ date: function(value, element) {
+ return this.optional(element) || !/Invalid|NaN/.test(new Date(value));
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/dateISO
+ dateISO: function(value, element) {
+ return this.optional(element) || /^\d{4}[\/-]\d{1,2}[\/-]\d{1,2}$/.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/number
+ number: function(value, element) {
+ return this.optional(element) || /^-?(?:\d+|\d{1,3}(?:,\d{3})+)(?:\.\d+)?$/.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/digits
+ digits: function(value, element) {
+ return this.optional(element) || /^\d+$/.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/creditcard
+ // based on http://en.wikipedia.org/wiki/Luhn
+ creditcard: function(value, element) {
+ if ( this.optional(element) )
+ return "dependency-mismatch";
+ // accept only digits and dashes
+ if (/[^0-9-]+/.test(value))
+ return false;
+ var nCheck = 0,
+ nDigit = 0,
+ bEven = false;
+
+ value = value.replace(/\D/g, "");
+
+ for (var n = value.length - 1; n >= 0; n--) {
+ var cDigit = value.charAt(n);
+ var nDigit = parseInt(cDigit, 10);
+ if (bEven) {
+ if ((nDigit *= 2) > 9)
+ nDigit -= 9;
+ }
+ nCheck += nDigit;
+ bEven = !bEven;
+ }
+
+ return (nCheck % 10) == 0;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/accept
+ accept: function(value, element, param) {
+ param = typeof param == "string" ? param.replace(/,/g, '|') : "png|jpe?g|gif";
+ return this.optional(element) || value.match(new RegExp(".(" + param + ")$", "i"));
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/equalTo
+ equalTo: function(value, element, param) {
+ // bind to the blur event of the target in order to revalidate whenever the target field is updated
+ // TODO find a way to bind the event just once, avoiding the unbind-rebind overhead
+ var target = $(param).unbind(".validate-equalTo").bind("blur.validate-equalTo", function() {
+ $(element).valid();
+ });
+ return value == target.val();
+ }
+
+ }
+
+});
+
+// deprecated, use $.validator.format instead
+$.format = $.validator.format;
+
+})(jQuery);
+
+// ajax mode: abort
+// usage: $.ajax({ mode: "abort"[, port: "uniqueport"]});
+// if mode:"abort" is used, the previous request on that port (port can be undefined) is aborted via XMLHttpRequest.abort()
+;(function($) {
+ var pendingRequests = {};
+ // Use a prefilter if available (1.5+)
+ if ( $.ajaxPrefilter ) {
+ $.ajaxPrefilter(function(settings, _, xhr) {
+ var port = settings.port;
+ if (settings.mode == "abort") {
+ if ( pendingRequests[port] ) {
+ pendingRequests[port].abort();
+ } pendingRequests[port] = xhr;
+ }
+ });
+ } else {
+ // Proxy ajax
+ var ajax = $.ajax;
+ $.ajax = function(settings) {
+ var mode = ( "mode" in settings ? settings : $.ajaxSettings ).mode,
+ port = ( "port" in settings ? settings : $.ajaxSettings ).port;
+ if (mode == "abort") {
+ if ( pendingRequests[port] ) {
+ pendingRequests[port].abort();
+ }
+
+ return (pendingRequests[port] = ajax.apply(this, arguments));
+ }
+ return ajax.apply(this, arguments);
+ };
+ }
+})(jQuery);
+
+// provides cross-browser focusin and focusout events
+// IE has native support, in other browsers, use event caputuring (neither bubbles)
+
+// provides delegate(type: String, delegate: Selector, handler: Callback) plugin for easier event delegation
+// handler is only called when $(event.target).is(delegate), in the scope of the jquery-object for event.target
+;(function($) {
+ // only implement if not provided by jQuery core (since 1.4)
+ // TODO verify if jQuery 1.4's implementation is compatible with older jQuery special-event APIs
+ if (!jQuery.event.special.focusin && !jQuery.event.special.focusout && document.addEventListener) {
+ $.each({
+ focus: 'focusin',
+ blur: 'focusout'
+ }, function( original, fix ){
+ $.event.special[fix] = {
+ setup:function() {
+ this.addEventListener( original, handler, true );
+ },
+ teardown:function() {
+ this.removeEventListener( original, handler, true );
+ },
+ handler: function(e) {
+ arguments[0] = $.event.fix(e);
+ arguments[0].type = fix;
+ return $.event.handle.apply(this, arguments);
+ }
+ };
+ function handler(e) {
+ e = $.event.fix(e);
+ e.type = fix;
+ return $.event.handle.call(this, e);
+ }
+ });
+ };
+ $.extend($.fn, {
+ validateDelegate: function(delegate, type, handler) {
+ return this.bind(type, function(event) {
+ var target = $(event.target);
+ if (target.is(delegate)) {
+ return handler.apply(target, arguments);
+ }
+ });
+ }
+ });
+})(jQuery);
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.js b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.js
new file mode 100644
index 000000000..d0a9bc973
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.js
@@ -0,0 +1,1245 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*!
+ * jQuery Validation Plugin 1.11.1
+ *
+ * http://bassistance.de/jquery-plugins/jquery-plugin-validation/
+ * http://docs.jquery.com/Plugins/Validation
+ *
+ * Copyright 2013 Jörn Zaefferer
+ * Released under the MIT license:
+ * http://www.opensource.org/licenses/mit-license.php
+ */
+
+(function($) {
+
+$.extend($.fn, {
+ // http://docs.jquery.com/Plugins/Validation/validate
+ validate: function( options ) {
+
+ // if nothing is selected, return nothing; can't chain anyway
+ if ( !this.length ) {
+ if ( options && options.debug && window.console ) {
+ console.warn( "Nothing selected, can't validate, returning nothing." );
+ }
+ return;
+ }
+
+ // check if a validator for this form was already created
+ var validator = $.data( this[0], "validator" );
+ if ( validator ) {
+ return validator;
+ }
+
+ // Add novalidate tag if HTML5.
+ this.attr( "novalidate", "novalidate" );
+
+ validator = new $.validator( options, this[0] );
+ $.data( this[0], "validator", validator );
+
+ if ( validator.settings.onsubmit ) {
+
+ this.validateDelegate( ":submit", "click", function( event ) {
+ if ( validator.settings.submitHandler ) {
+ validator.submitButton = event.target;
+ }
+ // allow suppressing validation by adding a cancel class to the submit button
+ if ( $(event.target).hasClass("cancel") ) {
+ validator.cancelSubmit = true;
+ }
+
+ // allow suppressing validation by adding the html5 formnovalidate attribute to the submit button
+ if ( $(event.target).attr("formnovalidate") !== undefined ) {
+ validator.cancelSubmit = true;
+ }
+ });
+
+ // validate the form on submit
+ this.submit( function( event ) {
+ if ( validator.settings.debug ) {
+ // prevent form submit to be able to see console output
+ event.preventDefault();
+ }
+ function handle() {
+ var hidden;
+ if ( validator.settings.submitHandler ) {
+ if ( validator.submitButton ) {
+ // insert a hidden input as a replacement for the missing submit button
+ hidden = $("
").attr("name", validator.submitButton.name).val( $(validator.submitButton).val() ).appendTo(validator.currentForm);
+ }
+ validator.settings.submitHandler.call( validator, validator.currentForm, event );
+ if ( validator.submitButton ) {
+ // and clean up afterwards; thanks to no-block-scope, hidden can be referenced
+ hidden.remove();
+ }
+ return false;
+ }
+ return true;
+ }
+
+ // prevent submit for invalid forms or custom submit handlers
+ if ( validator.cancelSubmit ) {
+ validator.cancelSubmit = false;
+ return handle();
+ }
+ if ( validator.form() ) {
+ if ( validator.pendingRequest ) {
+ validator.formSubmitted = true;
+ return false;
+ }
+ return handle();
+ } else {
+ validator.focusInvalid();
+ return false;
+ }
+ });
+ }
+
+ return validator;
+ },
+ // http://docs.jquery.com/Plugins/Validation/valid
+ valid: function() {
+ if ( $(this[0]).is("form")) {
+ return this.validate().form();
+ } else {
+ var valid = true;
+ var validator = $(this[0].form).validate();
+ this.each(function() {
+ valid = valid && validator.element(this);
+ });
+ return valid;
+ }
+ },
+ // attributes: space seperated list of attributes to retrieve and remove
+ removeAttrs: function( attributes ) {
+ var result = {},
+ $element = this;
+ $.each(attributes.split(/\s/), function( index, value ) {
+ result[value] = $element.attr(value);
+ $element.removeAttr(value);
+ });
+ return result;
+ },
+ // http://docs.jquery.com/Plugins/Validation/rules
+ rules: function( command, argument ) {
+ var element = this[0];
+
+ if ( command ) {
+ var settings = $.data(element.form, "validator").settings;
+ var staticRules = settings.rules;
+ var existingRules = $.validator.staticRules(element);
+ switch(command) {
+ case "add":
+ $.extend(existingRules, $.validator.normalizeRule(argument));
+ // remove messages from rules, but allow them to be set separetely
+ delete existingRules.messages;
+ staticRules[element.name] = existingRules;
+ if ( argument.messages ) {
+ settings.messages[element.name] = $.extend( settings.messages[element.name], argument.messages );
+ }
+ break;
+ case "remove":
+ if ( !argument ) {
+ delete staticRules[element.name];
+ return existingRules;
+ }
+ var filtered = {};
+ $.each(argument.split(/\s/), function( index, method ) {
+ filtered[method] = existingRules[method];
+ delete existingRules[method];
+ });
+ return filtered;
+ }
+ }
+
+ var data = $.validator.normalizeRules(
+ $.extend(
+ {},
+ $.validator.classRules(element),
+ $.validator.attributeRules(element),
+ $.validator.dataRules(element),
+ $.validator.staticRules(element)
+ ), element);
+
+ // make sure required is at front
+ if ( data.required ) {
+ var param = data.required;
+ delete data.required;
+ data = $.extend({required: param}, data);
+ }
+
+ return data;
+ }
+});
+
+// Custom selectors
+$.extend($.expr[":"], {
+ // http://docs.jquery.com/Plugins/Validation/blank
+ blank: function( a ) { return !$.trim("" + $(a).val()); },
+ // http://docs.jquery.com/Plugins/Validation/filled
+ filled: function( a ) { return !!$.trim("" + $(a).val()); },
+ // http://docs.jquery.com/Plugins/Validation/unchecked
+ unchecked: function( a ) { return !$(a).prop("checked"); }
+});
+
+// constructor for validator
+$.validator = function( options, form ) {
+ this.settings = $.extend( true, {}, $.validator.defaults, options );
+ this.currentForm = form;
+ this.init();
+};
+
+$.validator.format = function( source, params ) {
+ if ( arguments.length === 1 ) {
+ return function() {
+ var args = $.makeArray(arguments);
+ args.unshift(source);
+ return $.validator.format.apply( this, args );
+ };
+ }
+ if ( arguments.length > 2 && params.constructor !== Array ) {
+ params = $.makeArray(arguments).slice(1);
+ }
+ if ( params.constructor !== Array ) {
+ params = [ params ];
+ }
+ $.each(params, function( i, n ) {
+ source = source.replace( new RegExp("\\{" + i + "\\}", "g"), function() {
+ return n;
+ });
+ });
+ return source;
+};
+
+$.extend($.validator, {
+
+ defaults: {
+ messages: {},
+ groups: {},
+ rules: {},
+ errorClass: "error",
+ validClass: "valid",
+ errorElement: "label",
+ focusInvalid: true,
+ errorContainer: $([]),
+ errorLabelContainer: $([]),
+ onsubmit: true,
+ ignore: ":hidden",
+ ignoreTitle: false,
+ onfocusin: function( element, event ) {
+ this.lastActive = element;
+
+ // hide error label and remove error class on focus if enabled
+ if ( this.settings.focusCleanup && !this.blockFocusCleanup ) {
+ if ( this.settings.unhighlight ) {
+ this.settings.unhighlight.call( this, element, this.settings.errorClass, this.settings.validClass );
+ }
+ this.addWrapper(this.errorsFor(element)).hide();
+ }
+ },
+ onfocusout: function( element, event ) {
+ if ( !this.checkable(element) && (element.name in this.submitted || !this.optional(element)) ) {
+ this.element(element);
+ }
+ },
+ onkeyup: function( element, event ) {
+ if ( event.which === 9 && this.elementValue(element) === "" ) {
+ return;
+ } else if ( element.name in this.submitted || element === this.lastElement ) {
+ this.element(element);
+ }
+ },
+ onclick: function( element, event ) {
+ // click on selects, radiobuttons and checkboxes
+ if ( element.name in this.submitted ) {
+ this.element(element);
+ }
+ // or option elements, check parent select in that case
+ else if ( element.parentNode.name in this.submitted ) {
+ this.element(element.parentNode);
+ }
+ },
+ highlight: function( element, errorClass, validClass ) {
+ if ( element.type === "radio" ) {
+ this.findByName(element.name).addClass(errorClass).removeClass(validClass);
+ } else {
+ $(element).addClass(errorClass).removeClass(validClass);
+ }
+ },
+ unhighlight: function( element, errorClass, validClass ) {
+ if ( element.type === "radio" ) {
+ this.findByName(element.name).removeClass(errorClass).addClass(validClass);
+ } else {
+ $(element).removeClass(errorClass).addClass(validClass);
+ }
+ }
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/setDefaults
+ setDefaults: function( settings ) {
+ $.extend( $.validator.defaults, settings );
+ },
+
+ messages: {
+ required: "This field is required.",
+ remote: "Please fix this field.",
+ email: "Please enter a valid email address.",
+ url: "Please enter a valid URL.",
+ date: "Please enter a valid date.",
+ dateISO: "Please enter a valid date (ISO).",
+ number: "Please enter a valid number.",
+ digits: "Please enter only digits.",
+ creditcard: "Please enter a valid credit card number.",
+ equalTo: "Please enter the same value again.",
+ maxlength: $.validator.format("Please enter no more than {0} characters."),
+ minlength: $.validator.format("Please enter at least {0} characters."),
+ rangelength: $.validator.format("Please enter a value between {0} and {1} characters long."),
+ range: $.validator.format("Please enter a value between {0} and {1}."),
+ max: $.validator.format("Please enter a value less than or equal to {0}."),
+ min: $.validator.format("Please enter a value greater than or equal to {0}.")
+ },
+
+ autoCreateRanges: false,
+
+ prototype: {
+
+ init: function() {
+ this.labelContainer = $(this.settings.errorLabelContainer);
+ this.errorContext = this.labelContainer.length && this.labelContainer || $(this.currentForm);
+ this.containers = $(this.settings.errorContainer).add( this.settings.errorLabelContainer );
+ this.submitted = {};
+ this.valueCache = {};
+ this.pendingRequest = 0;
+ this.pending = {};
+ this.invalid = {};
+ this.reset();
+
+ var groups = (this.groups = {});
+ $.each(this.settings.groups, function( key, value ) {
+ if ( typeof value === "string" ) {
+ value = value.split(/\s/);
+ }
+ $.each(value, function( index, name ) {
+ groups[name] = key;
+ });
+ });
+ var rules = this.settings.rules;
+ $.each(rules, function( key, value ) {
+ rules[key] = $.validator.normalizeRule(value);
+ });
+
+ function delegate(event) {
+ var validator = $.data(this[0].form, "validator"),
+ eventType = "on" + event.type.replace(/^validate/, "");
+ if ( validator.settings[eventType] ) {
+ validator.settings[eventType].call(validator, this[0], event);
+ }
+ }
+ $(this.currentForm)
+ .validateDelegate(":text, [type='password'], [type='file'], select, textarea, " +
+ "[type='number'], [type='search'] ,[type='tel'], [type='url'], " +
+ "[type='email'], [type='datetime'], [type='date'], [type='month'], " +
+ "[type='week'], [type='time'], [type='datetime-local'], " +
+ "[type='range'], [type='color'] ",
+ "focusin focusout keyup", delegate)
+ .validateDelegate("[type='radio'], [type='checkbox'], select, option", "click", delegate);
+
+ if ( this.settings.invalidHandler ) {
+ $(this.currentForm).bind("invalid-form.validate", this.settings.invalidHandler);
+ }
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/form
+ form: function() {
+ this.checkForm();
+ $.extend(this.submitted, this.errorMap);
+ this.invalid = $.extend({}, this.errorMap);
+ if ( !this.valid() ) {
+ $(this.currentForm).triggerHandler("invalid-form", [this]);
+ }
+ this.showErrors();
+ return this.valid();
+ },
+
+ checkForm: function() {
+ this.prepareForm();
+ for ( var i = 0, elements = (this.currentElements = this.elements()); elements[i]; i++ ) {
+ this.check( elements[i] );
+ }
+ return this.valid();
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/element
+ element: function( element ) {
+ element = this.validationTargetFor( this.clean( element ) );
+ this.lastElement = element;
+ this.prepareElement( element );
+ this.currentElements = $(element);
+ var result = this.check( element ) !== false;
+ if ( result ) {
+ delete this.invalid[element.name];
+ } else {
+ this.invalid[element.name] = true;
+ }
+ if ( !this.numberOfInvalids() ) {
+ // Hide error containers on last error
+ this.toHide = this.toHide.add( this.containers );
+ }
+ this.showErrors();
+ return result;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/showErrors
+ showErrors: function( errors ) {
+ if ( errors ) {
+ // add items to error list and map
+ $.extend( this.errorMap, errors );
+ this.errorList = [];
+ for ( var name in errors ) {
+ this.errorList.push({
+ message: errors[name],
+ element: this.findByName(name)[0]
+ });
+ }
+ // remove items from success list
+ this.successList = $.grep( this.successList, function( element ) {
+ return !(element.name in errors);
+ });
+ }
+ if ( this.settings.showErrors ) {
+ this.settings.showErrors.call( this, this.errorMap, this.errorList );
+ } else {
+ this.defaultShowErrors();
+ }
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/resetForm
+ resetForm: function() {
+ if ( $.fn.resetForm ) {
+ $(this.currentForm).resetForm();
+ }
+ this.submitted = {};
+ this.lastElement = null;
+ this.prepareForm();
+ this.hideErrors();
+ this.elements().removeClass( this.settings.errorClass ).removeData( "previousValue" );
+ },
+
+ numberOfInvalids: function() {
+ return this.objectLength(this.invalid);
+ },
+
+ objectLength: function( obj ) {
+ var count = 0;
+ for ( var i in obj ) {
+ count++;
+ }
+ return count;
+ },
+
+ hideErrors: function() {
+ this.addWrapper( this.toHide ).hide();
+ },
+
+ valid: function() {
+ return this.size() === 0;
+ },
+
+ size: function() {
+ return this.errorList.length;
+ },
+
+ focusInvalid: function() {
+ if ( this.settings.focusInvalid ) {
+ try {
+ $(this.findLastActive() || this.errorList.length && this.errorList[0].element || [])
+ .filter(":visible")
+ .focus()
+ // manually trigger focusin event; without it, focusin handler isn't called, findLastActive won't have anything to find
+ .trigger("focusin");
+ } catch(e) {
+ // ignore IE throwing errors when focusing hidden elements
+ }
+ }
+ },
+
+ findLastActive: function() {
+ var lastActive = this.lastActive;
+ return lastActive && $.grep(this.errorList, function( n ) {
+ return n.element.name === lastActive.name;
+ }).length === 1 && lastActive;
+ },
+
+ elements: function() {
+ var validator = this,
+ rulesCache = {};
+
+ // select all valid inputs inside the form (no submit or reset buttons)
+ return $(this.currentForm)
+ .find("input, select, textarea")
+ .not(":submit, :reset, :image, [disabled]")
+ .not( this.settings.ignore )
+ .filter(function() {
+ if ( !this.name && validator.settings.debug && window.console ) {
+ console.error( "%o has no name assigned", this);
+ }
+
+ // select only the first element for each name, and only those with rules specified
+ if ( this.name in rulesCache || !validator.objectLength($(this).rules()) ) {
+ return false;
+ }
+
+ rulesCache[this.name] = true;
+ return true;
+ });
+ },
+
+ clean: function( selector ) {
+ return $(selector)[0];
+ },
+
+ errors: function() {
+ var errorClass = this.settings.errorClass.replace(" ", ".");
+ return $(this.settings.errorElement + "." + errorClass, this.errorContext);
+ },
+
+ reset: function() {
+ this.successList = [];
+ this.errorList = [];
+ this.errorMap = {};
+ this.toShow = $([]);
+ this.toHide = $([]);
+ this.currentElements = $([]);
+ },
+
+ prepareForm: function() {
+ this.reset();
+ this.toHide = this.errors().add( this.containers );
+ },
+
+ prepareElement: function( element ) {
+ this.reset();
+ this.toHide = this.errorsFor(element);
+ },
+
+ elementValue: function( element ) {
+ var type = $(element).attr("type"),
+ val = $(element).val();
+
+ if ( type === "radio" || type === "checkbox" ) {
+ return $("input[name='" + $(element).attr("name") + "']:checked").val();
+ }
+
+ if ( typeof val === "string" ) {
+ return val.replace(/\r/g, "");
+ }
+ return val;
+ },
+
+ check: function( element ) {
+ element = this.validationTargetFor( this.clean( element ) );
+
+ var rules = $(element).rules();
+ var dependencyMismatch = false;
+ var val = this.elementValue(element);
+ var result;
+
+ for (var method in rules ) {
+ var rule = { method: method, parameters: rules[method] };
+ try {
+
+ result = $.validator.methods[method].call( this, val, element, rule.parameters );
+
+ // if a method indicates that the field is optional and therefore valid,
+ // don't mark it as valid when there are no other rules
+ if ( result === "dependency-mismatch" ) {
+ dependencyMismatch = true;
+ continue;
+ }
+ dependencyMismatch = false;
+
+ if ( result === "pending" ) {
+ this.toHide = this.toHide.not( this.errorsFor(element) );
+ return;
+ }
+
+ if ( !result ) {
+ this.formatAndAdd( element, rule );
+ return false;
+ }
+ } catch(e) {
+ if ( this.settings.debug && window.console ) {
+ console.log( "Exception occurred when checking element " + element.id + ", check the '" + rule.method + "' method.", e );
+ }
+ throw e;
+ }
+ }
+ if ( dependencyMismatch ) {
+ return;
+ }
+ if ( this.objectLength(rules) ) {
+ this.successList.push(element);
+ }
+ return true;
+ },
+
+ // return the custom message for the given element and validation method
+ // specified in the element's HTML5 data attribute
+ customDataMessage: function( element, method ) {
+ return $(element).data("msg-" + method.toLowerCase()) || (element.attributes && $(element).attr("data-msg-" + method.toLowerCase()));
+ },
+
+ // return the custom message for the given element name and validation method
+ customMessage: function( name, method ) {
+ var m = this.settings.messages[name];
+ return m && (m.constructor === String ? m : m[method]);
+ },
+
+ // return the first defined argument, allowing empty strings
+ findDefined: function() {
+ for(var i = 0; i < arguments.length; i++) {
+ if ( arguments[i] !== undefined ) {
+ return arguments[i];
+ }
+ }
+ return undefined;
+ },
+
+ defaultMessage: function( element, method ) {
+ return this.findDefined(
+ this.customMessage( element.name, method ),
+ this.customDataMessage( element, method ),
+ // title is never undefined, so handle empty string as undefined
+ !this.settings.ignoreTitle && element.title || undefined,
+ $.validator.messages[method],
+ "
Warning: No message defined for " + element.name + ""
+ );
+ },
+
+ formatAndAdd: function( element, rule ) {
+ var message = this.defaultMessage( element, rule.method ),
+ theregex = /\$?\{(\d+)\}/g;
+ if ( typeof message === "function" ) {
+ message = message.call(this, rule.parameters, element);
+ } else if (theregex.test(message)) {
+ message = $.validator.format(message.replace(theregex, "{$1}"), rule.parameters);
+ }
+ this.errorList.push({
+ message: message,
+ element: element
+ });
+
+ this.errorMap[element.name] = message;
+ this.submitted[element.name] = message;
+ },
+
+ addWrapper: function( toToggle ) {
+ if ( this.settings.wrapper ) {
+ toToggle = toToggle.add( toToggle.parent( this.settings.wrapper ) );
+ }
+ return toToggle;
+ },
+
+ defaultShowErrors: function() {
+ var i, elements;
+ for ( i = 0; this.errorList[i]; i++ ) {
+ var error = this.errorList[i];
+ if ( this.settings.highlight ) {
+ this.settings.highlight.call( this, error.element, this.settings.errorClass, this.settings.validClass );
+ }
+ this.showLabel( error.element, error.message );
+ }
+ if ( this.errorList.length ) {
+ this.toShow = this.toShow.add( this.containers );
+ }
+ if ( this.settings.success ) {
+ for ( i = 0; this.successList[i]; i++ ) {
+ this.showLabel( this.successList[i] );
+ }
+ }
+ if ( this.settings.unhighlight ) {
+ for ( i = 0, elements = this.validElements(); elements[i]; i++ ) {
+ this.settings.unhighlight.call( this, elements[i], this.settings.errorClass, this.settings.validClass );
+ }
+ }
+ this.toHide = this.toHide.not( this.toShow );
+ this.hideErrors();
+ this.addWrapper( this.toShow ).show();
+ },
+
+ validElements: function() {
+ return this.currentElements.not(this.invalidElements());
+ },
+
+ invalidElements: function() {
+ return $(this.errorList).map(function() {
+ return this.element;
+ });
+ },
+
+ showLabel: function( element, message ) {
+ var label = this.errorsFor( element );
+ if ( label.length ) {
+ // refresh error/success class
+ label.removeClass( this.settings.validClass ).addClass( this.settings.errorClass );
+ // replace message on existing label
+ label.html(message);
+ } else {
+ // create label
+ label = $("<" + this.settings.errorElement + ">")
+ .attr("for", this.idOrName(element))
+ .addClass(this.settings.errorClass)
+ .html(message || "");
+ if ( this.settings.wrapper ) {
+ // make sure the element is visible, even in IE
+ // actually showing the wrapped element is handled elsewhere
+ label = label.hide().show().wrap("<" + this.settings.wrapper + "/>").parent();
+ }
+ if ( !this.labelContainer.append(label).length ) {
+ if ( this.settings.errorPlacement ) {
+ this.settings.errorPlacement(label, $(element) );
+ } else {
+ label.insertAfter(element);
+ }
+ }
+ }
+ if ( !message && this.settings.success ) {
+ label.text("");
+ if ( typeof this.settings.success === "string" ) {
+ label.addClass( this.settings.success );
+ } else {
+ this.settings.success( label, element );
+ }
+ }
+ this.toShow = this.toShow.add(label);
+ },
+
+ errorsFor: function( element ) {
+ var name = this.idOrName(element);
+ return this.errors().filter(function() {
+ return $(this).attr("for") === name;
+ });
+ },
+
+ idOrName: function( element ) {
+ return this.groups[element.name] || (this.checkable(element) ? element.name : element.id || element.name);
+ },
+
+ validationTargetFor: function( element ) {
+ // if radio/checkbox, validate first element in group instead
+ if ( this.checkable(element) ) {
+ element = this.findByName( element.name ).not(this.settings.ignore)[0];
+ }
+ return element;
+ },
+
+ checkable: function( element ) {
+ return (/radio|checkbox/i).test(element.type);
+ },
+
+ findByName: function( name ) {
+ return $(this.currentForm).find("[name='" + name + "']");
+ },
+
+ getLength: function( value, element ) {
+ switch( element.nodeName.toLowerCase() ) {
+ case "select":
+ return $("option:selected", element).length;
+ case "input":
+ if ( this.checkable( element) ) {
+ return this.findByName(element.name).filter(":checked").length;
+ }
+ }
+ return value.length;
+ },
+
+ depend: function( param, element ) {
+ return this.dependTypes[typeof param] ? this.dependTypes[typeof param](param, element) : true;
+ },
+
+ dependTypes: {
+ "boolean": function( param, element ) {
+ return param;
+ },
+ "string": function( param, element ) {
+ return !!$(param, element.form).length;
+ },
+ "function": function( param, element ) {
+ return param(element);
+ }
+ },
+
+ optional: function( element ) {
+ var val = this.elementValue(element);
+ return !$.validator.methods.required.call(this, val, element) && "dependency-mismatch";
+ },
+
+ startRequest: function( element ) {
+ if ( !this.pending[element.name] ) {
+ this.pendingRequest++;
+ this.pending[element.name] = true;
+ }
+ },
+
+ stopRequest: function( element, valid ) {
+ this.pendingRequest--;
+ // sometimes synchronization fails, make sure pendingRequest is never < 0
+ if ( this.pendingRequest < 0 ) {
+ this.pendingRequest = 0;
+ }
+ delete this.pending[element.name];
+ if ( valid && this.pendingRequest === 0 && this.formSubmitted && this.form() ) {
+ $(this.currentForm).submit();
+ this.formSubmitted = false;
+ } else if (!valid && this.pendingRequest === 0 && this.formSubmitted) {
+ $(this.currentForm).triggerHandler("invalid-form", [this]);
+ this.formSubmitted = false;
+ }
+ },
+
+ previousValue: function( element ) {
+ return $.data(element, "previousValue") || $.data(element, "previousValue", {
+ old: null,
+ valid: true,
+ message: this.defaultMessage( element, "remote" )
+ });
+ }
+
+ },
+
+ classRuleSettings: {
+ required: {required: true},
+ email: {email: true},
+ url: {url: true},
+ date: {date: true},
+ dateISO: {dateISO: true},
+ number: {number: true},
+ digits: {digits: true},
+ creditcard: {creditcard: true}
+ },
+
+ addClassRules: function( className, rules ) {
+ if ( className.constructor === String ) {
+ this.classRuleSettings[className] = rules;
+ } else {
+ $.extend(this.classRuleSettings, className);
+ }
+ },
+
+ classRules: function( element ) {
+ var rules = {};
+ var classes = $(element).attr("class");
+ if ( classes ) {
+ $.each(classes.split(" "), function() {
+ if ( this in $.validator.classRuleSettings ) {
+ $.extend(rules, $.validator.classRuleSettings[this]);
+ }
+ });
+ }
+ return rules;
+ },
+
+ attributeRules: function( element ) {
+ var rules = {};
+ var $element = $(element);
+ var type = $element[0].getAttribute("type");
+
+ for (var method in $.validator.methods) {
+ var value;
+
+ // support for
in both html5 and older browsers
+ if ( method === "required" ) {
+ value = $element.get(0).getAttribute(method);
+ // Some browsers return an empty string for the required attribute
+ // and non-HTML5 browsers might have required="" markup
+ if ( value === "" ) {
+ value = true;
+ }
+ // force non-HTML5 browsers to return bool
+ value = !!value;
+ } else {
+ value = $element.attr(method);
+ }
+
+ // convert the value to a number for number inputs, and for text for backwards compability
+ // allows type="date" and others to be compared as strings
+ if ( /min|max/.test( method ) && ( type === null || /number|range|text/.test( type ) ) ) {
+ value = Number(value);
+ }
+
+ if ( value ) {
+ rules[method] = value;
+ } else if ( type === method && type !== 'range' ) {
+ // exception: the jquery validate 'range' method
+ // does not test for the html5 'range' type
+ rules[method] = true;
+ }
+ }
+
+ // maxlength may be returned as -1, 2147483647 (IE) and 524288 (safari) for text inputs
+ if ( rules.maxlength && /-1|2147483647|524288/.test(rules.maxlength) ) {
+ delete rules.maxlength;
+ }
+
+ return rules;
+ },
+
+ dataRules: function( element ) {
+ var method, value,
+ rules = {}, $element = $(element);
+ for (method in $.validator.methods) {
+ value = $element.data("rule-" + method.toLowerCase());
+ if ( value !== undefined ) {
+ rules[method] = value;
+ }
+ }
+ return rules;
+ },
+
+ staticRules: function( element ) {
+ var rules = {};
+ var validator = $.data(element.form, "validator");
+ if ( validator.settings.rules ) {
+ rules = $.validator.normalizeRule(validator.settings.rules[element.name]) || {};
+ }
+ return rules;
+ },
+
+ normalizeRules: function( rules, element ) {
+ // handle dependency check
+ $.each(rules, function( prop, val ) {
+ // ignore rule when param is explicitly false, eg. required:false
+ if ( val === false ) {
+ delete rules[prop];
+ return;
+ }
+ if ( val.param || val.depends ) {
+ var keepRule = true;
+ switch (typeof val.depends) {
+ case "string":
+ keepRule = !!$(val.depends, element.form).length;
+ break;
+ case "function":
+ keepRule = val.depends.call(element, element);
+ break;
+ }
+ if ( keepRule ) {
+ rules[prop] = val.param !== undefined ? val.param : true;
+ } else {
+ delete rules[prop];
+ }
+ }
+ });
+
+ // evaluate parameters
+ $.each(rules, function( rule, parameter ) {
+ rules[rule] = $.isFunction(parameter) ? parameter(element) : parameter;
+ });
+
+ // clean number parameters
+ $.each(['minlength', 'maxlength'], function() {
+ if ( rules[this] ) {
+ rules[this] = Number(rules[this]);
+ }
+ });
+ $.each(['rangelength', 'range'], function() {
+ var parts;
+ if ( rules[this] ) {
+ if ( $.isArray(rules[this]) ) {
+ rules[this] = [Number(rules[this][0]), Number(rules[this][1])];
+ } else if ( typeof rules[this] === "string" ) {
+ parts = rules[this].split(/[\s,]+/);
+ rules[this] = [Number(parts[0]), Number(parts[1])];
+ }
+ }
+ });
+
+ if ( $.validator.autoCreateRanges ) {
+ // auto-create ranges
+ if ( rules.min && rules.max ) {
+ rules.range = [rules.min, rules.max];
+ delete rules.min;
+ delete rules.max;
+ }
+ if ( rules.minlength && rules.maxlength ) {
+ rules.rangelength = [rules.minlength, rules.maxlength];
+ delete rules.minlength;
+ delete rules.maxlength;
+ }
+ }
+
+ return rules;
+ },
+
+ // Converts a simple string to a {string: true} rule, e.g., "required" to {required:true}
+ normalizeRule: function( data ) {
+ if ( typeof data === "string" ) {
+ var transformed = {};
+ $.each(data.split(/\s/), function() {
+ transformed[this] = true;
+ });
+ data = transformed;
+ }
+ return data;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Validator/addMethod
+ addMethod: function( name, method, message ) {
+ $.validator.methods[name] = method;
+ $.validator.messages[name] = message !== undefined ? message : $.validator.messages[name];
+ if ( method.length < 3 ) {
+ $.validator.addClassRules(name, $.validator.normalizeRule(name));
+ }
+ },
+
+ methods: {
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/required
+ required: function( value, element, param ) {
+ // check if dependency is met
+ if ( !this.depend(param, element) ) {
+ return "dependency-mismatch";
+ }
+ if ( element.nodeName.toLowerCase() === "select" ) {
+ // could be an array for select-multiple or a string, both are fine this way
+ var val = $(element).val();
+ return val && val.length > 0;
+ }
+ if ( this.checkable(element) ) {
+ return this.getLength(value, element) > 0;
+ }
+ return $.trim(value).length > 0;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/email
+ email: function( value, element ) {
+ // contributed by Scott Gonzalez: http://projects.scottsplayground.com/email_address_validation/
+ return this.optional(element) || /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))$/i.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/url
+ url: function( value, element ) {
+ // contributed by Scott Gonzalez: http://projects.scottsplayground.com/iri/
+ return this.optional(element) || /^(https?|s?ftp):\/\/(((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(#((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/i.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/date
+ date: function( value, element ) {
+ return this.optional(element) || !/Invalid|NaN/.test(new Date(value).toString());
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/dateISO
+ dateISO: function( value, element ) {
+ return this.optional(element) || /^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/number
+ number: function( value, element ) {
+ return this.optional(element) || /^-?(?:\d+|\d{1,3}(?:,\d{3})+)?(?:\.\d+)?$/.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/digits
+ digits: function( value, element ) {
+ return this.optional(element) || /^\d+$/.test(value);
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/creditcard
+ // based on http://en.wikipedia.org/wiki/Luhn
+ creditcard: function( value, element ) {
+ if ( this.optional(element) ) {
+ return "dependency-mismatch";
+ }
+ // accept only spaces, digits and dashes
+ if ( /[^0-9 \-]+/.test(value) ) {
+ return false;
+ }
+ var nCheck = 0,
+ nDigit = 0,
+ bEven = false;
+
+ value = value.replace(/\D/g, "");
+
+ for (var n = value.length - 1; n >= 0; n--) {
+ var cDigit = value.charAt(n);
+ nDigit = parseInt(cDigit, 10);
+ if ( bEven ) {
+ if ( (nDigit *= 2) > 9 ) {
+ nDigit -= 9;
+ }
+ }
+ nCheck += nDigit;
+ bEven = !bEven;
+ }
+
+ return (nCheck % 10) === 0;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/minlength
+ minlength: function( value, element, param ) {
+ var length = $.isArray( value ) ? value.length : this.getLength($.trim(value), element);
+ return this.optional(element) || length >= param;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/maxlength
+ maxlength: function( value, element, param ) {
+ var length = $.isArray( value ) ? value.length : this.getLength($.trim(value), element);
+ return this.optional(element) || length <= param;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/rangelength
+ rangelength: function( value, element, param ) {
+ var length = $.isArray( value ) ? value.length : this.getLength($.trim(value), element);
+ return this.optional(element) || ( length >= param[0] && length <= param[1] );
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/min
+ min: function( value, element, param ) {
+ return this.optional(element) || value >= param;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/max
+ max: function( value, element, param ) {
+ return this.optional(element) || value <= param;
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/range
+ range: function( value, element, param ) {
+ return this.optional(element) || ( value >= param[0] && value <= param[1] );
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/equalTo
+ equalTo: function( value, element, param ) {
+ // bind to the blur event of the target in order to revalidate whenever the target field is updated
+ // TODO find a way to bind the event just once, avoiding the unbind-rebind overhead
+ var target = $(param);
+ if ( this.settings.onfocusout ) {
+ target.unbind(".validate-equalTo").bind("blur.validate-equalTo", function() {
+ $(element).valid();
+ });
+ }
+ return value === target.val();
+ },
+
+ // http://docs.jquery.com/Plugins/Validation/Methods/remote
+ remote: function( value, element, param ) {
+ if ( this.optional(element) ) {
+ return "dependency-mismatch";
+ }
+
+ var previous = this.previousValue(element);
+ if (!this.settings.messages[element.name] ) {
+ this.settings.messages[element.name] = {};
+ }
+ previous.originalMessage = this.settings.messages[element.name].remote;
+ this.settings.messages[element.name].remote = previous.message;
+
+ param = typeof param === "string" && {url:param} || param;
+
+ if ( previous.old === value ) {
+ return previous.valid;
+ }
+
+ previous.old = value;
+ var validator = this;
+ this.startRequest(element);
+ var data = {};
+ data[element.name] = value;
+ $.ajax($.extend(true, {
+ url: param,
+ mode: "abort",
+ port: "validate" + element.name,
+ dataType: "json",
+ data: data,
+ success: function( response ) {
+ validator.settings.messages[element.name].remote = previous.originalMessage;
+ var valid = response === true || response === "true";
+ if ( valid ) {
+ var submitted = validator.formSubmitted;
+ validator.prepareElement(element);
+ validator.formSubmitted = submitted;
+ validator.successList.push(element);
+ delete validator.invalid[element.name];
+ validator.showErrors();
+ } else {
+ var errors = {};
+ var message = response || validator.defaultMessage( element, "remote" );
+ errors[element.name] = previous.message = $.isFunction(message) ? message(value) : message;
+ validator.invalid[element.name] = true;
+ validator.showErrors(errors);
+ }
+ previous.valid = valid;
+ validator.stopRequest(element, valid);
+ }
+ }, param));
+ return "pending";
+ }
+
+ }
+
+});
+
+// deprecated, use $.validator.format instead
+$.format = $.validator.format;
+
+}(jQuery));
+
+// ajax mode: abort
+// usage: $.ajax({ mode: "abort"[, port: "uniqueport"]});
+// if mode:"abort" is used, the previous request on that port (port can be undefined) is aborted via XMLHttpRequest.abort()
+(function($) {
+ var pendingRequests = {};
+ // Use a prefilter if available (1.5+)
+ if ( $.ajaxPrefilter ) {
+ $.ajaxPrefilter(function( settings, _, xhr ) {
+ var port = settings.port;
+ if ( settings.mode === "abort" ) {
+ if ( pendingRequests[port] ) {
+ pendingRequests[port].abort();
+ }
+ pendingRequests[port] = xhr;
+ }
+ });
+ } else {
+ // Proxy ajax
+ var ajax = $.ajax;
+ $.ajax = function( settings ) {
+ var mode = ( "mode" in settings ? settings : $.ajaxSettings ).mode,
+ port = ( "port" in settings ? settings : $.ajaxSettings ).port;
+ if ( mode === "abort" ) {
+ if ( pendingRequests[port] ) {
+ pendingRequests[port].abort();
+ }
+ pendingRequests[port] = ajax.apply(this, arguments);
+ return pendingRequests[port];
+ }
+ return ajax.apply(this, arguments);
+ };
+ }
+}(jQuery));
+
+// provides delegate(type: String, delegate: Selector, handler: Callback) plugin for easier event delegation
+// handler is only called when $(event.target).is(delegate), in the scope of the jquery-object for event.target
+(function($) {
+ $.extend($.fn, {
+ validateDelegate: function( delegate, type, handler ) {
+ return this.bind(type, function( event ) {
+ var target = $(event.target);
+ if ( target.is(delegate) ) {
+ return handler.apply(target, arguments);
+ }
+ });
+ }
+ });
+}(jQuery));
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.min.js b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.min.js
new file mode 100644
index 000000000..3efb64822
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.min.js
@@ -0,0 +1,16 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*! jQuery Validation Plugin - v1.11.1 - 3/22/2013\n* https://github.com/jzaefferer/jquery-validation
+* Copyright (c) 2013 Jörn Zaefferer; Licensed MIT */(function(t){t.extend(t.fn,{validate:function(e){if(!this.length)return e&&e.debug&&window.console&&console.warn("Nothing selected, can't validate, returning nothing."),void 0;var i=t.data(this[0],"validator");return i?i:(this.attr("novalidate","novalidate"),i=new t.validator(e,this[0]),t.data(this[0],"validator",i),i.settings.onsubmit&&(this.validateDelegate(":submit","click",function(e){i.settings.submitHandler&&(i.submitButton=e.target),t(e.target).hasClass("cancel")&&(i.cancelSubmit=!0),void 0!==t(e.target).attr("formnovalidate")&&(i.cancelSubmit=!0)}),this.submit(function(e){function s(){var s;return i.settings.submitHandler?(i.submitButton&&(s=t("
").attr("name",i.submitButton.name).val(t(i.submitButton).val()).appendTo(i.currentForm)),i.settings.submitHandler.call(i,i.currentForm,e),i.submitButton&&s.remove(),!1):!0}return i.settings.debug&&e.preventDefault(),i.cancelSubmit?(i.cancelSubmit=!1,s()):i.form()?i.pendingRequest?(i.formSubmitted=!0,!1):s():(i.focusInvalid(),!1)})),i)},valid:function(){if(t(this[0]).is("form"))return this.validate().form();var e=!0,i=t(this[0].form).validate();return this.each(function(){e=e&&i.element(this)}),e},removeAttrs:function(e){var i={},s=this;return t.each(e.split(/\s/),function(t,e){i[e]=s.attr(e),s.removeAttr(e)}),i},rules:function(e,i){var s=this[0];if(e){var r=t.data(s.form,"validator").settings,n=r.rules,a=t.validator.staticRules(s);switch(e){case"add":t.extend(a,t.validator.normalizeRule(i)),delete a.messages,n[s.name]=a,i.messages&&(r.messages[s.name]=t.extend(r.messages[s.name],i.messages));break;case"remove":if(!i)return delete n[s.name],a;var u={};return t.each(i.split(/\s/),function(t,e){u[e]=a[e],delete a[e]}),u}}var o=t.validator.normalizeRules(t.extend({},t.validator.classRules(s),t.validator.attributeRules(s),t.validator.dataRules(s),t.validator.staticRules(s)),s);if(o.required){var l=o.required;delete o.required,o=t.extend({required:l},o)}return o}}),t.extend(t.expr[":"],{blank:function(e){return!t.trim(""+t(e).val())},filled:function(e){return!!t.trim(""+t(e).val())},unchecked:function(e){return!t(e).prop("checked")}}),t.validator=function(e,i){this.settings=t.extend(!0,{},t.validator.defaults,e),this.currentForm=i,this.init()},t.validator.format=function(e,i){return 1===arguments.length?function(){var i=t.makeArray(arguments);return i.unshift(e),t.validator.format.apply(this,i)}:(arguments.length>2&&i.constructor!==Array&&(i=t.makeArray(arguments).slice(1)),i.constructor!==Array&&(i=[i]),t.each(i,function(t,i){e=e.replace(RegExp("\\{"+t+"\\}","g"),function(){return i})}),e)},t.extend(t.validator,{defaults:{messages:{},groups:{},rules:{},errorClass:"error",validClass:"valid",errorElement:"label",focusInvalid:!0,errorContainer:t([]),errorLabelContainer:t([]),onsubmit:!0,ignore:":hidden",ignoreTitle:!1,onfocusin:function(t){this.lastActive=t,this.settings.focusCleanup&&!this.blockFocusCleanup&&(this.settings.unhighlight&&this.settings.unhighlight.call(this,t,this.settings.errorClass,this.settings.validClass),this.addWrapper(this.errorsFor(t)).hide())},onfocusout:function(t){this.checkable(t)||!(t.name in this.submitted)&&this.optional(t)||this.element(t)},onkeyup:function(t,e){(9!==e.which||""!==this.elementValue(t))&&(t.name in this.submitted||t===this.lastElement)&&this.element(t)},onclick:function(t){t.name in this.submitted?this.element(t):t.parentNode.name in this.submitted&&this.element(t.parentNode)},highlight:function(e,i,s){"radio"===e.type?this.findByName(e.name).addClass(i).removeClass(s):t(e).addClass(i).removeClass(s)},unhighlight:function(e,i,s){"radio"===e.type?this.findByName(e.name).removeClass(i).addClass(s):t(e).removeClass(i).addClass(s)}},setDefaults:function(e){t.extend(t.validator.defaults,e)},messages:{required:"This field is required.",remote:"Please fix this field.",email:"Please enter a valid email address.",url:"Please enter a valid URL.",date:"Please enter a valid date.",dateISO:"Please enter a valid date (ISO).",number:"Please enter a valid number.",digits:"Please enter only digits.",creditcard:"Please enter a valid credit card number.",equalTo:"Please enter the same value again.",maxlength:t.validator.format("Please enter no more than {0} characters."),minlength:t.validator.format("Please enter at least {0} characters."),rangelength:t.validator.format("Please enter a value between {0} and {1} characters long."),range:t.validator.format("Please enter a value between {0} and {1}."),max:t.validator.format("Please enter a value less than or equal to {0}."),min:t.validator.format("Please enter a value greater than or equal to {0}.")},autoCreateRanges:!1,prototype:{init:function(){function e(e){var i=t.data(this[0].form,"validator"),s="on"+e.type.replace(/^validate/,"");i.settings[s]&&i.settings[s].call(i,this[0],e)}this.labelContainer=t(this.settings.errorLabelContainer),this.errorContext=this.labelContainer.length&&this.labelContainer||t(this.currentForm),this.containers=t(this.settings.errorContainer).add(this.settings.errorLabelContainer),this.submitted={},this.valueCache={},this.pendingRequest=0,this.pending={},this.invalid={},this.reset();var i=this.groups={};t.each(this.settings.groups,function(e,s){"string"==typeof s&&(s=s.split(/\s/)),t.each(s,function(t,s){i[s]=e})});var s=this.settings.rules;t.each(s,function(e,i){s[e]=t.validator.normalizeRule(i)}),t(this.currentForm).validateDelegate(":text, [type='password'], [type='file'], select, textarea, [type='number'], [type='search'] ,[type='tel'], [type='url'], [type='email'], [type='datetime'], [type='date'], [type='month'], [type='week'], [type='time'], [type='datetime-local'], [type='range'], [type='color'] ","focusin focusout keyup",e).validateDelegate("[type='radio'], [type='checkbox'], select, option","click",e),this.settings.invalidHandler&&t(this.currentForm).bind("invalid-form.validate",this.settings.invalidHandler)},form:function(){return this.checkForm(),t.extend(this.submitted,this.errorMap),this.invalid=t.extend({},this.errorMap),this.valid()||t(this.currentForm).triggerHandler("invalid-form",[this]),this.showErrors(),this.valid()},checkForm:function(){this.prepareForm();for(var t=0,e=this.currentElements=this.elements();e[t];t++)this.check(e[t]);return this.valid()},element:function(e){e=this.validationTargetFor(this.clean(e)),this.lastElement=e,this.prepareElement(e),this.currentElements=t(e);var i=this.check(e)!==!1;return i?delete this.invalid[e.name]:this.invalid[e.name]=!0,this.numberOfInvalids()||(this.toHide=this.toHide.add(this.containers)),this.showErrors(),i},showErrors:function(e){if(e){t.extend(this.errorMap,e),this.errorList=[];for(var i in e)this.errorList.push({message:e[i],element:this.findByName(i)[0]});this.successList=t.grep(this.successList,function(t){return!(t.name in e)})}this.settings.showErrors?this.settings.showErrors.call(this,this.errorMap,this.errorList):this.defaultShowErrors()},resetForm:function(){t.fn.resetForm&&t(this.currentForm).resetForm(),this.submitted={},this.lastElement=null,this.prepareForm(),this.hideErrors(),this.elements().removeClass(this.settings.errorClass).removeData("previousValue")},numberOfInvalids:function(){return this.objectLength(this.invalid)},objectLength:function(t){var e=0;for(var i in t)e++;return e},hideErrors:function(){this.addWrapper(this.toHide).hide()},valid:function(){return 0===this.size()},size:function(){return this.errorList.length},focusInvalid:function(){if(this.settings.focusInvalid)try{t(this.findLastActive()||this.errorList.length&&this.errorList[0].element||[]).filter(":visible").focus().trigger("focusin")}catch(e){}},findLastActive:function(){var e=this.lastActive;return e&&1===t.grep(this.errorList,function(t){return t.element.name===e.name}).length&&e},elements:function(){var e=this,i={};return t(this.currentForm).find("input, select, textarea").not(":submit, :reset, :image, [disabled]").not(this.settings.ignore).filter(function(){return!this.name&&e.settings.debug&&window.console&&console.error("%o has no name assigned",this),this.name in i||!e.objectLength(t(this).rules())?!1:(i[this.name]=!0,!0)})},clean:function(e){return t(e)[0]},errors:function(){var e=this.settings.errorClass.replace(" ",".");return t(this.settings.errorElement+"."+e,this.errorContext)},reset:function(){this.successList=[],this.errorList=[],this.errorMap={},this.toShow=t([]),this.toHide=t([]),this.currentElements=t([])},prepareForm:function(){this.reset(),this.toHide=this.errors().add(this.containers)},prepareElement:function(t){this.reset(),this.toHide=this.errorsFor(t)},elementValue:function(e){var i=t(e).attr("type"),s=t(e).val();return"radio"===i||"checkbox"===i?t("input[name='"+t(e).attr("name")+"']:checked").val():"string"==typeof s?s.replace(/\r/g,""):s},check:function(e){e=this.validationTargetFor(this.clean(e));var i,s=t(e).rules(),r=!1,n=this.elementValue(e);for(var a in s){var u={method:a,parameters:s[a]};try{if(i=t.validator.methods[a].call(this,n,e,u.parameters),"dependency-mismatch"===i){r=!0;continue}if(r=!1,"pending"===i)return this.toHide=this.toHide.not(this.errorsFor(e)),void 0;if(!i)return this.formatAndAdd(e,u),!1}catch(o){throw this.settings.debug&&window.console&&console.log("Exception occurred when checking element "+e.id+", check the '"+u.method+"' method.",o),o}}return r?void 0:(this.objectLength(s)&&this.successList.push(e),!0)},customDataMessage:function(e,i){return t(e).data("msg-"+i.toLowerCase())||e.attributes&&t(e).attr("data-msg-"+i.toLowerCase())},customMessage:function(t,e){var i=this.settings.messages[t];return i&&(i.constructor===String?i:i[e])},findDefined:function(){for(var t=0;arguments.length>t;t++)if(void 0!==arguments[t])return arguments[t];return void 0},defaultMessage:function(e,i){return this.findDefined(this.customMessage(e.name,i),this.customDataMessage(e,i),!this.settings.ignoreTitle&&e.title||void 0,t.validator.messages[i],"
Warning: No message defined for "+e.name+"")},formatAndAdd:function(e,i){var s=this.defaultMessage(e,i.method),r=/\$?\{(\d+)\}/g;"function"==typeof s?s=s.call(this,i.parameters,e):r.test(s)&&(s=t.validator.format(s.replace(r,"{$1}"),i.parameters)),this.errorList.push({message:s,element:e}),this.errorMap[e.name]=s,this.submitted[e.name]=s},addWrapper:function(t){return this.settings.wrapper&&(t=t.add(t.parent(this.settings.wrapper))),t},defaultShowErrors:function(){var t,e;for(t=0;this.errorList[t];t++){var i=this.errorList[t];this.settings.highlight&&this.settings.highlight.call(this,i.element,this.settings.errorClass,this.settings.validClass),this.showLabel(i.element,i.message)}if(this.errorList.length&&(this.toShow=this.toShow.add(this.containers)),this.settings.success)for(t=0;this.successList[t];t++)this.showLabel(this.successList[t]);if(this.settings.unhighlight)for(t=0,e=this.validElements();e[t];t++)this.settings.unhighlight.call(this,e[t],this.settings.errorClass,this.settings.validClass);this.toHide=this.toHide.not(this.toShow),this.hideErrors(),this.addWrapper(this.toShow).show()},validElements:function(){return this.currentElements.not(this.invalidElements())},invalidElements:function(){return t(this.errorList).map(function(){return this.element})},showLabel:function(e,i){var s=this.errorsFor(e);s.length?(s.removeClass(this.settings.validClass).addClass(this.settings.errorClass),s.html(i)):(s=t("<"+this.settings.errorElement+">").attr("for",this.idOrName(e)).addClass(this.settings.errorClass).html(i||""),this.settings.wrapper&&(s=s.hide().show().wrap("<"+this.settings.wrapper+"/>").parent()),this.labelContainer.append(s).length||(this.settings.errorPlacement?this.settings.errorPlacement(s,t(e)):s.insertAfter(e))),!i&&this.settings.success&&(s.text(""),"string"==typeof this.settings.success?s.addClass(this.settings.success):this.settings.success(s,e)),this.toShow=this.toShow.add(s)},errorsFor:function(e){var i=this.idOrName(e);return this.errors().filter(function(){return t(this).attr("for")===i})},idOrName:function(t){return this.groups[t.name]||(this.checkable(t)?t.name:t.id||t.name)},validationTargetFor:function(t){return this.checkable(t)&&(t=this.findByName(t.name).not(this.settings.ignore)[0]),t},checkable:function(t){return/radio|checkbox/i.test(t.type)},findByName:function(e){return t(this.currentForm).find("[name='"+e+"']")},getLength:function(e,i){switch(i.nodeName.toLowerCase()){case"select":return t("option:selected",i).length;case"input":if(this.checkable(i))return this.findByName(i.name).filter(":checked").length}return e.length},depend:function(t,e){return this.dependTypes[typeof t]?this.dependTypes[typeof t](t,e):!0},dependTypes:{"boolean":function(t){return t},string:function(e,i){return!!t(e,i.form).length},"function":function(t,e){return t(e)}},optional:function(e){var i=this.elementValue(e);return!t.validator.methods.required.call(this,i,e)&&"dependency-mismatch"},startRequest:function(t){this.pending[t.name]||(this.pendingRequest++,this.pending[t.name]=!0)},stopRequest:function(e,i){this.pendingRequest--,0>this.pendingRequest&&(this.pendingRequest=0),delete this.pending[e.name],i&&0===this.pendingRequest&&this.formSubmitted&&this.form()?(t(this.currentForm).submit(),this.formSubmitted=!1):!i&&0===this.pendingRequest&&this.formSubmitted&&(t(this.currentForm).triggerHandler("invalid-form",[this]),this.formSubmitted=!1)},previousValue:function(e){return t.data(e,"previousValue")||t.data(e,"previousValue",{old:null,valid:!0,message:this.defaultMessage(e,"remote")})}},classRuleSettings:{required:{required:!0},email:{email:!0},url:{url:!0},date:{date:!0},dateISO:{dateISO:!0},number:{number:!0},digits:{digits:!0},creditcard:{creditcard:!0}},addClassRules:function(e,i){e.constructor===String?this.classRuleSettings[e]=i:t.extend(this.classRuleSettings,e)},classRules:function(e){var i={},s=t(e).attr("class");return s&&t.each(s.split(" "),function(){this in t.validator.classRuleSettings&&t.extend(i,t.validator.classRuleSettings[this])}),i},attributeRules:function(e){var i={},s=t(e),r=s[0].getAttribute("type");for(var n in t.validator.methods){var a;"required"===n?(a=s.get(0).getAttribute(n),""===a&&(a=!0),a=!!a):a=s.attr(n),/min|max/.test(n)&&(null===r||/number|range|text/.test(r))&&(a=Number(a)),a?i[n]=a:r===n&&"range"!==r&&(i[n]=!0)}return i.maxlength&&/-1|2147483647|524288/.test(i.maxlength)&&delete i.maxlength,i},dataRules:function(e){var i,s,r={},n=t(e);for(i in t.validator.methods)s=n.data("rule-"+i.toLowerCase()),void 0!==s&&(r[i]=s);return r},staticRules:function(e){var i={},s=t.data(e.form,"validator");return s.settings.rules&&(i=t.validator.normalizeRule(s.settings.rules[e.name])||{}),i},normalizeRules:function(e,i){return t.each(e,function(s,r){if(r===!1)return delete e[s],void 0;if(r.param||r.depends){var n=!0;switch(typeof r.depends){case"string":n=!!t(r.depends,i.form).length;break;case"function":n=r.depends.call(i,i)}n?e[s]=void 0!==r.param?r.param:!0:delete e[s]}}),t.each(e,function(s,r){e[s]=t.isFunction(r)?r(i):r}),t.each(["minlength","maxlength"],function(){e[this]&&(e[this]=Number(e[this]))}),t.each(["rangelength","range"],function(){var i;e[this]&&(t.isArray(e[this])?e[this]=[Number(e[this][0]),Number(e[this][1])]:"string"==typeof e[this]&&(i=e[this].split(/[\s,]+/),e[this]=[Number(i[0]),Number(i[1])]))}),t.validator.autoCreateRanges&&(e.min&&e.max&&(e.range=[e.min,e.max],delete e.min,delete e.max),e.minlength&&e.maxlength&&(e.rangelength=[e.minlength,e.maxlength],delete e.minlength,delete e.maxlength)),e},normalizeRule:function(e){if("string"==typeof e){var i={};t.each(e.split(/\s/),function(){i[this]=!0}),e=i}return e},addMethod:function(e,i,s){t.validator.methods[e]=i,t.validator.messages[e]=void 0!==s?s:t.validator.messages[e],3>i.length&&t.validator.addClassRules(e,t.validator.normalizeRule(e))},methods:{required:function(e,i,s){if(!this.depend(s,i))return"dependency-mismatch";if("select"===i.nodeName.toLowerCase()){var r=t(i).val();return r&&r.length>0}return this.checkable(i)?this.getLength(e,i)>0:t.trim(e).length>0},email:function(t,e){return this.optional(e)||/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))$/i.test(t)},url:function(t,e){return this.optional(e)||/^(https?|s?ftp):\/\/(((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(#((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/i.test(t)},date:function(t,e){return this.optional(e)||!/Invalid|NaN/.test(""+new Date(t))},dateISO:function(t,e){return this.optional(e)||/^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/.test(t)},number:function(t,e){return this.optional(e)||/^-?(?:\d+|\d{1,3}(?:,\d{3})+)?(?:\.\d+)?$/.test(t)},digits:function(t,e){return this.optional(e)||/^\d+$/.test(t)},creditcard:function(t,e){if(this.optional(e))return"dependency-mismatch";if(/[^0-9 \-]+/.test(t))return!1;var i=0,s=0,r=!1;t=t.replace(/\D/g,"");for(var n=t.length-1;n>=0;n--){var a=t.charAt(n);s=parseInt(a,10),r&&(s*=2)>9&&(s-=9),i+=s,r=!r}return 0===i%10},minlength:function(e,i,s){var r=t.isArray(e)?e.length:this.getLength(t.trim(e),i);return this.optional(i)||r>=s},maxlength:function(e,i,s){var r=t.isArray(e)?e.length:this.getLength(t.trim(e),i);return this.optional(i)||s>=r},rangelength:function(e,i,s){var r=t.isArray(e)?e.length:this.getLength(t.trim(e),i);return this.optional(i)||r>=s[0]&&s[1]>=r},min:function(t,e,i){return this.optional(e)||t>=i},max:function(t,e,i){return this.optional(e)||i>=t},range:function(t,e,i){return this.optional(e)||t>=i[0]&&i[1]>=t},equalTo:function(e,i,s){var r=t(s);return this.settings.onfocusout&&r.unbind(".validate-equalTo").bind("blur.validate-equalTo",function(){t(i).valid()}),e===r.val()},remote:function(e,i,s){if(this.optional(i))return"dependency-mismatch";var r=this.previousValue(i);if(this.settings.messages[i.name]||(this.settings.messages[i.name]={}),r.originalMessage=this.settings.messages[i.name].remote,this.settings.messages[i.name].remote=r.message,s="string"==typeof s&&{url:s}||s,r.old===e)return r.valid;r.old=e;var n=this;this.startRequest(i);var a={};return a[i.name]=e,t.ajax(t.extend(!0,{url:s,mode:"abort",port:"validate"+i.name,dataType:"json",data:a,success:function(s){n.settings.messages[i.name].remote=r.originalMessage;var a=s===!0||"true"===s;if(a){var u=n.formSubmitted;n.prepareElement(i),n.formSubmitted=u,n.successList.push(i),delete n.invalid[i.name],n.showErrors()}else{var o={},l=s||n.defaultMessage(i,"remote");o[i.name]=r.message=t.isFunction(l)?l(e):l,n.invalid[i.name]=!0,n.showErrors(o)}r.valid=a,n.stopRequest(i,a)}},s)),"pending"}}}),t.format=t.validator.format})(jQuery),function(t){var e={};if(t.ajaxPrefilter)t.ajaxPrefilter(function(t,i,s){var r=t.port;"abort"===t.mode&&(e[r]&&e[r].abort(),e[r]=s)});else{var i=t.ajax;t.ajax=function(s){var r=("mode"in s?s:t.ajaxSettings).mode,n=("port"in s?s:t.ajaxSettings).port;return"abort"===r?(e[n]&&e[n].abort(),e[n]=i.apply(this,arguments),e[n]):i.apply(this,arguments)}}}(jQuery),function(t){t.extend(t.fn,{validateDelegate:function(e,i,s){return this.bind(i,function(i){var r=t(i.target);return r.is(e)?s.apply(r,arguments):void 0})}})}(jQuery);
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.unobtrusive.js b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.unobtrusive.js
new file mode 100644
index 000000000..05033349d
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.unobtrusive.js
@@ -0,0 +1,429 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*!
+** Unobtrusive validation support library for jQuery and jQuery Validate
+** Copyright (C) Microsoft Corporation. All rights reserved.
+*/
+
+/*jslint white: true, browser: true, onevar: true, undef: true, nomen: true, eqeqeq: true, plusplus: true, bitwise: true, regexp: true, newcap: true, immed: true, strict: false */
+/*global document: false, jQuery: false */
+
+(function ($) {
+ var $jQval = $.validator,
+ adapters,
+ data_validation = "unobtrusiveValidation";
+
+ function setValidationValues(options, ruleName, value) {
+ options.rules[ruleName] = value;
+ if (options.message) {
+ options.messages[ruleName] = options.message;
+ }
+ }
+
+ function splitAndTrim(value) {
+ return value.replace(/^\s+|\s+$/g, "").split(/\s*,\s*/g);
+ }
+
+ function escapeAttributeValue(value) {
+ // As mentioned on http://api.jquery.com/category/selectors/
+ return value.replace(/([!"#$%&'()*+,./:;<=>?@\[\\\]^`{|}~])/g, "\\$1");
+ }
+
+ function getModelPrefix(fieldName) {
+ return fieldName.substr(0, fieldName.lastIndexOf(".") + 1);
+ }
+
+ function appendModelPrefix(value, prefix) {
+ if (value.indexOf("*.") === 0) {
+ value = value.replace("*.", prefix);
+ }
+ return value;
+ }
+
+ function onError(error, inputElement) { // 'this' is the form element
+ var container = $(this).find("[data-valmsg-for='" + escapeAttributeValue(inputElement[0].name) + "']"),
+ replaceAttrValue = container.attr("data-valmsg-replace"),
+ replace = replaceAttrValue ? $.parseJSON(replaceAttrValue) !== false : null;
+
+ container.removeClass("field-validation-valid").addClass("field-validation-error");
+ error.data("unobtrusiveContainer", container);
+
+ if (replace) {
+ container.empty();
+ error.removeClass("input-validation-error").appendTo(container);
+ }
+ else {
+ error.hide();
+ }
+ }
+
+ function onErrors(event, validator) { // 'this' is the form element
+ var container = $(this).find("[data-valmsg-summary=true]"),
+ list = container.find("ul");
+
+ if (list && list.length && validator.errorList.length) {
+ list.empty();
+ container.addClass("validation-summary-errors").removeClass("validation-summary-valid");
+
+ $.each(validator.errorList, function () {
+ $("
").html(this.message).appendTo(list);
+ });
+ }
+ }
+
+ function onSuccess(error) { // 'this' is the form element
+ var container = error.data("unobtrusiveContainer"),
+ replaceAttrValue = container.attr("data-valmsg-replace"),
+ replace = replaceAttrValue ? $.parseJSON(replaceAttrValue) : null;
+
+ if (container) {
+ container.addClass("field-validation-valid").removeClass("field-validation-error");
+ error.removeData("unobtrusiveContainer");
+
+ if (replace) {
+ container.empty();
+ }
+ }
+ }
+
+ function onReset(event) { // 'this' is the form element
+ var $form = $(this),
+ key = '__jquery_unobtrusive_validation_form_reset';
+ if ($form.data(key)) {
+ return;
+ }
+ // Set a flag that indicates we're currently resetting the form.
+ $form.data(key, true);
+ try {
+ $form.data("validator").resetForm();
+ } finally {
+ $form.removeData(key);
+ }
+
+ $form.find(".validation-summary-errors")
+ .addClass("validation-summary-valid")
+ .removeClass("validation-summary-errors");
+ $form.find(".field-validation-error")
+ .addClass("field-validation-valid")
+ .removeClass("field-validation-error")
+ .removeData("unobtrusiveContainer")
+ .find(">*") // If we were using valmsg-replace, get the underlying error
+ .removeData("unobtrusiveContainer");
+ }
+
+ function validationInfo(form) {
+ var $form = $(form),
+ result = $form.data(data_validation),
+ onResetProxy = $.proxy(onReset, form),
+ defaultOptions = $jQval.unobtrusive.options || {},
+ execInContext = function (name, args) {
+ var func = defaultOptions[name];
+ func && $.isFunction(func) && func.apply(form, args);
+ }
+
+ if (!result) {
+ result = {
+ options: { // options structure passed to jQuery Validate's validate() method
+ errorClass: defaultOptions.errorClass || "input-validation-error",
+ errorElement: defaultOptions.errorElement || "span",
+ errorPlacement: function () {
+ onError.apply(form, arguments);
+ execInContext("errorPlacement", arguments);
+ },
+ invalidHandler: function () {
+ onErrors.apply(form, arguments);
+ execInContext("invalidHandler", arguments);
+ },
+ messages: {},
+ rules: {},
+ success: function () {
+ onSuccess.apply(form, arguments);
+ execInContext("success", arguments);
+ }
+ },
+ attachValidation: function () {
+ $form
+ .off("reset." + data_validation, onResetProxy)
+ .on("reset." + data_validation, onResetProxy)
+ .validate(this.options);
+ },
+ validate: function () { // a validation function that is called by unobtrusive Ajax
+ $form.validate();
+ return $form.valid();
+ }
+ };
+ $form.data(data_validation, result);
+ }
+
+ return result;
+ }
+
+ $jQval.unobtrusive = {
+ adapters: [],
+
+ parseElement: function (element, skipAttach) {
+ ///
+ /// Parses a single HTML element for unobtrusive validation attributes.
+ ///
+ ///
The HTML element to be parsed.
+ ///
[Optional] true to skip attaching the
+ /// validation to the form. If parsing just this single element, you should specify true.
+ /// If parsing several elements, you should specify false, and manually attach the validation
+ /// to the form when you are finished. The default is false.
+ var $element = $(element),
+ form = $element.parents("form")[0],
+ valInfo, rules, messages;
+
+ if (!form) { // Cannot do client-side validation without a form
+ return;
+ }
+
+ valInfo = validationInfo(form);
+ valInfo.options.rules[element.name] = rules = {};
+ valInfo.options.messages[element.name] = messages = {};
+
+ $.each(this.adapters, function () {
+ var prefix = "data-val-" + this.name,
+ message = $element.attr(prefix),
+ paramValues = {};
+
+ if (message !== undefined) { // Compare against undefined, because an empty message is legal (and falsy)
+ prefix += "-";
+
+ $.each(this.params, function () {
+ paramValues[this] = $element.attr(prefix + this);
+ });
+
+ this.adapt({
+ element: element,
+ form: form,
+ message: message,
+ params: paramValues,
+ rules: rules,
+ messages: messages
+ });
+ }
+ });
+
+ $.extend(rules, { "__dummy__": true });
+
+ if (!skipAttach) {
+ valInfo.attachValidation();
+ }
+ },
+
+ parse: function (selector) {
+ ///
+ /// Parses all the HTML elements in the specified selector. It looks for input elements decorated
+ /// with the [data-val=true] attribute value and enables validation according to the data-val-*
+ /// attribute values.
+ ///
+ ///
Any valid jQuery selector.
+
+ // $forms includes all forms in selector's DOM hierarchy (parent, children and self) that have at least one
+ // element with data-val=true
+ var $selector = $(selector),
+ $forms = $selector.parents()
+ .addBack()
+ .filter("form")
+ .add($selector.find("form"))
+ .has("[data-val=true]");
+
+ $selector.find("[data-val=true]").each(function () {
+ $jQval.unobtrusive.parseElement(this, true);
+ });
+
+ $forms.each(function () {
+ var info = validationInfo(this);
+ if (info) {
+ info.attachValidation();
+ }
+ });
+ }
+ };
+
+ adapters = $jQval.unobtrusive.adapters;
+
+ adapters.add = function (adapterName, params, fn) {
+ ///
Adds a new adapter to convert unobtrusive HTML into a jQuery Validate validation.
+ ///
The name of the adapter to be added. This matches the name used
+ /// in the data-val-nnnn HTML attribute (where nnnn is the adapter name).
+ ///
[Optional] An array of parameter names (strings) that will
+ /// be extracted from the data-val-nnnn-mmmm HTML attributes (where nnnn is the adapter name, and
+ /// mmmm is the parameter name).
+ ///
The function to call, which adapts the values from the HTML
+ /// attributes into jQuery Validate rules and/or messages.
+ ///
+ if (!fn) { // Called with no params, just a function
+ fn = params;
+ params = [];
+ }
+ this.push({ name: adapterName, params: params, adapt: fn });
+ return this;
+ };
+
+ adapters.addBool = function (adapterName, ruleName) {
+ ///
Adds a new adapter to convert unobtrusive HTML into a jQuery Validate validation, where
+ /// the jQuery Validate validation rule has no parameter values.
+ ///
The name of the adapter to be added. This matches the name used
+ /// in the data-val-nnnn HTML attribute (where nnnn is the adapter name).
+ ///
[Optional] The name of the jQuery Validate rule. If not provided, the value
+ /// of adapterName will be used instead.
+ ///
+ return this.add(adapterName, function (options) {
+ setValidationValues(options, ruleName || adapterName, true);
+ });
+ };
+
+ adapters.addMinMax = function (adapterName, minRuleName, maxRuleName, minMaxRuleName, minAttribute, maxAttribute) {
+ ///
Adds a new adapter to convert unobtrusive HTML into a jQuery Validate validation, where
+ /// the jQuery Validate validation has three potential rules (one for min-only, one for max-only, and
+ /// one for min-and-max). The HTML parameters are expected to be named -min and -max.
+ ///
The name of the adapter to be added. This matches the name used
+ /// in the data-val-nnnn HTML attribute (where nnnn is the adapter name).
+ ///
The name of the jQuery Validate rule to be used when you only
+ /// have a minimum value.
+ ///
The name of the jQuery Validate rule to be used when you only
+ /// have a maximum value.
+ ///
The name of the jQuery Validate rule to be used when you
+ /// have both a minimum and maximum value.
+ ///
[Optional] The name of the HTML attribute that
+ /// contains the minimum value. The default is "min".
+ ///
[Optional] The name of the HTML attribute that
+ /// contains the maximum value. The default is "max".
+ ///
+ return this.add(adapterName, [minAttribute || "min", maxAttribute || "max"], function (options) {
+ var min = options.params.min,
+ max = options.params.max;
+
+ if (min && max) {
+ setValidationValues(options, minMaxRuleName, [min, max]);
+ }
+ else if (min) {
+ setValidationValues(options, minRuleName, min);
+ }
+ else if (max) {
+ setValidationValues(options, maxRuleName, max);
+ }
+ });
+ };
+
+ adapters.addSingleVal = function (adapterName, attribute, ruleName) {
+ ///
Adds a new adapter to convert unobtrusive HTML into a jQuery Validate validation, where
+ /// the jQuery Validate validation rule has a single value.
+ ///
The name of the adapter to be added. This matches the name used
+ /// in the data-val-nnnn HTML attribute(where nnnn is the adapter name).
+ ///
[Optional] The name of the HTML attribute that contains the value.
+ /// The default is "val".
+ ///
[Optional] The name of the jQuery Validate rule. If not provided, the value
+ /// of adapterName will be used instead.
+ ///
+ return this.add(adapterName, [attribute || "val"], function (options) {
+ setValidationValues(options, ruleName || adapterName, options.params[attribute]);
+ });
+ };
+
+ $jQval.addMethod("__dummy__", function (value, element, params) {
+ return true;
+ });
+
+ $jQval.addMethod("regex", function (value, element, params) {
+ var match;
+ if (this.optional(element)) {
+ return true;
+ }
+
+ match = new RegExp(params).exec(value);
+ return (match && (match.index === 0) && (match[0].length === value.length));
+ });
+
+ $jQval.addMethod("nonalphamin", function (value, element, nonalphamin) {
+ var match;
+ if (nonalphamin) {
+ match = value.match(/\W/g);
+ match = match && match.length >= nonalphamin;
+ }
+ return match;
+ });
+
+ if ($jQval.methods.extension) {
+ adapters.addSingleVal("accept", "mimtype");
+ adapters.addSingleVal("extension", "extension");
+ } else {
+ // for backward compatibility, when the 'extension' validation method does not exist, such as with versions
+ // of JQuery Validation plugin prior to 1.10, we should use the 'accept' method for
+ // validating the extension, and ignore mime-type validations as they are not supported.
+ adapters.addSingleVal("extension", "extension", "accept");
+ }
+
+ adapters.addSingleVal("regex", "pattern");
+ adapters.addBool("creditcard").addBool("date").addBool("digits").addBool("email").addBool("number").addBool("url");
+ adapters.addMinMax("length", "minlength", "maxlength", "rangelength").addMinMax("range", "min", "max", "range");
+ adapters.addMinMax("minlength", "minlength").addMinMax("maxlength", "minlength", "maxlength");
+ adapters.add("equalto", ["other"], function (options) {
+ var prefix = getModelPrefix(options.element.name),
+ other = options.params.other,
+ fullOtherName = appendModelPrefix(other, prefix),
+ element = $(options.form).find(":input").filter("[name='" + escapeAttributeValue(fullOtherName) + "']")[0];
+
+ setValidationValues(options, "equalTo", element);
+ });
+ adapters.add("required", function (options) {
+ // jQuery Validate equates "required" with "mandatory" for checkbox elements
+ if (options.element.tagName.toUpperCase() !== "INPUT" || options.element.type.toUpperCase() !== "CHECKBOX") {
+ setValidationValues(options, "required", true);
+ }
+ });
+ adapters.add("remote", ["url", "type", "additionalfields"], function (options) {
+ var value = {
+ url: options.params.url,
+ type: options.params.type || "GET",
+ data: {}
+ },
+ prefix = getModelPrefix(options.element.name);
+
+ $.each(splitAndTrim(options.params.additionalfields || options.element.name), function (i, fieldName) {
+ var paramName = appendModelPrefix(fieldName, prefix);
+ value.data[paramName] = function () {
+ var field = $(options.form).find(":input").filter("[name='" + escapeAttributeValue(paramName) + "']");
+ // For checkboxes and radio buttons, only pick up values from checked fields.
+ if (field.is(":checkbox")) {
+ return field.filter(":checked").val() || field.filter(":hidden").val() || '';
+ }
+ else if (field.is(":radio")) {
+ return field.filter(":checked").val() || '';
+ }
+ return field.val();
+ };
+ });
+
+ setValidationValues(options, "remote", value);
+ });
+ adapters.add("password", ["min", "nonalphamin", "regex"], function (options) {
+ if (options.params.min) {
+ setValidationValues(options, "minlength", options.params.min);
+ }
+ if (options.params.nonalphamin) {
+ setValidationValues(options, "nonalphamin", options.params.nonalphamin);
+ }
+ if (options.params.regex) {
+ setValidationValues(options, "regex", options.params.regex);
+ }
+ });
+
+ $(function () {
+ $jQval.unobtrusive.parse(document);
+ });
+}(jQuery));
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.unobtrusive.min.js b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.unobtrusive.min.js
new file mode 100644
index 000000000..dfeaf38ec
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/jquery.validate.unobtrusive.min.js
@@ -0,0 +1,19 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*
+** Unobtrusive validation support library for jQuery and jQuery Validate
+** Copyright (C) Microsoft Corporation. All rights reserved.
+*/
+(function(a){var d=a.validator,b,e="unobtrusiveValidation";function c(a,b,c){a.rules[b]=c;if(a.message)a.messages[b]=a.message}function j(a){return a.replace(/^\s+|\s+$/g,"").split(/\s*,\s*/g)}function f(a){return a.replace(/([!"#$%&'()*+,./:;<=>?@\[\\\]^`{|}~])/g,"\\$1")}function h(a){return a.substr(0,a.lastIndexOf(".")+1)}function g(a,b){if(a.indexOf("*.")===0)a=a.replace("*.",b);return a}function m(c,e){var b=a(this).find("[data-valmsg-for='"+f(e[0].name)+"']"),d=b.attr("data-valmsg-replace"),g=d?a.parseJSON(d)!==false:null;b.removeClass("field-validation-valid").addClass("field-validation-error");c.data("unobtrusiveContainer",b);if(g){b.empty();c.removeClass("input-validation-error").appendTo(b)}else c.hide()}function l(e,d){var c=a(this).find("[data-valmsg-summary=true]"),b=c.find("ul");if(b&&b.length&&d.errorList.length){b.empty();c.addClass("validation-summary-errors").removeClass("validation-summary-valid");a.each(d.errorList,function(){a("
").html(this.message).appendTo(b)})}}function k(d){var b=d.data("unobtrusiveContainer"),c=b.attr("data-valmsg-replace"),e=c?a.parseJSON(c):null;if(b){b.addClass("field-validation-valid").removeClass("field-validation-error");d.removeData("unobtrusiveContainer");e&&b.empty()}}function n(){var b=a(this),c="__jquery_unobtrusive_validation_form_reset";if(b.data(c))return;b.data(c,true);try{b.data("validator").resetForm()}finally{b.removeData(c)}b.find(".validation-summary-errors").addClass("validation-summary-valid").removeClass("validation-summary-errors");b.find(".field-validation-error").addClass("field-validation-valid").removeClass("field-validation-error").removeData("unobtrusiveContainer").find(">*").removeData("unobtrusiveContainer")}function i(b){var c=a(b),f=c.data(e),i=a.proxy(n,b),g=d.unobtrusive.options||{},h=function(e,d){var c=g[e];c&&a.isFunction(c)&&c.apply(b,d)};if(!f){f={options:{errorClass:g.errorClass||"input-validation-error",errorElement:g.errorElement||"span",errorPlacement:function(){m.apply(b,arguments);h("errorPlacement",arguments)},invalidHandler:function(){l.apply(b,arguments);h("invalidHandler",arguments)},messages:{},rules:{},success:function(){k.apply(b,arguments);h("success",arguments)}},attachValidation:function(){c.off("reset."+e,i).on("reset."+e,i).validate(this.options)},validate:function(){c.validate();return c.valid()}};c.data(e,f)}return f}d.unobtrusive={adapters:[],parseElement:function(b,h){var d=a(b),f=d.parents("form")[0],c,e,g;if(!f)return;c=i(f);c.options.rules[b.name]=e={};c.options.messages[b.name]=g={};a.each(this.adapters,function(){var c="data-val-"+this.name,i=d.attr(c),h={};if(i!==undefined){c+="-";a.each(this.params,function(){h[this]=d.attr(c+this)});this.adapt({element:b,form:f,message:i,params:h,rules:e,messages:g})}});a.extend(e,{__dummy__:true});!h&&c.attachValidation()},parse:function(c){var b=a(c),e=b.parents().addBack().filter("form").add(b.find("form")).has("[data-val=true]");b.find("[data-val=true]").each(function(){d.unobtrusive.parseElement(this,true)});e.each(function(){var a=i(this);a&&a.attachValidation()})}};b=d.unobtrusive.adapters;b.add=function(c,a,b){if(!b){b=a;a=[]}this.push({name:c,params:a,adapt:b});return this};b.addBool=function(a,b){return this.add(a,function(d){c(d,b||a,true)})};b.addMinMax=function(e,g,f,a,d,b){return this.add(e,[d||"min",b||"max"],function(b){var e=b.params.min,d=b.params.max;if(e&&d)c(b,a,[e,d]);else if(e)c(b,g,e);else d&&c(b,f,d)})};b.addSingleVal=function(a,b,d){return this.add(a,[b||"val"],function(e){c(e,d||a,e.params[b])})};d.addMethod("__dummy__",function(){return true});d.addMethod("regex",function(b,c,d){var a;if(this.optional(c))return true;a=(new RegExp(d)).exec(b);return a&&a.index===0&&a[0].length===b.length});d.addMethod("nonalphamin",function(c,d,b){var a;if(b){a=c.match(/\W/g);a=a&&a.length>=b}return a});if(d.methods.extension){b.addSingleVal("accept","mimtype");b.addSingleVal("extension","extension")}else b.addSingleVal("extension","extension","accept");b.addSingleVal("regex","pattern");b.addBool("creditcard").addBool("date").addBool("digits").addBool("email").addBool("number").addBool("url");b.addMinMax("length","minlength","maxlength","rangelength").addMinMax("range","min","max","range");b.addMinMax("minlength","minlength").addMinMax("maxlength","minlength","maxlength");b.add("equalto",["other"],function(b){var i=h(b.element.name),j=b.params.other,d=g(j,i),e=a(b.form).find(":input").filter("[name='"+f(d)+"']")[0];c(b,"equalTo",e)});b.add("required",function(a){(a.element.tagName.toUpperCase()!=="INPUT"||a.element.type.toUpperCase()!=="CHECKBOX")&&c(a,"required",true)});b.add("remote",["url","type","additionalfields"],function(b){var d={url:b.params.url,type:b.params.type||"GET",data:{}},e=h(b.element.name);a.each(j(b.params.additionalfields||b.element.name),function(i,h){var c=g(h,e);d.data[c]=function(){var d=a(b.form).find(":input").filter("[name='"+f(c)+"']");return d.is(":checkbox")?d.filter(":checked").val()||d.filter(":hidden").val()||"":d.is(":radio")?d.filter(":checked").val()||"":d.val()}});c(b,"remote",d)});b.add("password",["min","nonalphamin","regex"],function(a){a.params.min&&c(a,"minlength",a.params.min);a.params.nonalphamin&&c(a,"nonalphamin",a.params.nonalphamin);a.params.regex&&c(a,"regex",a.params.regex)});a(function(){d.unobtrusive.parse(document)})})(jQuery);
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/modernizr-2.6.2.js b/samples/angular-aad-webapi/api/api.securecall/Scripts/modernizr-2.6.2.js
new file mode 100644
index 000000000..cbfe1f390
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/modernizr-2.6.2.js
@@ -0,0 +1,1416 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * Copyright (c) Faruk Ates, Paul Irish, Alex Sexton; http://www.modernizr.com/license/
+ *
+ * Includes matchMedia polyfill; Copyright (c) 2010 Filament Group, Inc; http://opensource.org/licenses/MIT
+ *
+ * Includes material adapted from ES5-shim https://github.com/kriskowal/es5-shim/blob/master/es5-shim.js; Copyright 2009-2012 by contributors; http://opensource.org/licenses/MIT
+ *
+ * Includes material from css-support; Copyright (c) 2005-2012 Diego Perini; https://github.com/dperini/css-support/blob/master/LICENSE
+ *
+ * NUGET: END LICENSE TEXT */
+
+/*!
+ * Modernizr v2.6.2
+ * www.modernizr.com
+ *
+ * Copyright (c) Faruk Ates, Paul Irish, Alex Sexton
+ * Available under the BSD and MIT licenses: www.modernizr.com/license/
+ */
+
+/*
+ * Modernizr tests which native CSS3 and HTML5 features are available in
+ * the current UA and makes the results available to you in two ways:
+ * as properties on a global Modernizr object, and as classes on the
+ * element. This information allows you to progressively enhance
+ * your pages with a granular level of control over the experience.
+ *
+ * Modernizr has an optional (not included) conditional resource loader
+ * called Modernizr.load(), based on Yepnope.js (yepnopejs.com).
+ * To get a build that includes Modernizr.load(), as well as choosing
+ * which tests to include, go to www.modernizr.com/download/
+ *
+ * Authors Faruk Ates, Paul Irish, Alex Sexton
+ * Contributors Ryan Seddon, Ben Alman
+ */
+
+window.Modernizr = (function( window, document, undefined ) {
+
+ var version = '2.6.2',
+
+ Modernizr = {},
+
+ /*>>cssclasses*/
+ // option for enabling the HTML classes to be added
+ enableClasses = true,
+ /*>>cssclasses*/
+
+ docElement = document.documentElement,
+
+ /**
+ * Create our "modernizr" element that we do most feature tests on.
+ */
+ mod = 'modernizr',
+ modElem = document.createElement(mod),
+ mStyle = modElem.style,
+
+ /**
+ * Create the input element for various Web Forms feature tests.
+ */
+ inputElem /*>>inputelem*/ = document.createElement('input') /*>>inputelem*/ ,
+
+ /*>>smile*/
+ smile = ':)',
+ /*>>smile*/
+
+ toString = {}.toString,
+
+ // TODO :: make the prefixes more granular
+ /*>>prefixes*/
+ // List of property values to set for css tests. See ticket #21
+ prefixes = ' -webkit- -moz- -o- -ms- '.split(' '),
+ /*>>prefixes*/
+
+ /*>>domprefixes*/
+ // Following spec is to expose vendor-specific style properties as:
+ // elem.style.WebkitBorderRadius
+ // and the following would be incorrect:
+ // elem.style.webkitBorderRadius
+
+ // Webkit ghosts their properties in lowercase but Opera & Moz do not.
+ // Microsoft uses a lowercase `ms` instead of the correct `Ms` in IE8+
+ // erik.eae.net/archives/2008/03/10/21.48.10/
+
+ // More here: github.com/Modernizr/Modernizr/issues/issue/21
+ omPrefixes = 'Webkit Moz O ms',
+
+ cssomPrefixes = omPrefixes.split(' '),
+
+ domPrefixes = omPrefixes.toLowerCase().split(' '),
+ /*>>domprefixes*/
+
+ /*>>ns*/
+ ns = {'svg': 'http://www.w3.org/2000/svg'},
+ /*>>ns*/
+
+ tests = {},
+ inputs = {},
+ attrs = {},
+
+ classes = [],
+
+ slice = classes.slice,
+
+ featureName, // used in testing loop
+
+
+ /*>>teststyles*/
+ // Inject element with style element and some CSS rules
+ injectElementWithStyles = function( rule, callback, nodes, testnames ) {
+
+ var style, ret, node, docOverflow,
+ div = document.createElement('div'),
+ // After page load injecting a fake body doesn't work so check if body exists
+ body = document.body,
+ // IE6 and 7 won't return offsetWidth or offsetHeight unless it's in the body element, so we fake it.
+ fakeBody = body || document.createElement('body');
+
+ if ( parseInt(nodes, 10) ) {
+ // In order not to give false positives we create a node for each test
+ // This also allows the method to scale for unspecified uses
+ while ( nodes-- ) {
+ node = document.createElement('div');
+ node.id = testnames ? testnames[nodes] : mod + (nodes + 1);
+ div.appendChild(node);
+ }
+ }
+
+ // '].join('');
+ div.id = mod;
+ // IE6 will false positive on some tests due to the style element inside the test div somehow interfering offsetHeight, so insert it into body or fakebody.
+ // Opera will act all quirky when injecting elements in documentElement when page is served as xml, needs fakebody too. #270
+ (body ? div : fakeBody).innerHTML += style;
+ fakeBody.appendChild(div);
+ if ( !body ) {
+ //avoid crashing IE8, if background image is used
+ fakeBody.style.background = '';
+ //Safari 5.13/5.1.4 OSX stops loading if ::-webkit-scrollbar is used and scrollbars are visible
+ fakeBody.style.overflow = 'hidden';
+ docOverflow = docElement.style.overflow;
+ docElement.style.overflow = 'hidden';
+ docElement.appendChild(fakeBody);
+ }
+
+ ret = callback(div, rule);
+ // If this is done after page load we don't want to remove the body so check if body exists
+ if ( !body ) {
+ fakeBody.parentNode.removeChild(fakeBody);
+ docElement.style.overflow = docOverflow;
+ } else {
+ div.parentNode.removeChild(div);
+ }
+
+ return !!ret;
+
+ },
+ /*>>teststyles*/
+
+ /*>>mq*/
+ // adapted from matchMedia polyfill
+ // by Scott Jehl and Paul Irish
+ // gist.github.com/786768
+ testMediaQuery = function( mq ) {
+
+ var matchMedia = window.matchMedia || window.msMatchMedia;
+ if ( matchMedia ) {
+ return matchMedia(mq).matches;
+ }
+
+ var bool;
+
+ injectElementWithStyles('@media ' + mq + ' { #' + mod + ' { position: absolute; } }', function( node ) {
+ bool = (window.getComputedStyle ?
+ getComputedStyle(node, null) :
+ node.currentStyle)['position'] == 'absolute';
+ });
+
+ return bool;
+
+ },
+ /*>>mq*/
+
+
+ /*>>hasevent*/
+ //
+ // isEventSupported determines if a given element supports the given event
+ // kangax.github.com/iseventsupported/
+ //
+ // The following results are known incorrects:
+ // Modernizr.hasEvent("webkitTransitionEnd", elem) // false negative
+ // Modernizr.hasEvent("textInput") // in Webkit. github.com/Modernizr/Modernizr/issues/333
+ // ...
+ isEventSupported = (function() {
+
+ var TAGNAMES = {
+ 'select': 'input', 'change': 'input',
+ 'submit': 'form', 'reset': 'form',
+ 'error': 'img', 'load': 'img', 'abort': 'img'
+ };
+
+ function isEventSupported( eventName, element ) {
+
+ element = element || document.createElement(TAGNAMES[eventName] || 'div');
+ eventName = 'on' + eventName;
+
+ // When using `setAttribute`, IE skips "unload", WebKit skips "unload" and "resize", whereas `in` "catches" those
+ var isSupported = eventName in element;
+
+ if ( !isSupported ) {
+ // If it has no `setAttribute` (i.e. doesn't implement Node interface), try generic element
+ if ( !element.setAttribute ) {
+ element = document.createElement('div');
+ }
+ if ( element.setAttribute && element.removeAttribute ) {
+ element.setAttribute(eventName, '');
+ isSupported = is(element[eventName], 'function');
+
+ // If property was created, "remove it" (by setting value to `undefined`)
+ if ( !is(element[eventName], 'undefined') ) {
+ element[eventName] = undefined;
+ }
+ element.removeAttribute(eventName);
+ }
+ }
+
+ element = null;
+ return isSupported;
+ }
+ return isEventSupported;
+ })(),
+ /*>>hasevent*/
+
+ // TODO :: Add flag for hasownprop ? didn't last time
+
+ // hasOwnProperty shim by kangax needed for Safari 2.0 support
+ _hasOwnProperty = ({}).hasOwnProperty, hasOwnProp;
+
+ if ( !is(_hasOwnProperty, 'undefined') && !is(_hasOwnProperty.call, 'undefined') ) {
+ hasOwnProp = function (object, property) {
+ return _hasOwnProperty.call(object, property);
+ };
+ }
+ else {
+ hasOwnProp = function (object, property) { /* yes, this can give false positives/negatives, but most of the time we don't care about those */
+ return ((property in object) && is(object.constructor.prototype[property], 'undefined'));
+ };
+ }
+
+ // Adapted from ES5-shim https://github.com/kriskowal/es5-shim/blob/master/es5-shim.js
+ // es5.github.com/#x15.3.4.5
+
+ if (!Function.prototype.bind) {
+ Function.prototype.bind = function bind(that) {
+
+ var target = this;
+
+ if (typeof target != "function") {
+ throw new TypeError();
+ }
+
+ var args = slice.call(arguments, 1),
+ bound = function () {
+
+ if (this instanceof bound) {
+
+ var F = function(){};
+ F.prototype = target.prototype;
+ var self = new F();
+
+ var result = target.apply(
+ self,
+ args.concat(slice.call(arguments))
+ );
+ if (Object(result) === result) {
+ return result;
+ }
+ return self;
+
+ } else {
+
+ return target.apply(
+ that,
+ args.concat(slice.call(arguments))
+ );
+
+ }
+
+ };
+
+ return bound;
+ };
+ }
+
+ /**
+ * setCss applies given styles to the Modernizr DOM node.
+ */
+ function setCss( str ) {
+ mStyle.cssText = str;
+ }
+
+ /**
+ * setCssAll extrapolates all vendor-specific css strings.
+ */
+ function setCssAll( str1, str2 ) {
+ return setCss(prefixes.join(str1 + ';') + ( str2 || '' ));
+ }
+
+ /**
+ * is returns a boolean for if typeof obj is exactly type.
+ */
+ function is( obj, type ) {
+ return typeof obj === type;
+ }
+
+ /**
+ * contains returns a boolean for if substr is found within str.
+ */
+ function contains( str, substr ) {
+ return !!~('' + str).indexOf(substr);
+ }
+
+ /*>>testprop*/
+
+ // testProps is a generic CSS / DOM property test.
+
+ // In testing support for a given CSS property, it's legit to test:
+ // `elem.style[styleName] !== undefined`
+ // If the property is supported it will return an empty string,
+ // if unsupported it will return undefined.
+
+ // We'll take advantage of this quick test and skip setting a style
+ // on our modernizr element, but instead just testing undefined vs
+ // empty string.
+
+ // Because the testing of the CSS property names (with "-", as
+ // opposed to the camelCase DOM properties) is non-portable and
+ // non-standard but works in WebKit and IE (but not Gecko or Opera),
+ // we explicitly reject properties with dashes so that authors
+ // developing in WebKit or IE first don't end up with
+ // browser-specific content by accident.
+
+ function testProps( props, prefixed ) {
+ for ( var i in props ) {
+ var prop = props[i];
+ if ( !contains(prop, "-") && mStyle[prop] !== undefined ) {
+ return prefixed == 'pfx' ? prop : true;
+ }
+ }
+ return false;
+ }
+ /*>>testprop*/
+
+ // TODO :: add testDOMProps
+ /**
+ * testDOMProps is a generic DOM property test; if a browser supports
+ * a certain property, it won't return undefined for it.
+ */
+ function testDOMProps( props, obj, elem ) {
+ for ( var i in props ) {
+ var item = obj[props[i]];
+ if ( item !== undefined) {
+
+ // return the property name as a string
+ if (elem === false) return props[i];
+
+ // let's bind a function
+ if (is(item, 'function')){
+ // default to autobind unless override
+ return item.bind(elem || obj);
+ }
+
+ // return the unbound function or obj or value
+ return item;
+ }
+ }
+ return false;
+ }
+
+ /*>>testallprops*/
+ /**
+ * testPropsAll tests a list of DOM properties we want to check against.
+ * We specify literally ALL possible (known and/or likely) properties on
+ * the element including the non-vendor prefixed one, for forward-
+ * compatibility.
+ */
+ function testPropsAll( prop, prefixed, elem ) {
+
+ var ucProp = prop.charAt(0).toUpperCase() + prop.slice(1),
+ props = (prop + ' ' + cssomPrefixes.join(ucProp + ' ') + ucProp).split(' ');
+
+ // did they call .prefixed('boxSizing') or are we just testing a prop?
+ if(is(prefixed, "string") || is(prefixed, "undefined")) {
+ return testProps(props, prefixed);
+
+ // otherwise, they called .prefixed('requestAnimationFrame', window[, elem])
+ } else {
+ props = (prop + ' ' + (domPrefixes).join(ucProp + ' ') + ucProp).split(' ');
+ return testDOMProps(props, prefixed, elem);
+ }
+ }
+ /*>>testallprops*/
+
+
+ /**
+ * Tests
+ * -----
+ */
+
+ // The *new* flexbox
+ // dev.w3.org/csswg/css3-flexbox
+
+ tests['flexbox'] = function() {
+ return testPropsAll('flexWrap');
+ };
+
+ // The *old* flexbox
+ // www.w3.org/TR/2009/WD-css3-flexbox-20090723/
+
+ tests['flexboxlegacy'] = function() {
+ return testPropsAll('boxDirection');
+ };
+
+ // On the S60 and BB Storm, getContext exists, but always returns undefined
+ // so we actually have to call getContext() to verify
+ // github.com/Modernizr/Modernizr/issues/issue/97/
+
+ tests['canvas'] = function() {
+ var elem = document.createElement('canvas');
+ return !!(elem.getContext && elem.getContext('2d'));
+ };
+
+ tests['canvastext'] = function() {
+ return !!(Modernizr['canvas'] && is(document.createElement('canvas').getContext('2d').fillText, 'function'));
+ };
+
+ // webk.it/70117 is tracking a legit WebGL feature detect proposal
+
+ // We do a soft detect which may false positive in order to avoid
+ // an expensive context creation: bugzil.la/732441
+
+ tests['webgl'] = function() {
+ return !!window.WebGLRenderingContext;
+ };
+
+ /*
+ * The Modernizr.touch test only indicates if the browser supports
+ * touch events, which does not necessarily reflect a touchscreen
+ * device, as evidenced by tablets running Windows 7 or, alas,
+ * the Palm Pre / WebOS (touch) phones.
+ *
+ * Additionally, Chrome (desktop) used to lie about its support on this,
+ * but that has since been rectified: crbug.com/36415
+ *
+ * We also test for Firefox 4 Multitouch Support.
+ *
+ * For more info, see: modernizr.github.com/Modernizr/touch.html
+ */
+
+ tests['touch'] = function() {
+ var bool;
+
+ if(('ontouchstart' in window) || window.DocumentTouch && document instanceof DocumentTouch) {
+ bool = true;
+ } else {
+ injectElementWithStyles(['@media (',prefixes.join('touch-enabled),('),mod,')','{#modernizr{top:9px;position:absolute}}'].join(''), function( node ) {
+ bool = node.offsetTop === 9;
+ });
+ }
+
+ return bool;
+ };
+
+
+ // geolocation is often considered a trivial feature detect...
+ // Turns out, it's quite tricky to get right:
+ //
+ // Using !!navigator.geolocation does two things we don't want. It:
+ // 1. Leaks memory in IE9: github.com/Modernizr/Modernizr/issues/513
+ // 2. Disables page caching in WebKit: webk.it/43956
+ //
+ // Meanwhile, in Firefox < 8, an about:config setting could expose
+ // a false positive that would throw an exception: bugzil.la/688158
+
+ tests['geolocation'] = function() {
+ return 'geolocation' in navigator;
+ };
+
+
+ tests['postmessage'] = function() {
+ return !!window.postMessage;
+ };
+
+
+ // Chrome incognito mode used to throw an exception when using openDatabase
+ // It doesn't anymore.
+ tests['websqldatabase'] = function() {
+ return !!window.openDatabase;
+ };
+
+ // Vendors had inconsistent prefixing with the experimental Indexed DB:
+ // - Webkit's implementation is accessible through webkitIndexedDB
+ // - Firefox shipped moz_indexedDB before FF4b9, but since then has been mozIndexedDB
+ // For speed, we don't test the legacy (and beta-only) indexedDB
+ tests['indexedDB'] = function() {
+ return !!testPropsAll("indexedDB", window);
+ };
+
+ // documentMode logic from YUI to filter out IE8 Compat Mode
+ // which false positives.
+ tests['hashchange'] = function() {
+ return isEventSupported('hashchange', window) && (document.documentMode === undefined || document.documentMode > 7);
+ };
+
+ // Per 1.6:
+ // This used to be Modernizr.historymanagement but the longer
+ // name has been deprecated in favor of a shorter and property-matching one.
+ // The old API is still available in 1.6, but as of 2.0 will throw a warning,
+ // and in the first release thereafter disappear entirely.
+ tests['history'] = function() {
+ return !!(window.history && history.pushState);
+ };
+
+ tests['draganddrop'] = function() {
+ var div = document.createElement('div');
+ return ('draggable' in div) || ('ondragstart' in div && 'ondrop' in div);
+ };
+
+ // FF3.6 was EOL'ed on 4/24/12, but the ESR version of FF10
+ // will be supported until FF19 (2/12/13), at which time, ESR becomes FF17.
+ // FF10 still uses prefixes, so check for it until then.
+ // for more ESR info, see: mozilla.org/en-US/firefox/organizations/faq/
+ tests['websockets'] = function() {
+ return 'WebSocket' in window || 'MozWebSocket' in window;
+ };
+
+
+ // css-tricks.com/rgba-browser-support/
+ tests['rgba'] = function() {
+ // Set an rgba() color and check the returned value
+
+ setCss('background-color:rgba(150,255,150,.5)');
+
+ return contains(mStyle.backgroundColor, 'rgba');
+ };
+
+ tests['hsla'] = function() {
+ // Same as rgba(), in fact, browsers re-map hsla() to rgba() internally,
+ // except IE9 who retains it as hsla
+
+ setCss('background-color:hsla(120,40%,100%,.5)');
+
+ return contains(mStyle.backgroundColor, 'rgba') || contains(mStyle.backgroundColor, 'hsla');
+ };
+
+ tests['multiplebgs'] = function() {
+ // Setting multiple images AND a color on the background shorthand property
+ // and then querying the style.background property value for the number of
+ // occurrences of "url(" is a reliable method for detecting ACTUAL support for this!
+
+ setCss('background:url(https://),url(https://),red url(https://)');
+
+ // If the UA supports multiple backgrounds, there should be three occurrences
+ // of the string "url(" in the return value for elemStyle.background
+
+ return (/(url\s*\(.*?){3}/).test(mStyle.background);
+ };
+
+
+
+ // this will false positive in Opera Mini
+ // github.com/Modernizr/Modernizr/issues/396
+
+ tests['backgroundsize'] = function() {
+ return testPropsAll('backgroundSize');
+ };
+
+ tests['borderimage'] = function() {
+ return testPropsAll('borderImage');
+ };
+
+
+ // Super comprehensive table about all the unique implementations of
+ // border-radius: muddledramblings.com/table-of-css3-border-radius-compliance
+
+ tests['borderradius'] = function() {
+ return testPropsAll('borderRadius');
+ };
+
+ // WebOS unfortunately false positives on this test.
+ tests['boxshadow'] = function() {
+ return testPropsAll('boxShadow');
+ };
+
+ // FF3.0 will false positive on this test
+ tests['textshadow'] = function() {
+ return document.createElement('div').style.textShadow === '';
+ };
+
+
+ tests['opacity'] = function() {
+ // Browsers that actually have CSS Opacity implemented have done so
+ // according to spec, which means their return values are within the
+ // range of [0.0,1.0] - including the leading zero.
+
+ setCssAll('opacity:.55');
+
+ // The non-literal . in this regex is intentional:
+ // German Chrome returns this value as 0,55
+ // github.com/Modernizr/Modernizr/issues/#issue/59/comment/516632
+ return (/^0.55$/).test(mStyle.opacity);
+ };
+
+
+ // Note, Android < 4 will pass this test, but can only animate
+ // a single property at a time
+ // daneden.me/2011/12/putting-up-with-androids-bullshit/
+ tests['cssanimations'] = function() {
+ return testPropsAll('animationName');
+ };
+
+
+ tests['csscolumns'] = function() {
+ return testPropsAll('columnCount');
+ };
+
+
+ tests['cssgradients'] = function() {
+ /**
+ * For CSS Gradients syntax, please see:
+ * webkit.org/blog/175/introducing-css-gradients/
+ * developer.mozilla.org/en/CSS/-moz-linear-gradient
+ * developer.mozilla.org/en/CSS/-moz-radial-gradient
+ * dev.w3.org/csswg/css3-images/#gradients-
+ */
+
+ var str1 = 'background-image:',
+ str2 = 'gradient(linear,left top,right bottom,from(#9f9),to(white));',
+ str3 = 'linear-gradient(left top,#9f9, white);';
+
+ setCss(
+ // legacy webkit syntax (FIXME: remove when syntax not in use anymore)
+ (str1 + '-webkit- '.split(' ').join(str2 + str1) +
+ // standard syntax // trailing 'background-image:'
+ prefixes.join(str3 + str1)).slice(0, -str1.length)
+ );
+
+ return contains(mStyle.backgroundImage, 'gradient');
+ };
+
+
+ tests['cssreflections'] = function() {
+ return testPropsAll('boxReflect');
+ };
+
+
+ tests['csstransforms'] = function() {
+ return !!testPropsAll('transform');
+ };
+
+
+ tests['csstransforms3d'] = function() {
+
+ var ret = !!testPropsAll('perspective');
+
+ // Webkit's 3D transforms are passed off to the browser's own graphics renderer.
+ // It works fine in Safari on Leopard and Snow Leopard, but not in Chrome in
+ // some conditions. As a result, Webkit typically recognizes the syntax but
+ // will sometimes throw a false positive, thus we must do a more thorough check:
+ if ( ret && 'webkitPerspective' in docElement.style ) {
+
+ // Webkit allows this media query to succeed only if the feature is enabled.
+ // `@media (transform-3d),(-webkit-transform-3d){ ... }`
+ injectElementWithStyles('@media (transform-3d),(-webkit-transform-3d){#modernizr{left:9px;position:absolute;height:3px;}}', function( node, rule ) {
+ ret = node.offsetLeft === 9 && node.offsetHeight === 3;
+ });
+ }
+ return ret;
+ };
+
+
+ tests['csstransitions'] = function() {
+ return testPropsAll('transition');
+ };
+
+
+ /*>>fontface*/
+ // @font-face detection routine by Diego Perini
+ // javascript.nwbox.com/CSSSupport/
+
+ // false positives:
+ // WebOS github.com/Modernizr/Modernizr/issues/342
+ // WP7 github.com/Modernizr/Modernizr/issues/538
+ tests['fontface'] = function() {
+ var bool;
+
+ injectElementWithStyles('@font-face {font-family:"font";src:url("https://")}', function( node, rule ) {
+ var style = document.getElementById('smodernizr'),
+ sheet = style.sheet || style.styleSheet,
+ cssText = sheet ? (sheet.cssRules && sheet.cssRules[0] ? sheet.cssRules[0].cssText : sheet.cssText || '') : '';
+
+ bool = /src/i.test(cssText) && cssText.indexOf(rule.split(' ')[0]) === 0;
+ });
+
+ return bool;
+ };
+ /*>>fontface*/
+
+ // CSS generated content detection
+ tests['generatedcontent'] = function() {
+ var bool;
+
+ injectElementWithStyles(['#',mod,'{font:0/0 a}#',mod,':after{content:"',smile,'";visibility:hidden;font:3px/1 a}'].join(''), function( node ) {
+ bool = node.offsetHeight >= 3;
+ });
+
+ return bool;
+ };
+
+
+
+ // These tests evaluate support of the video/audio elements, as well as
+ // testing what types of content they support.
+ //
+ // We're using the Boolean constructor here, so that we can extend the value
+ // e.g. Modernizr.video // true
+ // Modernizr.video.ogg // 'probably'
+ //
+ // Codec values from : github.com/NielsLeenheer/html5test/blob/9106a8/index.html#L845
+ // thx to NielsLeenheer and zcorpan
+
+ // Note: in some older browsers, "no" was a return value instead of empty string.
+ // It was live in FF3.5.0 and 3.5.1, but fixed in 3.5.2
+ // It was also live in Safari 4.0.0 - 4.0.4, but fixed in 4.0.5
+
+ tests['video'] = function() {
+ var elem = document.createElement('video'),
+ bool = false;
+
+ // IE9 Running on Windows Server SKU can cause an exception to be thrown, bug #224
+ try {
+ if ( bool = !!elem.canPlayType ) {
+ bool = new Boolean(bool);
+ bool.ogg = elem.canPlayType('video/ogg; codecs="theora"') .replace(/^no$/,'');
+
+ // Without QuickTime, this value will be `undefined`. github.com/Modernizr/Modernizr/issues/546
+ bool.h264 = elem.canPlayType('video/mp4; codecs="avc1.42E01E"') .replace(/^no$/,'');
+
+ bool.webm = elem.canPlayType('video/webm; codecs="vp8, vorbis"').replace(/^no$/,'');
+ }
+
+ } catch(e) { }
+
+ return bool;
+ };
+
+ tests['audio'] = function() {
+ var elem = document.createElement('audio'),
+ bool = false;
+
+ try {
+ if ( bool = !!elem.canPlayType ) {
+ bool = new Boolean(bool);
+ bool.ogg = elem.canPlayType('audio/ogg; codecs="vorbis"').replace(/^no$/,'');
+ bool.mp3 = elem.canPlayType('audio/mpeg;') .replace(/^no$/,'');
+
+ // Mimetypes accepted:
+ // developer.mozilla.org/En/Media_formats_supported_by_the_audio_and_video_elements
+ // bit.ly/iphoneoscodecs
+ bool.wav = elem.canPlayType('audio/wav; codecs="1"') .replace(/^no$/,'');
+ bool.m4a = ( elem.canPlayType('audio/x-m4a;') ||
+ elem.canPlayType('audio/aac;')) .replace(/^no$/,'');
+ }
+ } catch(e) { }
+
+ return bool;
+ };
+
+
+ // In FF4, if disabled, window.localStorage should === null.
+
+ // Normally, we could not test that directly and need to do a
+ // `('localStorage' in window) && ` test first because otherwise Firefox will
+ // throw bugzil.la/365772 if cookies are disabled
+
+ // Also in iOS5 Private Browsing mode, attempting to use localStorage.setItem
+ // will throw the exception:
+ // QUOTA_EXCEEDED_ERRROR DOM Exception 22.
+ // Peculiarly, getItem and removeItem calls do not throw.
+
+ // Because we are forced to try/catch this, we'll go aggressive.
+
+ // Just FWIW: IE8 Compat mode supports these features completely:
+ // www.quirksmode.org/dom/html5.html
+ // But IE8 doesn't support either with local files
+
+ tests['localstorage'] = function() {
+ try {
+ localStorage.setItem(mod, mod);
+ localStorage.removeItem(mod);
+ return true;
+ } catch(e) {
+ return false;
+ }
+ };
+
+ tests['sessionstorage'] = function() {
+ try {
+ sessionStorage.setItem(mod, mod);
+ sessionStorage.removeItem(mod);
+ return true;
+ } catch(e) {
+ return false;
+ }
+ };
+
+
+ tests['webworkers'] = function() {
+ return !!window.Worker;
+ };
+
+
+ tests['applicationcache'] = function() {
+ return !!window.applicationCache;
+ };
+
+
+ // Thanks to Erik Dahlstrom
+ tests['svg'] = function() {
+ return !!document.createElementNS && !!document.createElementNS(ns.svg, 'svg').createSVGRect;
+ };
+
+ // specifically for SVG inline in HTML, not within XHTML
+ // test page: paulirish.com/demo/inline-svg
+ tests['inlinesvg'] = function() {
+ var div = document.createElement('div');
+ div.innerHTML = '
';
+ return (div.firstChild && div.firstChild.namespaceURI) == ns.svg;
+ };
+
+ // SVG SMIL animation
+ tests['smil'] = function() {
+ return !!document.createElementNS && /SVGAnimate/.test(toString.call(document.createElementNS(ns.svg, 'animate')));
+ };
+
+ // This test is only for clip paths in SVG proper, not clip paths on HTML content
+ // demo: srufaculty.sru.edu/david.dailey/svg/newstuff/clipPath4.svg
+
+ // However read the comments to dig into applying SVG clippaths to HTML content here:
+ // github.com/Modernizr/Modernizr/issues/213#issuecomment-1149491
+ tests['svgclippaths'] = function() {
+ return !!document.createElementNS && /SVGClipPath/.test(toString.call(document.createElementNS(ns.svg, 'clipPath')));
+ };
+
+ /*>>webforms*/
+ // input features and input types go directly onto the ret object, bypassing the tests loop.
+ // Hold this guy to execute in a moment.
+ function webforms() {
+ /*>>input*/
+ // Run through HTML5's new input attributes to see if the UA understands any.
+ // We're using f which is the
element created early on
+ // Mike Taylr has created a comprehensive resource for testing these attributes
+ // when applied to all input types:
+ // miketaylr.com/code/input-type-attr.html
+ // spec: www.whatwg.org/specs/web-apps/current-work/multipage/the-input-element.html#input-type-attr-summary
+
+ // Only input placeholder is tested while textarea's placeholder is not.
+ // Currently Safari 4 and Opera 11 have support only for the input placeholder
+ // Both tests are available in feature-detects/forms-placeholder.js
+ Modernizr['input'] = (function( props ) {
+ for ( var i = 0, len = props.length; i < len; i++ ) {
+ attrs[ props[i] ] = !!(props[i] in inputElem);
+ }
+ if (attrs.list){
+ // safari false positive's on datalist: webk.it/74252
+ // see also github.com/Modernizr/Modernizr/issues/146
+ attrs.list = !!(document.createElement('datalist') && window.HTMLDataListElement);
+ }
+ return attrs;
+ })('autocomplete autofocus list placeholder max min multiple pattern required step'.split(' '));
+ /*>>input*/
+
+ /*>>inputtypes*/
+ // Run through HTML5's new input types to see if the UA understands any.
+ // This is put behind the tests runloop because it doesn't return a
+ // true/false like all the other tests; instead, it returns an object
+ // containing each input type with its corresponding true/false value
+
+ // Big thanks to @miketaylr for the html5 forms expertise. miketaylr.com/
+ Modernizr['inputtypes'] = (function(props) {
+
+ for ( var i = 0, bool, inputElemType, defaultView, len = props.length; i < len; i++ ) {
+
+ inputElem.setAttribute('type', inputElemType = props[i]);
+ bool = inputElem.type !== 'text';
+
+ // We first check to see if the type we give it sticks..
+ // If the type does, we feed it a textual value, which shouldn't be valid.
+ // If the value doesn't stick, we know there's input sanitization which infers a custom UI
+ if ( bool ) {
+
+ inputElem.value = smile;
+ inputElem.style.cssText = 'position:absolute;visibility:hidden;';
+
+ if ( /^range$/.test(inputElemType) && inputElem.style.WebkitAppearance !== undefined ) {
+
+ docElement.appendChild(inputElem);
+ defaultView = document.defaultView;
+
+ // Safari 2-4 allows the smiley as a value, despite making a slider
+ bool = defaultView.getComputedStyle &&
+ defaultView.getComputedStyle(inputElem, null).WebkitAppearance !== 'textfield' &&
+ // Mobile android web browser has false positive, so must
+ // check the height to see if the widget is actually there.
+ (inputElem.offsetHeight !== 0);
+
+ docElement.removeChild(inputElem);
+
+ } else if ( /^(search|tel)$/.test(inputElemType) ){
+ // Spec doesn't define any special parsing or detectable UI
+ // behaviors so we pass these through as true
+
+ // Interestingly, opera fails the earlier test, so it doesn't
+ // even make it here.
+
+ } else if ( /^(url|email)$/.test(inputElemType) ) {
+ // Real url and email support comes with prebaked validation.
+ bool = inputElem.checkValidity && inputElem.checkValidity() === false;
+
+ } else {
+ // If the upgraded input compontent rejects the :) text, we got a winner
+ bool = inputElem.value != smile;
+ }
+ }
+
+ inputs[ props[i] ] = !!bool;
+ }
+ return inputs;
+ })('search tel url email datetime date month week time datetime-local number range color'.split(' '));
+ /*>>inputtypes*/
+ }
+ /*>>webforms*/
+
+
+ // End of test definitions
+ // -----------------------
+
+
+
+ // Run through all tests and detect their support in the current UA.
+ // todo: hypothetically we could be doing an array of tests and use a basic loop here.
+ for ( var feature in tests ) {
+ if ( hasOwnProp(tests, feature) ) {
+ // run the test, throw the return value into the Modernizr,
+ // then based on that boolean, define an appropriate className
+ // and push it into an array of classes we'll join later.
+ featureName = feature.toLowerCase();
+ Modernizr[featureName] = tests[feature]();
+
+ classes.push((Modernizr[featureName] ? '' : 'no-') + featureName);
+ }
+ }
+
+ /*>>webforms*/
+ // input tests need to run.
+ Modernizr.input || webforms();
+ /*>>webforms*/
+
+
+ /**
+ * addTest allows the user to define their own feature tests
+ * the result will be added onto the Modernizr object,
+ * as well as an appropriate className set on the html element
+ *
+ * @param feature - String naming the feature
+ * @param test - Function returning true if feature is supported, false if not
+ */
+ Modernizr.addTest = function ( feature, test ) {
+ if ( typeof feature == 'object' ) {
+ for ( var key in feature ) {
+ if ( hasOwnProp( feature, key ) ) {
+ Modernizr.addTest( key, feature[ key ] );
+ }
+ }
+ } else {
+
+ feature = feature.toLowerCase();
+
+ if ( Modernizr[feature] !== undefined ) {
+ // we're going to quit if you're trying to overwrite an existing test
+ // if we were to allow it, we'd do this:
+ // var re = new RegExp("\\b(no-)?" + feature + "\\b");
+ // docElement.className = docElement.className.replace( re, '' );
+ // but, no rly, stuff 'em.
+ return Modernizr;
+ }
+
+ test = typeof test == 'function' ? test() : test;
+
+ if (typeof enableClasses !== "undefined" && enableClasses) {
+ docElement.className += ' ' + (test ? '' : 'no-') + feature;
+ }
+ Modernizr[feature] = test;
+
+ }
+
+ return Modernizr; // allow chaining.
+ };
+
+
+ // Reset modElem.cssText to nothing to reduce memory footprint.
+ setCss('');
+ modElem = inputElem = null;
+
+ /*>>shiv*/
+ /*! HTML5 Shiv v3.6.1 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed */
+ ;(function(window, document) {
+ /*jshint evil:true */
+ /** Preset options */
+ var options = window.html5 || {};
+
+ /** Used to skip problem elements */
+ var reSkip = /^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i;
+
+ /** Not all elements can be cloned in IE **/
+ var saveClones = /^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i;
+
+ /** Detect whether the browser supports default html5 styles */
+ var supportsHtml5Styles;
+
+ /** Name of the expando, to work with multiple documents or to re-shiv one document */
+ var expando = '_html5shiv';
+
+ /** The id for the the documents expando */
+ var expanID = 0;
+
+ /** Cached data for each document */
+ var expandoData = {};
+
+ /** Detect whether the browser supports unknown elements */
+ var supportsUnknownElements;
+
+ (function() {
+ try {
+ var a = document.createElement('a');
+ a.innerHTML = '
';
+ //if the hidden property is implemented we can assume, that the browser supports basic HTML5 Styles
+ supportsHtml5Styles = ('hidden' in a);
+
+ supportsUnknownElements = a.childNodes.length == 1 || (function() {
+ // assign a false positive if unable to shiv
+ (document.createElement)('a');
+ var frag = document.createDocumentFragment();
+ return (
+ typeof frag.cloneNode == 'undefined' ||
+ typeof frag.createDocumentFragment == 'undefined' ||
+ typeof frag.createElement == 'undefined'
+ );
+ }());
+ } catch(e) {
+ supportsHtml5Styles = true;
+ supportsUnknownElements = true;
+ }
+
+ }());
+
+ /*--------------------------------------------------------------------------*/
+
+ /**
+ * Creates a style sheet with the given CSS text and adds it to the document.
+ * @private
+ * @param {Document} ownerDocument The document.
+ * @param {String} cssText The CSS text.
+ * @returns {StyleSheet} The style element.
+ */
+ function addStyleSheet(ownerDocument, cssText) {
+ var p = ownerDocument.createElement('p'),
+ parent = ownerDocument.getElementsByTagName('head')[0] || ownerDocument.documentElement;
+
+ p.innerHTML = 'x';
+ return parent.insertBefore(p.lastChild, parent.firstChild);
+ }
+
+ /**
+ * Returns the value of `html5.elements` as an array.
+ * @private
+ * @returns {Array} An array of shived element node names.
+ */
+ function getElements() {
+ var elements = html5.elements;
+ return typeof elements == 'string' ? elements.split(' ') : elements;
+ }
+
+ /**
+ * Returns the data associated to the given document
+ * @private
+ * @param {Document} ownerDocument The document.
+ * @returns {Object} An object of data.
+ */
+ function getExpandoData(ownerDocument) {
+ var data = expandoData[ownerDocument[expando]];
+ if (!data) {
+ data = {};
+ expanID++;
+ ownerDocument[expando] = expanID;
+ expandoData[expanID] = data;
+ }
+ return data;
+ }
+
+ /**
+ * returns a shived element for the given nodeName and document
+ * @memberOf html5
+ * @param {String} nodeName name of the element
+ * @param {Document} ownerDocument The context document.
+ * @returns {Object} The shived element.
+ */
+ function createElement(nodeName, ownerDocument, data){
+ if (!ownerDocument) {
+ ownerDocument = document;
+ }
+ if(supportsUnknownElements){
+ return ownerDocument.createElement(nodeName);
+ }
+ if (!data) {
+ data = getExpandoData(ownerDocument);
+ }
+ var node;
+
+ if (data.cache[nodeName]) {
+ node = data.cache[nodeName].cloneNode();
+ } else if (saveClones.test(nodeName)) {
+ node = (data.cache[nodeName] = data.createElem(nodeName)).cloneNode();
+ } else {
+ node = data.createElem(nodeName);
+ }
+
+ // Avoid adding some elements to fragments in IE < 9 because
+ // * Attributes like `name` or `type` cannot be set/changed once an element
+ // is inserted into a document/fragment
+ // * Link elements with `src` attributes that are inaccessible, as with
+ // a 403 response, will cause the tab/window to crash
+ // * Script elements appended to fragments will execute when their `src`
+ // or `text` property is set
+ return node.canHaveChildren && !reSkip.test(nodeName) ? data.frag.appendChild(node) : node;
+ }
+
+ /**
+ * returns a shived DocumentFragment for the given document
+ * @memberOf html5
+ * @param {Document} ownerDocument The context document.
+ * @returns {Object} The shived DocumentFragment.
+ */
+ function createDocumentFragment(ownerDocument, data){
+ if (!ownerDocument) {
+ ownerDocument = document;
+ }
+ if(supportsUnknownElements){
+ return ownerDocument.createDocumentFragment();
+ }
+ data = data || getExpandoData(ownerDocument);
+ var clone = data.frag.cloneNode(),
+ i = 0,
+ elems = getElements(),
+ l = elems.length;
+ for(;i
>shiv*/
+
+ // Assign private properties to the return object with prefix
+ Modernizr._version = version;
+
+ // expose these for the plugin API. Look in the source for how to join() them against your input
+ /*>>prefixes*/
+ Modernizr._prefixes = prefixes;
+ /*>>prefixes*/
+ /*>>domprefixes*/
+ Modernizr._domPrefixes = domPrefixes;
+ Modernizr._cssomPrefixes = cssomPrefixes;
+ /*>>domprefixes*/
+
+ /*>>mq*/
+ // Modernizr.mq tests a given media query, live against the current state of the window
+ // A few important notes:
+ // * If a browser does not support media queries at all (eg. oldIE) the mq() will always return false
+ // * A max-width or orientation query will be evaluated against the current state, which may change later.
+ // * You must specify values. Eg. If you are testing support for the min-width media query use:
+ // Modernizr.mq('(min-width:0)')
+ // usage:
+ // Modernizr.mq('only screen and (max-width:768)')
+ Modernizr.mq = testMediaQuery;
+ /*>>mq*/
+
+ /*>>hasevent*/
+ // Modernizr.hasEvent() detects support for a given event, with an optional element to test on
+ // Modernizr.hasEvent('gesturestart', elem)
+ Modernizr.hasEvent = isEventSupported;
+ /*>>hasevent*/
+
+ /*>>testprop*/
+ // Modernizr.testProp() investigates whether a given style property is recognized
+ // Note that the property names must be provided in the camelCase variant.
+ // Modernizr.testProp('pointerEvents')
+ Modernizr.testProp = function(prop){
+ return testProps([prop]);
+ };
+ /*>>testprop*/
+
+ /*>>testallprops*/
+ // Modernizr.testAllProps() investigates whether a given style property,
+ // or any of its vendor-prefixed variants, is recognized
+ // Note that the property names must be provided in the camelCase variant.
+ // Modernizr.testAllProps('boxSizing')
+ Modernizr.testAllProps = testPropsAll;
+ /*>>testallprops*/
+
+
+ /*>>teststyles*/
+ // Modernizr.testStyles() allows you to add custom styles to the document and test an element afterwards
+ // Modernizr.testStyles('#modernizr { position:absolute }', function(elem, rule){ ... })
+ Modernizr.testStyles = injectElementWithStyles;
+ /*>>teststyles*/
+
+
+ /*>>prefixed*/
+ // Modernizr.prefixed() returns the prefixed or nonprefixed property name variant of your input
+ // Modernizr.prefixed('boxSizing') // 'MozBoxSizing'
+
+ // Properties must be passed as dom-style camelcase, rather than `box-sizing` hypentated style.
+ // Return values will also be the camelCase variant, if you need to translate that to hypenated style use:
+ //
+ // str.replace(/([A-Z])/g, function(str,m1){ return '-' + m1.toLowerCase(); }).replace(/^ms-/,'-ms-');
+
+ // If you're trying to ascertain which transition end event to bind to, you might do something like...
+ //
+ // var transEndEventNames = {
+ // 'WebkitTransition' : 'webkitTransitionEnd',
+ // 'MozTransition' : 'transitionend',
+ // 'OTransition' : 'oTransitionEnd',
+ // 'msTransition' : 'MSTransitionEnd',
+ // 'transition' : 'transitionend'
+ // },
+ // transEndEventName = transEndEventNames[ Modernizr.prefixed('transition') ];
+
+ Modernizr.prefixed = function(prop, obj, elem){
+ if(!obj) {
+ return testPropsAll(prop, 'pfx');
+ } else {
+ // Testing DOM property e.g. Modernizr.prefixed('requestAnimationFrame', window) // 'mozRequestAnimationFrame'
+ return testPropsAll(prop, obj, elem);
+ }
+ };
+ /*>>prefixed*/
+
+
+ /*>>cssclasses*/
+ // Remove "no-js" class from element, if it exists:
+ docElement.className = docElement.className.replace(/(^|\s)no-js(\s|$)/, '$1$2') +
+
+ // Add the new classes to the element.
+ (enableClasses ? ' js ' + classes.join(' ') : '');
+ /*>>cssclasses*/
+
+ return Modernizr;
+
+})(this, this.document);
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/respond.js b/samples/angular-aad-webapi/api/api.securecall/Scripts/respond.js
new file mode 100644
index 000000000..378d773d1
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/respond.js
@@ -0,0 +1,340 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*! matchMedia() polyfill - Test a CSS media type/query in JS. Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas. Dual MIT/BSD license */
+/*! NOTE: If you're already including a window.matchMedia polyfill via Modernizr or otherwise, you don't need this part */
+window.matchMedia = window.matchMedia || (function(doc, undefined){
+
+ var bool,
+ docElem = doc.documentElement,
+ refNode = docElem.firstElementChild || docElem.firstChild,
+ // fakeBody required for
+ fakeBody = doc.createElement('body'),
+ div = doc.createElement('div');
+
+ div.id = 'mq-test-1';
+ div.style.cssText = "position:absolute;top:-100em";
+ fakeBody.style.background = "none";
+ fakeBody.appendChild(div);
+
+ return function(q){
+
+ div.innerHTML = '';
+
+ docElem.insertBefore(fakeBody, refNode);
+ bool = div.offsetWidth == 42;
+ docElem.removeChild(fakeBody);
+
+ return { matches: bool, media: q };
+ };
+
+})(document);
+
+
+
+
+/*! Respond.js v1.2.0: min/max-width media query polyfill. (c) Scott Jehl. MIT/GPLv2 Lic. j.mp/respondjs */
+(function( win ){
+ //exposed namespace
+ win.respond = {};
+
+ //define update even in native-mq-supporting browsers, to avoid errors
+ respond.update = function(){};
+
+ //expose media query support flag for external use
+ respond.mediaQueriesSupported = win.matchMedia && win.matchMedia( "only all" ).matches;
+
+ //if media queries are supported, exit here
+ if( respond.mediaQueriesSupported ){ return; }
+
+ //define vars
+ var doc = win.document,
+ docElem = doc.documentElement,
+ mediastyles = [],
+ rules = [],
+ appendedEls = [],
+ parsedSheets = {},
+ resizeThrottle = 30,
+ head = doc.getElementsByTagName( "head" )[0] || docElem,
+ base = doc.getElementsByTagName( "base" )[0],
+ links = head.getElementsByTagName( "link" ),
+ requestQueue = [],
+
+ //loop stylesheets, send text content to translate
+ ripCSS = function(){
+ var sheets = links,
+ sl = sheets.length,
+ i = 0,
+ //vars for loop:
+ sheet, href, media, isCSS;
+
+ for( ; i < sl; i++ ){
+ sheet = sheets[ i ],
+ href = sheet.href,
+ media = sheet.media,
+ isCSS = sheet.rel && sheet.rel.toLowerCase() === "stylesheet";
+
+ //only links plz and prevent re-parsing
+ if( !!href && isCSS && !parsedSheets[ href ] ){
+ // selectivizr exposes css through the rawCssText expando
+ if (sheet.styleSheet && sheet.styleSheet.rawCssText) {
+ translate( sheet.styleSheet.rawCssText, href, media );
+ parsedSheets[ href ] = true;
+ } else {
+ if( (!/^([a-zA-Z:]*\/\/)/.test( href ) && !base)
+ || href.replace( RegExp.$1, "" ).split( "/" )[0] === win.location.host ){
+ requestQueue.push( {
+ href: href,
+ media: media
+ } );
+ }
+ }
+ }
+ }
+ makeRequests();
+ },
+
+ //recurse through request queue, get css text
+ makeRequests = function(){
+ if( requestQueue.length ){
+ var thisRequest = requestQueue.shift();
+
+ ajax( thisRequest.href, function( styles ){
+ translate( styles, thisRequest.href, thisRequest.media );
+ parsedSheets[ thisRequest.href ] = true;
+ makeRequests();
+ } );
+ }
+ },
+
+ //find media blocks in css text, convert to style blocks
+ translate = function( styles, href, media ){
+ var qs = styles.match( /@media[^\{]+\{([^\{\}]*\{[^\}\{]*\})+/gi ),
+ ql = qs && qs.length || 0,
+ //try to get CSS path
+ href = href.substring( 0, href.lastIndexOf( "/" )),
+ repUrls = function( css ){
+ return css.replace( /(url\()['"]?([^\/\)'"][^:\)'"]+)['"]?(\))/g, "$1" + href + "$2$3" );
+ },
+ useMedia = !ql && media,
+ //vars used in loop
+ i = 0,
+ j, fullq, thisq, eachq, eql;
+
+ //if path exists, tack on trailing slash
+ if( href.length ){ href += "/"; }
+
+ //if no internal queries exist, but media attr does, use that
+ //note: this currently lacks support for situations where a media attr is specified on a link AND
+ //its associated stylesheet has internal CSS media queries.
+ //In those cases, the media attribute will currently be ignored.
+ if( useMedia ){
+ ql = 1;
+ }
+
+
+ for( ; i < ql; i++ ){
+ j = 0;
+
+ //media attr
+ if( useMedia ){
+ fullq = media;
+ rules.push( repUrls( styles ) );
+ }
+ //parse for styles
+ else{
+ fullq = qs[ i ].match( /@media *([^\{]+)\{([\S\s]+?)$/ ) && RegExp.$1;
+ rules.push( RegExp.$2 && repUrls( RegExp.$2 ) );
+ }
+
+ eachq = fullq.split( "," );
+ eql = eachq.length;
+
+ for( ; j < eql; j++ ){
+ thisq = eachq[ j ];
+ mediastyles.push( {
+ media : thisq.split( "(" )[ 0 ].match( /(only\s+)?([a-zA-Z]+)\s?/ ) && RegExp.$2 || "all",
+ rules : rules.length - 1,
+ hasquery: thisq.indexOf("(") > -1,
+ minw : thisq.match( /\(min\-width:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/ ) && parseFloat( RegExp.$1 ) + ( RegExp.$2 || "" ),
+ maxw : thisq.match( /\(max\-width:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/ ) && parseFloat( RegExp.$1 ) + ( RegExp.$2 || "" )
+ } );
+ }
+ }
+
+ applyMedia();
+ },
+
+ lastCall,
+
+ resizeDefer,
+
+ // returns the value of 1em in pixels
+ getEmValue = function() {
+ var ret,
+ div = doc.createElement('div'),
+ body = doc.body,
+ fakeUsed = false;
+
+ div.style.cssText = "position:absolute;font-size:1em;width:1em";
+
+ if( !body ){
+ body = fakeUsed = doc.createElement( "body" );
+ body.style.background = "none";
+ }
+
+ body.appendChild( div );
+
+ docElem.insertBefore( body, docElem.firstChild );
+
+ ret = div.offsetWidth;
+
+ if( fakeUsed ){
+ docElem.removeChild( body );
+ }
+ else {
+ body.removeChild( div );
+ }
+
+ //also update eminpx before returning
+ ret = eminpx = parseFloat(ret);
+
+ return ret;
+ },
+
+ //cached container for 1em value, populated the first time it's needed
+ eminpx,
+
+ //enable/disable styles
+ applyMedia = function( fromResize ){
+ var name = "clientWidth",
+ docElemProp = docElem[ name ],
+ currWidth = doc.compatMode === "CSS1Compat" && docElemProp || doc.body[ name ] || docElemProp,
+ styleBlocks = {},
+ lastLink = links[ links.length-1 ],
+ now = (new Date()).getTime();
+
+ //throttle resize calls
+ if( fromResize && lastCall && now - lastCall < resizeThrottle ){
+ clearTimeout( resizeDefer );
+ resizeDefer = setTimeout( applyMedia, resizeThrottle );
+ return;
+ }
+ else {
+ lastCall = now;
+ }
+
+ for( var i in mediastyles ){
+ var thisstyle = mediastyles[ i ],
+ min = thisstyle.minw,
+ max = thisstyle.maxw,
+ minnull = min === null,
+ maxnull = max === null,
+ em = "em";
+
+ if( !!min ){
+ min = parseFloat( min ) * ( min.indexOf( em ) > -1 ? ( eminpx || getEmValue() ) : 1 );
+ }
+ if( !!max ){
+ max = parseFloat( max ) * ( max.indexOf( em ) > -1 ? ( eminpx || getEmValue() ) : 1 );
+ }
+
+ // if there's no media query at all (the () part), or min or max is not null, and if either is present, they're true
+ if( !thisstyle.hasquery || ( !minnull || !maxnull ) && ( minnull || currWidth >= min ) && ( maxnull || currWidth <= max ) ){
+ if( !styleBlocks[ thisstyle.media ] ){
+ styleBlocks[ thisstyle.media ] = [];
+ }
+ styleBlocks[ thisstyle.media ].push( rules[ thisstyle.rules ] );
+ }
+ }
+
+ //remove any existing respond style element(s)
+ for( var i in appendedEls ){
+ if( appendedEls[ i ] && appendedEls[ i ].parentNode === head ){
+ head.removeChild( appendedEls[ i ] );
+ }
+ }
+
+ //inject active styles, grouped by media type
+ for( var i in styleBlocks ){
+ var ss = doc.createElement( "style" ),
+ css = styleBlocks[ i ].join( "\n" );
+
+ ss.type = "text/css";
+ ss.media = i;
+
+ //originally, ss was appended to a documentFragment and sheets were appended in bulk.
+ //this caused crashes in IE in a number of circumstances, such as when the HTML element had a bg image set, so appending beforehand seems best. Thanks to @dvelyk for the initial research on this one!
+ head.insertBefore( ss, lastLink.nextSibling );
+
+ if ( ss.styleSheet ){
+ ss.styleSheet.cssText = css;
+ }
+ else {
+ ss.appendChild( doc.createTextNode( css ) );
+ }
+
+ //push to appendedEls to track for later removal
+ appendedEls.push( ss );
+ }
+ },
+ //tweaked Ajax functions from Quirksmode
+ ajax = function( url, callback ) {
+ var req = xmlHttp();
+ if (!req){
+ return;
+ }
+ req.open( "GET", url, true );
+ req.onreadystatechange = function () {
+ if ( req.readyState != 4 || req.status != 200 && req.status != 304 ){
+ return;
+ }
+ callback( req.responseText );
+ }
+ if ( req.readyState == 4 ){
+ return;
+ }
+ req.send( null );
+ },
+ //define ajax obj
+ xmlHttp = (function() {
+ var xmlhttpmethod = false;
+ try {
+ xmlhttpmethod = new XMLHttpRequest();
+ }
+ catch( e ){
+ xmlhttpmethod = new ActiveXObject( "Microsoft.XMLHTTP" );
+ }
+ return function(){
+ return xmlhttpmethod;
+ };
+ })();
+
+ //translate CSS
+ ripCSS();
+
+ //expose update for re-running respond later on
+ respond.update = ripCSS;
+
+ //adjust on resize
+ function callMedia(){
+ applyMedia( true );
+ }
+ if( win.addEventListener ){
+ win.addEventListener( "resize", callMedia, false );
+ }
+ else if( win.attachEvent ){
+ win.attachEvent( "onresize", callMedia );
+ }
+})(this);
diff --git a/samples/angular-aad-webapi/api/api.securecall/Scripts/respond.min.js b/samples/angular-aad-webapi/api/api.securecall/Scripts/respond.min.js
new file mode 100644
index 000000000..a84813706
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Scripts/respond.min.js
@@ -0,0 +1,20 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*! matchMedia() polyfill - Test a CSS media type/query in JS. Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas. Dual MIT/BSD license */
+/*! NOTE: If you're already including a window.matchMedia polyfill via Modernizr or otherwise, you don't need this part */
+window.matchMedia=window.matchMedia||(function(e,f){var c,a=e.documentElement,b=a.firstElementChild||a.firstChild,d=e.createElement("body"),g=e.createElement("div");g.id="mq-test-1";g.style.cssText="position:absolute;top:-100em";d.style.background="none";d.appendChild(g);return function(h){g.innerHTML='';a.insertBefore(d,b);c=g.offsetWidth==42;a.removeChild(d);return{matches:c,media:h}}})(document);
+
+/*! Respond.js v1.2.0: min/max-width media query polyfill. (c) Scott Jehl. MIT/GPLv2 Lic. j.mp/respondjs */
+(function(e){e.respond={};respond.update=function(){};respond.mediaQueriesSupported=e.matchMedia&&e.matchMedia("only all").matches;if(respond.mediaQueriesSupported){return}var w=e.document,s=w.documentElement,i=[],k=[],q=[],o={},h=30,f=w.getElementsByTagName("head")[0]||s,g=w.getElementsByTagName("base")[0],b=f.getElementsByTagName("link"),d=[],a=function(){var D=b,y=D.length,B=0,A,z,C,x;for(;B-1,minw:F.match(/\(min\-width:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/)&&parseFloat(RegExp.$1)+(RegExp.$2||""),maxw:F.match(/\(max\-width:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/)&&parseFloat(RegExp.$1)+(RegExp.$2||"")})}}j()},l,r,v=function(){var z,A=w.createElement("div"),x=w.body,y=false;A.style.cssText="position:absolute;font-size:1em;width:1em";if(!x){x=y=w.createElement("body");x.style.background="none"}x.appendChild(A);s.insertBefore(x,s.firstChild);z=A.offsetWidth;if(y){s.removeChild(x)}else{x.removeChild(A)}z=p=parseFloat(z);return z},p,j=function(I){var x="clientWidth",B=s[x],H=w.compatMode==="CSS1Compat"&&B||w.body[x]||B,D={},G=b[b.length-1],z=(new Date()).getTime();if(I&&l&&z-l-1?(p||v()):1)}if(!!J){J=parseFloat(J)*(J.indexOf(y)>-1?(p||v()):1)}if(!K.hasquery||(!A||!L)&&(A||H>=C)&&(L||H<=J)){if(!D[K.media]){D[K.media]=[]}D[K.media].push(k[K.rules])}}for(var E in q){if(q[E]&&q[E].parentNode===f){f.removeChild(q[E])}}for(var E in D){var M=w.createElement("style"),F=D[E].join("\n");M.type="text/css";M.media=E;f.insertBefore(M,G.nextSibling);if(M.styleSheet){M.styleSheet.cssText=F}else{M.appendChild(w.createTextNode(F))}q.push(M)}},n=function(x,z){var y=c();if(!y){return}y.open("GET",x,true);y.onreadystatechange=function(){if(y.readyState!=4||y.status!=200&&y.status!=304){return}z(y.responseText)};if(y.readyState==4){return}y.send(null)},c=(function(){var x=false;try{x=new XMLHttpRequest()}catch(y){x=new ActiveXObject("Microsoft.XMLHTTP")}return function(){return x}})();a();respond.update=a;function t(){j(true)}if(e.addEventListener){e.addEventListener("resize",t,false)}else{if(e.attachEvent){e.attachEvent("onresize",t)}}})(this);
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/Startup.cs b/samples/angular-aad-webapi/api/api.securecall/Startup.cs
new file mode 100644
index 000000000..8d428cbe5
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Startup.cs
@@ -0,0 +1,41 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using Microsoft.Owin;
+using Owin;
+using System.Web.Http;
+using Microsoft.Owin.Security.ActiveDirectory;
+using System.IdentityModel.Tokens;
+using System.Configuration;
+
+[assembly: OwinStartup(typeof(api.securecall.Startup))]
+
+namespace api.securecall
+{
+ public partial class Startup
+ {
+ public void Configuration(IAppBuilder app)
+ {
+ HttpConfiguration config = new HttpConfiguration();
+
+ ConfigureAuthNew(app);
+
+ WebApiConfig.Register(config);
+
+ app.UseWebApi(config);
+ }
+
+ public void ConfigureAuthNew(IAppBuilder app)
+ {
+ app.UseWindowsAzureActiveDirectoryBearerAuthentication(
+ new WindowsAzureActiveDirectoryBearerAuthenticationOptions
+ {
+ TokenValidationParameters = new TokenValidationParameters
+ {
+ ValidAudience = ConfigurationManager.AppSettings["Audience"]
+ },
+ Tenant = ConfigurationManager.AppSettings["Tenant"]
+ });
+ }
+ }
+}
diff --git a/samples/angular-aad-webapi/api/api.securecall/Views/Home/Index.cshtml b/samples/angular-aad-webapi/api/api.securecall/Views/Home/Index.cshtml
new file mode 100644
index 000000000..acaf98f38
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Views/Home/Index.cshtml
@@ -0,0 +1,24 @@
+
+
ASP.NET
+
ASP.NET is a free web framework for building great Web sites and Web applications using HTML, CSS, and JavaScript.
+
Learn more »
+
+
+
+
Getting started
+
ASP.NET Web API is a framework that makes it easy to build HTTP services that reach
+ a broad range of clients, including browsers and mobile devices. ASP.NET Web API
+ is an ideal platform for building RESTful applications on the .NET Framework.
+
Learn more »
+
+
+
Get more libraries
+
NuGet is a free Visual Studio extension that makes it easy to add, remove, and update libraries and tools in Visual Studio projects.
+
Learn more »
+
+
+
Web Hosting
+
You can easily find a web hosting company that offers the right mix of features and price for your applications.
+
Learn more »
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/Views/Shared/Error.cshtml b/samples/angular-aad-webapi/api/api.securecall/Views/Shared/Error.cshtml
new file mode 100644
index 000000000..4c9a28a21
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Views/Shared/Error.cshtml
@@ -0,0 +1,13 @@
+
+
+
+
+ Error
+
+
+
+ Error.
+ An error occurred while processing your request.
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/Views/Shared/_Layout.cshtml b/samples/angular-aad-webapi/api/api.securecall/Views/Shared/_Layout.cshtml
new file mode 100644
index 000000000..7b23b2f31
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Views/Shared/_Layout.cshtml
@@ -0,0 +1,41 @@
+
+
+
+
+
+ @ViewBag.Title
+ @Styles.Render("~/Content/css")
+ @Scripts.Render("~/bundles/modernizr")
+
+
+
+
+
+
+
+ - @Html.ActionLink("Home", "Index", "Home", new { area = "" }, null)
+ - @Html.ActionLink("API", "Index", "Help", new { area = "" }, null)
+
+
+
+
+
+
+ @Scripts.Render("~/bundles/jquery")
+ @Scripts.Render("~/bundles/bootstrap")
+ @RenderSection("scripts", required: false)
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/Views/Web.config b/samples/angular-aad-webapi/api/api.securecall/Views/Web.config
new file mode 100644
index 000000000..ccaa33499
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Views/Web.config
@@ -0,0 +1,43 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/Views/_ViewStart.cshtml b/samples/angular-aad-webapi/api/api.securecall/Views/_ViewStart.cshtml
new file mode 100644
index 000000000..2de62418c
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Views/_ViewStart.cshtml
@@ -0,0 +1,3 @@
+@{
+ Layout = "~/Views/Shared/_Layout.cshtml";
+}
diff --git a/samples/angular-aad-webapi/api/api.securecall/Web.Debug.config b/samples/angular-aad-webapi/api/api.securecall/Web.Debug.config
new file mode 100644
index 000000000..680849f61
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Web.Debug.config
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/Web.Release.config b/samples/angular-aad-webapi/api/api.securecall/Web.Release.config
new file mode 100644
index 000000000..943c9c0de
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Web.Release.config
@@ -0,0 +1,31 @@
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/Web.config b/samples/angular-aad-webapi/api/api.securecall/Web.config
new file mode 100644
index 000000000..3efc57005
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/Web.config
@@ -0,0 +1,94 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/api.securecall.csproj b/samples/angular-aad-webapi/api/api.securecall/api.securecall.csproj
new file mode 100644
index 000000000..1c7cc734e
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/api.securecall.csproj
@@ -0,0 +1,352 @@
+
+
+
+
+
+
+ Debug
+ AnyCPU
+
+
+ 2.0
+ {2B18BBA3-F890-4279-932D-2803C08DA798}
+ {349c5851-65df-11da-9384-00065b846f21};{fae04ec0-301f-11d3-bf4b-00c04f79efbc}
+ Library
+ Properties
+ api.securecall
+ api.securecall
+ v4.5
+ false
+ true
+
+
+
+
+
+
+
+
+
+ true
+ full
+ false
+ bin\
+ DEBUG;TRACE
+ prompt
+ 4
+
+
+ pdbonly
+ true
+ bin\
+ TRACE
+ prompt
+ 4
+
+
+
+ ..\packages\Microsoft.CodeDom.Providers.DotNetCompilerPlatform.1.0.0\lib\net45\Microsoft.CodeDom.Providers.DotNetCompilerPlatform.dll
+ True
+
+
+
+ ..\packages\Microsoft.Owin.Security.ActiveDirectory.3.0.1\lib\net45\Microsoft.Owin.Security.ActiveDirectory.dll
+ True
+
+
+ ..\packages\Microsoft.Owin.Security.Jwt.3.0.1\lib\net45\Microsoft.Owin.Security.Jwt.dll
+ True
+
+
+
+
+
+ ..\packages\System.IdentityModel.Tokens.Jwt.4.0.0\lib\net45\System.IdentityModel.Tokens.Jwt.dll
+ True
+
+
+ ..\packages\Microsoft.AspNet.Cors.5.2.3\lib\net45\System.Web.Cors.dll
+ True
+
+
+
+
+
+
+
+ ..\packages\Microsoft.AspNet.WebApi.Cors.5.2.3\lib\net45\System.Web.Http.Cors.dll
+ True
+
+
+
+
+
+
+
+
+
+ True
+ ..\packages\Microsoft.Web.Infrastructure.1.0.0.0\lib\net40\Microsoft.Web.Infrastructure.dll
+
+
+ ..\packages\Newtonsoft.Json.6.0.4\lib\net45\Newtonsoft.Json.dll
+
+
+
+
+ ..\packages\Microsoft.AspNet.WebApi.Client.5.2.3\lib\net45\System.Net.Http.Formatting.dll
+
+
+
+
+ True
+ ..\packages\Microsoft.AspNet.WebPages.3.2.3\lib\net45\System.Web.Helpers.dll
+
+
+ ..\packages\Microsoft.AspNet.WebApi.Core.5.2.3\lib\net45\System.Web.Http.dll
+
+
+ ..\packages\Microsoft.AspNet.WebApi.WebHost.5.2.3\lib\net45\System.Web.Http.WebHost.dll
+
+
+ True
+ ..\packages\Microsoft.AspNet.Mvc.5.2.3\lib\net45\System.Web.Mvc.dll
+
+
+ ..\packages\Microsoft.AspNet.Web.Optimization.1.1.3\lib\net40\System.Web.Optimization.dll
+
+
+ True
+ ..\packages\Microsoft.AspNet.Razor.3.2.3\lib\net45\System.Web.Razor.dll
+
+
+ True
+ ..\packages\Microsoft.AspNet.WebPages.3.2.3\lib\net45\System.Web.WebPages.dll
+
+
+ True
+ ..\packages\Microsoft.AspNet.WebPages.3.2.3\lib\net45\System.Web.WebPages.Deployment.dll
+
+
+ True
+ ..\packages\Microsoft.AspNet.WebPages.3.2.3\lib\net45\System.Web.WebPages.Razor.dll
+
+
+ True
+ ..\packages\WebGrease.1.5.2\lib\WebGrease.dll
+
+
+ True
+ ..\packages\Antlr.3.4.1.9004\lib\Antlr3.Runtime.dll
+
+
+
+
+ ..\packages\EntityFramework.6.1.3\lib\net45\EntityFramework.dll
+
+
+ ..\packages\EntityFramework.6.1.3\lib\net45\EntityFramework.SqlServer.dll
+
+
+ ..\packages\Microsoft.AspNet.Identity.Core.2.2.1\lib\net45\Microsoft.AspNet.Identity.Core.dll
+
+
+ ..\packages\Microsoft.AspNet.Identity.Owin.2.2.1\lib\net45\Microsoft.AspNet.Identity.Owin.dll
+
+
+ ..\packages\Microsoft.AspNet.Identity.EntityFramework.2.2.1\lib\net45\Microsoft.AspNet.Identity.EntityFramework.dll
+
+
+ ..\packages\Owin.1.0\lib\net40\Owin.dll
+
+
+ ..\packages\Microsoft.Owin.3.0.1\lib\net45\Microsoft.Owin.dll
+
+
+ ..\packages\Microsoft.Owin.Host.SystemWeb.3.0.1\lib\net45\Microsoft.Owin.Host.SystemWeb.dll
+
+
+ ..\packages\Microsoft.Owin.Security.3.0.1\lib\net45\Microsoft.Owin.Security.dll
+
+
+ ..\packages\Microsoft.Owin.Security.Facebook.3.0.1\lib\net45\Microsoft.Owin.Security.Facebook.dll
+
+
+ ..\packages\Microsoft.Owin.Security.Cookies.3.0.1\lib\net45\Microsoft.Owin.Security.Cookies.dll
+
+
+ ..\packages\Microsoft.Owin.Security.OAuth.3.0.1\lib\net45\Microsoft.Owin.Security.OAuth.dll
+
+
+ ..\packages\Microsoft.Owin.Security.Google.3.0.1\lib\net45\Microsoft.Owin.Security.Google.dll
+
+
+ ..\packages\Microsoft.Owin.Security.Twitter.3.0.1\lib\net45\Microsoft.Owin.Security.Twitter.dll
+
+
+ ..\packages\Microsoft.Owin.Security.MicrosoftAccount.3.0.1\lib\net45\Microsoft.Owin.Security.MicrosoftAccount.dll
+
+
+ ..\packages\Microsoft.AspNet.WebApi.Owin.5.2.3\lib\net45\System.Web.Http.Owin.dll
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Global.asax
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Web.config
+
+
+ Web.config
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 10.0
+ $(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)
+
+
+
+
+
+
+
+
+
+
+
+ True
+ True
+ 49242
+ /
+ http://localhost:49242/
+ False
+ False
+
+
+ False
+
+
+
+
+
+
+ This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}.
+
+
+
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/api.securecall.csproj.user b/samples/angular-aad-webapi/api/api.securecall/api.securecall.csproj.user
new file mode 100644
index 000000000..3e80ea46a
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/api.securecall.csproj.user
@@ -0,0 +1,38 @@
+
+
+
+ true
+ 600
+ True
+ False
+ True
+
+ False
+ pnpwebappsecure - Web Deploy
+
+
+
+
+
+
+
+ CurrentPage
+ True
+ False
+ False
+ False
+
+
+
+
+
+
+
+
+ True
+ True
+
+
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Antlr3.Runtime.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Antlr3.Runtime.dll
new file mode 100644
index 000000000..34bd478f1
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Antlr3.Runtime.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Antlr3.Runtime.pdb b/samples/angular-aad-webapi/api/api.securecall/bin/Antlr3.Runtime.pdb
new file mode 100644
index 000000000..315edcf38
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Antlr3.Runtime.pdb differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.SqlServer.dll b/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.SqlServer.dll
new file mode 100644
index 000000000..481c1c7c1
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.SqlServer.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.SqlServer.xml b/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.SqlServer.xml
new file mode 100644
index 000000000..e2e028a17
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.SqlServer.xml
@@ -0,0 +1,2048 @@
+
+
+
+ EntityFramework.SqlServer
+
+
+
+
+ Contains extension methods for the class.
+
+
+
+
+ Configures an awaiter used to await this to avoid
+ marshalling the continuation
+ back to the original context, but preserve the current culture and UI culture.
+
+
+ The type of the result produced by the associated .
+
+ The task to be awaited on.
+ An object used to await this task.
+
+
+
+ Configures an awaiter used to await this to avoid
+ marshalling the continuation
+ back to the original context, but preserve the current culture and UI culture.
+
+ The task to be awaited on.
+ An object used to await this task.
+
+
+
+ Provides an awaitable object that allows for awaits on that
+ preserve the culture.
+
+
+ The type of the result produced by the associated .
+
+ This type is intended for compiler use only.
+
+
+
+ Constructs a new instance of the class.
+
+ The task to be awaited on.
+
+
+ Gets an awaiter used to await this .
+ An awaiter instance.
+ This method is intended for compiler user rather than use directly in code.
+
+
+ Ends the await on the completed .
+ The result of the completed .
+ The awaiter was not properly initialized.
+ The task was canceled.
+ The task completed in a Faulted state.
+
+
+ This method is not implemented and should not be called.
+ The action to invoke when the await operation completes.
+
+
+
+ Schedules the continuation onto the associated with this
+ .
+
+ The action to invoke when the await operation completes.
+
+ The argument is null
+ (Nothing in Visual Basic).
+
+ The awaiter was not properly initialized.
+ This method is intended for compiler user rather than use directly in code.
+
+
+
+ Gets whether this Task has completed.
+
+
+ will return true when the Task is in one of the three
+ final states: RanToCompletion,
+ Faulted, or
+ Canceled.
+
+
+
+
+ Provides an awaitable object that allows for awaits on that
+ preserve the culture.
+
+ This type is intended for compiler use only.
+
+
+
+ Constructs a new instance of the class.
+
+ The task to be awaited on.
+
+
+ Gets an awaiter used to await this .
+ An awaiter instance.
+ This method is intended for compiler user rather than use directly in code.
+
+
+ Ends the await on the completed .
+ The awaiter was not properly initialized.
+ The task was canceled.
+ The task completed in a Faulted state.
+
+
+ This method is not implemented and should not be called.
+ The action to invoke when the await operation completes.
+
+
+
+ Schedules the continuation onto the associated with this
+ .
+
+ The action to invoke when the await operation completes.
+
+ The argument is null
+ (Nothing in Visual Basic).
+
+ The awaiter was not properly initialized.
+ This method is intended for compiler user rather than use directly in code.
+
+
+
+ Gets whether this Task has completed.
+
+
+ will return true when the Task is in one of the three
+ final states: RanToCompletion,
+ Faulted, or
+ Canceled.
+
+
+
+
+ An that retries actions that throw exceptions caused by SQL Azure transient failures.
+
+
+ This execution strategy will retry the operation on and
+ if the contains any of the following error numbers:
+ 40613, 40501, 40197, 10929, 10928, 10060, 10054, 10053, 233, 64 and 20
+
+
+
+
+ Creates a new instance of .
+
+
+ The default retry limit is 5, which means that the total amount of time spent between retries is 26 seconds plus the random factor.
+
+
+
+
+ Creates a new instance of with the specified limits for
+ number of retries and the delay between retries.
+
+ The maximum number of retry attempts.
+ The maximum delay in milliseconds between retries.
+
+
+
+
+
+
+ Contains function stubs that expose SqlServer methods in Linq to Entities.
+
+
+
+ Returns the checksum of the values in a collection. Null values are ignored.
+ The checksum computed from the input collection.
+ The collection of values over which the checksum is computed.
+
+
+ Returns the checksum of the values in a collection. Null values are ignored.
+ The checksum computed from the input collection.
+ The collection of values over which the checksum is computed.
+
+
+ Returns the ASCII code value of the left-most character of a character expression.
+ The ASCII code of the first character in the input string.
+ A valid string.
+
+
+ Returns the character that corresponds to the specified integer ASCII value.
+ The character that corresponds to the specified ASCII value.
+ An ASCII code.
+
+
+ Returns the starting position of one expression found within another expression.
+ The starting position of target if it is found in toSearch .
+ The string expression to be searched.
+ The string expression to be found.
+
+
+ Returns the starting position of one expression found within another expression.
+ The starting position of target if it is found in toSearch .
+ The string expression to be searched.
+ The string expression to be found.
+
+
+ Returns the starting position of one expression found within another expression.
+ The starting position of target if it is found in toSearch .
+ The string expression to be searched.
+ The string expression to be found.
+ The character position in toSearch where searching begins.
+
+
+ Returns the starting position of one expression found within another expression.
+ The starting position of target if it is found in toSearch .
+ The string expression to be searched.
+ The string expression to be found.
+ The character position in toSearch where searching begins.
+
+
+ Returns the starting position of one expression found within another expression.
+
+ A of value that is the starting position of target if it is found in toSearch .
+
+ The string expression to be searched.
+ The string expression to be found.
+ The character position in toSearch where searching begins.
+
+
+ Returns the starting position of one expression found within another expression.
+ The starting position of target if it is found in toSearch .
+ The string expression to be searched.
+ The string expression to be found.
+ The character position in toSearch at which searching begins.
+
+
+ Returns an integer value that indicates the difference between the SOUNDEX values of two character expressions.
+ The SOUNDEX difference between the two strings.
+ The first string.
+ The second string.
+
+
+ Returns the Unicode character with the specified integer code, as defined by the Unicode standard.
+ The character that corresponds to the input character code.
+ A character code.
+
+
+ Returns the starting position of the first occurrence of a pattern in a specified expression, or zeros if the pattern is not found, on all valid text and character data types.
+ The starting character position where the string pattern was found.
+ A string pattern to search for.
+ The string to search.
+
+
+ Returns a Unicode string with the delimiters added to make the input string a valid Microsoft SQL Server delimited identifier.
+ The original string with brackets added.
+ The expression that quote characters will be added to.
+
+
+ Returns a Unicode string with the delimiters added to make the input string a valid Microsoft SQL Server delimited identifier.
+ The original string with the specified quote characters added.
+ The expression that quote characters will be added to.
+ The one-character string to use as the delimiter. It can be a single quotation mark ( ' ), a left or right bracket ( [ ] ), or a double quotation mark ( " ). If quote_character is not specified, brackets are used.
+
+
+ Repeats a string value a specified number of times.
+ The target string, repeated the number of times specified by count .
+ A valid string.
+ The value that specifies how many time to repeat target .
+
+
+ Converts an alphanumeric string to a four-character (SOUNDEX) code to find similar-sounding words or names.
+ The SOUNDEX code of the input string.
+ A valid string.
+
+
+ Returns a string of repeated spaces.
+ A string that consists of the specified number of spaces.
+ The number of spaces. If negative, a null string is returned.
+
+
+ Returns character data converted from numeric data.
+ The numeric input expression converted to a string.
+ A numeric expression.
+
+
+ Returns character data converted from numeric data.
+ The input expression converted to a string.
+ A numeric expression.
+
+
+ Returns character data converted from numeric data.
+ The numeric input expression converted to a string.
+ A numeric expression.
+ The total length of the string. This includes decimal point, sign, digits, and spaces. The default is 10.
+
+
+ Returns character data converted from numeric data.
+ The input expression converted to a string.
+ A numeric expression.
+ The total length of the string. This includes decimal point, sign, digits, and spaces. The default is 10.
+
+
+ Returns character data converted from numeric data.
+ The numeric input expression converted to a string.
+ A numeric expression.
+ The total length of the string. This includes decimal point, sign, digits, and spaces. The default is 10.
+ The number of places to the right of the decimal point. decimal must be less than or equal to 16. If decimal is more than 16 then the result is truncated to sixteen places to the right of the decimal point.
+
+
+ Returns character data converted from numeric data.
+ The input expression converted to a string.
+ A numeric expression.
+ The total length of the string. This includes decimal point, sign, digits, and spaces. The default is 10.
+ The number of places to the right of the decimal point. decimal must be less than or equal to 16. If decimal is more than 16 then the result is truncated to sixteen places to the right of the decimal point.
+
+
+ Inserts a string into another string. It deletes a specified length of characters in the target string at the start position and then inserts the second string into the target string at the start position.
+ A string consisting of the two strings.
+ The target string.
+ The character position in stringinput where the replacement string is to be inserted.
+ The number of characters to delete from stringInput . If length is longer than stringInput , deletion occurs up to the last character in stringReplacement .
+ The substring to be inserted into stringInput .
+
+
+ Returns the integer value, as defined by the Unicode standard, for the first character of the input expression.
+ The character code for the first character in the input string.
+ A valid string.
+
+
+ A mathematical function that returns the angle, in radians, whose cosine is the specified numerical value. This angle is called the arccosine.
+ The angle, in radians, defined by the input cosine value.
+ The cosine of an angle.
+
+
+ A mathematical function that returns the angle, in radians, whose cosine is the specified numerical value. This angle is called the arccosine.
+ An angle, measured in radians.
+ The cosine of an angle.
+
+
+ A mathematical function that returns the angle, in radians, whose sine is the specified numerical value. This angle is called the arcsine.
+ An angle, measured in radians.
+ The sine of an angle.
+
+
+ A mathematical function that returns the angle, in radians, whose sine is the specified numerical value. This angle is called the arcsine.
+ An angle, measured in radians.
+ The sine of an angle.
+
+
+ A mathematical function that returns the angle, in radians, whose tangent is the specified numerical value. This angle is called the arctangent.
+ An angle, measured in radians.
+ The tangent of an angle.
+
+
+ A mathematical function that returns the angle, in radians, whose tangent is the specified numerical value. This angle is called the arctangent.
+ An angle, measured in radians.
+ The tangent of an angle.
+
+
+ Returns the positive angle, in radians, between the positive x-axis and the ray from the origin through the point (x, y), where x and y are the two specified numerical values. The first parameter passed to the function is the y-value and the second parameter is the x-value.
+ An angle, measured in radians.
+ The y-coordinate of a point.
+ The x-coordinate of a point.
+
+
+ Returns the positive angle, in radians, between the positive x-axis and the ray from the origin through the point (x, y), where x and y are the two specified numerical values. The first parameter passed to the function is the y-value and the second parameter is the x-value.
+ An angle, measured in radians.
+ The y-coordinate of a point.
+ The x-coordinate of a point.
+
+
+ Returns the trigonometric cosine of the specified angle, in radians, in the specified expression.
+ The trigonometric cosine of the specified angle.
+ An angle, measured in radians.
+
+
+ Returns the trigonometric cosine of the specified angle, in radians, in the specified expression.
+ The trigonometric cosine of the specified angle.
+ An angle, measured in radians.
+
+
+ A mathematical function that returns the trigonometric cotangent of the specified angle, in radians.
+ The trigonometric cotangent of the specified angle.
+ An angle, measured in radians.
+
+
+ A mathematical function that returns the trigonometric cotangent of the specified angle, in radians.
+ The trigonometric cotangent of the specified angle.
+ An angle, measured in radians.
+
+
+ Returns the corresponding angle in degrees for an angle specified in radians.
+ The specified angle converted to degrees.
+ An angle, measured in radians.
+
+
+ Returns the corresponding angle in degrees for an angle specified in radians.
+ The specified angle converted to degrees.
+ An angle, measured in radians.
+
+
+ Returns the corresponding angle in degrees for an angle specified in radians.
+ The specified angle converted to degrees.
+ An angle, measured in radians.
+
+
+ Returns the corresponding angle in degrees for an angle specified in radians.
+ The specified angle converted to degrees.
+ An angle, measured in radians.
+
+
+ Returns the exponential value of the specified float expression.
+ The constant e raised to the power of the input value.
+ The input value.
+
+
+ Returns the exponential value of the specified float expression.
+ The constant e raised to the power of the input value.
+ The input value.
+
+
+ Returns the natural logarithm of the specified input value.
+ The natural logarithm of the input value.
+ A numeric expression.
+
+
+ Returns the natural logarithm of the specified input value.
+ The natural logarithm of the input value.
+ A numeric expression.
+
+
+ Returns the base-10 logarithm of the specified input value.
+ The base-10 logarithm of the input value.
+ A numeric expression.
+
+
+ Returns the base-10 logarithm of the specified input value.
+ The base-10 logarithm of the input value.
+ A numeric expression.
+
+
+ Returns the constant value of pi.
+ The numeric value of pi.
+
+
+ Returns the radian measure corresponding to the specified angle in degrees.
+ The radian measure of the specified angle.
+ The angle, measured in degrees
+
+
+ Returns the radian measure corresponding to the specified angle in degrees.
+ The radian measure of the specified angle.
+ The angle, measured in degrees
+
+
+ Returns the radian measure corresponding to the specified angle in degrees.
+ The radian measure of the specified angle.
+ The angle, measured in degrees.
+
+
+ Returns the radian measure corresponding to the specified angle in degrees.
+ The radian measure of the specified angle.
+ The angle, measured in degrees.
+
+
+ Returns a pseudo-random float value from 0 through 1, exclusive.
+ The pseudo-random value.
+
+
+ Returns a pseudo-random float value from 0 through 1, exclusive.
+ The pseudo-random value.
+ The seed value. If seed is not specified, the SQL Server Database Engine assigns a seed value at random. For a specified seed value, the result returned is always the same.
+
+
+ Returns the positive (+1), zero (0), or negative (-1) sign of the specified expression.
+ The sign of the input expression.
+ A numeric expression.
+
+
+ Returns the positive (+1), zero (0), or negative (-1) sign of the specified expression.
+ The sign of the input expression.
+ A numeric expression.
+
+
+ Returns the positive (+1), zero (0), or negative (-1) sign of the specified expression.
+ The sign of the input expression.
+ A numeric expression.
+
+
+ Returns the positive (+1), zero (0), or negative (-1) sign of the specified expression.
+ The sign of the input expression.
+ A numeric expression.
+
+
+ Returns the trigonometric sine of the specified angle.
+ The trigonometric sine of the input expression.
+ An angle, measured in radians.
+
+
+ Returns the trigonometric sine of the specified angle.
+ The trigonometric sine of the input expression.
+ An angle, measured in radians.
+
+
+ Returns the square root of the specified number.
+ The square root of the input value.
+ A numeric expression.
+
+
+ Returns the square root of the specified number.
+ The square root of the input value.
+ A numeric expression.
+
+
+ Returns the square of the specified number.
+ The square of the input value.
+ A numeric expression.
+
+
+ Returns the square of the specified number.
+ The square of the input value.
+ A numeric expression.
+
+
+ Returns the trigonometric tangent of the input expression.
+ The tangent of the input angle.
+ An angle, measured in radians.
+
+
+ Returns the trigonometric tangent of the input expression.
+ The tangent of the input angle.
+ An angle, measured in radians.
+
+
+ Returns a new datetime value based on adding an interval to the specified date.
+ The new date.
+ The part of the date to increment.
+ The value used to increment a date by a specified amount.
+ The date to increment.
+
+
+ Returns a new time span value based on adding an interval to the specified time span.
+ The new time span.
+ The part of the date to increment.
+ The value used to increment a date by a specified amount.
+ The time span to increment.
+
+
+ Returns a new date value based on adding an interval to the specified date.
+ The new point in time, expressed as a date and time of day, relative to Coordinated Universal Time (UTC).
+ The part of the date to increment.
+ The value used to increment a date by a specified amount.
+ The date to increment.
+
+
+ Returns a new datetime value based on adding an interval to the specified date.
+
+ A of value that is the new date.
+
+ The part of the date to increment.
+ The value used to increment a date by a specified amount.
+ The date to increment.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The value specifying the number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two Dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns the count of the specified datepart boundaries crossed between the specified start date and end date.
+ The number of time intervals between the two dates.
+ The part of the date to calculate the differing number of time intervals.
+ The first date.
+ The second date.
+
+
+ Returns a character string that represents the specified datepart of the specified date.
+ The specified part of the specified date.
+ The part of the date to calculate the differing number of time intervals.
+ The date.
+
+
+ Returns a character string that represents the specified datepart of the specified date.
+ The specified part of the specified date.
+ The part of the date to calculate the differing number of time intervals.
+ The date.
+
+
+ Returns a character string that represents the specified datepart of the specified date.
+ The specified part of the specified date.
+ The part of the date to calculate the differing number of time intervals.
+ The date.
+
+
+ Returns a character string that represents the specified datepart of the specified date.
+ The specified part of the specified date.
+ The part of the date to calculate the differing number of time intervals.
+ The date.
+
+
+ Returns an integer that represents the specified datepart of the specified date.
+ The the specified datepart of the specified date.
+ The part of the date to return the value.
+ The date.
+
+
+ Returns an integer that represents the specified datepart of the specified date.
+ The specified datepart of the specified date.
+ The part of the date to return the value.
+ The date.
+
+
+ Returns an integer that represents the specified datepart of the specified date.
+ The specified datepart of the specified date.
+ The part of the date to return the value.
+ The date.
+
+
+ Returns an integer that represents the specified datepart of the specified date.
+ The specified datepart of the specified date.
+ The part of the date to return the value.
+ The date.
+
+
+ Returns the current database system timestamp as a datetime value without the database time zone offset. This value is derived from the operating system of the computer on which the instance of SQL Server is running.
+ The current database timestamp.
+
+
+ Returns the current database system timestamp as a datetime value. The database time zone offset is not included. This value represents the current UTC time (Coordinated Universal Time). This value is derived from the operating system of the computer on which the instance of SQL Server is running.
+ The current database UTC timestamp.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for data length.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for data length.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for data length.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for data length.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for data length.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for data length.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for data length.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for length.
+
+
+ Returns the number of bytes used to represent any expression.
+ The number of bytes in the input value.
+ The value to be examined for data length.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input value.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input value.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input value.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input value.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input value.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input value.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input value.
+ The character array for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input argument.
+ The checksum computed over the input value.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The character array for which the checksum is calculated.
+ The character array for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The character array for which the checksum is calculated.
+ The character array for which the checksum is calculated.
+ The character array for which the checksum is calculated.
+
+
+ Returns the checksum value computed over the input arguments.
+ The checksum computed over the input values.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+ The value for which the checksum is calculated.
+
+
+ Returns the current date and time.
+ The current date and time.
+
+
+ Returns the name of the current user.
+ The name of the current user.
+
+
+ Returns the workstation name.
+ The name of the workstation.
+
+
+ Returns a database user name corresponding to a specified identification number.
+ The user name.
+ A user ID.
+
+
+ Returns a database user name corresponding to a specified identification number.
+ The user name.
+
+
+ Indicates whether the input value is a valid numeric type.
+ 1 if the input expression is a valid numeric data type; otherwise, 0.
+ A string expression.
+
+
+ Indicates whether the input value is a valid date or time.
+ 1 if the input expression is a valid date or time value of datetime or smalldatetime data types; otherwise, 0.
+ The tested value.
+
+
+
+ Provider to convert provider agnostic migration operations into SQL commands
+ that can be run against a Microsoft SQL Server database.
+
+
+
+
+ Converts a set of migration operations into Microsoft SQL Server specific SQL.
+
+ The operations to be converted.
+ Token representing the version of SQL Server being targeted (i.e. "2005", "2008").
+ A list of SQL statements to be executed to perform the migration operations.
+
+
+
+ Generates the SQL body for a stored procedure.
+
+ The command trees representing the commands for an insert, update or delete operation.
+ The rows affected parameter name.
+ The provider manifest token.
+ The SQL body for the stored procedure.
+
+
+
+ Generates the specified update database operation which represents applying a series of migrations.
+ The generated script is idempotent, meaning it contains conditional logic to check if individual migrations
+ have already been applied and only apply the pending ones.
+
+ The update database operation.
+
+
+
+ Generates SQL for a .
+ Allows derived providers to handle additional operation types.
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Creates an empty connection for the current provider.
+ Allows derived providers to use connection other than .
+
+ An empty connection for the current provider.
+
+
+
+ Generates the specified create procedure operation.
+
+ The create procedure operation.
+
+
+
+ Generates the specified alter procedure operation.
+
+ The alter procedure operation.
+
+
+
+ Generates the specified drop procedure operation.
+
+ The drop procedure operation.
+
+
+
+ Generates SQL for a . This method differs from
+ in that it will
+ create the target database schema if it does not already exist.
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Writes CREATE TABLE SQL to the target writer.
+
+ The operation to produce SQL for.
+ The target writer.
+
+
+
+ Override this method to generate SQL when the definition of a table or its attributes are changed.
+ The default implementation of this method does nothing.
+
+ The operation describing changes to the table.
+
+
+
+ Generates SQL to mark a table as a system table.
+ Generated SQL should be added using the Statement method.
+
+ The table to mark as a system table.
+ The to write the generated SQL to.
+
+
+
+ Generates SQL to create a database schema.
+ Generated SQL should be added using the Statement method.
+
+ The name of the schema to create.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Call this method to generate SQL that will attempt to drop the default constraint created
+ when a column is created. This method is usually called by code that overrides the creation or
+ altering of columns.
+
+ The table to which the constraint applies.
+ The column to which the constraint applies.
+ The writer to which generated SQL should be written.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement or StatementBatch methods.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates the specified rename procedure operation.
+
+ The rename procedure operation.
+
+
+
+ Generates the specified move procedure operation.
+
+ The move procedure operation.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL for the given column model. This method is called by other methods that
+ process columns and can be overridden to change the SQL generated.
+
+ The column for which SQL is being generated.
+ The writer to which generated SQL should be written.
+
+
+
+ Generates SQL for a .
+ Generated SQL should be added using the Statement method.
+
+ The operation to produce SQL for.
+
+
+
+ Generates SQL to specify a constant byte[] default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant bool default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant DateTime default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant DateTimeOffset default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant Guid default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant string default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant TimeSpan default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant geogrpahy default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant geometry default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify a constant default value being set on a column.
+ This method just generates the actual value, not the SQL to set the default value.
+
+ The value to be set.
+ SQL representing the default value.
+
+
+
+ Generates SQL to specify the data type of a column.
+ This method just generates the actual type, not the SQL to create the column.
+
+ The definition of the column.
+ SQL representing the data type.
+
+
+
+ Generates a quoted name. The supplied name may or may not contain the schema.
+
+ The name to be quoted.
+ The quoted name.
+
+
+
+ Quotes an identifier for SQL Server.
+
+ The identifier to be quoted.
+ The quoted identifier.
+
+
+
+ Adds a new Statement to be executed against the database.
+
+ The statement to be executed.
+ Gets or sets a value indicating whether this statement should be performed outside of the transaction scope that is used to make the migration process transactional. If set to true, this operation will not be rolled back if the migration process fails.
+ The batch terminator for the database provider.
+
+
+
+ Gets a new that can be used to build SQL.
+ This is just a helper method to create a writer. Writing to the writer will
+ not cause SQL to be registered for execution. You must pass the generated
+ SQL to the Statement method.
+
+ An empty text writer to use for SQL generation.
+
+
+
+ Adds a new Statement to be executed against the database.
+
+ The writer containing the SQL to be executed.
+ The batch terminator for the database provider.
+
+
+
+ Breaks sql string into one or more statements, handling T-SQL utility statements as necessary.
+
+ The SQL to split into one ore more statements to be executed.
+ Gets or sets a value indicating whether this statement should be performed outside of the transaction scope that is used to make the migration process transactional. If set to true, this operation will not be rolled back if the migration process fails.
+
+
+
+ Returns the column default value to use for store-generated GUID columns when
+ no default value is explicitly specified in the migration.
+ Returns newsequentialid() for on-premises SQL Server 2005 and later.
+ Returns newid() for SQL Azure.
+
+ Either newsequentialid() or newid() as described above.
+
+
+
+ Contains function stubs that expose SqlServer methods in Linq to Entities.
+
+
+
+ Constructs a geography instance representing a Point instance from its x and y values and a spatial reference ID (SRID).
+ The constructed geography instance.
+ The x-coordinate of the Point being generated.
+ The y-coordinate of the Point being generated
+ The SRID of the geography instance.
+
+
+ Returns the Open Geospatial Consortium (OGC) Well-Known Text (WKT) representation of a geography instance augmented with any Z (elevation) and M (measure) values carried by the instance.
+ The Open Geospatial Consortium (OGC) Well-Known Text (WKT) representation of a geography instance.
+ The geography value.
+
+
+ Returns a geometric object representing the union of all point values whose distance from a geography instance is less than or equal to a specified value, allowing for a specified tolerance.
+ The union of all point values whose distance from a geography instance is less than or equal to a specified value
+ The geography value.
+ The distance.
+ The specified tolerance.
+ Specifying whether the tolerance value is relative or absolute.
+
+
+ Returns the maximum angle between the point returned by EnvelopeCenter() and a point in the geography instance in degrees.
+ the maximum angle between the point returned by EnvelopeCenter().
+ The geography value.
+
+
+ Returns a point that can be used as the center of a bounding circle for the geography instance.
+ A SqlGeography value that specifies the location of the center of a bounding circle.
+ The geography value.
+
+
+ Offers a fast, index-only intersection method to determine if a geography instance intersects another SqlGeography instance, assuming an index is available.
+ True if a geography instance potentially intersects another SqlGeography instance; otherwise, false.
+ The geography value.
+ Another geography instance to compare against the instance on which Filter is invoked.
+
+
+ Tests if the SqlGeography instance is the same as the specified type.
+ A string that specifies one of the 12 types exposed in the geography type hierarchy.
+ The geography value.
+ A string that specifies one of the 12 types exposed in the geography type hierarchy.
+
+
+ Returns the total number of rings in a Polygon instance.
+ The total number of rings.
+ The geography value.
+
+
+ Returns an approximation of the given geography instance produced by running the Douglas-Peucker algorithm on the instance with the given tolerance.
+
+ Returns .
+
+ The geography value.
+ The tolerance to input to the Douglas-Peucker algorithm. tolerance must be a positive number.
+
+
+ Returns the specified ring of the SqlGeography instance: 1 ≤ n ≤ NumRings().
+ A SqlGeography object that represents the ring specified by n.
+ The geography value.
+ An int expression between 1 and the number of rings in a polygon instance.
+
+
+ Constructs a geometry instance representing a Point instance from its x and y values and a spatial reference ID (SRID).
+ The constructed geometry instance.
+ The x-coordinate of the Point being generated.
+ The y-coordinate of the Point being generated
+ The SRID of the geography instance.
+
+
+ Returns the Open Geospatial Consortium (OGC) Well-Known Text (WKT) representation of a geography instance augmented with any Z (elevation) and M (measure) values carried by the instance.
+ The Open Geospatial Consortium (OGC) Well-Known Text (WKT) representation of a geometry instance.
+ The geometry value.
+
+
+ Returns a geometric object representing the union of all point values whose distance from a geometry instance is less than or equal to a specified value, allowing for a specified tolerance.
+ The union of all point values whose distance from a geometry instance is less than or equal to a specified value
+ The geometry value.
+ The distance.
+ The specified tolerance.
+ Specifying whether the tolerance value is relative or absolute.
+
+
+ Tests if the SqlGeometry instance is the same as the specified type.
+ A string that specifies one of the 12 types exposed in the geography type hierarchy.
+ The geometry value.
+ A string that specifies one of the 12 types exposed in the geography type hierarchy.
+
+
+ Offers a fast, index-only intersection method to determine if a geography instance intersects another SqlGeometry instance, assuming an index is available.
+ True if a geography instance potentially intersects another SqlGeography instance; otherwise, false.
+ The geometry value.
+ Another geography instance to compare against the instance on which Filter is invoked.
+
+
+ Converts an invalid geometry instance into a geometry instance with a valid Open Geospatial Consortium (OGC) type.
+ The converted geometry instance.
+ The geometry value.
+
+
+ Returns an approximation of the given geography instance produced by running the Douglas-Peucker algorithm on the instance with the given tolerance.
+
+ Returns .
+
+ The geometry value.
+ The tolerance to input to the Douglas-Peucker algorithm. tolerance must be a positive number.
+
+
+
+ The DbProviderServices implementation for the SqlClient provider for SQL Server.
+
+
+ Note that instance of this type also resolve additional provider services for Microsoft SQL Server
+ when this type is registered as an EF provider either using an entry in the application's config file
+ or through code-based registration in .
+ The services resolved are:
+ Requests for are resolved to a Singleton instance of
+ to create connections to SQL Express by default.
+ Requests for for the invariant name "System.Data.SqlClient"
+ for any server name are resolved to a delegate that returns a
+ to provide a non-retrying policy for SQL Server.
+ Requests for for the invariant name "System.Data.SqlClient" are
+ resolved to instances to provide default Migrations SQL
+ generation for SQL Server.
+ Requests for for the invariant name "System.Data.SqlClient" are
+ resolved to a Singleton instance of to provide default spatial
+ services for SQL Server.
+
+
+
+
+ This is the well-known string using in configuration files and code-based configuration as
+ the "provider invariant name" used to specify Microsoft SQL Server for ADO.NET and
+ Entity Framework provider services.
+
+
+
+
+ Registers a handler to process non-error messages coming from the database provider.
+
+ The connection to receive information for.
+ The handler to process messages.
+
+
+
+ Create a Command Definition object, given the connection and command tree
+
+ provider manifest that was determined from metadata
+ command tree for the statement
+ an executable command definition object
+
+
+
+ See issue 2390 - cloning the DesignTimeVisible property on the
+ can cause deadlocks.
+ So here overriding to provide a method that does not clone DesignTimeVisible.
+
+ the object to clone
+ a clone of the
+
+
+
+ Sets the parameter value and appropriate facets for the given .
+
+ The parameter.
+ The type of the parameter.
+ The value of the parameter.
+
+
+
+ Returns provider manifest token for a given connection.
+
+ Connection to find manifest token from.
+ The provider manifest token for the specified connection.
+
+
+
+ Returns the provider manifest by using the specified version information.
+
+ The token information associated with the provider manifest.
+ The provider manifest by using the specified version information.
+
+
+
+ Gets a spatial data reader for SQL Server.
+
+ The reader where the spatial data came from.
+ The manifest token associated with the provider manifest.
+ The spatial data reader.
+
+
+
+ Gets a spatial data reader for SQL Server.
+
+ The manifest token associated with the provider manifest.
+ The spatial data reader.
+
+
+
+ Generates a data definition language (DDL) script that creates schema objects
+ (tables, primary keys, foreign keys) based on the contents of the StoreItemCollection
+ parameter and targeted for the version of the database corresponding to the provider manifest token.
+
+ The provider manifest token identifying the target version.
+ The structure of the database.
+
+ A DDL script that creates schema objects based on the contents of the StoreItemCollection parameter
+ and targeted for the version of the database corresponding to the provider manifest token.
+
+
+
+
+ Create the database and the database objects.
+ If initial catalog is not specified, but AttachDBFilename is specified, we generate a random database name based on the AttachDBFilename.
+ Note: this causes pollution of the db, as when the connection string is later used, the mdf will get attached under a different name.
+ However if we try to replicate the name under which it would be attached, the following scenario would fail:
+ The file does not exist, but registered with database.
+ The user calls: If (DatabaseExists) DeleteDatabase
+ CreateDatabase
+ For further details on the behavior when AttachDBFilename is specified see Dev10# 188936
+
+ Connection to a non-existent database that needs to be created and populated with the store objects indicated with the storeItemCollection parameter.
+ Execution timeout for any commands needed to create the database.
+ The collection of all store items based on which the script should be created.
+
+
+
+ Determines whether the database for the given connection exists.
+ There are three cases:
+ 1. Initial Catalog = X, AttachDBFilename = null: (SELECT Count(*) FROM sys.databases WHERE [name]= X) > 0
+ 2. Initial Catalog = X, AttachDBFilename = F: if (SELECT Count(*) FROM sys.databases WHERE [name]= X) > true,
+ if not, try to open the connection and then return (SELECT Count(*) FROM sys.databases WHERE [name]= X) > 0
+ 3. Initial Catalog = null, AttachDBFilename = F: Try to open the connection. If that succeeds the result is true, otherwise
+ if the there are no databases corresponding to the given file return false, otherwise throw.
+ Note: We open the connection to cover the scenario when the mdf exists, but is not attached.
+ Given that opening the connection would auto-attach it, it would not be appropriate to return false in this case.
+ Also note that checking for the existence of the file does not work for a remote server. (Dev11 #290487)
+ For further details on the behavior when AttachDBFilename is specified see Dev10# 188936
+
+ Connection to a database whose existence is checked by this method.
+ Execution timeout for any commands needed to determine the existence of the database.
+ The collection of all store items from the model. This parameter is no longer used for determining database existence.
+ True if the provider can deduce the database only based on the connection.
+
+
+
+ Determines whether the database for the given connection exists.
+ There are three cases:
+ 1. Initial Catalog = X, AttachDBFilename = null: (SELECT Count(*) FROM sys.databases WHERE [name]= X) > 0
+ 2. Initial Catalog = X, AttachDBFilename = F: if (SELECT Count(*) FROM sys.databases WHERE [name]= X) > true,
+ if not, try to open the connection and then return (SELECT Count(*) FROM sys.databases WHERE [name]= X) > 0
+ 3. Initial Catalog = null, AttachDBFilename = F: Try to open the connection. If that succeeds the result is true, otherwise
+ if the there are no databases corresponding to the given file return false, otherwise throw.
+ Note: We open the connection to cover the scenario when the mdf exists, but is not attached.
+ Given that opening the connection would auto-attach it, it would not be appropriate to return false in this case.
+ Also note that checking for the existence of the file does not work for a remote server. (Dev11 #290487)
+ For further details on the behavior when AttachDBFilename is specified see Dev10# 188936
+
+ Connection to a database whose existence is checked by this method.
+ Execution timeout for any commands needed to determine the existence of the database.
+ The collection of all store items from the model. This parameter is no longer used for determining database existence.
+ True if the provider can deduce the database only based on the connection.
+
+
+
+ Delete the database for the given connection.
+ There are three cases:
+ 1. If Initial Catalog is specified (X) drop database X
+ 2. Else if AttachDBFilename is specified (F) drop all the databases corresponding to F
+ if none throw
+ 3. If niether the catalog not the file name is specified - throw
+ Note that directly deleting the files does not work for a remote server. However, even for not attached
+ databases the current logic would work assuming the user does: if (DatabaseExists) DeleteDatabase
+
+ Connection
+ Timeout for internal commands.
+ Item Collection.
+
+
+
+ The Singleton instance of the SqlProviderServices type.
+
+
+
+
+ Set to the full name of the Microsoft.SqlServer.Types assembly to override the default selection
+
+
+
+
+ Set this flag to false to prevent values from being truncated to
+ the scale (number of decimal places) defined for the column. The default value is true,
+ indicating that decimal values will be truncated, in order to prevent breaking existing
+ applications that depend on this behavior.
+
+
+ With this flag set to true objects are created with their Scale
+ properties set. When this flag is set to false then the Scale properties are not set, meaning
+ that the truncation behavior of SqlParameter is avoided.
+
+
+
+
+ An implementation of to provide support for geospatial types when using
+ Entity Framework with Microsoft SQL Server.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.dll b/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.dll
new file mode 100644
index 000000000..774321afb
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.xml b/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.xml
new file mode 100644
index 000000000..899647ea8
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/EntityFramework.xml
@@ -0,0 +1,52816 @@
+
+
+
+ EntityFramework
+
+
+
+
+ Represents a result mapping for a function import.
+
+
+
+
+ Base class for items in the mapping space (DataSpace.CSSpace)
+
+
+
+
+ Adds a type mapping.
+
+ The type mapping to add.
+
+
+
+ Removes a type mapping.
+
+ The type mapping to remove.
+
+
+
+ Gets the type mappings.
+
+
+
+
+ Specifies a mapping condition evaluated by checking whether the value
+ of the a property/column is null or not null.
+
+
+
+
+ Mapping metadata for Conditional property mapping on a type.
+ Condition Property Mapping specifies a Condition either on the C side property or S side property.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ConditionProperyMap ( constant value-->SMemberMetadata )
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ComplexPropertyMap
+ --ComplexTypeMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --ConditionProperyMap ( constant value-->SMemberMetadata )
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ This class represents the metadata for all the condition property map elements in the
+ above example.
+
+
+
+
+ Mapping metadata for all types of property mappings.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap
+ --ScalarPropertyMap
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap
+ --ComplexPropertyMap
+ --ScalarPropertyMap
+ --ScalarProperyMap
+ --ScalarPropertyMap
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap
+ --ScalarProperyMap
+ --EndPropertyMap
+ --ScalarPropertyMap
+ This class represents the metadata for all property map elements in the
+ above example. This includes the scalar property maps, complex property maps
+ and end property maps.
+
+
+
+
+ Gets an EdmProperty that specifies the mapped property.
+
+
+
+
+ Gets an EdmProperty that specifies the mapped property.
+
+
+
+
+ Gets an EdmProperty that specifies the mapped column.
+
+
+
+
+ Creates an IsNullConditionMapping instance.
+
+ An EdmProperty that specifies a property or column.
+ A boolean that indicates whether to perform a null or a not-null check.
+
+
+
+ Gets a bool that specifies whether the condition is evaluated by performing a null check
+ or a not-null check.
+
+
+
+
+ Specifies a mapping condition evaluated by comparing the value of
+ a property or column with a given value.
+
+
+
+
+ Creates a ValueConditionMapping instance.
+
+ An EdmProperty that specifies a property or column.
+ An object that specifies the value to compare with.
+
+
+
+ Gets an object that specifies the value to check against.
+
+
+
+
+ Serializes an that conforms to the restrictions of a single
+ CSDL schema file to an XML writer. The model to be serialized must contain a single
+ .
+
+
+
+
+ Serialize the to the XmlWriter.
+
+
+ The EdmModel to serialize.
+
+ The XmlWriter to serialize to.
+ The serialized model's namespace.
+ true if the model is valid; otherwise, false.
+
+
+
+ Occurs when an error is encountered serializing the model.
+
+
+
+
+ Information about an error that occurred processing an Entity Framework model.
+
+
+
+
+ Gets an optional value indicating which property of the source item caused the event to be raised.
+
+
+
+
+ Gets an optional descriptive message the describes the error that is being raised.
+
+
+
+
+ Gets a value indicating the that caused the event to be raised.
+
+
+
+
+ Contains additional attributes and properties of the
+
+
+ Note that objects are short lived and exist only to
+ make initialization easier. Instance of this type are not
+ compared to each other and arrays returned by array properties are copied to internal
+ collections in the ctor. Therefore it is fine to suppress the
+ Code Analysis messages.
+
+
+
+ Gets or sets the function schema.
+ The function schema.
+
+
+ Gets or sets the store function name.
+ The store function name.
+
+
+ Gets or sets the command text associated with the function.
+ The command text associated with the function.
+
+
+ Gets or sets the entity sets for the function.
+ The entity sets for the function.
+
+
+ Gets a value that indicates whether this is an aggregate function.
+ true if this is an aggregate function; otherwise, false.
+
+
+ Gets or sets whether this function is a built-in function.
+ true if this function is a built-in function; otherwise, false.
+
+
+ Gets or sets whether the function contains no arguments.
+ true if the function contains no arguments; otherwise, false.
+
+
+ Gets or sets whether this function can be composed.
+ true if this function can be composed; otherwise, false.
+
+
+ Gets or sets whether this function is from a provider manifest.
+ true if this function is from a provider manifest; otherwise, false.
+
+
+ Gets or sets whether this function is a cached store function.
+ true if this function is a cached store function; otherwise, false.
+
+
+ Gets or sets whether this function is a function import.
+ true if this function is a function import; otherwise, false.
+
+
+ Gets or sets the return parameters.
+ The return parameters.
+
+
+ Gets or sets the parameter type semantics.
+ The parameter type semantics.
+
+
+ Gets or sets the function parameters.
+ The function parameters.
+
+
+
+ Serializes the storage (database) section of an to XML.
+
+
+
+
+ Serialize the to the
+
+ The EdmModel to serialize
+ Provider information on the Schema element
+ ProviderManifestToken information on the Schema element
+ The XmlWriter to serialize to
+ A value indicating whether to serialize Nullable attributes when they are set to the default value.
+ true if model can be serialized, otherwise false
+
+
+
+ Serialize the to the
+
+ The EdmModel to serialize
+ Namespace name on the Schema element
+ Provider information on the Schema element
+ ProviderManifestToken information on the Schema element
+ The XmlWriter to serialize to
+ A value indicating whether to serialize Nullable attributes when they are set to the default value.
+ true if model can be serialized, otherwise false
+
+
+
+ Occurs when an error is encountered serializing the model.
+
+
+
+ Visits each element of an expression tree from a given root expression. If any element changes, the tree is rebuilt back to the root and the new root expression is returned; otherwise the original root expression is returned.
+
+
+ Defines the basic functionality that should be implemented by visitors that return a result value of a specific type.
+ The type of the result produced by the visitor.
+
+
+ When overridden in a derived class, handles any expression of an unrecognized type.
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern method for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+ A result value of a specific type.
+
+ The that is being visited.
+
+
+
+
+ Typed visitor pattern method for DbInExpression.
+
+ The DbInExpression that is being visited.
+ An instance of TResultType.
+
+
+
+ Initializes a new instance of the
+
+ class.
+
+
+
+ Replaces an old expression with a new one for the expression visitor.
+ The old expression.
+ The new expression.
+
+
+ Represents an event when the variable is rebound for the expression visitor.
+ The location of the variable.
+ The reference of the variable where it is rebounded.
+
+
+ Represents an event when entering the scope for the expression visitor with specified scope variables.
+ The collection of scope variables.
+
+
+ Exits the scope for the expression visitor.
+
+
+ Implements the visitor pattern for the expression.
+ The implemented visitor pattern.
+ The expression.
+
+
+ Implements the visitor pattern for the expression list.
+ The implemented visitor pattern.
+ The expression list.
+
+
+ Implements the visitor pattern for expression binding.
+ The implemented visitor pattern.
+ The expression binding.
+
+
+ Implements the visitor pattern for the expression binding list.
+ The implemented visitor pattern.
+ The expression binding list.
+
+
+ Implements the visitor pattern for the group expression binding.
+ The implemented visitor pattern.
+ The binding.
+
+
+ Implements the visitor pattern for the sort clause.
+ The implemented visitor pattern.
+ The sort clause.
+
+
+ Implements the visitor pattern for the sort order.
+ The implemented visitor pattern.
+ The sort order.
+
+
+ Implements the visitor pattern for the aggregate.
+ The implemented visitor pattern.
+ The aggregate.
+
+
+ Implements the visitor pattern for the function aggregate.
+ The implemented visitor pattern.
+ The aggregate.
+
+
+ Implements the visitor pattern for the group aggregate.
+ The implemented visitor pattern.
+ The aggregate.
+
+
+ Implements the visitor pattern for the Lambda function.
+ The implemented visitor pattern.
+ The lambda function.
+
+
+ Implements the visitor pattern for the type.
+ The implemented visitor pattern.
+ The type.
+
+
+ Implements the visitor pattern for the type usage.
+ The implemented visitor pattern.
+ The type.
+
+
+ Implements the visitor pattern for the entity set.
+ The implemented visitor pattern.
+ The entity set.
+
+
+ Implements the visitor pattern for the function.
+ The implemented visitor pattern.
+ The function metadata.
+
+
+ Implements the visitor pattern for the basic functionality required by expression types.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the different kinds of constants.
+ The implemented visitor.
+ The constant expression.
+
+
+ Implements the visitor pattern for a reference to a typed null literal.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for a reference to a variable that is currently in scope.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for a reference to a parameter declared on the command tree that contains this expression.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for an invocation of a function.
+ The implemented visitor.
+ The function expression.
+
+
+ Implements the visitor pattern for the application of a lambda function to arguments represented by DbExpression objects.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for retrieving an instance property.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the comparison operation applied to two arguments.
+ The implemented visitor.
+ The cast expression.
+
+
+ Implements the visitor pattern for a string comparison against the specified pattern with an optional escape string.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the restriction of the number of elements in the argument collection to the specified limit value.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the null determination applied to a single argument.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the arithmetic operation applied to numeric arguments.
+ The implemented visitor.
+ The arithmetic expression.
+
+
+ Implements the visitor pattern for the logical AND expression.
+ The implemented visitor.
+ The logical AND expression.
+
+
+ Implements the visitor pattern for the logical OR of two Boolean arguments.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the DbInExpression.
+ The implemented visitor.
+ The DbInExpression that is being visited.
+
+
+ Implements the visitor pattern for the logical NOT of a single Boolean argument.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the removed duplicate elements from the specified set argument.
+ The implemented visitor.
+ The distinct expression.
+
+
+ Implements the visitor pattern for the conversion of the specified set argument to a singleton the conversion of the specified set argument to a singleton.
+ The implemented visitor.
+ The element expression.
+
+
+ Implements the visitor pattern for an empty set determination applied to a single set argument.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the set union operation between the left and right operands.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the set intersection operation between the left and right operands.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the set subtraction operation between the left and right operands.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for a type conversion operation applied to a polymorphic argument.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the type comparison of a single argument against the specified type.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the type conversion of a single argument to the specified type.
+ The implemented visitor.
+ The cast expression.
+
+
+ Implements the visitor pattern for the When, Then, and Else clauses.
+ The implemented visitor.
+ The case expression.
+
+
+ Implements the visitor pattern for the retrieval of elements of the specified type from the given set argument.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the construction of a new instance of a given type, including set and record types.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for a strongly typed reference to a specific instance within an entity set.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the navigation of a relationship.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the expression that retrieves an entity based on the specified reference.
+ The implemented visitor.
+ The DEREF expression.
+
+
+ Implements the visitor pattern for the retrieval of the key value from the underlying reference value.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the expression that extracts a reference from the underlying entity instance.
+ The implemented visitor.
+ The entity reference expression.
+
+
+ Implements the visitor pattern for a scan over an entity set or relationship set, as indicated by the Target property.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for a predicate applied to filter an input set.
+ The implemented visitor.
+ The filter expression.
+
+
+ Implements the visitor pattern for the projection of a given input set over the specified expression.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the unconditional join operation between the given collection arguments.
+ The implemented visitor.
+ The join expression.
+
+
+ Implements the visitor pattern for an inner, left outer, or full outer join operation between the given collection arguments on the specified join condition.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the invocation of the specified function for each element in the specified input set.
+ The implemented visitor.
+ The APPLY expression.
+
+
+ Implements the visitor pattern for a group by operation.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for the skip expression.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for a sort key that can be used as part of the sort order.
+ The implemented visitor.
+ The expression.
+
+
+ Implements the visitor pattern for a quantifier operation of the specified kind over the elements of the specified input set.
+ The implemented visitor.
+ The expression.
+
+
+
+ When this attribute is placed on a property it indicates that the database column to which the
+ property is mapped has an index.
+
+
+ This attribute is used by Entity Framework Migrations to create indexes on mapped database columns.
+ Multi-column indexes are created by using the same index name in multiple attributes. The information
+ in these attributes is then merged together to specify the actual database index.
+
+
+
+
+ Creates a instance for an index that will be named by convention and
+ has no column order, clustering, or uniqueness specified.
+
+
+
+
+ Creates a instance for an index with the given name and
+ has no column order, clustering, or uniqueness specified.
+
+ The index name.
+
+
+
+ Creates a instance for an index with the given name and column order,
+ but with no clustering or uniqueness specified.
+
+
+ Multi-column indexes are created by using the same index name in multiple attributes. The information
+ in these attributes is then merged together to specify the actual database index.
+
+ The index name.
+ A number which will be used to determine column ordering for multi-column indexes.
+
+
+
+ Returns true if this attribute specifies the same name and configuration as the given attribute.
+
+ The attribute to compare.
+ True if the other object is equal to this object; otherwise false.
+
+
+
+
+
+
+ Returns true if this attribute specifies the same name and configuration as the given attribute.
+
+ The attribute to compare.
+ True if the other object is equal to this object; otherwise false.
+
+
+
+
+
+
+ The index name.
+
+
+ Multi-column indexes are created by using the same index name in multiple attributes. The information
+ in these attributes is then merged together to specify the actual database index.
+
+
+
+
+ A number which will be used to determine column ordering for multi-column indexes. This will be -1 if no
+ column order has been specified.
+
+
+ Multi-column indexes are created by using the same index name in multiple attributes. The information
+ in these attributes is then merged together to specify the actual database index.
+
+
+
+
+ Set this property to true to define a clustered index. Set this property to false to define a
+ non-clustered index.
+
+
+ The value of this property is only relevant if returns true.
+ If returns false, then the value of this property is meaningless.
+
+
+
+
+ Returns true if has been set to a value.
+
+
+
+
+ Set this property to true to define a unique index. Set this property to false to define a
+ non-unique index.
+
+
+ The value of this property is only relevant if returns true.
+ If returns false, then the value of this property is meaningless.
+
+
+
+
+ Returns true if has been set to a value.
+
+
+
+
+ Returns a different ID for each object instance such that type descriptors won't
+ attempt to combine all IndexAttribute instances into a single instance.
+
+
+
+
+ A class derived from this class can be placed in the same assembly as a class derived from
+ to define Entity Framework configuration for an application.
+ Configuration is set by calling protected methods and setting protected properties of this
+ class in the constructor of your derived type.
+ The type to use can also be registered in the config file of the application.
+ See http://go.microsoft.com/fwlink/?LinkId=260883 for more information about Entity Framework configuration.
+
+
+
+
+ Any class derived from must have a public parameterless constructor
+ and that constructor should call this constructor.
+
+
+
+
+ The Singleton instance of for this app domain. This can be
+ set at application start before any Entity Framework features have been used and afterwards
+ should be treated as read-only.
+
+ The instance of .
+
+
+
+ Attempts to discover and load the associated with the given
+ type. This method is intended to be used by tooling to ensure that
+ the correct configuration is loaded into the app domain. Tooling should use this method
+ before accessing the property.
+
+ A type to use for configuration discovery.
+
+
+
+ Attempts to discover and load the from the given assembly.
+ This method is intended to be used by tooling to ensure that the correct configuration is loaded into
+ the app domain. Tooling should use this method before accessing the
+ property. If the tooling knows the type being used, then the
+ method should be used since it gives a greater chance that
+ the correct configuration will be found.
+
+ An to use for configuration discovery.
+
+
+
+ Call this method from the constructor of a class derived from to
+ add a instance to the Chain of Responsibility of resolvers that
+ are used to resolve dependencies needed by the Entity Framework.
+
+
+ Resolvers are asked to resolve dependencies in reverse order from which they are added. This means
+ that a resolver can be added to override resolution of a dependency that would already have been
+ resolved in a different way.
+ The exceptions to this is that any dependency registered in the application's config file
+ will always be used in preference to using a dependency resolver added here.
+
+ The resolver to add.
+
+
+
+ Call this method from the constructor of a class derived from to
+ add a instance to the Chain of Responsibility of resolvers that
+ are used to resolve dependencies needed by the Entity Framework. Unlike the AddDependencyResolver
+ method, this method puts the resolver at the bottom of the Chain of Responsibility such that it will only
+ be used to resolve a dependency that could not be resolved by any of the other resolvers.
+
+
+ A implementation is automatically registered as a default resolver
+ when it is added with a call to . This allows EF providers to act as
+ resolvers for other services that may need to be overridden by the provider.
+
+ The resolver to add.
+
+
+
+ Call this method from the constructor of a class derived from to register
+ an Entity Framework provider.
+
+
+ Note that the provider is both registered as a service itself and also registered as a default resolver with
+ a call to AddDefaultResolver. This allows EF providers to act as resolvers for other services that
+ may need to be overridden by the provider.
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ and also using AddDefaultResolver to add the provider as a default
+ resolver. This means that, if desired, the same functionality can be achieved using a custom resolver or a
+ resolver backed by an Inversion-of-Control container.
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this provider will be used.
+ The provider instance.
+
+
+
+ Call this method from the constructor of a class derived from to register
+ an ADO.NET provider.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolvers for
+ and . This means that, if desired,
+ the same functionality can be achieved using a custom resolver or a resolver backed by an
+ Inversion-of-Control container.
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this provider will be used.
+ The provider instance.
+
+
+
+ Call this method from the constructor of a class derived from to register an
+ for use with the provider represented by the given invariant name.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this execution strategy will be used.
+ A function that returns a new instance of an execution strategy.
+
+
+
+ Call this method from the constructor of a class derived from to register an
+ for use with the provider represented by the given invariant name and
+ for a given server name.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this execution strategy will be used.
+
+ A function that returns a new instance of an execution strategy.
+ A string that will be matched against the server name in the connection string.
+
+
+
+ Call this method from the constructor of a class derived from to register a
+ .
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ A function that returns a new instance of a transaction handler.
+
+
+
+ Call this method from the constructor of a class derived from to register a
+ for use with the provider represented by the given invariant name.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this transaction handler will be used.
+
+ A function that returns a new instance of a transaction handler.
+
+
+
+ Call this method from the constructor of a class derived from to register a
+ for use with the provider represented by the given invariant name and
+ for a given server name.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this transaction handler will be used.
+
+ A function that returns a new instance of a transaction handler.
+ A string that will be matched against the server name in the connection string.
+
+
+
+ Sets the that is used to create connections by convention if no other
+ connection string or connection is given to or can be discovered by .
+ Note that a default connection factory is set in the app.config or web.config file whenever the
+ EntityFramework NuGet package is installed. As for all config file settings, the default connection factory
+ set in the config file will take precedence over any setting made with this method. Therefore the setting
+ must be removed from the config file before calling this method will have any effect.
+ Call this method from the constructor of a class derived from to change
+ the default connection factory being used.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The connection factory.
+
+
+
+ Call this method from the constructor of a class derived from to
+ set the pluralization service.
+
+ The pluralization service to use.
+
+
+
+ Call this method from the constructor of a class derived from to
+ set the database initializer to use for the given context type. The database initializer is called when a
+ the given type is used to access a database for the first time.
+ The default strategy for Code First contexts is an instance of .
+
+
+ Calling this method is equivalent to calling .
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The type of the context.
+ The initializer to use, or null to disable initialization for the given context type.
+
+
+
+ Call this method from the constructor of a class derived from to register a
+ for use with the provider represented by the given invariant name.
+
+
+ This method is typically used by providers to register an associated SQL generator for Code First Migrations.
+ It is different from setting the generator in the because it allows
+ EF to use the Migrations pipeline to create a database even when there is no Migrations configuration in the project
+ and/or Migrations are not being explicitly used.
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The invariant name of the ADO.NET provider for which this generator should be used.
+ A delegate that returns a new instance of the SQL generator each time it is called.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ an implementation of which allows provider manifest tokens to
+ be obtained from connections without necessarily opening the connection.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The manifest token resolver.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ a factory for implementations of which allows custom annotations
+ represented by instances to be serialized to and from the EDMX XML.
+
+
+ Note that an is not needed if the annotation uses a simple string value.
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The name of custom annotation that will be handled by this serializer.
+ A delegate that will be used to create serializer instances.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ an implementation of which allows a
+ to be obtained from a in cases where the default implementation is not
+ sufficient.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The provider factory service.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ a as the model cache key factory which allows the key
+ used to cache the model behind a to be changed.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can
+ be achieved using a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The key factory.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ a delegate which which be used for
+ creation of the default for a any
+ . This default factory will only be used if no factory is
+ set explicitly in the and if no factory has been registered
+ for the provider in use using the
+
+ method.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality
+ can be achieved using a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+
+ A factory for creating instances for a given and
+ representing the default schema.
+
+
+
+
+ Call this method from the constructor of a class derived from to set
+ a delegate which allows for creation of a customized
+ for the given provider for any
+ that does not have an explicit factory set.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality
+ can be achieved using a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The invariant name of the ADO.NET provider for which this generator should be used.
+
+ A factory for creating instances for a given and
+ representing the default schema.
+
+
+
+
+ Call this method from the constructor of a class derived from to set
+ the global instance of which will be used whenever a spatial provider is
+ required and a provider-specific spatial provider cannot be found. Normally, a provider-specific spatial provider
+ is obtained from the a implementation which is in turn returned by resolving
+ a service for passing the provider invariant name as a key. However, this
+ cannot work for stand-alone instances of and since
+ it is impossible to know the spatial provider to use. Therefore, when creating stand-alone instances
+ of and the global spatial provider is always used.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The spatial provider.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ an implementation of to use for a specific provider and provider
+ manifest token.
+
+
+ Use
+ to register spatial services for use only when a specific manifest token is returned by the provider.
+ Use to register global
+ spatial services to be used when provider information is not available or no provider-specific
+ spatial services are found.
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+
+ The indicating the type of ADO.NET connection for which this spatial provider will be used.
+
+ The spatial provider.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ an implementation of to use for a specific provider with any
+ manifest token.
+
+
+ Use
+ to register spatial services for use when any manifest token is returned by the provider.
+ Use to register global
+ spatial services to be used when provider information is not available or no provider-specific
+ spatial services are found.
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this spatial provider will be used.
+ The spatial provider.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ a factory for the type of to use with .
+
+
+ Note that setting the type of formatter to use with this method does change the way command are
+ logged when is used. It is still necessary to set a
+ instance onto before any commands will be logged.
+ For more low-level control over logging/interception see and
+ .
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ A delegate that will create formatter instances.
+
+
+
+ Call this method from the constructor of a class derived from to
+ register an at application startup. Note that interceptors can also
+ be added and removed at any time using .
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ . This means that, if desired, the same functionality can be achieved using
+ a custom resolver or a resolver backed by an Inversion-of-Control container.
+
+ The interceptor to register.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ a factory to allow to create instances of a context that does not have a public,
+ parameterless constructor.
+
+
+ This is typically needed to allow design-time tools like Migrations or scaffolding code to use contexts that
+ do not have public, parameterless constructors.
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ with the context as the key. This means that, if desired,
+ the same functionality can be achieved using a custom resolver or a resolver backed by an
+ Inversion-of-Control container.
+
+ The context type for which the factory should be used.
+ The delegate to use to create context instances.
+
+
+
+ Call this method from the constructor of a class derived from to set
+ a factory to allow to create instances of a context that does not have a public,
+ parameterless constructor.
+
+
+ This is typically needed to allow design-time tools like Migrations or scaffolding code to use contexts that
+ do not have public, parameterless constructors.
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ with the context as the key. This means that, if desired,
+ the same functionality can be achieved using a custom resolver or a resolver backed by an
+ Inversion-of-Control container.
+
+ The context type for which the factory should be used.
+ The delegate to use to create context instances.
+
+
+
+ Call this method from the constructor of a class derived from to register
+ a database table existence checker for a given provider.
+
+
+ This method is provided as a convenient and discoverable way to add configuration to the Entity Framework.
+ Internally it works in the same way as using AddDependencyResolver to add an appropriate resolver for
+ and also using AddDefaultResolver to add the provider as a default
+ resolver. This means that, if desired, the same functionality can be achieved using a custom resolver or a
+ resolver backed by an Inversion-of-Control container.
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this provider will be used.
+ The table existence checker to use.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Creates a shallow copy of the current .
+
+ A shallow copy of the current .
+
+
+
+ Occurs during EF initialization after the DbConfiguration has been constructed but just before
+ it is locked ready for use. Use this event to inspect and/or override services that have been
+ registered before the configuration is locked. Note that this event should be used carefully
+ since it may prevent tooling from discovering the same configuration that is used at runtime.
+
+
+ Handlers can only be added before EF starts to use the configuration and so handlers should
+ generally be added as part of application initialization. Do not access the DbConfiguration
+ static methods inside the handler; instead use the the members of
+ to get current services and/or add overrides.
+
+
+
+
+ Gets the that is being used to resolve service
+ dependencies in the Entity Framework.
+
+
+
+
+ This attribute can be placed on a subclass of to indicate that the subclass of
+ representing the code-based configuration for the application is in a different
+ assembly than the context type.
+
+
+ Normally a subclass of should be placed in the same assembly as
+ the subclass of used by the application. It will then be discovered automatically.
+ However, if this is not possible or if the application contains multiple context types in different
+ assemblies, then this attribute can be used to direct DbConfiguration discovery to the appropriate type.
+ An alternative to using this attribute is to specify the DbConfiguration type to use in the application's
+ config file. See http://go.microsoft.com/fwlink/?LinkId=260883 for more information.
+
+
+
+
+ Indicates that the given subclass of should be used for code-based configuration
+ for this application.
+
+
+ The type to use.
+
+
+
+
+ Indicates that the subclass of represented by the given assembly-qualified
+ name should be used for code-based configuration for this application.
+
+
+ The type to use.
+
+
+
+
+ Gets the subclass of that should be used for code-based configuration
+ for this application.
+
+
+
+ Implements the basic functionality required by aggregates in a GroupBy clause.
+
+
+
+ Gets the result type of this .
+
+
+ The result type of this .
+
+
+
+
+ Gets the list of expressions that define the arguments to this
+
+ .
+
+
+ The list of expressions that define the arguments to this
+
+ .
+
+
+
+ Represents the logical AND of two Boolean arguments. This class cannot be inherited.
+
+
+ Implements the basic functionality required by expressions that accept two expression operands.
+
+
+ Represents the base type for all expressions.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ The type of the result produced by .
+
+
+ An instance of .
+
+ The type of the result produced by visitor.
+
+
+
+ Determines whether the specified is equal to the current DbExpression instance.
+
+
+ True if the specified is equal to the current DbExpression instance; otherwise, false.
+
+
+ The object to compare to the current .
+
+
+
+ Serves as a hash function for the type.
+ A hash code for the current expression.
+
+
+
+ Creates a that represents the specified binary value, which may be null
+
+
+ A that represents the specified binary value.
+
+ The binary value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from a byte array.
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable) Boolean value.
+
+
+ A that represents the specified Boolean value.
+
+ The Boolean value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable) byte value.
+
+
+ A that represents the specified byte value.
+
+ The byte value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable)
+
+ value.
+
+
+ A that represents the specified DateTime value.
+
+ The DateTime value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The expression to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable)
+
+ value.
+
+
+ A that represents the specified DateTimeOffset value.
+
+ The DateTimeOffset value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable) decimal value.
+
+
+ A that represents the specified decimal value.
+
+ The decimal value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable) double value.
+
+
+ A that represents the specified double value.
+
+ The double value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified
+
+ value, which may be null.
+
+
+ A that represents the specified DbGeography value.
+
+ The DbGeography value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified
+
+ value, which may be null.
+
+
+ A that represents the specified DbGeometry value.
+
+ The DbGeometry value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable)
+
+ value.
+
+
+ A that represents the specified Guid value.
+
+ The Guid value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable) Int16 value.
+
+
+ A that represents the specified Int16 value.
+
+ The Int16 value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable) Int32 value.
+
+
+ A that represents the specified Int32 value.
+
+ The Int32 value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable) Int64 value.
+
+
+ A that represents the specified Int64 value.
+
+ The Int64 value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified (nullable) Single value.
+
+
+ A that represents the specified Single value.
+
+ The Single value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+
+ Creates a that represents the specified string value.
+
+
+ A that represents the specified string value.
+
+ The string value on which the returned expression should be based.
+
+
+
+ Enables implicit casting from .
+
+ The value to be converted.
+ The converted value.
+
+
+ Gets the type metadata for the result type of the expression.
+ The type metadata for the result type of the expression.
+
+
+ Gets the kind of the expression, which indicates the operation of this expression.
+ The kind of the expression, which indicates the operation of this expression.
+
+
+
+ Gets the that defines the left argument.
+
+
+ The that defines the left argument.
+
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ ,or its result type is not equal or promotable to the required type for the left argument.
+
+
+
+
+ Gets the that defines the right argument.
+
+
+ The that defines the right argument.
+
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ ,or its result type is not equal or promotable to the required type for the right argument.
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by the visitor .
+ visitor is null.
+
+
+ Represents an apply operation, which is the invocation of the specified function for each element in the specified input set. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by the visitor .
+ visitor is null.
+
+
+
+ Gets the that specifies the function that is invoked for each element in the input set.
+
+
+ The that specifies the function that is invoked for each element in the input set.
+
+
+
+
+ Gets the that specifies the input set.
+
+
+ The that specifies the input set.
+
+
+
+
+ Represents an arithmetic operation applied to numeric arguments.
+ Addition, subtraction, multiplication, division, modulo, and negation are arithmetic operations.
+ This class cannot be inherited.
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Gets the list of elements that define the current arguments.
+
+
+ A fixed-size list of elements.
+
+
+
+
+ Represents the When, Then, and Else clauses of the
+
+ . This class cannot be inherited.
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+
+ Gets the When clauses of this .
+
+
+ The When clauses of this .
+
+
+
+
+ Gets the Then clauses of this .
+
+
+ The Then clauses of this .
+
+
+
+
+ Gets the Else clause of this .
+
+
+ The Else clause of this .
+
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ ,or its result type is not equal or promotable to the result type of the
+
+ .
+
+
+
+ Represents the type conversion of a single argument to the specified type. This class cannot be inherited.
+
+
+ Implements the basic functionality required by expressions that accept a single expression argument.
+
+
+
+ Gets the that defines the argument.
+
+
+ The that defines the argument.
+
+ The expression is null.
+
+ The expression is not associated with the command tree of a
+
+ , or its result type is not equal or promotable to the required type for the argument.
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+
+ Describes the different "kinds" (classes) of command trees.
+
+
+
+
+ A query to retrieve data
+
+
+
+
+ Update existing data
+
+
+
+
+ Insert new data
+
+
+
+
+ Deleted existing data
+
+
+
+
+ Call a function
+
+
+
+ Represents a comparison operation applied to two arguments. Equality, greater than, greater than or equal, less than, less than or equal, and inequality are comparison operations. This class cannot be inherited.
+
+ DbComparisonExpression requires that its arguments have a common result type
+ that is equality comparable (for .Equals and .NotEquals),
+ order comparable (for .GreaterThan and .LessThan),
+ or both (for .GreaterThanOrEquals and .LessThanOrEquals).
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+ Represents different kinds of constants (literals). This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+ Gets the constant value.
+ The constant value.
+
+
+ Represents an unconditional join operation between the given collection arguments. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+
+ Gets a list that provides the input sets to the join.
+
+
+ A list that provides the input sets to the join.
+
+
+
+ Represents the an expression that retrieves an entity based on the specified reference. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+ Removes duplicate elements from the specified set argument. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+ Represents the conversion of the specified set argument to a singleton. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+ Represents an expression that extracts a reference from the underlying entity instance. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+ Represents the set subtraction operation between the left and right operands. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor.
+ visitor is null.
+
+
+
+ Describes a binding for an expression. Conceptually similar to a foreach loop
+ in C#. The DbExpression property defines the collection being iterated over,
+ while the Var property provides a means to reference the current element
+ of the collection during the iteration. DbExpressionBinding is used to describe the set arguments
+ to relational expressions such as ,
+ and .
+
+
+
+
+
+
+ Gets the that defines the input set.
+
+
+ The that defines the input set.
+
+ The expression is null.
+ The expression is not associated with the command tree of the binding, or its result type is not equal or promotable to the result type of the current value of the property.
+
+
+ Gets the name assigned to the element variable.
+ The name assigned to the element variable.
+
+
+ Gets the type metadata of the element variable.
+ The type metadata of the element variable.
+
+
+
+ Gets the that references the element variable.
+
+ The variable reference.
+
+
+ Represents a predicate applied to filter an input set. This produces the set of elements that satisfy the predicate. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Gets the that specifies the input set.
+
+
+ The that specifies the input set.
+
+
+
+
+ Gets the that specifies the predicate used to filter the input set.
+
+
+ The that specifies the predicate used to filter the input set.
+
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ , or its result type is not a Boolean type.
+
+
+
+ Represents an invocation of a function. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets the metadata for the function to invoke.
+ The metadata for the function to invoke.
+
+
+
+ Gets an list that provides the arguments to the function.
+
+
+ An list that provides the arguments to the function.
+
+
+
+ Represents a collection of elements that compose a group.
+
+
+ Represents a group by operation. A group by operation is a grouping of the elements in the input set based on the specified key expressions followed by the application of the specified aggregates. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Gets the that specifies the input set and provides access to the set element and group element variables.
+
+
+ The that specifies the input set and provides access to the set element and group element variables.
+
+
+
+
+ Gets a list that provides grouping keys.
+
+
+ A list that provides grouping keys.
+
+
+
+
+ Gets a list that provides the aggregates to apply.
+
+
+ A list that provides the aggregates to apply.
+
+
+
+ Represents the set intersection operation between the left and right operands. This class cannot be inherited.
+
+ DbIntersectExpression requires that its arguments have a common collection result type
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Represents an empty set determination applied to a single set argument. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Represents null determination applied to a single argument. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Represents the type comparison of a single argument against the specified type. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets the type metadata that the type metadata of the argument should be compared to.
+ The type metadata that the type metadata of the argument should be compared to.
+
+
+ Represents an inner, left outer, or full outer join operation between the given collection arguments on the specified join condition.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Gets the that provides the left input.
+
+
+ The that provides the left input.
+
+
+
+
+ Gets the that provides the right input.
+
+
+ The that provides the right input.
+
+
+
+ Gets the join condition to apply.
+ The join condition to apply.
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ , or its result type is not a Boolean type.
+
+
+
+
+ Allows the application of a lambda function to arguments represented by
+
+ objects.
+
+
+
+ The visitor pattern method for expression visitors that do not produce a result value.
+
+ An instance of .
+
+ visitor is null
+
+
+ The visitor pattern method for expression visitors that produce a result value of a specific type.
+ The type of the result produced by the expression visitor.
+
+ An instance of a typed that produces a result value of type TResultType.
+
+ The type of the result produced by visitor
+ visitor is null
+
+
+
+ Gets the representing the Lambda function applied by this expression.
+
+
+ The representing the Lambda function applied by this expression.
+
+
+
+
+ Gets a list that provides the arguments to which the Lambda function should be applied.
+
+
+ The list.
+
+
+
+ Represents a string comparison against the specified pattern with an optional escape string. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets an expression that specifies the string to compare against the given pattern.
+ An expression that specifies the string to compare against the given pattern.
+ The expression is null.
+
+ The expression is not associated with the command tree of
+
+ , or its result type is not a string type.
+
+
+
+ Gets an expression that specifies the pattern against which the given string should be compared.
+ An expression that specifies the pattern against which the given string should be compared.
+ The expression is null.
+
+ The expression is not associated with the command tree of
+
+ , or its result type is not a string type.
+
+
+
+ Gets an expression that provides an optional escape string to use for the comparison.
+ An expression that provides an optional escape string to use for the comparison.
+ The expression is null.
+
+ The expression is not associated with the command tree of
+
+ , or its result type is not a string type.
+
+
+
+ Represents the restriction of the number of elements in the argument collection to the specified limit value.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets an expression that specifies the input collection.
+ An expression that specifies the input collection.
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ , or its result type is not a collection type.
+
+
+
+ Gets an expression that specifies the limit on the number of elements returned from the input collection.
+ An expression that specifies the limit on the number of elements returned from the input collection.
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ , or is not one of
+
+ or
+
+ , or its result type is not equal or promotable to a 64-bit integer type.
+
+
+
+
+ Gets whether the limit operation will include tied results. Including tied results might produce more results than specified by the
+
+ value.
+
+ true if the limit operation will include tied results; otherwise, false. The default is false.
+
+
+ Represents the construction of a new instance of a given type, including set and record types. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Gets an list that provides the property/column values or set elements for the new instance.
+
+
+ An list that provides the property/column values or set elements for the new instance.
+
+
+
+ Represents the logical NOT of a single Boolean argument. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Represents a reference to a typed null literal. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Represents the retrieval of elements of the specified type from the given set argument. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets the metadata of the type of elements that should be retrieved from the set argument.
+ The metadata of the type of elements that should be retrieved from the set argument.
+
+
+ Represents the logical OR of two Boolean arguments. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Represents a reference to a parameter declared on the command tree that contains this expression. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets the name of the referenced parameter.
+ The name of the referenced parameter.
+
+
+ Represents the projection of a given input set over the specified expression. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Gets the that specifies the input set.
+
+
+ The that specifies the input set.
+
+
+
+
+ Gets the that defines the projection.
+
+
+ The that defines the projection.
+
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ , or its result type is not equal or promotable to the reference type of the current projection.
+
+
+
+ Provides methods and properties for retrieving an instance property. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Creates a new key/value pair based on this property expression.
+
+ A new key/value pair with the key and value derived from the
+
+ .
+
+
+
+
+ Enables implicit casting to .
+
+ The expression to be converted.
+ The converted value.
+
+
+ Gets the property metadata for the property to retrieve.
+ The property metadata for the property to retrieve.
+
+
+
+ Gets a that defines the instance from which the property should be retrieved.
+
+
+ A that defines the instance from which the property should be retrieved.
+
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ , or its result type is not equal or promotable to the type that defines the property.
+
+
+
+ Represents a quantifier operation of the specified kind over the elements of the specified input set. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Gets the that specifies the input set.
+
+
+ The that specifies the input set.
+
+
+
+ Gets the Boolean predicate that should be evaluated for each element in the input set.
+ The Boolean predicate that should be evaluated for each element in the input set.
+ The expression is null.
+
+ The expression is not associated with the command tree for the
+
+ ,or its result type is not a Boolean type.
+
+
+
+ Represents a strongly typed reference to a specific instance within an entity set. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets the metadata for the entity set that contains the instance.
+ The metadata for the entity set that contains the instance.
+
+
+ Represents the navigation of a relationship. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets the metadata for the relationship over which navigation occurs.
+ The metadata for the relationship over which navigation occurs.
+
+
+ Gets the metadata for the relationship end to navigate from.
+ The metadata for the relationship end to navigate from.
+
+
+ Gets the metadata for the relationship end to navigate to.
+ The metadata for the relationship end to navigate to.
+
+
+
+ Gets an that specifies the starting point of the navigation and must be a reference to an entity instance.
+
+
+ An that specifies the instance of the source relationship end from which navigation should occur.
+
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ , or its result type is not equal or promotable to the reference type of the
+
+ property.
+
+
+
+
+ Skips a specified number of elements in the input set.
+
+ can only be used after the input collection has been sorted as specified by the sort keys.
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Gets the that specifies the input set.
+
+
+ The that specifies the input set.
+
+
+
+
+ Gets a list that defines the sort order.
+
+
+ A list that defines the sort order.
+
+
+
+ Gets an expression that specifies the number of elements to skip from the input collection.
+ An expression that specifies the number of elements to skip from the input collection.
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ ; the expression is not either a
+
+ or a
+
+ ; or the result type of the expression is not equal or promotable to a 64-bit integer type.
+
+
+
+
+ Specifies a sort key that can be used as part of the sort order in a
+
+ . This class cannot be inherited.
+
+
+
+ Gets a Boolean value indicating whether or not this sort key uses an ascending sort order.
+ true if this sort key uses an ascending sort order; otherwise, false.
+
+
+ Gets a string value that specifies the collation for this sort key.
+ A string value that specifies the collation for this sort key.
+
+
+
+ Gets the that provides the value for this sort key.
+
+
+ The that provides the value for this sort key.
+
+
+
+ Represents a sort operation applied to the elements of the specified input set based on the given sort keys. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by
+ visitor
+
+
+ visitor
+ is null.
+
+
+
+ Gets the that specifies the input set.
+
+
+ The that specifies the input set.
+
+
+
+
+ Gets a list that defines the sort order.
+
+
+ A list that defines the sort order.
+
+
+
+ Represents a type conversion operation applied to a polymorphic argument. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Supports standard aggregate functions, such as MIN, MAX, AVG, SUM, and so on. This class cannot be inherited.
+
+
+ Gets a value indicating whether this aggregate is a distinct aggregate.
+ true if the aggregate is a distinct aggregate; otherwise, false.
+
+
+ Gets the method metadata that specifies the aggregate function to invoke.
+ The method metadata that specifies the aggregate function to invoke.
+
+
+
+ An abstract base type for types that implement the IExpressionVisitor interface to derive from.
+
+
+
+
+ An abstract base type for types that implement the IExpressionVisitor interface to derive from.
+
+
+
+ Defines the basic functionality that should be implemented by visitors that do not return a result value.
+
+
+ When overridden in a derived class, handles any expression of an unrecognized type.
+ The expression to be handled.
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ When overridden in a derived class, implements the visitor pattern for
+
+ .
+
+
+ The that is visited.
+
+
+
+
+ Visitor pattern method for DbInExpression.
+
+ The DbInExpression that is being visited.
+
+
+
+ Convenience method to visit the specified .
+
+ The DbUnaryExpression to visit.
+
+
+ is null
+
+
+
+
+ Convenience method to visit the specified .
+
+ The DbBinaryExpression to visit.
+
+
+ is null
+
+
+
+
+ Convenience method to visit the specified .
+
+ The DbExpressionBinding to visit.
+
+
+ is null
+
+
+
+
+ Convenience method for post-processing after a DbExpressionBinding has been visited.
+
+ The previously visited DbExpressionBinding.
+
+
+
+ Convenience method to visit the specified .
+
+ The DbGroupExpressionBinding to visit.
+
+
+ is null
+
+
+
+
+ Convenience method indicating that the grouping keys of a have been visited and the aggregates are now about to be visited.
+
+ The DbGroupExpressionBinding of the DbGroupByExpression
+
+
+
+ Convenience method for post-processing after a DbGroupExpressionBinding has been visited.
+
+ The previously visited DbGroupExpressionBinding.
+
+
+
+ Convenience method indicating that the body of a Lambda is now about to be visited.
+
+ The DbLambda that is about to be visited
+
+
+ is null
+
+
+
+
+ Convenience method for post-processing after a DbLambda has been visited.
+
+ The previously visited DbLambda.
+
+
+
+ Convenience method to visit the specified , if non-null.
+
+ The expression to visit.
+
+
+ is null
+
+
+
+
+ Convenience method to visit each in the given list, if the list is non-null.
+
+ The list of expressions to visit.
+
+
+ is null
+
+
+
+
+ Convenience method to visit each in the list, if the list is non-null.
+
+ The list of aggregates to visit.
+
+
+ is null
+
+
+
+
+ Convenience method to visit the specified .
+
+ The aggregate to visit.
+
+
+ is null
+
+
+
+
+ Called when an of an otherwise unrecognized type is encountered.
+
+ The expression
+
+
+ is null
+
+
+ Always thrown if this method is called, since it indicates that
+
+ is of an unsupported type
+
+
+
+
+ Visitor pattern method for .
+
+ The DbConstantExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbNullExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbVariableReferenceExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbParameterReferenceExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbFunctionExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbLambdaExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbPropertyExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbComparisonExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbLikeExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbLimitExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbIsNullExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbArithmeticExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbAndExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbOrExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbInExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbNotExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbDistinctExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbElementExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbIsEmptyExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbUnionAllExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbIntersectExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbExceptExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbOfTypeExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbTreatExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbCastExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbIsOfExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbCaseExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbNewInstanceExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbRefExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbRelationshipNavigationExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DeRefExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbRefKeyExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbEntityRefExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbScanExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbFilterExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbProjectExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbCrossJoinExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbJoinExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbApplyExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbSkipExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbSortExpression that is being visited.
+
+
+ is null
+
+
+
+
+ Visitor pattern method for .
+
+ The DbQuantifierExpression that is being visited.
+
+
+ is null
+
+
+
+ Implements the visitor pattern for the set clause.
+ The set clause.
+
+
+ Implements the visitor pattern for the modification clause.
+ The modification clause.
+
+
+ Implements the visitor pattern for the collection of modification clauses.
+ The modification clauses.
+
+
+ Implements the visitor pattern for the command tree.
+ The command tree.
+
+
+ Implements the visitor pattern for the delete command tree.
+ The delete command tree.
+
+
+ Implements the visitor pattern for the function command tree.
+ The function command tree.
+
+
+ Implements the visitor pattern for the insert command tree.
+ The insert command tree.
+
+
+ Implements the visitor pattern for the query command tree.
+ The query command tree.
+
+
+ Implements the visitor pattern for the update command tree.
+ The update command tree.
+
+
+ An immutable class that implements the basic functionality for the Query, Insert, Update, Delete, and function invocation command tree types.
+
+
+
+ Returns a that represents this command.
+
+
+ A that represents this command.
+
+
+
+
+ Gets a value indicating whether database null semantics are exhibited when comparing
+ two operands, both of which are potentially nullable. The default value is true.
+
+ For example (operand1 == operand2) will be translated as:
+
+ (operand1 = operand2)
+
+ if UseDatabaseNullSemantics is true, respectively
+
+ (((operand1 = operand2) AND (NOT (operand1 IS NULL OR operand2 IS NULL))) OR ((operand1 IS NULL) AND (operand2 IS NULL)))
+
+ if UseDatabaseNullSemantics is false.
+
+
+ true if database null comparison behavior is enabled, otherwise false .
+
+
+
+
+ Gets the name and corresponding type of each parameter that can be referenced within this
+
+ .
+
+
+ The name and corresponding type of each parameter that can be referenced within this
+
+ .
+
+
+
+
+ Gets the kind of this command tree.
+
+
+
+
+ Gets the metadata workspace used by this command tree.
+
+
+
+
+ Gets the data space in which metadata used by this command tree must reside.
+
+
+
+ Represents a single row delete operation expressed as a command tree. This class cannot be inherited.
+
+
+ Represents a data manipulation language (DML) operation expressed as a command tree.
+
+
+
+ Gets the that specifies the target table for the data manipulation language (DML) operation.
+
+
+ The that specifies the target table for the DML operation.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The model this command will operate on.
+ The data space.
+ The target table for the data manipulation language (DML) operation.
+ A predicate used to determine which members of the target collection should be deleted.
+
+
+
+ Gets an that specifies the predicate used to determine which members of the target collection should be deleted.
+
+
+ The predicate can include only the following elements:
+
+ - Equality expression
+ - Constant expression
+ - IsNull expression
+ - Property expression
+ - Reference expression to the target
+ - And expression
+ - Or expression
+ - Not expression
+
+
+
+ An that specifies the predicate used to determine which members of the target collection should be deleted.
+
+
+
+ Gets the kind of this command tree.
+ The kind of this command tree.
+
+
+
+ Contains values that each expression class uses to denote the operation it represents. The
+
+ property of an
+
+ can be retrieved to determine which operation that expression represents.
+
+
+
+
+ True for all.
+
+
+
+
+ Logical And.
+
+
+
+
+ True for any.
+
+
+
+
+ Conditional case statement.
+
+
+
+
+ Polymorphic type cast.
+
+
+
+
+ A constant value.
+
+
+
+
+ Cross apply
+
+
+
+
+ Cross join
+
+
+
+
+ Dereference.
+
+
+
+
+ Duplicate removal.
+
+
+
+
+ Division.
+
+
+
+
+ Set to singleton conversion.
+
+
+
+
+ Entity ref value retrieval.
+
+
+
+
+ Equality
+
+
+
+
+ Set subtraction
+
+
+
+
+ Restriction.
+
+
+
+
+ Full outer join
+
+
+
+
+ Invocation of a stand-alone function
+
+
+
+
+ Greater than.
+
+
+
+
+ Greater than or equal.
+
+
+
+
+ Grouping.
+
+
+
+
+ Inner join
+
+
+
+
+ Set intersection.
+
+
+
+
+ Empty set determination.
+
+
+
+
+ Null determination.
+
+
+
+
+ Type comparison (specified Type or Subtype).
+
+
+
+
+ Type comparison (specified Type only).
+
+
+
+
+ Left outer join
+
+
+
+
+ Less than.
+
+
+
+
+ Less than or equal.
+
+
+
+
+ String comparison.
+
+
+
+
+ Result count restriction (TOP n).
+
+
+
+
+ Subtraction.
+
+
+
+
+ Modulo.
+
+
+
+
+ Multiplication.
+
+
+
+
+ Instance, row, and set construction.
+
+
+
+
+ Logical Not.
+
+
+
+
+ Inequality.
+
+
+
+
+ Null.
+
+
+
+
+ Set members by type (or subtype).
+
+
+
+
+ Set members by (exact) type.
+
+
+
+
+ Logical Or.
+
+
+
+
+ Outer apply.
+
+
+
+
+ A reference to a parameter.
+
+
+
+
+ Addition.
+
+
+
+
+ Projection.
+
+
+
+
+ Retrieval of a static or instance property.
+
+
+
+
+ Reference.
+
+
+
+
+ Ref key value retrieval.
+
+
+
+
+ Navigation of a (composition or association) relationship.
+
+
+
+
+ Entity or relationship set scan.
+
+
+
+
+ Skip elements of an ordered collection.
+
+
+
+
+ Sorting.
+
+
+
+
+ Type conversion.
+
+
+
+
+ Negation.
+
+
+
+
+ Set union (with duplicates).
+
+
+
+
+ A reference to a variable.
+
+
+
+
+ Application of a lambda function
+
+
+
+
+ In.
+
+
+
+ Represents the invocation of a database function.
+
+
+
+ Constructs a new DbFunctionCommandTree that uses the specified metadata workspace, data space and function metadata
+
+ The metadata workspace that the command tree should use.
+ The logical 'space' that metadata in the expressions used in this command tree must belong to.
+ The that represents the function that is being invoked.
+ The expected result type for the function’s first result set.
+ The function's parameters.
+
+ , or is null
+
+
+ does not represent a valid data space or
+ is a composable function
+
+
+
+
+ Gets the that represents the function that is being invoked.
+
+
+ The that represents the function that is being invoked.
+
+
+
+ Gets the expected result type for the function’s first result set.
+ The expected result type for the function’s first result set.
+
+
+ Gets or sets the command tree kind.
+ The command tree kind.
+
+
+ Represents a single row insert operation expressed as a command tree. This class cannot be inherited.
+
+ Represents a single row insert operation expressed as a canonical command tree.
+ When the property is set, the command returns a reader; otherwise,
+ it returns a scalar value indicating the number of rows affected.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The model this command will operate on.
+ The data space.
+ The target table for the data manipulation language (DML) operation.
+ The list of insert set clauses that define the insert operation. .
+ A that specifies a projection of results to be returned, based on the modified rows.
+
+
+ Gets the list of insert set clauses that define the insert operation.
+ The list of insert set clauses that define the insert operation.
+
+
+
+ Gets an that specifies a projection of results to be returned based on the modified rows.
+
+
+ An that specifies a projection of results to be returned based on the modified rows. null indicates that no results should be returned from this command.
+
+
+
+ Gets the command tree kind.
+ The command tree kind.
+
+
+
+ Represents a Lambda function that can be invoked to produce a
+
+ .
+
+
+
+
+ Creates a with the specified inline Lambda function implementation and formal parameters.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters
+ An expression that defines the logic of the Lambda function
+
+ A collection that represents the formal parameters to the Lambda function. These variables are valid for use in the body expression.
+
+
+
+ is null or contains null, or
+
+ is null
+
+
+
+ contains more than one element with the same variable name.
+
+
+
+
+ Creates a with the specified inline Lambda function implementation and formal parameters.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters
+ An expression that defines the logic of the Lambda function
+
+ A collection that represents the formal parameters to the Lambda function. These variables are valid for use in the body expression.
+
+
+
+ is null or contains null, or
+
+ is null.
+
+
+
+ contains more than one element with the same variable name.
+
+
+
+
+ Creates a new with a single argument of the specified type, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and single formal parameter.
+
+ A that defines the EDM type of the argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A that defines the EDM type of the ninth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A that defines the EDM type of the ninth argument to the Lambda function
+
+
+ A that defines the EDM type of the tenth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A that defines the EDM type of the ninth argument to the Lambda function
+
+
+ A that defines the EDM type of the tenth argument to the Lambda function
+
+
+ A that defines the EDM type of the eleventh argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A that defines the EDM type of the ninth argument to the Lambda function
+
+
+ A that defines the EDM type of the tenth argument to the Lambda function
+
+
+ A that defines the EDM type of the eleventh argument to the Lambda function
+
+
+ A that defines the EDM type of the twelfth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A that defines the EDM type of the ninth argument to the Lambda function
+
+
+ A that defines the EDM type of the tenth argument to the Lambda function
+
+
+ A that defines the EDM type of the eleventh argument to the Lambda function
+
+
+ A that defines the EDM type of the twelfth argument to the Lambda function
+
+
+ A that defines the EDM type of the thirteenth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A that defines the EDM type of the ninth argument to the Lambda function
+
+
+ A that defines the EDM type of the tenth argument to the Lambda function
+
+
+ A that defines the EDM type of the eleventh argument to the Lambda function
+
+
+ A that defines the EDM type of the twelfth argument to the Lambda function
+
+
+ A that defines the EDM type of the thirteenth argument to the Lambda function
+
+
+ A that defines the EDM type of the fourteenth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A that defines the EDM type of the ninth argument to the Lambda function
+
+
+ A that defines the EDM type of the tenth argument to the Lambda function
+
+
+ A that defines the EDM type of the eleventh argument to the Lambda function
+
+
+ A that defines the EDM type of the twelfth argument to the Lambda function
+
+
+ A that defines the EDM type of the thirteenth argument to the Lambda function
+
+
+ A that defines the EDM type of the fourteenth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifteenth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+ or
+
+ is null or produces a result of null.
+
+
+
+
+ Creates a new with arguments of the specified types, as defined by the specified function.
+
+ A new DbLambda that describes an inline Lambda function with the specified body and formal parameters.
+
+ A that defines the EDM type of the first argument to the Lambda function
+
+
+ A that defines the EDM type of the second argument to the Lambda function
+
+
+ A that defines the EDM type of the third argument to the Lambda function
+
+
+ A that defines the EDM type of the fourth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixth argument to the Lambda function
+
+
+ A that defines the EDM type of the seventh argument to the Lambda function
+
+
+ A that defines the EDM type of the eighth argument to the Lambda function
+
+
+ A that defines the EDM type of the ninth argument to the Lambda function
+
+
+ A that defines the EDM type of the tenth argument to the Lambda function
+
+
+ A that defines the EDM type of the eleventh argument to the Lambda function
+
+
+ A that defines the EDM type of the twelfth argument to the Lambda function
+
+
+ A that defines the EDM type of the thirteenth argument to the Lambda function
+
+
+ A that defines the EDM type of the fourteenth argument to the Lambda function
+
+
+ A that defines the EDM type of the fifteenth argument to the Lambda function
+
+
+ A that defines the EDM type of the sixteenth argument to the Lambda function
+
+
+ A function that defines the logic of the Lambda function as a
+
+
+
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null,
+
+ is null, or
+
+ is null or produces a result of null.
+
+
+
+ Gets the body of the lambda expression.
+
+ A that represents the body of the lambda function.
+
+
+
+ Gets the parameters of the lambda expression.
+ The list of lambda function parameters represented as DbVariableReferenceExpression objects.
+
+
+
+ Specifies a single clause in an insert or update modification operation, see
+ and
+
+
+ An abstract base class allows the possibility of patterns other than
+ Property = Value in future versions, e.g.,
+ update SomeTable
+ set ComplexTypeColumn.SomeProperty()
+ where Id = 2
+
+
+
+ Represents a query operation expressed as a command tree. This class cannot be inherited.
+
+
+
+ Constructs a new DbQueryCommandTree that uses the specified metadata workspace.
+
+ The metadata workspace that the command tree should use.
+ The logical 'space' that metadata in the expressions used in this command tree must belong to.
+
+ A that defines the logic of the query.
+
+ When set to false the validation of the tree is turned off.
+ A boolean that indicates whether database null semantics are exhibited when comparing
+ two operands, both of which are potentially nullable.
+
+
+ or
+
+ is null
+
+
+
+ does not represent a valid data space
+
+
+
+
+ Constructs a new DbQueryCommandTree that uses the specified metadata workspace, using database null semantics.
+
+ The metadata workspace that the command tree should use.
+ The logical 'space' that metadata in the expressions used in this command tree must belong to.
+
+ A that defines the logic of the query.
+
+ When set to false the validation of the tree is turned off.
+
+
+ or
+
+ is null
+
+
+
+ does not represent a valid data space
+
+
+
+
+ Constructs a new DbQueryCommandTree that uses the specified metadata workspace, using database null semantics.
+
+ The metadata workspace that the command tree should use.
+ The logical 'space' that metadata in the expressions used in this command tree must belong to.
+
+ A that defines the logic of the query.
+
+
+
+ or
+
+ is null
+
+
+
+ does not represent a valid data space
+
+
+
+
+ Gets an that defines the logic of the query operation.
+
+
+ An that defines the logic of the query operation.
+
+ The expression is null.
+ The expression is associated with a different command tree.
+
+
+ Gets the kind of this command tree.
+ The kind of this command tree.
+
+
+ Specifies the clause in a modification operation that sets the value of a property. This class cannot be inherited.
+
+
+
+ Gets an that specifies the property that should be updated.
+
+
+ An that specifies the property that should be updated.
+
+
+
+
+ Gets an that specifies the new value with which to update the property.
+
+
+ An that specifies the new value with which to update the property.
+
+
+
+ Represents a single-row update operation expressed as a command tree. This class cannot be inherited.
+
+ Represents a single-row update operation expressed as a canonical command tree.
+ When the property is set, the command returns a reader; otherwise,
+ it returns a scalar indicating the number of rows affected.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The model this command will operate on.
+ The data space.
+ The target table for the data manipulation language (DML) operation.
+ A predicate used to determine which members of the target collection should be updated.
+ The list of update set clauses that define the update operation.
+ A that specifies a projection of results to be returned, based on the modified rows.
+
+
+ Gets the list of update set clauses that define the update operation.
+ The list of update set clauses that define the update operation.
+
+
+
+ Gets an that specifies a projection of results to be returned, based on the modified rows.
+
+
+ An that specifies a projection of results to be returned based, on the modified rows. null indicates that no results should be returned from this command.
+
+
+
+
+ Gets an that specifies the predicate used to determine which members of the target collection should be updated.
+
+
+ An that specifies the predicate used to determine which members of the target collection should be updated.
+
+
+
+ Gets the kind of this command tree.
+ The kind of this command tree.
+
+
+ Represents a reference to a variable that is currently in scope. This class cannot be inherited.
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets the name of the referenced variable.
+ The name of the referenced variable.
+
+
+
+ Defines the binding for the input set to a .
+ In addition to the properties of , DbGroupExpressionBinding
+ also provides access to the group element via the variable reference
+ and to the group aggregate via the property.
+
+
+
+
+ Gets the that defines the input set.
+
+
+ The that defines the input set.
+
+ The expression is null.
+
+ The expression is not associated with the command tree of the
+
+ , or its result type is not equal or promotable to the result type of the current value of the property.
+
+
+
+ Gets the name assigned to the element variable.
+ The name assigned to the element variable.
+
+
+ Gets the type metadata of the element variable.
+ The type metadata of the element variable.
+
+
+
+ Gets the that references the element variable.
+
+ A reference to the element variable.
+
+
+ Gets the name assigned to the group element variable.
+ The name assigned to the group element variable.
+
+
+ Gets the type metadata of the group element variable.
+ The type metadata of the group element variable.
+
+
+
+ Gets the that references the group element variable.
+
+ A reference to the group element variable.
+
+
+
+ Gets the that represents the collection of elements in the group.
+
+ The elements in the group.
+
+
+
+ Provides an API to construct s and allows that API to be accessed as extension methods on the expression type itself.
+
+
+
+ Returns the specified arguments as a key/value pair object.
+ A key/value pair object.
+ The value in the key/value pair.
+ The key in the key/value pair.
+
+
+ Returns the specified arguments as a key/value pair object.
+ A key/value pair object.
+ The value in the key/value pair.
+ The key in the key/value pair.
+
+
+
+ Creates a new that uses a generated variable name to bind the given expression.
+
+ A new expression binding with the specified expression and a generated variable name.
+ The expression to bind.
+ input is null.
+ input does not have a collection result.
+
+
+
+ Creates a new that uses the specified variable name to bind the given expression
+
+ A new expression binding with the specified expression and variable name.
+ The expression to bind.
+ The variable name that should be used for the binding.
+ input or varName is null.
+ input does not have a collection result.
+
+
+ Creates a new group expression binding that uses generated variable and group variable names to bind the given expression.
+ A new group expression binding with the specified expression and a generated variable name and group variable name.
+ The expression to bind.
+ input is null.
+ input does not have a collection result type.
+
+
+
+ Creates a new that uses the specified variable name and group variable names to bind the given expression.
+
+ A new group expression binding with the specified expression, variable name and group variable name.
+ The expression to bind.
+ The variable name that should be used for the binding.
+ The variable name that should be used to refer to the group when the new group expression binding is used in a group-by expression.
+ input, varName or groupVarName is null.
+ input does not have a collection result type.
+
+
+
+ Creates a new .
+
+ A new function aggregate with a reference to the given function and argument. The function aggregate's Distinct property will have the value false.
+ The function that defines the aggregate operation.
+ The argument over which the aggregate function should be calculated.
+ function or argument null.
+ function is not an aggregate function or has more than one argument, or the result type of argument is not equal or promotable to the parameter type of function.
+
+
+
+ Creates a new that is applied in a distinct fashion.
+
+ A new function aggregate with a reference to the given function and argument. The function aggregate's Distinct property will have the value true.
+ The function that defines the aggregate operation.
+ The argument over which the aggregate function should be calculated.
+ function or argument is null.
+ function is not an aggregate function or has more than one argument, or the result type of argument is not equal or promotable to the parameter type of function.
+
+
+
+ Creates a new over the specified argument
+
+ The argument over which to perform the nest operation
+ A new group aggregate representing the elements of the group referenced by the given argument.
+
+
+ is null
+
+
+
+
+ Creates a with the specified inline Lambda function implementation and formal parameters.
+
+ A new expression that describes an inline Lambda function with the specified body and formal parameters.
+ An expression that defines the logic of the Lambda function.
+
+ A collection that represents the formal parameters to the Lambda function. These variables are valid for use in the body expression.
+
+ variables is null or contains null, or body is null.
+ variables contains more than one element with the same variable name.
+
+
+
+ Creates a with the specified inline Lambda function implementation and formal parameters.
+
+ A new expression that describes an inline Lambda function with the specified body and formal parameters.
+ An expression that defines the logic of the Lambda function.
+
+ A collection that represents the formal parameters to the Lambda function. These variables are valid for use in the body expression.
+
+ variables is null or contains null, or body is null.
+ variables contains more than one element with the same variable name.
+
+
+
+ Creates a new with an ascending sort order and default collation.
+
+ A new sort clause with the given sort key and ascending sort order.
+ The expression that defines the sort key.
+ key is null.
+ key does not have an order-comparable result type.
+
+
+
+ Creates a new with a descending sort order and default collation.
+
+ A new sort clause with the given sort key and descending sort order.
+ The expression that defines the sort key.
+ key is null.
+ key does not have an order-comparable result type.
+
+
+
+ Creates a new with an ascending sort order and the specified collation.
+
+ A new sort clause with the given sort key and collation, and ascending sort order.
+ The expression that defines the sort key.
+ The collation to sort under.
+ key is null.
+ collation is empty or contains only space characters.
+ key does not have an order-comparable result type.
+
+
+
+ Creates a new with a descending sort order and the specified collation.
+
+ A new sort clause with the given sort key and collation, and descending sort order.
+ The expression that defines the sort key.
+ The collation to sort under.
+ key is null.
+ collation is empty or contains only space characters.
+ key does not have an order-comparable result type.
+
+
+
+ Creates a new that determines whether the given predicate holds for all elements of the input set.
+
+ A new DbQuantifierExpression that represents the All operation.
+ An expression binding that specifies the input set.
+ An expression representing a predicate to evaluate for each member of the input set.
+ input or predicate is null.
+ predicate does not have a Boolean result type.
+
+
+
+ Creates a new that determines whether the given predicate holds for any element of the input set.
+
+ A new DbQuantifierExpression that represents the Any operation.
+ An expression binding that specifies the input set.
+ An expression representing a predicate to evaluate for each member of the input set.
+ input or predicate is null.
+ The expression produced by predicate does not have a Boolean result type.
+
+
+
+ Creates a new that evaluates the given apply expression once for each element of a given input set, producing a collection of rows with corresponding input and apply columns. Rows for which apply evaluates to an empty set are not included.
+
+
+ An new DbApplyExpression with the specified input and apply bindings and an
+
+ of CrossApply.
+
+
+ An that specifies the input set.
+
+
+ An that specifies logic to evaluate once for each member of the input set.
+
+ input or apply is null.
+
+
+
+ Creates a new that evaluates the given apply expression once for each element of a given input set, producing a collection of rows with corresponding input and apply columns. Rows for which apply evaluates to an empty set have an apply column value of null.
+
+
+ An new DbApplyExpression with the specified input and apply bindings and an
+
+ of OuterApply.
+
+
+ An that specifies the input set.
+
+
+ An that specifies logic to evaluate once for each member of the input set.
+
+ input or apply is null.
+
+
+
+ Creates a new that unconditionally joins the sets specified by the list of input expression bindings.
+
+
+ A new DbCrossJoinExpression, with an of CrossJoin, that represents the unconditional join of the input sets.
+
+ A list of expression bindings that specifies the input sets.
+ inputs is null or contains null element.
+ inputs contains fewer than 2 expression bindings.
+
+
+
+ Creates a new that joins the sets specified by the left and right expression bindings, on the specified join condition, using InnerJoin as the
+
+ .
+
+
+ A new DbJoinExpression, with an of InnerJoin, that represents the inner join operation applied to the left and right input sets under the given join condition.
+
+
+ An that specifies the left set argument.
+
+
+ An that specifies the right set argument.
+
+ An expression that specifies the condition on which to join.
+ left, right or joinCondition is null.
+ joinCondition does not have a Boolean result type.
+
+
+
+ Creates a new that joins the sets specified by the left and right expression bindings, on the specified join condition, using LeftOuterJoin as the
+
+ .
+
+
+ A new DbJoinExpression, with an of LeftOuterJoin, that represents the left outer join operation applied to the left and right input sets under the given join condition.
+
+
+ An that specifies the left set argument.
+
+
+ An that specifies the right set argument.
+
+ An expression that specifies the condition on which to join.
+ left, right or joinCondition is null.
+ joinCondition does not have a Boolean result type.
+
+
+
+ Creates a new that joins the sets specified by the left and right expression bindings, on the specified join condition, using FullOuterJoin as the
+
+ .
+
+
+ A new DbJoinExpression, with an of FullOuterJoin, that represents the full outer join operation applied to the left and right input sets under the given join condition.
+
+
+ An that specifies the left set argument.
+
+
+ An that specifies the right set argument.
+
+ An expression that specifies the condition on which to join.
+ left, right or joinCondition is null.
+ The expression produced by joinCondition does not have a Boolean result type.
+
+
+
+ Creates a new that filters the elements in the given input set using the specified predicate.
+
+ A new DbFilterExpression that produces the filtered set.
+ An expression binding that specifies the input set.
+ An expression representing a predicate to evaluate for each member of the input set.
+ input or predicate is null.
+ predicate does not have a Boolean result type.
+
+
+
+ Creates a new that groups the elements of the input set according to the specified group keys and applies the given aggregates.
+
+ A new DbGroupByExpression with the specified input set, grouping keys and aggregates.
+
+ A that specifies the input set.
+
+ A list of string-expression pairs that define the grouping columns.
+ A list of expressions that specify aggregates to apply.
+ input, keys or aggregates is null, keys contains a null column key or expression, or aggregates contains a null aggregate column name or aggregate.
+ Both keys and aggregates are empty, or an invalid or duplicate column name was specified.
+
+
+
+ Creates a new that projects the specified expression over the given input set.
+
+ A new DbProjectExpression that represents the projection operation.
+ An expression binding that specifies the input set.
+ An expression to project over the set.
+ input or projection is null.
+
+
+
+ Creates a new that sorts the given input set by the given sort specifications before skipping the specified number of elements.
+
+ A new DbSkipExpression that represents the skip operation.
+ An expression binding that specifies the input set.
+ A list of sort specifications that determine how the elements of the input set should be sorted.
+ An expression the specifies how many elements of the ordered set to skip.
+ input, sortOrder or count is null, or sortOrder contains null.
+
+ sortOrder is empty, or count is not or
+
+ or has a result type that is not equal or promotable to a 64-bit integer type.
+
+
+
+
+ Creates a new that sorts the given input set by the specified sort specifications.
+
+ A new DbSortExpression that represents the sort operation.
+ An expression binding that specifies the input set.
+ A list of sort specifications that determine how the elements of the input set should be sorted.
+ input or sortOrder is null, or sortOrder contains null.
+ sortOrder is empty.
+
+
+
+ Creates a new , which represents a typed null value.
+
+ An instance of DbNullExpression.
+ The type of the null value.
+ nullType is null.
+
+
+
+ Creates a new with the given constant value.
+
+ A new DbConstantExpression with the given value.
+ The constant value to represent.
+ value is null.
+ value is not an instance of a valid constant type.
+
+
+
+ Creates a new of the specified primitive type with the given constant value.
+
+ A new DbConstantExpression with the given value and a result type of constantType.
+ The type of the constant value.
+ The constant value to represent.
+ value or constantType is null.
+ value is not an instance of a valid constant type, constantType does not represent a primitive type, or value is of a different primitive type than that represented by constantType.
+
+
+
+ Creates a new that references a parameter with the specified name and type.
+
+ A DbParameterReferenceExpression that represents a reference to a parameter with the specified name and type. The result type of the expression will be the same as type.
+ The type of the referenced parameter.
+ The name of the referenced parameter.
+
+
+
+ Creates a new that references a variable with the specified name and type.
+
+ A DbVariableReferenceExpression that represents a reference to a variable with the specified name and type. The result type of the expression will be the same as type.
+ The type of the referenced variable.
+ The name of the referenced variable.
+
+
+
+ Creates a new that references the specified entity or relationship set.
+
+ A new DbScanExpression based on the specified entity or relationship set.
+ Metadata for the entity or relationship set to reference.
+ targetSet is null.
+
+
+
+ Creates an that performs the logical And of the left and right arguments.
+
+ A new DbAndExpression with the specified arguments.
+ A Boolean expression that specifies the left argument.
+ A Boolean expression that specifies the right argument.
+ left or right is null.
+ left and right does not have a Boolean result type.
+
+
+
+ Creates an that performs the logical Or of the left and right arguments.
+
+ A new DbOrExpression with the specified arguments.
+ A Boolean expression that specifies the left argument.
+ A Boolean expression that specifies the right argument.
+ left or right is null.
+ left or right does not have a Boolean result type.
+
+
+
+ Creates a that matches the result of the specified
+ expression with the results of the constant expressions in the specified list.
+
+ A DbExpression to be matched.
+ A list of DbConstantExpression to test for a match.
+
+ A new DbInExpression with the specified arguments.
+
+
+
+ or
+
+ is null.
+
+
+ The result type of
+
+ is different than the result type of an expression from
+ .
+
+
+
+
+ Creates a that performs the logical negation of the given argument.
+
+ A new DbNotExpression with the specified argument.
+ A Boolean expression that specifies the argument.
+ argument is null.
+ argument does not have a Boolean result type.
+
+
+
+ Creates a new that divides the left argument by the right argument.
+
+ A new DbArithmeticExpression representing the division operation.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common numeric result type exists between left or right.
+
+
+
+ Creates a new that subtracts the right argument from the left argument.
+
+ A new DbArithmeticExpression representing the subtraction operation.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common numeric result type exists between left and right.
+
+
+
+ Creates a new that computes the remainder of the left argument divided by the right argument.
+
+ A new DbArithmeticExpression representing the modulo operation.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common numeric result type exists between left and right.
+
+
+
+ Creates a new that multiplies the left argument by the right argument.
+
+ A new DbArithmeticExpression representing the multiplication operation.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common numeric result type exists between left and right.
+
+
+
+ Creates a new that adds the left argument to the right argument.
+
+ A new DbArithmeticExpression representing the addition operation.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common numeric result type exists between left and right.
+
+
+
+ Creates a new that negates the value of the argument.
+
+ A new DbArithmeticExpression representing the negation operation.
+ An expression that specifies the argument.
+ argument is null.
+ No numeric result type exists for argument.
+
+
+
+ Creates a new that negates the value of the argument.
+
+ A new DbArithmeticExpression representing the negation operation.
+ An expression that specifies the argument.
+ argument is null.
+ No numeric result type exists for argument.
+
+
+
+ Creates a new that compares the left and right arguments for equality.
+
+ A new DbComparisonExpression representing the equality comparison.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common equality-comparable result type exists between left and right.
+
+
+
+ Creates a new that compares the left and right arguments for inequality.
+
+ A new DbComparisonExpression representing the inequality comparison.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common equality-comparable result type exists between left and right.
+
+
+
+ Creates a new that determines whether the left argument is greater than the right argument.
+
+ A new DbComparisonExpression representing the greater-than comparison.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common order-comparable result type exists between left and right.
+
+
+
+ Creates a new that determines whether the left argument is less than the right argument.
+
+ A new DbComparisonExpression representing the less-than comparison.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common order-comparable result type exists between left and right.
+
+
+
+ Creates a new that determines whether the left argument is greater than or equal to the right argument.
+
+ A new DbComparisonExpression representing the greater-than-or-equal-to comparison.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common order-comparable result type exists between left and right.
+
+
+
+ Creates a new that determines whether the left argument is less than or equal to the right argument.
+
+ A new DbComparisonExpression representing the less-than-or-equal-to comparison.
+ An expression that specifies the left argument.
+ An expression that specifies the right argument.
+ left or right is null.
+ No common result type that is both equality- and order-comparable exists between left and right.
+
+
+
+ Creates a new that determines whether the specified argument is null.
+
+ A new DbIsNullExpression with the specified argument.
+ An expression that specifies the argument.
+ argument is null.
+ argument has a collection result type.
+
+
+
+ Creates a new that compares the specified input string to the given pattern.
+
+ A new DbLikeExpression with the specified input, pattern and a null escape.
+ An expression that specifies the input string.
+ An expression that specifies the pattern string.
+ Argument or pattern is null.
+ Argument or pattern does not have a string result type.
+
+
+
+ Creates a new that compares the specified input string to the given pattern using the optional escape.
+
+ A new DbLikeExpression with the specified input, pattern and escape.
+ An expression that specifies the input string.
+ An expression that specifies the pattern string.
+ An optional expression that specifies the escape string.
+ argument, pattern or escape is null.
+ argument, pattern or escape does not have a string result type.
+
+
+
+ Creates a new that applies a cast operation to a polymorphic argument.
+
+ A new DbCastExpression with the specified argument and target type.
+ The argument to which the cast should be applied.
+ Type metadata that specifies the type to cast to.
+ Argument or toType is null.
+ The specified cast is not valid.
+
+
+
+ Creates a new .
+
+ A new DbTreatExpression with the specified argument and type.
+ An expression that specifies the instance.
+ Type metadata for the treat-as type.
+ argument or treatType is null.
+ treatType is not in the same type hierarchy as the result type of argument.
+
+
+
+ Creates a new that produces a set consisting of the elements of the given input set that are of the specified type.
+
+
+ A new DbOfTypeExpression with the specified set argument and type, and an ExpressionKind of
+
+ .
+
+
+ A that specifies the input set.
+
+ Type metadata for the type that elements of the input set must have to be included in the resulting set.
+ argument or type is null.
+ argument does not have a collection result type, or type is not a type in the same type hierarchy as the element type of the collection result type of argument.
+
+
+
+ Creates a new that produces a set consisting of the elements of the given input set that are of exactly the specified type.
+
+
+ A new DbOfTypeExpression with the specified set argument and type, and an ExpressionKind of
+
+ .
+
+
+ An that specifies the input set.
+
+ Type metadata for the type that elements of the input set must match exactly to be included in the resulting set.
+ argument or type is null.
+ argument does not have a collection result type, or type is not a type in the same type hierarchy as the element type of the collection result type of argument.
+
+
+
+ Creates a new that determines whether the given argument is of the specified type or a subtype.
+
+ A new DbIsOfExpression with the specified instance and type and DbExpressionKind IsOf.
+ An expression that specifies the instance.
+ Type metadata that specifies the type that the instance's result type should be compared to.
+ argument or type is null.
+ type is not in the same type hierarchy as the result type of argument.
+
+
+
+ Creates a new expression that determines whether the given argument is of the specified type, and only that type (not a subtype).
+
+ A new DbIsOfExpression with the specified instance and type and DbExpressionKind IsOfOnly.
+ An expression that specifies the instance.
+ Type metadata that specifies the type that the instance's result type should be compared to.
+ argument or type is null.
+ type is not in the same type hierarchy as the result type of argument.
+
+
+
+ Creates a new that retrieves a specific Entity given a reference expression.
+
+ A new DbDerefExpression that retrieves the specified Entity.
+
+ An that provides the reference. This expression must have a reference Type.
+
+ argument is null.
+ argument does not have a reference result type.
+
+
+
+ Creates a new that retrieves the ref of the specifed entity in structural form.
+
+ A new DbEntityRefExpression that retrieves a reference to the specified entity.
+ The expression that provides the entity. This expression must have an entity result type.
+ argument is null.
+ argument does not have an entity result type.
+
+
+
+ Creates a new that encodes a reference to a specific entity based on key values.
+
+ A new DbRefExpression that references the element with the specified key values in the given entity set.
+ The entity set in which the referenced element resides.
+
+ A collection of s that provide the key values. These expressions must match (in number, type, and order) the key properties of the referenced entity type.
+
+ entitySet is null, or keyValues is null or contains null.
+ The count of keyValues does not match the count of key members declared by the entitySet’s element type, or keyValues contains an expression with a result type that is not compatible with the type of the corresponding key member.
+
+
+
+ Creates a new that encodes a reference to a specific entity based on key values.
+
+ A new DbRefExpression that references the element with the specified key values in the given entity set.
+ The entity set in which the referenced element resides.
+
+ A collection of s that provide the key values. These expressions must match (in number, type, and order) the key properties of the referenced entity type.
+
+ entitySet is null, or keyValues is null or contains null.
+ The count of keyValues does not match the count of key members declared by the entitySet’s element type, or keyValues contains an expression with a result type that is not compatible with the type of the corresponding key member.
+
+
+
+ Creates a new that encodes a reference to a specific entity of a given type based on key values.
+
+ A new DbRefExpression that references the element with the specified key values in the given entity set.
+ The entity set in which the referenced element resides.
+ The specific type of the referenced entity. This must be an entity type from the same hierarchy as the entity set's element type.
+
+ A collection of s that provide the key values. These expressions must match (in number, type, and order) the key properties of the referenced entity type.
+
+ entitySet or entityType is null, or keyValues is null or contains null.
+ entityType is not from the same type hierarchy (a subtype, supertype, or the same type) as entitySet's element type.
+ The count of keyValues does not match the count of key members declared by the entitySet’s element type, or keyValues contains an expression with a result type that is not compatible with the type of the corresponding key member.
+
+
+
+ Creates a new that encodes a reference to a specific entity of a given type based on key values.
+
+ A new DbRefExpression that references the element with the specified key values in the given entity set.
+ The entity set in which the referenced element resides.
+ The specific type of the referenced entity. This must be an entity type from the same hierarchy as the entity set's element type.
+
+ A collection of s that provide the key values. These expressions must match (in number, type, and order) the key properties of the referenced entity type.
+
+ entitySet or entityType is null, or keyValues is null or contains null.
+ entityType is not from the same type hierarchy (a subtype, supertype, or the same type) as entitySet's element type.
+ The count of keyValues does not match the count of key members declared by the entitySet’s element type, or keyValues contains an expression with a result type that is not compatible with the type of the corresponding key member.
+
+
+
+ Creates a new that encodes a reference to a specific Entity based on key values.
+
+ A new DbRefExpression that references the element with the specified key values in the given Entity set.
+ The Entity set in which the referenced element resides.
+
+ A that constructs a record with columns that match (in number, type, and order) the Key properties of the referenced Entity type.
+
+ entitySet or keyRow is null.
+ keyRow does not have a record result type that matches the key properties of the referenced entity set's entity type.
+
+
+
+ Creates a new that encodes a reference to a specific Entity based on key values.
+
+ A new DbRefExpression that references the element with the specified key values in the given Entity set.
+ The Entity set in which the referenced element resides.
+
+ A that constructs a record with columns that match (in number, type, and order) the Key properties of the referenced Entity type.
+
+ The type of the Entity that the reference should refer to.
+ entitySet, keyRow or entityType is null.
+ entityType is not in the same type hierarchy as the entity set's entity type, or keyRow does not have a record result type that matches the key properties of the referenced entity set's entity type.
+
+
+
+ Creates a new that retrieves the key values of the specifed reference in structural form.
+
+ A new DbRefKeyExpression that retrieves the key values of the specified reference.
+ The expression that provides the reference. This expression must have a reference Type with an Entity element type.
+ argument is null.
+ argument does not have a reference result type.
+
+
+
+ Creates a new representing the navigation of a composition or association relationship.
+
+ A new DbRelationshipNavigationExpression representing the navigation of the specified from and to relation ends of the specified relation type from the specified navigation source instance.
+ An expression that specifies the instance from which navigation should occur.
+ Metadata for the property that represents the end of the relationship from which navigation should occur.
+ Metadata for the property that represents the end of the relationship to which navigation should occur.
+ fromEnd, toEnd or navigateFrom is null.
+ fromEnd and toEnd are not declared by the same relationship type, or navigateFrom has a result type that is not compatible with the property type of fromEnd.
+
+
+
+ Creates a new representing the navigation of a composition or association relationship.
+
+ A new DbRelationshipNavigationExpression representing the navigation of the specified from and to relation ends of the specified relation type from the specified navigation source instance.
+ Metadata for the relation type that represents the relationship.
+ The name of the property of the relation type that represents the end of the relationship from which navigation should occur.
+ The name of the property of the relation type that represents the end of the relationship to which navigation should occur.
+ An expression the specifies the instance from which naviagtion should occur.
+ type, fromEndName, toEndName or navigateFrom is null.
+ type is not associated with this command tree's metadata workspace or navigateFrom is associated with a different command tree, or type does not declare a relation end property with name toEndName or fromEndName, or navigateFrom has a result type that is not compatible with the property type of the relation end property with name fromEndName.
+
+
+
+ Creates a new that removes duplicates from the given set argument.
+
+ A new DbDistinctExpression that represents the distinct operation applied to the specified set argument.
+ An expression that defines the set over which to perfom the distinct operation.
+ argument is null.
+ argument does not have a collection result type.
+
+
+
+ Creates a new that converts a set into a singleton.
+
+ A DbElementExpression that represents the conversion of the set argument to a singleton.
+ An expression that specifies the input set.
+ argument is null.
+ argument does not have a collection result type.
+
+
+
+ Creates a new that determines whether the specified set argument is an empty set.
+
+ A new DbIsEmptyExpression with the specified argument.
+ An expression that specifies the input set.
+ argument is null.
+ argument does not have a collection result type.
+
+
+
+ Creates a new that computes the subtraction of the right set argument from the left set argument.
+
+ A new DbExceptExpression that represents the difference of the left argument from the right argument.
+ An expression that defines the left set argument.
+ An expression that defines the right set argument.
+ left or right is null.
+ No common collection result type exists between left and right.
+
+
+
+ Creates a new that computes the intersection of the left and right set arguments.
+
+ A new DbIntersectExpression that represents the intersection of the left and right arguments.
+ An expression that defines the left set argument.
+ An expression that defines the right set argument.
+ left or right is null.
+ No common collection result type exists between left or right.
+
+
+
+ Creates a new that computes the union of the left and right set arguments and does not remove duplicates.
+
+ A new DbUnionAllExpression that union, including duplicates, of the the left and right arguments.
+ An expression that defines the left set argument.
+ An expression that defines the right set argument.
+ left or right is null.
+ No common collection result type with an equality-comparable element type exists between left and right.
+
+
+
+ Creates a new that restricts the number of elements in the Argument collection to the specified count Limit value. Tied results are not included in the output.
+
+ A new DbLimitExpression with the specified argument and count limit values that does not include tied results.
+ An expression that specifies the input collection.
+ An expression that specifies the limit value.
+ argument or count is null.
+ argument does not have a collection result type, or count does not have a result type that is equal or promotable to a 64-bit integer type.
+
+
+
+ Creates a new .
+
+ A new DbCaseExpression with the specified cases and default result.
+ A list of expressions that provide the conditional for of each case.
+ A list of expressions that provide the result of each case.
+ An expression that defines the result when no case is matched.
+ whenExpressions or thenExpressions is null or contains null, or elseExpression is null.
+ whenExpressions or thenExpressions is empty or whenExpressions contains an expression with a non-Boolean result type, or no common result type exists for all expressions in thenExpressions and elseExpression.
+
+
+
+ Creates a new representing the invocation of the specified function with the given arguments.
+
+ A new DbFunctionExpression representing the function invocation.
+ Metadata for the function to invoke.
+ A list of expressions that provide the arguments to the function.
+ function is null, or arguments is null or contains null.
+ The count of arguments does not equal the number of parameters declared by function, or arguments contains an expression that has a result type that is not equal or promotable to the corresponding function parameter type.
+
+
+
+ Creates a new representing the invocation of the specified function with the given arguments.
+
+ A new DbFunctionExpression representing the function invocation.
+ Metadata for the function to invoke.
+ Expressions that provide the arguments to the function.
+ function is null, or arguments is null or contains null.
+ The count of arguments does not equal the number of parameters declared by function, or arguments contains an expression that has a result type that is not equal or promotable to the corresponding function parameter type.
+
+
+
+ Creates a new representing the application of the specified Lambda function to the given arguments.
+
+ A new Expression representing the Lambda function application.
+
+ A instance representing the Lambda function to apply.
+
+ A list of expressions that provide the arguments.
+ lambda or arguments is null.
+ The count of arguments does not equal the number of variables declared by lambda, or arguments contains an expression that has a result type that is not equal or promotable to the corresponding variable type.
+
+
+
+ Creates a new representing the application of the specified Lambda function to the given arguments.
+
+ A new expression representing the Lambda function application.
+
+ A instance representing the Lambda function to apply.
+
+ Expressions that provide the arguments.
+ lambda or arguments is null.
+ The count of arguments does not equal the number of variables declared by lambda, or arguments contains an expression that has a result type that is not equal or promotable to the corresponding variable type.
+
+
+
+ Creates a new . If the type argument is a collection type, the arguments specify the elements of the collection. Otherwise the arguments are used as property or column values in the new instance.
+
+ A new DbNewInstanceExpression with the specified type and arguments.
+ The type of the new instance.
+ Expressions that specify values of the new instances, interpreted according to the instance's type.
+ instanceType or arguments is null, or arguments contains null.
+ arguments is empty or the result types of the contained expressions do not match the requirements of instanceType (as explained in the remarks section).
+
+
+
+ Creates a new . If the type argument is a collection type, the arguments specify the elements of the collection. Otherwise the arguments are used as property or column values in the new instance.
+
+ A new DbNewInstanceExpression with the specified type and arguments.
+ The type of the new instance.
+ Expressions that specify values of the new instances, interpreted according to the instance's type.
+ instanceType or arguments is null, or arguments contains null.
+ arguments is empty or the result types of the contained expressions do not match the requirements of instanceType (as explained in the remarks section).
+
+
+
+ Creates a new that constructs a collection containing the specified elements. The type of the collection is based on the common type of the elements. If no common element type exists an exception is thrown.
+
+ A new DbNewInstanceExpression with the specified collection type and arguments.
+ A list of expressions that provide the elements of the collection.
+ elements is null, or contains null.
+ elements is empty or contains expressions for which no common result type exists.
+
+
+
+ Creates a new that constructs a collection containing the specified elements. The type of the collection is based on the common type of the elements. If no common element type exists an exception is thrown.
+
+ A new DbNewInstanceExpression with the specified collection type and arguments.
+ A list of expressions that provide the elements of the collection.
+ elements is null, or contains null..
+ elements is empty or contains expressions for which no common result type exists.
+
+
+
+ Creates a new that constructs an empty collection of the specified collection type.
+
+ A new DbNewInstanceExpression with the specified collection type and an empty Arguments list.
+ The type metadata for the collection to create
+ collectionType is null.
+ collectionType is not a collection type.
+
+
+
+ Creates a new that produces a row with the specified named columns and the given values, specified as expressions.
+
+ A new DbNewInstanceExpression that represents the construction of the row.
+ A list of string-DbExpression key-value pairs that defines the structure and values of the row.
+ columnValues is null or contains an element with a null column name or expression.
+ columnValues is empty, or contains a duplicate or invalid column name.
+
+
+
+ Creates a new representing the retrieval of the specified property.
+
+ A new DbPropertyExpression representing the property retrieval.
+ The instance from which to retrieve the property. May be null if the property is static.
+ Metadata for the property to retrieve.
+ propertyMetadata is null or instance is null and the property is not static.
+
+
+
+ Creates a new representing the retrieval of the specified navigation property.
+
+ A new DbPropertyExpression representing the navigation property retrieval.
+ The instance from which to retrieve the navigation property.
+ Metadata for the navigation property to retrieve.
+ navigationProperty or instance is null.
+
+
+
+ Creates a new representing the retrieval of the specified relationship end member.
+
+ A new DbPropertyExpression representing the relationship end member retrieval.
+ The instance from which to retrieve the relationship end member.
+ Metadata for the relationship end member to retrieve.
+ relationshipEnd is null or instance is null and the property is not static.
+
+
+
+ Creates a new representing the retrieval of the instance property with the specified name from the given instance.
+
+ A new DbPropertyExpression that represents the property retrieval.
+ The instance from which to retrieve the property.
+ The name of the property to retrieve.
+ propertyName is null or instance is null and the property is not static.
+ No property with the specified name is declared by the type of instance.
+
+
+
+ Creates a new representing setting a property to a value.
+
+ The property to be set.
+ The value to set the property to.
+ The newly created set clause.
+
+
+
+ Creates a new that determines whether the given predicate holds for all elements of the input set.
+
+ A new DbQuantifierExpression that represents the All operation.
+ An expression that specifies the input set.
+ A method representing a predicate to evaluate for each member of the input set. This method must produce an expression with a Boolean result type that provides the predicate logic.
+ source or predicate is null.
+ The expression produced by predicate is null.
+ source does not have a collection result type.
+ The expression produced by Predicate does not have a Boolean result type.
+
+
+
+ Creates a new that determines whether the specified set argument is non-empty.
+
+
+ A new applied to a new
+
+ with the specified argument.
+
+ An expression that specifies the input set.
+ source is null.
+ source does not have a collection result type.
+
+
+
+ Creates a new that determines whether the specified set argument is non-empty.
+
+
+ A new applied to a new
+
+ with the specified argument.
+
+ An expression that specifies the input set.
+ argument is null.
+ argument does not have a collection result type.
+
+
+
+ Creates a new that determines whether the given predicate holds for any element of the input set.
+
+ A new DbQuantifierExpression that represents the Any operation.
+ An expression that specifies the input set.
+ A method representing the predicate to evaluate for each member of the input set. This method must produce an expression with a Boolean result type that provides the predicate logic.
+ source or predicate is null.
+ The expression produced by predicate is null.
+ source does not have a collection result type.
+ The expression produced by predicate does not have a Boolean result type.
+
+
+
+ Creates a new that evaluates the given apply expression once for each element of a given input set, producing a collection of rows with corresponding input and apply columns. Rows for which apply evaluates to an empty set are not included.
+
+
+ An new DbApplyExpression with the specified input and apply bindings and an
+
+ of CrossApply.
+
+
+ A that specifies the input set.
+
+ A method that specifies the logic to evaluate once for each member of the input set.
+ source or apply is null.
+ source does not have a collection result type.
+ The result of apply contains a name or expression that is null.
+ The result of apply contains a name or expression that is not valid in an expression binding.
+
+
+
+ Creates a new that evaluates the given apply expression once for each element of a given input set, producing a collection of rows with corresponding input and apply columns. Rows for which apply evaluates to an empty set have an apply column value of null.
+
+
+ An new DbApplyExpression with the specified input and apply bindings and an
+
+ of OuterApply.
+
+
+ A that specifies the input set.
+
+ A method that specifies the logic to evaluate once for each member of the input set.
+ source or apply is null.
+ Source does not have a collection result type.
+ The result of apply contains a name or expression that is null.
+ The result of apply contains a name or expression that is not valid in an expression binding.
+
+
+
+ Creates a new that joins the sets specified by the left and right expressions, on the specified join condition, using FullOuterJoin as the
+
+ .
+
+
+ A new DbJoinExpression, with an of FullOuterJoin, that represents the full outer join operation applied to the left and right input sets under the given join condition.
+
+
+ A that specifies the left set argument.
+
+
+ A that specifies the right set argument.
+
+ A method representing the condition on which to join. This method must produce an expression with a Boolean result type that provides the logic of the join condition.
+ left, right or joinCondition is null.
+ left or right does not have a collection result type.
+ The expression produced by joinCondition is null.
+ The expression produced by joinCondition does not have a Boolean result type.
+
+
+
+ Creates a new that joins the sets specified by the left and right expressions, on the specified join condition, using InnerJoin as the
+
+ .
+
+
+ A new DbJoinExpression, with an of InnerJoin, that represents the inner join operation applied to the left and right input sets under the given join condition.
+
+
+ A that specifies the left set argument.
+
+
+ A that specifies the right set argument.
+
+ A method representing the condition on which to join. This method must produce an expression with a Boolean result type that provides the logic of the join condition.
+ left, right or joinCondition is null.
+ left or right does not have a collection result type.
+ The expression produced by joinCondition is null.
+ The expression produced by joinCondition does not have a Boolean result type.
+
+
+
+ Creates a new that joins the sets specified by the left and right expressions, on the specified join condition, using LeftOuterJoin as the
+
+ .
+
+
+ A new DbJoinExpression, with an of LeftOuterJoin, that represents the left outer join operation applied to the left and right input sets under the given join condition.
+
+
+ A that specifies the left set argument.
+
+
+ A that specifies the right set argument.
+
+ A method representing the condition on which to join. This method must produce an expression with a Boolean result type that provides the logic of the join condition.
+ left, right or joinCondition is null.
+ left or right does not have a collection result type.
+ The expression produced by joinCondition is null.
+ The expression produced by joinCondition does not have a Boolean result type.
+
+
+
+ Creates a new that joins the sets specified by the outer and inner expressions, on an equality condition between the specified outer and inner keys, using InnerJoin as the
+
+ .
+
+
+ A new DbJoinExpression, with an of InnerJoin, that represents the inner join operation applied to the left and right input sets under a join condition that compares the outer and inner key values for equality.
+
+
+ A that specifies the outer set argument.
+
+
+ A that specifies the inner set argument.
+
+ A method that specifies how the outer key value should be derived from an element of the outer set.
+ A method that specifies how the inner key value should be derived from an element of the inner set.
+ outer, inner, outerKey or innerKey is null.
+ outer or inner does not have a collection result type.
+ The expression produced by outerKey or innerKey is null.
+ The expressions produced by outerKey and innerKey are not comparable for equality.
+
+
+
+ Creates a new that projects the specified selector over the sets specified by the outer and inner expressions, joined on an equality condition between the specified outer and inner keys, using InnerJoin as the
+
+ .
+
+
+ A new DbProjectExpression with the specified selector as its projection, and a new DbJoinExpression as its input. The input DbJoinExpression is created with an
+
+ of InnerJoin, that represents the inner join operation applied to the left and right input sets under a join condition that compares the outer and inner key values for equality.
+
+
+ A that specifies the outer set argument.
+
+
+ A that specifies the inner set argument.
+
+ A method that specifies how the outer key value should be derived from an element of the outer set.
+ A method that specifies how the inner key value should be derived from an element of the inner set.
+
+ A method that specifies how an element of the result set should be derived from elements of the inner and outer sets. This method must produce an instance of a type that is compatible with Join and can be resolved into a
+
+ . Compatibility requirements for TSelector are described in remarks.
+
+ The type of the selector .
+ outer, inner, outerKey, innerKey or selector is null.
+ outer or inner does not have a collection result type.
+ The expression produced by outerKey or innerKey is null.
+ The result of selector is null after conversion to DbExpression.
+ The expressions produced by outerKey and innerKey is not comparable for equality.
+ The result of Selector is not compatible with SelectMany.
+
+
+
+ Creates a new that sorts the given input set by the specified sort key, with ascending sort order and default collation.
+
+ A new DbSortExpression that represents the order-by operation.
+ An expression that specifies the input set.
+ A method that specifies how to derive the sort key expression given a member of the input set. This method must produce an expression with an order-comparable result type that provides the sort key definition.
+ source or sortKey is null.
+ The expression produced by sortKey is null.
+ source does not have a collection result type.
+ The expression produced by sortKey does not have an order-comparable result type.
+
+
+
+ Creates a new that sorts the given input set by the specified sort key, with ascending sort order and the specified collation.
+
+ A new DbSortExpression that represents the order-by operation.
+ An expression that specifies the input set.
+ A method that specifies how to derive the sort key expression given a member of the input set. This method must produce an expression with an order-comparable result type that provides the sort key definition.
+ The collation to sort under.
+ source, sortKey or collation is null.
+ The expression produced by sortKey is null.
+ source does not have a collection result type.
+ The expression produced by sortKey does not have an order-comparable string result type.
+ collation is empty or contains only space characters.
+
+
+
+ Creates a new that sorts the given input set by the specified sort key, with descending sort order and default collation.
+
+ A new DbSortExpression that represents the order-by operation.
+ An expression that specifies the input set.
+ A method that specifies how to derive the sort key expression given a member of the input set. This method must produce an expression with an order-comparable result type that provides the sort key definition.
+ source or sortKey is null.
+ The expression produced by sortKey is null.
+ source does not have a collection result type.
+ The expression produced by sortKey does not have an order-comparable result type.
+
+
+
+ Creates a new that sorts the given input set by the specified sort key, with descending sort order and the specified collation.
+
+ A new DbSortExpression that represents the order-by operation.
+ An expression that specifies the input set.
+ A method that specifies how to derive the sort key expression given a member of the input set. This method must produce an expression with an order-comparable result type that provides the sort key definition.
+ The collation to sort under.
+ source, sortKey or collation is null.
+ The expression produced by sortKey is null.
+ source does not have a collection result type.
+ The expression produced by sortKey does not have an order-comparable string result type.
+ collation is empty or contains only space characters.
+
+
+
+ Creates a new that selects the specified expression over the given input set.
+
+ A new DbProjectExpression that represents the select operation.
+ An expression that specifies the input set.
+
+ A method that specifies how to derive the projected expression given a member of the input set. This method must produce an instance of a type that is compatible with Select and can be resolved into a
+
+ . Compatibility requirements for TProjection are described in remarks.
+
+ The method result type of projection.
+ source or projection is null.
+ The result of projection is null.
+
+
+
+ Creates a new that evaluates the given apply expression once for each element of a given input set, producing a collection of rows with corresponding input and apply columns. Rows for which apply evaluates to an empty set are not included. A
+
+ is then created that selects the apply column from each row, producing the overall collection of apply results.
+
+
+ An new DbProjectExpression that selects the apply column from a new DbApplyExpression with the specified input and apply bindings and an
+
+ of CrossApply.
+
+
+ A that specifies the input set.
+
+ A method that represents the logic to evaluate once for each member of the input set.
+ source or apply is null.
+ The expression produced by apply is null.
+ source does not have a collection result type.
+ The expression produced by apply does not have a collection type.
+
+
+
+ Creates a new that evaluates the given apply expression once for each element of a given input set, producing a collection of rows with corresponding input and apply columns. Rows for which apply evaluates to an empty set are not included. A
+
+ is then created that selects the specified selector over each row, producing the overall collection of results.
+
+
+ An new DbProjectExpression that selects the result of the given selector from a new DbApplyExpression with the specified input and apply bindings and an
+
+ of CrossApply.
+
+
+ A that specifies the input set.
+
+ A method that represents the logic to evaluate once for each member of the input set.
+
+ A method that specifies how an element of the result set should be derived given an element of the input and apply sets. This method must produce an instance of a type that is compatible with SelectMany and can be resolved into a
+
+ . Compatibility requirements for TSelector are described in remarks.
+
+ The method result type of selector.
+ source, apply or selector is null.
+ The expression produced by apply is null.
+ The result of selector is null on conversion to DbExpression.
+ source does not have a collection result type.
+ The expression produced by apply does not have a collection type. does not have a collection type.
+
+
+
+ Creates a new that skips the specified number of elements from the given sorted input set.
+
+ A new DbSkipExpression that represents the skip operation.
+
+ A that specifies the sorted input set.
+
+ An expression the specifies how many elements of the ordered set to skip.
+ argument or count is null.
+
+ count is not or
+
+ or has a result type that is not equal or promotable to a 64-bit integer type.
+
+
+
+
+ Creates a new that restricts the number of elements in the Argument collection to the specified count Limit value. Tied results are not included in the output.
+
+ A new DbLimitExpression with the specified argument and count limit values that does not include tied results.
+ An expression that specifies the input collection.
+ An expression that specifies the limit value.
+ argument or count is null.
+ argument does not have a collection result type, count does not have a result type that is equal or promotable to a 64-bit integer type.
+
+
+
+ Creates a new that with a sort order that includes the sort order of the given order input set together with the specified sort key in ascending sort order and with default collation.
+
+ A new DbSortExpression that represents the new overall order-by operation.
+ A DbSortExpression that specifies the ordered input set.
+ A method that specifies how to derive the additional sort key expression given a member of the input set. This method must produce an expression with an order-comparable result type that provides the sort key definition.
+ source or sortKey is null.
+ The expression produced by sortKey is null.
+ source does not have a collection result type.
+ sortKey does not have an order-comparable result type.
+
+
+
+ Creates a new that with a sort order that includes the sort order of the given order input set together with the specified sort key in ascending sort order and with the specified collation.
+
+ A new DbSortExpression that represents the new overall order-by operation.
+ A DbSortExpression that specifies the ordered input set.
+ A method that specifies how to derive the additional sort key expression given a member of the input set. This method must produce an expression with an order-comparable result type that provides the sort key definition.
+ The collation to sort under.
+ source, sortKey or collation is null.
+ The expression produced by sortKey is null.
+ source does not have a collection result type.
+ The expression produced by sortKey does not have an order-comparable string result type.
+ collation is empty or contains only space characters.
+
+
+
+ Creates a new that with a sort order that includes the sort order of the given order input set together with the specified sort key in descending sort order and with default collation.
+
+ A new DbSortExpression that represents the new overall order-by operation.
+ A DbSortExpression that specifies the ordered input set.
+ A method that specifies how to derive the additional sort key expression given a member of the input set. This method must produce an expression with an order-comparable result type that provides the sort key definition.
+ source or sortKey is null.
+ The expression produced by sortKey is null.
+ source does not have a collection result type.
+ The expression produced by sortKey does not have an order-comparable result type.
+
+
+
+ Creates a new that with a sort order that includes the sort order of the given order input set together with the specified sort key in descending sort order and with the specified collation.
+
+ A new DbSortExpression that represents the new overall order-by operation.
+ A DbSortExpression that specifies the ordered input set.
+ A method that specifies how to derive the additional sort key expression given a member of the input set. This method must produce an expression with an order-comparable result type that provides the sort key definition.
+ The collation to sort under.
+ source, sortKey or collation is null.
+ The expression produced by sortKey is null.
+ source does not have a collection result type.
+ The expression produced by sortKey does not have an order-comparable string result type.
+ collation is empty or contains only space characters.
+
+
+
+ Creates a new that filters the elements in the given input set using the specified predicate.
+
+ A new DbQuantifierExpression that represents the Any operation.
+ An expression that specifies the input set.
+ A method representing the predicate to evaluate for each member of the input set. This method must produce an expression with a Boolean result type that provides the predicate logic.
+ source or predicate is null.
+ The expression produced by predicate is null.
+ The expression produced by predicate does not have a Boolean result type.
+
+
+
+ Creates a new that computes the union of the left and right set arguments with duplicates removed.
+
+ A new DbExpression that computes the union, without duplicates, of the the left and right arguments.
+ An expression that defines the left set argument.
+ An expression that defines the right set argument.
+ left or right is null.
+ No common collection result type with an equality-comparable element type exists between left and right.
+
+
+
+ Gets a with the Boolean value true.
+
+
+ A with the Boolean value true.
+
+
+
+
+ Gets a with the Boolean value false.
+
+
+ A with the Boolean value false.
+
+
+
+
+ Provides an API to construct s that invoke canonical EDM functions, and allows that API to be accessed as extension methods on the expression type itself.
+
+
+
+
+ Creates a that invokes the canonical 'Avg' function over the specified collection. The result type of the expression is the same as the element type of the collection.
+
+ A new DbFunctionExpression that produces the average value.
+ An expression that specifies the collection from which the average value should be computed.
+
+
+
+ Creates a that invokes the canonical 'Count' function over the specified collection. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that produces the count value.
+ An expression that specifies the collection over which the count value should be computed.
+
+
+
+ Creates a that invokes the canonical 'BigCount' function over the specified collection. The result type of the expression is Edm.Int64.
+
+ A new DbFunctionExpression that produces the count value.
+ An expression that specifies the collection over which the count value should be computed.
+
+
+
+ Creates a that invokes the canonical 'Max' function over the specified collection. The result type of the expression is the same as the element type of the collection.
+
+ A new DbFunctionExpression that produces the maximum value.
+ An expression that specifies the collection from which the maximum value should be retrieved
+
+
+
+ Creates a that invokes the canonical 'Min' function over the specified collection. The result type of the expression is the same as the element type of the collection.
+
+ A new DbFunctionExpression that produces the minimum value.
+ An expression that specifies the collection from which the minimum value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Sum' function over the specified collection. The result type of the expression is the same as the element type of the collection.
+
+ A new DbFunctionExpression that produces the sum.
+ An expression that specifies the collection from which the sum should be computed.
+
+
+
+ Creates a that invokes the canonical 'StDev' function over the non-null members of the specified collection. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that produces the standard deviation value over non-null members of the collection.
+ An expression that specifies the collection for which the standard deviation should be computed.
+
+
+
+ Creates a that invokes the canonical 'StDevP' function over the population of the specified collection. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that produces the standard deviation value.
+ An expression that specifies the collection for which the standard deviation should be computed.
+
+
+
+ Creates a that invokes the canonical 'Var' function over the non-null members of the specified collection. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that produces the statistical variance value for the non-null members of the collection.
+ An expression that specifies the collection for which the statistical variance should be computed.
+
+
+
+ Creates a that invokes the canonical 'VarP' function over the population of the specified collection. The result type of the expression Edm.Double.
+
+ A new DbFunctionExpression that produces the statistical variance value.
+ An expression that specifies the collection for which the statistical variance should be computed.
+
+
+
+ Creates a that invokes the canonical 'Concat' function with the specified arguments, which must each have a string result type. The result type of the expression is string.
+
+ A new DbFunctionExpression that produces the concatenated string.
+ An expression that specifies the string that should appear first in the concatenated result string.
+ An expression that specifies the string that should appear second in the concatenated result string.
+
+
+
+ Creates a that invokes the canonical 'Contains' function with the specified arguments, which must each have a string result type. The result type of the expression is Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether or not searchedForString occurs within searchedString.
+ An expression that specifies the string to search for any occurence of searchedForString.
+ An expression that specifies the string to search for in searchedString.
+
+
+
+ Creates a that invokes the canonical 'EndsWith' function with the specified arguments, which must each have a string result type. The result type of the expression is Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether or not stringArgument ends with suffix.
+ An expression that specifies the string that is searched at the end for string suffix.
+ An expression that specifies the target string that is searched for at the end of stringArgument.
+
+
+
+ Creates a that invokes the canonical 'IndexOf' function with the specified arguments, which must each have a string result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the first index of stringToFind in searchString.
+ An expression that specifies the string to search for stringToFind.
+ An expression that specifies the string to locate within searchString should be checked.
+
+
+
+ Creates a that invokes the canonical 'Left' function with the specified arguments, which must have a string and integer numeric result type. The result type of the expression is string.
+
+ A new DbFunctionExpression that returns the the leftmost substring of length length from stringArgument.
+ An expression that specifies the string from which to extract the leftmost substring.
+ An expression that specifies the length of the leftmost substring to extract from stringArgument.
+
+
+
+ Creates a that invokes the canonical 'Length' function with the specified argument, which must have a string result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the length of stringArgument.
+ An expression that specifies the string for which the length should be computed.
+
+
+
+ Creates a that invokes the canonical 'Replace' function with the specified arguments, which must each have a string result type. The result type of the expression is also string.
+
+ A new DbFunctionExpression than returns a new string based on stringArgument where every occurence of toReplace is replaced by replacement.
+ An expression that specifies the string in which to perform the replacement operation.
+ An expression that specifies the string that is replaced.
+ An expression that specifies the replacement string.
+
+
+
+ Creates a that invokes the canonical 'Reverse' function with the specified argument, which must have a string result type. The result type of the expression is also string.
+
+ A new DbFunctionExpression that produces the reversed value of stringArgument.
+ An expression that specifies the string to reverse.
+
+
+
+ Creates a that invokes the canonical 'Right' function with the specified arguments, which must have a string and integer numeric result type. The result type of the expression is string.
+
+ A new DbFunctionExpression that returns the the rightmost substring of length length from stringArgument.
+ An expression that specifies the string from which to extract the rightmost substring.
+ An expression that specifies the length of the rightmost substring to extract from stringArgument.
+
+
+
+ Creates a that invokes the canonical 'StartsWith' function with the specified arguments, which must each have a string result type. The result type of the expression is Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether or not stringArgument starts with prefix.
+ An expression that specifies the string that is searched at the start for string prefix.
+ An expression that specifies the target string that is searched for at the start of stringArgument.
+
+
+
+ Creates a that invokes the canonical 'Substring' function with the specified arguments, which must have a string and integer numeric result types. The result type of the expression is string.
+
+ A new DbFunctionExpression that returns the substring of length length from stringArgument starting at start.
+ An expression that specifies the string from which to extract the substring.
+ An expression that specifies the starting index from which the substring should be taken.
+ An expression that specifies the length of the substring.
+
+
+
+ Creates a that invokes the canonical 'ToLower' function with the specified argument, which must have a string result type. The result type of the expression is also string.
+
+ A new DbFunctionExpression that returns value of stringArgument converted to lower case.
+ An expression that specifies the string that should be converted to lower case.
+
+
+
+ Creates a that invokes the canonical 'ToUpper' function with the specified argument, which must have a string result type. The result type of the expression is also string.
+
+ A new DbFunctionExpression that returns value of stringArgument converted to upper case.
+ An expression that specifies the string that should be converted to upper case.
+
+
+
+ Creates a that invokes the canonical 'Trim' function with the specified argument, which must have a string result type. The result type of the expression is also string.
+
+ A new DbFunctionExpression that returns value of stringArgument with leading and trailing space removed.
+ An expression that specifies the string from which leading and trailing space should be removed.
+
+
+
+ Creates a that invokes the canonical 'RTrim' function with the specified argument, which must have a string result type. The result type of the expression is also string.
+
+ A new DbFunctionExpression that returns value of stringArgument with trailing space removed.
+ An expression that specifies the string from which trailing space should be removed.
+
+
+
+ Creates a that invokes the canonical 'LTrim' function with the specified argument, which must have a string result type. The result type of the expression is also string.
+
+ A new DbFunctionExpression that returns value of stringArgument with leading space removed.
+ An expression that specifies the string from which leading space should be removed.
+
+
+
+ Creates a that invokes the canonical 'Year' function with the specified argument, which must have a DateTime or DateTimeOffset result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer year value from dateValue.
+ An expression that specifies the value from which the year should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Month' function with the specified argument, which must have a DateTime or DateTimeOffset result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer month value from dateValue.
+ An expression that specifies the value from which the month should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Day' function with the specified argument, which must have a DateTime or DateTimeOffset result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer day value from dateValue.
+ An expression that specifies the value from which the day should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'DayOfYear' function with the specified argument, which must have a DateTime or DateTimeOffset result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer day of year value from dateValue.
+ An expression that specifies the value from which the day within the year should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Hour' function with the specified argument, which must have a DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer hour value from timeValue.
+ An expression that specifies the value from which the hour should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Minute' function with the specified argument, which must have a DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer minute value from timeValue.
+ An expression that specifies the value from which the minute should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Second' function with the specified argument, which must have a DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer second value from timeValue.
+ An expression that specifies the value from which the second should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Millisecond' function with the specified argument, which must have a DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer millisecond value from timeValue.
+ An expression that specifies the value from which the millisecond should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'GetTotalOffsetMinutes' function with the specified argument, which must have a DateTimeOffset result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of minutes dateTimeOffsetArgument is offset from GMT.
+ An expression that specifies the DateTimeOffset value from which the minute offset from GMT should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'CurrentDateTime' function.
+
+ A new DbFunctionExpression that returns the current date and time as an Edm.DateTime instance.
+
+
+
+ Creates a that invokes the canonical 'CurrentDateTimeOffset' function.
+
+ A new DbFunctionExpression that returns the current date and time as an Edm.DateTimeOffset instance.
+
+
+
+ Creates a that invokes the canonical 'CurrentUtcDateTime' function.
+
+ A new DbFunctionExpression that returns the current UTC date and time as an Edm.DateTime instance.
+
+
+
+ Creates a that invokes the canonical 'TruncateTime' function with the specified argument, which must have a DateTime or DateTimeOffset result type. The result type of the expression is the same as the result type of dateValue.
+
+ A new DbFunctionExpression that returns the value of dateValue with time set to zero.
+ An expression that specifies the value for which the time portion should be truncated.
+
+
+
+ Creates a that invokes the canonical 'CreateDateTime' function with the specified arguments. second must have a result type of Edm.Double, while all other arguments must have a result type of Edm.Int32. The result type of the expression is Edm.DateTime.
+
+ A new DbFunctionExpression that returns a new DateTime based on the specified values.
+ An expression that provides the year value for the new DateTime instance.
+ An expression that provides the month value for the new DateTime instance.
+ An expression that provides the day value for the new DateTime instance.
+ An expression that provides the hour value for the new DateTime instance.
+ An expression that provides the minute value for the new DateTime instance.
+ An expression that provides the second value for the new DateTime instance.
+
+
+
+ Creates a that invokes the canonical 'CreateDateTimeOffset' function with the specified arguments. second must have a result type of Edm.Double, while all other arguments must have a result type of Edm.Int32. The result type of the expression is Edm.DateTimeOffset.
+
+ A new DbFunctionExpression that returns a new DateTimeOffset based on the specified values.
+ An expression that provides the year value for the new DateTimeOffset instance.
+ An expression that provides the month value for the new DateTimeOffset instance.
+ An expression that provides the day value for the new DateTimeOffset instance.
+ An expression that provides the hour value for the new DateTimeOffset instance.
+ An expression that provides the minute value for the new DateTimeOffset instance.
+ An expression that provides the second value for the new DateTimeOffset instance.
+ An expression that provides the number of minutes in the time zone offset value for the new DateTimeOffset instance.
+
+
+
+ Creates a that invokes the canonical 'CreateTime' function with the specified arguments. second must have a result type of Edm.Double, while all other arguments must have a result type of Edm.Int32. The result type of the expression is Edm.Time.
+
+ A new DbFunctionExpression that returns a new Time based on the specified values.
+ An expression that provides the hour value for the new DateTime instance.
+ An expression that provides the minute value for the new DateTime instance.
+ An expression that provides the second value for the new DateTime instance.
+
+
+
+ Creates a that invokes the canonical 'AddYears' function with the specified arguments, which must have DateTime or DateTimeOffset and integer result types. The result type of the expression is the same as the result type of dateValue.
+
+ A new DbFunctionExpression that adds the number of years specified by addValue to the value specified by dateValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of years to add to dateValue.
+
+
+
+ Creates a that invokes the canonical 'AddMonths' function with the specified arguments, which must have DateTime or DateTimeOffset and integer result types. The result type of the expression is the same as the result type of dateValue.
+
+ A new DbFunctionExpression that adds the number of months specified by addValue to the value specified by dateValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of months to add to dateValue.
+
+
+
+ Creates a that invokes the canonical 'AddDays' function with the specified arguments, which must have DateTime or DateTimeOffset and integer result types. The result type of the expression is the same as the result type of dateValue.
+
+ A new DbFunctionExpression that adds the number of days specified by addValue to the value specified by dateValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of days to add to dateValue.
+
+
+
+ Creates a that invokes the canonical 'AddHours' function with the specified arguments, which must have DateTime, DateTimeOffset or Time, and integer result types. The result type of the expression is the same as the result type of timeValue.
+
+ A new DbFunctionExpression that adds the number of hours specified by addValue to the value specified by timeValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of hours to add to timeValue.
+
+
+
+ Creates a that invokes the canonical 'AddMinutes' function with the specified arguments, which must have DateTime, DateTimeOffset or Time, and integer result types. The result type of the expression is the same as the result type of timeValue.
+
+ A new DbFunctionExpression that adds the number of minutes specified by addValue to the value specified by timeValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of minutes to add to timeValue.
+
+
+
+ Creates a that invokes the canonical 'AddSeconds' function with the specified arguments, which must have DateTime, DateTimeOffset or Time, and integer result types. The result type of the expression is the same as the result type of timeValue.
+
+ A new DbFunctionExpression that adds the number of seconds specified by addValue to the value specified by timeValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of seconds to add to timeValue.
+
+
+
+ Creates a that invokes the canonical 'AddMilliseconds' function with the specified arguments, which must have DateTime, DateTimeOffset or Time, and integer result types. The result type of the expression is the same as the result type of timeValue.
+
+ A new DbFunctionExpression that adds the number of milliseconds specified by addValue to the value specified by timeValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of milliseconds to add to timeValue.
+
+
+
+ Creates a that invokes the canonical 'AddMicroseconds' function with the specified arguments, which must have DateTime, DateTimeOffset or Time, and integer result types. The result type of the expression is the same as the result type of timeValue.
+
+ A new DbFunctionExpression that adds the number of microseconds specified by addValue to the value specified by timeValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of microseconds to add to timeValue.
+
+
+
+ Creates a that invokes the canonical 'AddNanoseconds' function with the specified arguments, which must have DateTime, DateTimeOffset or Time, and integer result types. The result type of the expression is the same as the result type of timeValue.
+
+ A new DbFunctionExpression that adds the number of nanoseconds specified by addValue to the value specified by timeValue.
+ An expression that specifies the value to which addValueshould be added.
+ An expression that specifies the number of nanoseconds to add to timeValue.
+
+
+
+ Creates a that invokes the canonical 'DiffYears' function with the specified arguments, which must each have DateTime or DateTimeOffset result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of years that is the difference between dateValue1 and dateValue2.
+ An expression that specifies the first date value argument.
+ An expression that specifies the second date value argument.
+
+
+
+ Creates a that invokes the canonical 'DiffMonths' function with the specified arguments, which must each have DateTime or DateTimeOffset result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of months that is the difference between dateValue1 and dateValue2.
+ An expression that specifies the first date value argument.
+ An expression that specifies the second date value argument.
+
+
+
+ Creates a that invokes the canonical 'DiffDays' function with the specified arguments, which must each have DateTime or DateTimeOffset result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of days that is the difference between dateValue1 and dateValue2.
+ An expression that specifies the first date value argument.
+ An expression that specifies the second date value argument.
+
+
+
+ Creates a that invokes the canonical 'DiffHours' function with the specified arguments, which must each have DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of hours that is the difference between timeValue1 and timeValue2.
+ An expression that specifies the first time value argument.
+ An expression that specifies the second time value argument.
+
+
+
+ Creates a that invokes the canonical 'DiffMinutes' function with the specified arguments, which must each have DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of minutes that is the difference between timeValue1 and timeValue2.
+ An expression that specifies the first time value argument.
+ An expression that specifies the second time value argument.
+
+
+
+ Creates a that invokes the canonical 'DiffSeconds' function with the specified arguments, which must each have DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of seconds that is the difference between timeValue1 and timeValue2.
+ An expression that specifies the first time value argument.
+ An expression that specifies the second time value argument.
+
+
+
+ Creates a that invokes the canonical 'DiffMilliseconds' function with the specified arguments, which must each have DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of milliseconds that is the difference between timeValue1 and timeValue2.
+ An expression that specifies the first time value argument.
+ An expression that specifies the second time value argument.
+
+
+
+ Creates a that invokes the canonical 'DiffMicroseconds' function with the specified arguments, which must each have DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of microseconds that is the difference between timeValue1 and timeValue2.
+ An expression that specifies the first time value argument.
+ An expression that specifies the second time value argument.
+
+
+
+ Creates a that invokes the canonical 'DiffNanoseconds' function with the specified arguments, which must each have DateTime, DateTimeOffset or Time result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the number of nanoseconds that is the difference between timeValue1 and timeValue2.
+ An expression that specifies the first time value argument.
+ An expression that specifies the second time value argument.
+
+
+
+ Creates a that invokes the canonical 'Round' function with the specified argument, which must each have a single, double or decimal result type. The result type of the expression is the same as the result type of value.
+
+ A new DbFunctionExpression that rounds the specified argument to the nearest integer value.
+ An expression that specifies the numeric value to round.
+
+
+
+ Creates a that invokes the canonical 'Round' function with the specified arguments, which must have a single, double or decimal, and integer result types. The result type of the expression is the same as the result type of value.
+
+ A new DbFunctionExpression that rounds the specified argument to the nearest integer value, with precision as specified by digits.
+ An expression that specifies the numeric value to round.
+ An expression that specifies the number of digits of precision to use when rounding.
+
+
+
+ Creates a that invokes the canonical 'Floor' function with the specified argument, which must each have a single, double or decimal result type. The result type of the expression is the same as the result type of value.
+
+ A new DbFunctionExpression that returns the largest integer value not greater than value.
+ An expression that specifies the numeric value.
+
+
+
+ Creates a that invokes the canonical 'Ceiling' function with the specified argument, which must each have a single, double or decimal result type. The result type of the expression is the same as the result type of value.
+
+ A new DbFunctionExpression that returns the smallest integer value not less than than value.
+ An expression that specifies the numeric value.
+
+
+
+ Creates a that invokes the canonical 'Abs' function with the specified argument, which must each have a numeric result type. The result type of the expression is the same as the result type of value.
+
+ A new DbFunctionExpression that returns the absolute value of value.
+ An expression that specifies the numeric value.
+
+
+
+ Creates a that invokes the canonical 'Truncate' function with the specified arguments, which must have a single, double or decimal, and integer result types. The result type of the expression is the same as the result type of value.
+
+ A new DbFunctionExpression that truncates the specified argument to the nearest integer value, with precision as specified by digits.
+ An expression that specifies the numeric value to truncate.
+ An expression that specifies the number of digits of precision to use when truncating.
+
+
+
+ Creates a that invokes the canonical 'Power' function with the specified arguments, which must have numeric result types. The result type of the expression is the same as the result type of baseArgument.
+
+ A new DbFunctionExpression that returns the value of baseArgument raised to the power specified by exponent.
+ An expression that specifies the numeric value to raise to the given power.
+ An expression that specifies the power to which baseArgument should be raised.
+
+
+
+ Creates a that invokes the canonical 'BitwiseAnd' function with the specified arguments, which must have the same integer numeric result type. The result type of the expression is the same as the type of the arguments.
+
+ A new DbFunctionExpression that returns the value produced by performing the bitwise AND of value1 and value2.
+ An expression that specifies the first operand.
+ An expression that specifies the second operand.
+
+
+
+ Creates a that invokes the canonical 'BitwiseOr' function with the specified arguments, which must have the same integer numeric result type. The result type of the expression is the same as the type of the arguments.
+
+ A new DbFunctionExpression that returns the value produced by performing the bitwise OR of value1 and value2.
+ An expression that specifies the first operand.
+ An expression that specifies the second operand.
+
+
+
+ Creates a that invokes the canonical 'BitwiseNot' function with the specified argument, which must have an integer numeric result type. The result type of the expression is the same as the type of the arguments.
+
+ A new DbFunctionExpression that returns the value produced by performing the bitwise NOT of value.
+ An expression that specifies the first operand.
+
+
+
+ Creates a that invokes the canonical 'BitwiseXor' function with the specified arguments, which must have the same integer numeric result type. The result type of the expression is the same as the type of the arguments.
+
+ A new DbFunctionExpression that returns the value produced by performing the bitwise XOR (exclusive OR) of value1 and value2.
+ An expression that specifies the first operand.
+ An expression that specifies the second operand.
+
+
+
+ Creates a that invokes the canonical 'NewGuid' function.
+
+ A new DbFunctionExpression that returns a new GUID value.
+
+
+
+ Provides a constructor-like means of calling
+
+ .
+
+
+
+
+ Initializes a new instance of the class with the specified first column value and optional successive column values.
+
+ A key-value pair that provides the first column in the new row instance. (required)
+ A key-value pairs that provide any subsequent columns in the new row instance. (optional)
+
+
+
+ Creates a new that constructs a new row based on the columns contained in this Row instance.
+
+ A new DbNewInstanceExpression that constructs a row with the same column names and DbExpression values as this Row instance.
+
+
+
+ Converts the given Row instance into an instance of
+
+ The Row instance.
+ A DbExpression based on the Row instance
+
+
+ is null.
+
+
+
+
+
+ Provides an API to construct s that invoke spatial realted canonical EDM functions, and, where appropriate, allows that API to be accessed as extension methods on the expression type itself.
+
+
+
+
+ Creates a that invokes the canonical 'GeometryFromText' function with the specified argument, which must have a string result type. The result type of the expression is Edm.Geometry. Its value has the default coordinate system id (SRID) of the underlying provider.
+
+ A new DbFunctionExpression that returns a new geometry value based on the specified value.
+ An expression that provides the well known text representation of the geometry value.
+
+
+
+ Creates a that invokes the canonical 'GeometryFromText' function with the specified arguments. wellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry value based on the specified values.
+ An expression that provides the well known text representation of the geometry value.
+ An expression that provides the coordinate system id (SRID) of the geometry value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryPointFromText' function with the specified arguments. pointWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry point value based on the specified values.
+ An expression that provides the well known text representation of the geometry point value.
+ An expression that provides the coordinate system id (SRID) of the geometry point value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryLineFromText' function with the specified arguments. lineWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry line value based on the specified values.
+ An expression that provides the well known text representation of the geometry line value.
+ An expression that provides the coordinate system id (SRID) of the geometry line value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryPolygonFromText' function with the specified arguments. polygonWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry polygon value based on the specified values.
+ An expression that provides the well known text representation of the geometry polygon value.
+ An expression that provides the coordinate system id (SRID) of the geometry polygon value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryMultiPointFromText' function with the specified arguments. multiPointWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry multi-point value based on the specified values.
+ An expression that provides the well known text representation of the geometry multi-point value.
+ An expression that provides the coordinate system id (SRID) of the geometry multi-point value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryMultiLineFromText' function with the specified arguments. multiLineWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry multi-line value based on the specified values.
+ An expression that provides the well known text representation of the geometry multi-line value.
+ An expression that provides the coordinate system id (SRID) of the geometry multi-line value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryMultiPolygonFromText' function with the specified arguments. multiPolygonWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry multi-polygon value based on the specified values.
+ An expression that provides the well known text representation of the geometry multi-polygon value.
+ An expression that provides the coordinate system id (SRID) of the geometry multi-polygon value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryCollectionFromText' function with the specified arguments. geometryCollectionWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry collection value based on the specified values.
+ An expression that provides the well known text representation of the geometry collection value.
+ An expression that provides the coordinate system id (SRID) of the geometry collection value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryFromBinary' function with the specified argument, which must have a binary result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry value based on the specified binary value.
+ An expression that provides the well known binary representation of the geometry value.
+
+
+
+ Creates a that invokes the canonical 'GeometryFromBinary' function with the specified arguments. wellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry value based on the specified values.
+ An expression that provides the well known binary representation of the geometry value.
+ An expression that provides the coordinate system id (SRID) of the geometry value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryPointFromBinary' function with the specified arguments. pointWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry point value based on the specified values.
+ An expression that provides the well known binary representation of the geometry point value.
+ An expression that provides the coordinate system id (SRID) of the geometry point value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryLineFromBinary' function with the specified arguments. lineWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry line value based on the specified values.
+ An expression that provides the well known binary representation of the geometry line value.
+ An expression that provides the coordinate system id (SRID) of the geometry line value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryPolygonFromBinary' function with the specified arguments. polygonWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry polygon value based on the specified values.
+ An expression that provides the well known binary representation of the geometry polygon value.
+ An expression that provides the coordinate system id (SRID) of the geometry polygon value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryMultiPointFromBinary' function with the specified arguments. multiPointWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry multi-point value based on the specified values.
+ An expression that provides the well known binary representation of the geometry multi-point value.
+ An expression that provides the coordinate system id (SRID) of the geometry multi-point value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryMultiLineFromBinary' function with the specified arguments. multiLineWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry multi-line value based on the specified values.
+ An expression that provides the well known binary representation of the geometry multi-line value.
+ An expression that provides the coordinate system id (SRID) of the geometry multi-line value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryMultiPolygonFromBinary' function with the specified arguments. multiPolygonWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry multi-polygon value based on the specified values.
+ An expression that provides the well known binary representation of the geometry multi-polygon value.
+ An expression that provides the coordinate system id (SRID) of the geometry multi-polygon value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryCollectionFromBinary' function with the specified arguments. geometryCollectionWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry collection value based on the specified values.
+ An expression that provides the well known binary representation of the geometry collection value.
+ An expression that provides the coordinate system id (SRID) of the geometry collection value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeometryFromGml' function with the specified argument, which must have a string result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry value based on the specified value with the default coordinate system id (SRID) of the underlying provider.
+ An expression that provides the Geography Markup Language (GML) representation of the geometry value.
+
+
+
+ Creates a that invokes the canonical 'GeometryFromGml' function with the specified arguments. geometryMarkup must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a new geometry value based on the specified values.
+ An expression that provides the Geography Markup Language (GML) representation of the geometry value.
+ An expression that provides the coordinate system id (SRID) of the geometry value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyFromText' function with the specified argument, which must have a string result type. The result type of the expression is Edm.Geography. Its value has the default coordinate system id (SRID) of the underlying provider.
+
+ A new DbFunctionExpression that returns a new geography value based on the specified value.
+ An expression that provides the well known text representation of the geography value.
+
+
+
+ Creates a that invokes the canonical 'GeographyFromText' function with the specified arguments. wellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography value based on the specified values.
+ An expression that provides the well known text representation of the geography value.
+ An expression that provides the coordinate system id (SRID) of the geography value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyPointFromText' function with the specified arguments.
+
+ The canonical 'GeographyPointFromText' function.
+ An expression that provides the well-known text representation of the geography point value.
+ An expression that provides the coordinate system id (SRID) of the geography point value's coordinate systempointWellKnownTextValue.
+
+
+
+ Creates a that invokes the canonical 'GeographyLineFromText' function with the specified arguments. lineWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography line value based on the specified values.
+ An expression that provides the well known text representation of the geography line value.
+ An expression that provides the coordinate system id (SRID) of the geography line value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyPolygonFromText' function with the specified arguments. polygonWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography polygon value based on the specified values.
+ An expression that provides the well known text representation of the geography polygon value.
+ An expression that provides the coordinate system id (SRID) of the geography polygon value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyMultiPointFromText' function with the specified arguments. multiPointWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography multi-point value based on the specified values.
+ An expression that provides the well known text representation of the geography multi-point value.
+ An expression that provides the coordinate system id (SRID) of the geography multi-point value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyMultiLineFromText' function with the specified arguments. multiLineWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography multi-line value based on the specified values.
+ An expression that provides the well known text representation of the geography multi-line value.
+ An expression that provides the coordinate system id (SRID) of the geography multi-line value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyMultiPolygonFromText' function with the specified arguments. multiPolygonWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography multi-polygon value based on the specified values.
+ An expression that provides the well known text representation of the geography multi-polygon value.
+ An expression that provides the coordinate system id (SRID) of the geography multi-polygon value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyCollectionFromText' function with the specified arguments. geographyCollectionWellKnownText must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography collection value based on the specified values.
+ An expression that provides the well known text representation of the geography collection value.
+ An expression that provides the coordinate system id (SRID) of the geography collection value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyFromBinary' function with the specified argument, which must have a binary result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography value based on the specified binary value.
+ An expression that provides the well known binary representation of the geography value.
+
+
+
+ Creates a that invokes the canonical 'GeographyFromBinary' function with the specified arguments. wellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography value based on the specified values.
+ An expression that provides the well known binary representation of the geography value.
+ An expression that provides the coordinate system id (SRID) of the geography value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyPointFromBinary' function with the specified arguments. pointWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography point value based on the specified values.
+ An expression that provides the well known binary representation of the geography point value.
+ An expression that provides the coordinate system id (SRID) of the geography point value's coordinate systempointWellKnownBinaryValue.
+
+
+
+ Creates a that invokes the canonical 'GeographyLineFromBinary' function with the specified arguments. lineWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography line value based on the specified values.
+ An expression that provides the well known binary representation of the geography line value.
+ An expression that provides the coordinate system id (SRID) of the geography line value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyPolygonFromBinary' function with the specified arguments. polygonWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography polygon value based on the specified values.
+ An expression that provides the well known binary representation of the geography polygon value.
+ An expression that provides the coordinate system id (SRID) of the geography polygon value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyMultiPointFromBinary' function with the specified arguments. multiPointWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography multi-point value based on the specified values.
+ An expression that provides the well known binary representation of the geography multi-point value.
+ An expression that provides the coordinate system id (SRID) of the geography multi-point value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyMultiLineFromBinary' function with the specified arguments. multiLineWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography multi-line value based on the specified values.
+ An expression that provides the well known binary representation of the geography multi-line value.
+ An expression that provides the coordinate system id (SRID) of the geography multi-line value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyMultiPolygonFromBinary' function with the specified arguments. multiPolygonWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography multi-polygon value based on the specified values.
+ An expression that provides the well known binary representation of the geography multi-polygon value.
+ An expression that provides the coordinate system id (SRID) of the geography multi-polygon value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyCollectionFromBinary' function with the specified arguments. geographyCollectionWellKnownBinaryValue must have a binary result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography collection value based on the specified values.
+ An expression that provides the well known binary representation of the geography collection value.
+ An expression that provides the coordinate system id (SRID) of the geography collection value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'GeographyFromGml' function with the specified argument, which must have a string result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography value based on the specified value with the default coordinate system id (SRID) of the underlying provider.
+ An expression that provides the Geography Markup Language (GML) representation of the geography value.
+
+
+
+ Creates a that invokes the canonical 'GeographyFromGml' function with the specified arguments. geographyMarkup must have a string result type, while coordinateSystemId must have an integer numeric result type. The result type of the expression is Edm.Geography.
+
+ A new DbFunctionExpression that returns a new geography value based on the specified values.
+ An expression that provides the Geography Markup Language (GML) representation of the geography value.
+ An expression that provides the coordinate system id (SRID) of the geography value's coordinate system.
+
+
+
+ Creates a that invokes the canonical 'CoordinateSystemId' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the integer SRID value from spatialValue.
+ An expression that specifies the value from which the coordinate system id (SRID) should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'SpatialTypeName' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.String.
+
+ A new DbFunctionExpression that returns the string Geometry Type name from spatialValue.
+ An expression that specifies the value from which the Geometry Type name should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'SpatialDimension' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns the Dimension value from spatialValue.
+ An expression that specifies the value from which the Dimension value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'SpatialEnvelope' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns the the minimum bounding box for geometryValue.
+ An expression that specifies the value from which the Envelope value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'AsBinary' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Binary.
+
+ A new DbFunctionExpression that returns the well known binary representation of spatialValue.
+ An expression that specifies the spatial value from which the well known binary representation should be produced.
+
+
+
+ Creates a that invokes the canonical 'AsGml' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.String.
+
+ A new DbFunctionExpression that returns the Geography Markup Language (GML) representation of spatialValue.
+ An expression that specifies the spatial value from which the Geography Markup Language (GML) representation should be produced.
+
+
+
+ Creates a that invokes the canonical 'AsText' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.String.
+
+ A new DbFunctionExpression that returns the well known text representation of spatialValue.
+ An expression that specifies the spatial value from which the well known text representation should be produced.
+
+
+
+ Creates a that invokes the canonical 'IsEmptySpatial' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether spatialValue is empty.
+ An expression that specifies the spatial value from which the IsEmptySptiaal value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'IsSimpleGeometry' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether geometryValue is a simple geometry.
+ The geometry value.
+
+
+
+ Creates a that invokes the canonical 'SpatialBoundary' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns the the boundary for geometryValue.
+ An expression that specifies the geometry value from which the SpatialBoundary value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'IsValidGeometry' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether geometryValue is valid.
+ An expression that specifies the geometry value which should be tested for spatial validity.
+
+
+
+ Creates a that invokes the canonical 'SpatialEquals' function with the specified arguments, which must each have an Edm.Geography or Edm.Geometry result type. The result type of spatialValue1 must match the result type of spatialValue2. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether spatialValue1 and spatialValue2 are equal.
+ An expression that specifies the first spatial value.
+ An expression that specifies the spatial value that should be compared with spatialValue1 for equality.
+
+
+
+ Creates a that invokes the canonical 'SpatialDisjoint' function with the specified arguments, which must each have an Edm.Geography or Edm.Geometry result type. The result type of spatialValue1 must match the result type of spatialValue2. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether spatialValue1 and spatialValue2 are spatially disjoint.
+ An expression that specifies the first spatial value.
+ An expression that specifies the spatial value that should be compared with spatialValue1 for disjointness.
+
+
+
+ Creates a that invokes the canonical 'SpatialIntersects' function with the specified arguments, which must each have an Edm.Geography or Edm.Geometry result type. The result type of spatialValue1 must match the result type of spatialValue2. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether spatialValue1 and spatialValue2 intersect.
+ An expression that specifies the first spatial value.
+ An expression that specifies the spatial value that should be compared with spatialValue1 for intersection.
+
+
+
+ Creates a that invokes the canonical 'SpatialTouches' function with the specified arguments, which must each have an Edm.Geometry result type. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether geometryValue1 touches geometryValue2.
+ An expression that specifies the first geometry value.
+ An expression that specifies the geometry value that should be compared with geometryValue1.
+
+
+
+ Creates a that invokes the canonical 'SpatialCrosses' function with the specified arguments, which must each have an Edm.Geometry result type. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether geometryValue1 crosses geometryValue2 intersect.
+ An expression that specifies the first geometry value.
+ An expression that specifies the geometry value that should be compared with geometryValue1.
+
+
+
+ Creates a that invokes the canonical 'SpatialWithin' function with the specified arguments, which must each have an Edm.Geometry result type. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether geometryValue1 is spatially within geometryValue2.
+ An expression that specifies the first geometry value.
+ An expression that specifies the geometry value that should be compared with geometryValue1.
+
+
+
+ Creates a that invokes the canonical 'SpatialContains' function with the specified arguments, which must each have an Edm.Geometry result type. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether geometryValue1 spatially contains geometryValue2.
+ An expression that specifies the first geometry value.
+ An expression that specifies the geometry value that should be compared with geometryValue1.
+
+
+
+ Creates a that invokes the canonical 'SpatialOverlaps' function with the specified arguments, which must each have an Edm.Geometry result type. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether geometryValue1 spatially overlaps geometryValue2.
+ An expression that specifies the first geometry value.
+ An expression that specifies the geometry value that should be compared with geometryValue1.
+
+
+
+ Creates a that invokes the canonical 'SpatialRelate' function with the specified arguments, which must have Edm.Geometry and string result types. The result type of the expression is Edm.Boolean.
+
+ A new DbFunctionExpression that returns a Boolean value indicating whether geometryValue1 is spatially related to geometryValue2 according to the spatial relationship designated by intersectionPatternMatrix.
+ An expression that specifies the first geometry value.
+ An expression that specifies the geometry value that should be compared with geometryValue1.
+ An expression that specifies the text representation of the Dimensionally Extended Nine-Intersection Model (DE-9IM) intersection pattern used to compare geometryValue1 and geometryValue2.
+
+
+
+ Creates a that invokes the canonical 'SpatialBuffer' function with the specified arguments, which must have a Edm.Geography or Edm.Geometry and Edm.Double result types. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns a geometry value representing all points less than or equal to distance from spatialValue.
+ An expression that specifies the spatial value.
+ An expression that specifies the buffer distance.
+
+
+
+ Creates a that invokes the canonical 'Distance' function with the specified arguments, which must each have an Edm.Geography or Edm.Geometry result type. The result type of spatialValue1 must match the result type of spatialValue2. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns the distance between the closest points in spatialValue1 and spatialValue1.
+ An expression that specifies the first spatial value.
+ An expression that specifies the spatial value from which the distance from spatialValue1 should be measured.
+
+
+
+ Creates a that invokes the canonical 'SpatialConvexHull' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns the the convex hull for geometryValue.
+ An expression that specifies the geometry value from which the convex hull value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'SpatialIntersection' function with the specified arguments, which must each have an Edm.Geography or Edm.Geometry result type. The result type of spatialValue1 must match the result type of spatialValue2. The result type of the expression is the same as the type of spatialValue1 and spatialValue2.
+
+ A new DbFunctionExpression that returns the spatial value representing the intersection of spatialValue1 and spatialValue2.
+ An expression that specifies the first spatial value.
+ An expression that specifies the spatial value for which the intersection with spatialValue1 should be computed.
+
+
+
+ Creates a that invokes the canonical 'SpatialUnion' function with the specified arguments, which must each have an Edm.Geography or Edm.Geometry result type. The result type of spatialValue1 must match the result type of spatialValue2. The result type of the expression is the same as the type of spatialValue1 and spatialValue2.
+
+ A new DbFunctionExpression that returns the spatial value representing the union of spatialValue1 and spatialValue2.
+ An expression that specifies the first spatial value.
+ An expression that specifies the spatial value for which the union with spatialValue1 should be computed.
+
+
+
+ Creates a that invokes the canonical 'SpatialDifference' function with the specified arguments, which must each have an Edm.Geography or Edm.Geometry result type. The result type of spatialValue1 must match the result type of spatialValue2. The result type of the expression is the same as the type of spatialValue1 and spatialValue2.
+
+ A new DbFunctionExpression that returns the geometry value representing the difference of spatialValue2 with spatialValue1.
+ An expression that specifies the first spatial value.
+ An expression that specifies the spatial value for which the difference with spatialValue1 should be computed.
+
+
+
+ Creates a that invokes the canonical 'SpatialSymmetricDifference' function with the specified arguments, which must each have an Edm.Geography or Edm.Geometry result type. The result type of spatialValue1 must match the result type of spatialValue2. The result type of the expression is the same as the type of spatialValue1 and spatialValue2.
+
+ A new DbFunctionExpression that returns the geometry value representing the symmetric difference of spatialValue2 with spatialValue1.
+ An expression that specifies the first spatial value.
+ An expression that specifies the spatial value for which the symmetric difference with spatialValue1 should be computed.
+
+
+
+ Creates a that invokes the canonical 'SpatialElementCount' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns either the number of elements in spatialValue or null if spatialValue is not a collection.
+ An expression that specifies the geography or geometry collection value from which the number of elements should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'SpatialElementAt' function with the specified arguments. The first argument must have an Edm.Geography or Edm.Geometry result type. The second argument must have an integer numeric result type. The result type of the expression is the same as that of spatialValue.
+
+ A new DbFunctionExpression that returns either the collection element at position indexValue in spatialValue or null if spatialValue is not a collection.
+ An expression that specifies the geography or geometry collection value.
+ An expression that specifies the position of the element to be retrieved from within the geometry or geography collection.
+
+
+
+ Creates a that invokes the canonical 'XCoordinate' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns either the X co-ordinate value of geometryValue or null if geometryValue is not a point.
+ An expression that specifies the geometry point value from which the X co-ordinate value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'YCoordinate' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns either the Y co-ordinate value of geometryValue or null if geometryValue is not a point.
+ An expression that specifies the geometry point value from which the Y co-ordinate value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Elevation' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns either the elevation value of spatialValue or null if spatialValue is not a point.
+ An expression that specifies the spatial point value from which the elevation (Z co-ordinate) value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Measure' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns either the Measure of spatialValue or null if spatialValue is not a point.
+ An expression that specifies the spatial point value from which the Measure (M) co-ordinate value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Latitude' function with the specified argument, which must have an Edm.Geography result type. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns either the Latitude value of geographyValue or null if geographyValue is not a point.
+ An expression that specifies the geography point value from which the Latitude value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'Longitude' function with the specified argument, which must have an Edm.Geography result type. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns either the Longitude value of geographyValue or null if geographyValue is not a point.
+ An expression that specifies the geography point value from which the Longitude value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'SpatialLength' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns either the length of spatialValue or null if spatialValue is not a curve.
+ An expression that specifies the spatial curve value from which the length should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'StartPoint' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type is the same as that of spatialValue.
+
+ A new DbFunctionExpression that returns either the start point of spatialValue or null if spatialValue is not a curve.
+ An expression that specifies the spatial curve value from which the start point should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'EndPoint' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type is the same as that of spatialValue.
+
+ A new DbFunctionExpression that returns either the end point of spatialValue or null if spatialValue is not a curve.
+ An expression that specifies the spatial curve value from which the end point should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'IsClosedSpatial' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type is Edm.Boolean.
+
+ A new DbFunctionExpression that returns either a Boolean value indicating whether spatialValue is closed, or null if spatialValue is not a curve.
+ An expression that specifies the spatial curve value from which the IsClosedSpatial value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'IsRing' function with the specified argument, which must have an Edm.Geometry result type. The result type is Edm.Boolean.
+
+ A new DbFunctionExpression that returns either a Boolean value indicating whether geometryValue is a ring (both closed and simple), or null if geometryValue is not a curve.
+ An expression that specifies the geometry curve value from which the IsRing value should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'PointCount' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns either the number of points in spatialValue or null if spatialValue is not a line string.
+ An expression that specifies the spatial line string value from which the number of points should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'PointAt' function with the specified arguments. The first argument must have an Edm.Geography or Edm.Geometry result type. The second argument must have an integer numeric result type. The result type of the expression is the same as that of spatialValue.
+
+ A new DbFunctionExpression that returns either the point at position indexValue in spatialValue or null if spatialValue is not a line string.
+ An expression that specifies the spatial line string value.
+ An expression that specifies the position of the point to be retrieved from within the line string.
+
+
+
+ Creates a that invokes the canonical 'Area' function with the specified argument, which must have an Edm.Geography or Edm.Geometry result type. The result type of the expression is Edm.Double.
+
+ A new DbFunctionExpression that returns either the area of spatialValue or null if spatialValue is not a surface.
+ An expression that specifies the spatial surface value for which the area should be calculated.
+
+
+
+ Creates a that invokes the canonical 'Centroid' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns either the centroid point of geometryValue (which may not be on the surface itself) or null if geometryValue is not a surface.
+ An expression that specifies the geometry surface value from which the centroid should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'PointOnSurface' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns either a point guaranteed to be on the surface geometryValue or null if geometryValue is not a surface.
+ An expression that specifies the geometry surface value from which the point should be retrieved.
+
+
+
+ Creates a that invokes the canonical 'ExteriorRing' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns either the exterior ring of the polygon geometryValue or null if geometryValue is not a polygon.
+ The geometry value.
+
+
+
+ Creates a that invokes the canonical 'InteriorRingCount' function with the specified argument, which must have an Edm.Geometry result type. The result type of the expression is Edm.Int32.
+
+ A new DbFunctionExpression that returns either the number of interior rings in the polygon geometryValue or null if geometryValue is not a polygon.
+ The geometry value.
+
+
+
+ Creates a that invokes the canonical 'InteriorRingAt' function with the specified arguments. The first argument must have an Edm.Geometry result type. The second argument must have an integer numeric result types. The result type of the expression is Edm.Geometry.
+
+ A new DbFunctionExpression that returns either the interior ring at position indexValue in geometryValue or null if geometryValue is not a polygon.
+ The geometry value.
+ An expression that specifies the position of the interior ring to be retrieved from within the polygon.
+
+
+
+ Ensures that all metadata in a given expression tree is from the specified metadata workspace,
+ potentially rebinding and rebuilding the expressions to appropriate replacement metadata where necessary.
+
+
+
+ Initializes a new instance of the class.
+ The target workspace.
+
+
+ Implements the visitor pattern for the entity set.
+ The implemented visitor pattern.
+ The entity set.
+
+
+ Implements the visitor pattern for the function.
+ The implemented visitor pattern.
+ The function metadata.
+
+
+ Implements the visitor pattern for the type.
+ The implemented visitor pattern.
+ The type.
+
+
+ Implements the visitor pattern for the type usage.
+ The implemented visitor pattern.
+ The type.
+
+
+ Implements the visitor pattern for retrieving an instance property.
+ The implemented visitor.
+ The expression.
+
+
+
+ Represents a boolean expression that tests whether a specified item matches any element in a list.
+
+
+
+
+ The visitor pattern method for expression visitors that do not produce a result value.
+
+ An instance of DbExpressionVisitor.
+
+
+ is null
+
+
+
+
+ The visitor pattern method for expression visitors that produce a result value of a specific type.
+
+ An instance of a typed DbExpressionVisitor that produces a result value of type TResultType.
+
+ The type of the result produced by
+
+
+
+ is null
+
+
+ An instance of .
+
+
+
+
+ Gets a DbExpression that specifies the item to be matched.
+
+
+
+
+ Gets the list of DbExpression to test for a match.
+
+
+
+
+ Represents the retrieval of the key value of the specified Reference as a row.
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Represents the set union (without duplicate removal) operation between the left and right operands.
+
+
+ DbUnionAllExpression requires that its arguments have a common collection result type
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+
+ Represents a 'scan' of all elements of a given entity set.
+
+
+
+ Implements the visitor pattern for expressions that do not produce a result value.
+
+ An instance of .
+
+ visitor is null.
+
+
+ Implements the visitor pattern for expressions that produce a result value of a specific type.
+
+ A result value of a specific type produced by
+
+ .
+
+
+ An instance of a typed that produces a result value of a specific type.
+
+ The type of the result produced by visitor .
+ visitor is null.
+
+
+ Gets the metadata for the referenced entity or relationship set.
+ The metadata for the referenced entity or relationship set.
+
+
+
+ Extension methods for .
+
+
+
+
+ Gets the conceptual model from the specified DbModel.
+
+ An instance of a class that implements IEdmModelAdapter (ex. DbModel).
+ An instance of EdmModel that represents the conceptual model.
+
+
+
+ Gets the store model from the specified DbModel.
+
+ An instance of a class that implements IEdmModelAdapter (ex. DbModel).
+ An instance of EdmModel that represents the store model.
+
+
+
+ An interface to get the underlying store and conceptual model for a .
+
+
+
+
+ Gets the conceptual model.
+
+
+
+
+ Gets the store model.
+
+
+
+
+ Inherit from this class to create a service that allows for code generation of custom annotations as part of
+ scaffolding Migrations. The derived class should be set onto the .
+
+
+ Note that an is not needed if the annotation uses a simple string value,
+ or if calling ToString on the annotation object is sufficient for use in the scaffolded Migration.
+
+
+
+
+ Override this method to return additional namespaces that should be included in the code generated for the
+ scaffolded migration. The default implementation returns an empty enumeration.
+
+ The names of the annotations that are being included in the generated code.
+ A list of additional namespaces to include.
+
+
+
+ Implement this method to generate code for the given annotation value.
+
+ The name of the annotation for which a value is being generated.
+ The annotation value.
+ The writer to which generated code should be written.
+
+
+
+ Represents a pair of annotation values in a scaffolded or hand-coded .
+
+
+ Code First allows for custom annotations to be associated with columns and tables in the
+ generated model. This class represents a pair of annotation values in a migration such
+ that when the Code First model changes the old annotation value and the new annotation
+ value can be provided to the migration and used in SQL generation.
+
+
+
+
+ Creates a new pair of annotation values.
+
+ The old value of the annotation, which may be null if the annotation has just been created.
+ The new value of the annotation, which may be null if the annotation has been deleted.
+
+
+
+
+
+
+
+
+
+ Returns true if both annotation pairs contain the same values, otherwise false.
+
+ A pair of annotation values.
+ A pair of annotation values.
+ True if both pairs contain the same values.
+
+
+
+ Returns true if the two annotation pairs contain different values, otherwise false.
+
+ A pair of annotation values.
+ A pair of annotation values.
+ True if the pairs contain different values.
+
+
+
+ Gets the old value of the annotation, which may be null if the annotation has just been created.
+
+
+
+
+ Gets the new value of the annotation, which may be null if the annotation has been deleted.
+
+
+
+
+ Returned by and related methods to indicate whether or
+ not one object does not conflict with another such that the two can be combined into one.
+
+
+ If the two objects are not compatible then information about why they are not compatible is contained
+ in the property.
+
+
+
+
+ Creates a new instance.
+
+ Indicates whether or not the two tested objects are compatible.
+
+ An error message indicating how the objects are not compatible. Expected to be null if isCompatible is true.
+
+
+
+
+ Implicit conversion to a bool to allow the result object to be used directly in checks.
+
+ The object to convert.
+ True if the result is compatible; false otherwise.
+
+
+
+ True if the two tested objects are compatible; otherwise false.
+
+
+
+
+ If is true, then returns an error message indicating how the two tested objects
+ are incompatible.
+
+
+
+
+ Types used as custom annotations can implement this interface to indicate that an attempt to use
+ multiple annotations with the same name on a given table or column may be possible by merging
+ the multiple annotations into one.
+
+
+ Normally there can only be one custom annotation with a given name on a given table or
+ column. If a table or column ends up with multiple annotations, for example, because
+ multiple CLR properties map to the same column, then an exception will be thrown.
+ However, if the annotation type implements this interface, then the two annotations will be
+ checked for compatibility using the method and, if compatible,
+ will be merged into one using the method.
+
+
+
+
+ Returns true if this annotation does not conflict with the given annotation such that
+ the two can be combined together using the method.
+
+ The annotation to compare.
+ A CompatibilityResult indicating whether or not this annotation is compatible with the other.
+
+
+
+ Merges this annotation with the given annotation and returns a new merged annotation. This method is
+ only expected to succeed if returns true.
+
+ The annotation to merge with this one.
+ A new merged annotation.
+
+
+
+ Instances of this class are used as custom annotations for representing database indexes in an
+ Entity Framework model.
+
+
+ An index annotation is added to a Code First model when an is placed on
+ a mapped property of that model. This is used by Entity Framework Migrations to create indexes on
+ mapped database columns. Note that multiple index attributes on a property will be merged into a
+ single annotation for the column. Similarly, index attributes on multiple properties that map to the
+ same column will be merged into a single annotation for the column. This means that one index
+ annotation can represent multiple indexes. Within an annotation there can be only one index with any
+ given name.
+
+
+
+
+ The name used when this annotation is stored in Entity Framework metadata or serialized into
+ an SSDL/EDMX file.
+
+
+
+
+ Creates a new annotation for the given index.
+
+ An index attributes representing an index.
+
+
+
+ Creates a new annotation for the given collection of indexes.
+
+ Index attributes representing one or more indexes.
+
+
+
+ Returns true if this annotation does not conflict with the given annotation such that
+ the two can be combined together using the method.
+
+
+ Each index annotation contains at most one with a given name.
+ Two annotations are considered compatible if each IndexAttribute with a given name is only
+ contained in one annotation or the other, or if both annotations contain an IndexAttribute
+ with the given name.
+
+ The annotation to compare.
+ A CompatibilityResult indicating whether or not this annotation is compatible with the other.
+
+
+
+ Merges this annotation with the given annotation and returns a new annotation containing the merged indexes.
+
+
+ Each index annotation contains at most one with a given name.
+ The merged annotation will contain IndexAttributes from both this and the other annotation.
+ If both annotations contain an IndexAttribute with the same name, then the merged annotation
+ will contain one IndexAttribute with that name.
+
+ The annotation to merge with this one.
+ A new annotation with indexes from both annotations merged.
+
+ The other annotation contains indexes that are not compatible with indexes in this annotation.
+
+
+
+
+
+
+
+ Gets the indexes represented by this annotation.
+
+
+
+
+ This class is used to serialize and deserialize objects so that they
+ can be stored in the EDMX form of the Entity Framework model.
+
+
+ An example of the serialized format is:
+ { Name: 'MyIndex', Order: 7, IsClustered: True, IsUnique: False } { } { Name: 'MyOtherIndex' }.
+ Note that properties that have not been explicitly set in an index attribute will be excluded from
+ the serialized output. So, in the example above, the first index has all properties specified,
+ the second has none, and the third has just the name set.
+
+
+
+
+ Implement this interface to allow custom annotations represented by instances to be
+ serialized to and from the EDMX XML. Usually a serializer instance is set using the
+ method.
+
+
+
+
+ Serializes the given annotation value into a string for storage in the EDMX XML.
+
+ The name of the annotation that is being serialized.
+ The value to serialize.
+ The serialized value.
+
+
+
+ Deserializes the given string back into the expected annotation value.
+
+ The name of the annotation that is being deserialized.
+ The string to deserialize.
+ The deserialized annotation value.
+
+
+
+ Serializes the given into a string for storage in the EDMX XML.
+
+ The name of the annotation that is being serialized.
+ The value to serialize which must be an IndexAnnotation object.
+ The serialized value.
+
+
+
+ Deserializes the given string back into an object.
+
+ The name of the annotation that is being deserialized.
+ The string to deserialize.
+ The deserialized annotation value.
+ If there is an error reading the serialized value.
+
+
+
+ This interface is implemented by any object that can resolve a dependency, either directly
+ or through use of an external container.
+
+
+ The public services currently resolved using IDbDependencyResolver are documented here:
+ http://msdn.microsoft.com/en-us/data/jj680697
+
+
+
+
+ Attempts to resolve a dependency for a given contract type and optionally a given key.
+ If the resolver cannot resolve the dependency then it must return null and not throw. This
+ allows resolvers to be used in a Chain of Responsibility pattern such that multiple resolvers
+ can be asked to resolve a dependency until one finally does.
+
+ The interface or abstract base class that defines the dependency to be resolved. The returned object is expected to be an instance of this type.
+ Optionally, the key of the dependency to be resolved. This may be null for dependencies that are not differentiated by key.
+ The resolved dependency, which must be an instance of the given contract type, or null if the dependency could not be resolved.
+
+
+
+ Attempts to resolve a dependencies for a given contract type and optionally a given key.
+ If the resolver cannot resolve the dependency then it must return an empty enumeration and
+ not throw. This method differs from in that it returns all registered
+ services for the given type and key combination.
+
+ The interface or abstract base class that defines the dependency to be resolved. Every returned object is expected to be an instance of this type.
+ Optionally, the key of the dependency to be resolved. This may be null for dependencies that are not differentiated by key.
+ All services that resolve the dependency, which must be instances of the given contract type, or an empty enumeration if the dependency could not be resolved.
+
+
+
+ An implementation used for resolving
+ factories.
+
+
+
+
+ Initializes a new instance of
+
+ A function that returns a new instance of a transaction handler.
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which the transaction handler will be used.
+ null will match anything.
+
+
+ A string that will be matched against the server name in the connection string. null will match anything.
+
+
+
+
+ If the given type is , then this method will attempt
+ to return the service to use, otherwise it will return null. When the given type is
+ , then the key is expected to be a .
+
+ The service type to resolve.
+ A key used to make a determination of the service to return.
+
+ An , or null.
+
+
+
+
+ If the given type is , then this resolver will attempt
+ to return the service to use, otherwise it will return an empty enumeration. When the given type is
+ , then the key is expected to be an .
+
+ The service type to resolve.
+ A key used to make a determination of the service to return.
+
+ An enumerable of , or an empty enumeration.
+
+
+
+
+
+
+
+
+
+
+ Provides utility methods for reading from an App.config or Web.config file.
+
+
+
+
+ Initializes a new instance of .
+
+ The configuration to read from.
+
+
+
+ Gets the specified provider services from the configuration.
+
+ The invariant name of the provider services.
+ The provider services type name, or null if not found.
+
+
+
+ A simple logger for logging SQL and other database operations to the console or a file.
+ A logger can be registered in code or in the application's web.config /app.config file.
+
+
+
+
+ An object that implements this interface can be registered with to
+ receive notifications when Entity Framework loads the application's .
+
+
+ Interceptors can also be registered in the config file of the application.
+ See http://go.microsoft.com/fwlink/?LinkId=260883 for more information about Entity Framework configuration.
+
+
+
+
+ This is the base interface for all interfaces that provide interception points for various
+ different types and operations. For example, see .
+ Interceptors are registered on the class.
+
+
+
+
+ Occurs during EF initialization after the has been constructed but just before
+ it is locked ready for use. Use this event to inspect and/or override services that have been
+ registered before the configuration is locked. Note that an interceptor of this type should be used carefully
+ since it may prevent tooling from discovering the same configuration that is used at runtime.
+
+
+ Handlers can only be added before EF starts to use the configuration and so handlers should
+ generally be added as part of application initialization. Do not access the DbConfiguration
+ static methods inside the handler; instead use the the members of
+ to get current services and/or add overrides.
+
+ Arguments to the event that this interceptor mirrors.
+ Contextual information about the event.
+
+
+
+ Creates a new logger that will send log output to the console.
+
+
+
+
+ Creates a new logger that will send log output to a file. If the file already exists then
+ it is overwritten.
+
+ A path to the file to which log output will be written.
+
+
+
+ Creates a new logger that will send log output to a file.
+
+ A path to the file to which log output will be written.
+ True to append data to the file if it exists; false to overwrite the file.
+
+
+
+ Stops logging and closes the underlying file if output is being written to a file.
+
+
+
+
+ Stops logging and closes the underlying file if output is being written to a file.
+
+
+ True to release both managed and unmanaged resources; False to release only unmanaged resources.
+
+
+
+
+ Starts logging. This method is a no-op if logging is already started.
+
+
+
+
+ Stops logging. This method is a no-op if logging is not started.
+
+
+
+
+ Called to start logging during Entity Framework initialization when this logger is registered.
+ as an .
+
+ Arguments to the event that this interceptor mirrors.
+ Contextual information about the event.
+
+
+
+ Represents contextual information associated with calls into
+ implementations.
+
+
+ Instances of this class are publicly immutable for contextual information. To add
+ contextual information use one of the With... or As... methods to create a new
+ interception context containing the new information.
+
+
+
+
+ Represents contextual information associated with calls into
+ implementations.
+
+
+ Note that specific types/operations that can be intercepted may use a more specific
+ interception context derived from this class. For example, if SQL is being executed by
+ a , then the DbContext will be contained in the
+ instance that is passed to the methods
+ of .
+ Instances of this class are publicly immutable for contextual information. To add
+ contextual information use one of the With... or As... methods to create a new
+ interception context containing the new information.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying state from the given
+ interception context. See
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Call this method when creating a copy of an interception context in order to add new state
+ to it. Using this method instead of calling the constructor directly ensures virtual dispatch
+ so that the new type will have the same type (and any specialized state) as the context that
+ is being cloned.
+
+ A new context with all state copied.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets all the instances associated with this interception context.
+
+
+ This list usually contains zero or one items. However, it can contain more than one item if
+ a single has been used to construct multiple
+ instances.
+
+
+
+
+ Gets all the instances associated with this interception context.
+
+
+ This list usually contains zero or one items. However, it can contain more than one item when
+ EF has created a new for use in database creation and initialization, or
+ if a single is used with multiple .
+
+
+
+
+ True if the operation is being executed asynchronously, otherwise false.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+
+
+
+ Creates a new that contains all the contextual information in
+ this interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in
+ this interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in
+ this interception context the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Implemented by Entity Framework providers and used to check whether or not tables exist
+ in a given database. This is used by database initializers when determining whether or not to
+ treat an existing database as empty such that tables should be created.
+
+
+
+
+ When overridden in a derived class checks where the given tables exist in the database
+ for the given connection.
+
+
+ The context for which table checking is being performed, usually used to obtain an appropriate
+ .
+
+
+ A connection to the database. May be open or closed; should be closed again if opened. Do not
+ dispose.
+
+ The tables to check for existence.
+ The name of the EdmMetadata table to check for existence.
+ True if any of the model tables or EdmMetadata table exists.
+
+
+
+ Helper method to get the table name for the given s-space .
+
+ The s-space entity set for the table.
+ The table name.
+
+
+
+ Thrown when an error occurs committing a .
+
+
+
+
+ Initializes a new instance of
+
+
+
+
+ Initializes a new instance of
+
+ The exception message.
+
+
+
+ Initializes a new instance of
+
+ The exception message.
+ The inner exception.
+
+
+
+ Initializes a new instance of the class.
+
+ The data necessary to serialize or deserialize an object.
+ Description of the source and destination of the specified serialized stream.
+
+
+
+ Event arguments passed to event handlers.
+
+
+
+
+ Call this method to add a instance to the Chain of
+ Responsibility of resolvers that are used to resolve dependencies needed by the Entity Framework.
+
+
+ Resolvers are asked to resolve dependencies in reverse order from which they are added. This means
+ that a resolver can be added to override resolution of a dependency that would already have been
+ resolved in a different way.
+ The only exception to this is that any dependency registered in the application's config file
+ will always be used in preference to using a dependency resolver added here, unless the
+ overrideConfigFile is set to true in which case the resolver added here will also override config
+ file settings.
+
+ The resolver to add.
+ If true, then the resolver added will take precedence over settings in the config file.
+
+
+
+ Call this method to add a instance to the Chain of Responsibility
+ of resolvers that are used to resolve dependencies needed by the Entity Framework. Unlike the AddDependencyResolver
+ method, this method puts the resolver at the bottom of the Chain of Responsibility such that it will only
+ be used to resolve a dependency that could not be resolved by any of the other resolvers.
+
+ The resolver to add.
+
+
+
+ Adds a wrapping resolver to the configuration that is about to be locked. A wrapping
+ resolver is a resolver that incepts a service would have been returned by the resolver
+ chain and wraps or replaces it with another service of the same type.
+
+ The type of service to wrap or replace.
+ A delegate that takes the unwrapped service and key and returns the wrapped or replaced service.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Returns a snapshot of the that is about to be locked.
+ Use the GetService methods on this object to get services that have been registered.
+
+
+
+
+ An implementation used for resolving
+ factories.
+
+
+ This class can be used by to aid in the resolving
+ of factories as a default service for the provider.
+
+ The type of execution strategy that is resolved.
+
+
+
+ Initializes a new instance of
+
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this execution strategy will be used.
+
+
+ A string that will be matched against the server name in the connection string. null will match anything.
+
+ A function that returns a new instance of an execution strategy.
+
+
+
+ If the given type is , then this resolver will attempt
+ to return the service to use, otherwise it will return null. When the given type is
+ Func{IExecutionStrategy}, then the key is expected to be an .
+
+ The service type to resolve.
+ A key used to make a determination of the service to return.
+
+ An , or null.
+
+
+
+
+ If the given type is , then this resolver will attempt
+ to return the service to use, otherwise it will return an empty enumeration. When the given type is
+ Func{IExecutionStrategy}, then the key is expected to be an .
+
+ The service type to resolve.
+ A key used to make a determination of the service to return.
+
+ An enumerable of , or an empty enumeration.
+
+
+
+
+ Extension methods to call the method using
+ a generic type parameter and/or no name.
+
+
+
+
+ Calls passing the generic type of the method and the given
+ name as arguments.
+
+ The contract type to resolve.
+ The resolver to use.
+ The key of the dependency to resolve.
+ The resolved dependency, or null if the resolver could not resolve it.
+
+
+
+ Calls passing the generic type of the method as
+ the type argument and null for the name argument.
+
+ The contract type to resolve.
+ The resolver to use.
+ The resolved dependency, or null if the resolver could not resolve it.
+
+
+
+ Calls passing the given type argument and using
+ null for the name argument.
+
+ The resolver to use.
+ The contract type to resolve.
+ The resolved dependency, or null if the resolver could not resolve it.
+
+
+
+ Calls passing the generic type of the method and the given
+ name as arguments.
+
+ The contract type to resolve.
+ The resolver to use.
+ The key of the dependency to resolve.
+ All resolved dependencies, or an if no services are resolved.
+
+
+
+ Calls passing the generic type of the method as
+ the type argument and null for the name argument.
+
+ The contract type to resolve.
+ The resolver to use.
+ All resolved dependencies, or an if no services are resolved.
+
+
+
+ Calls passing the given type argument and using
+ null for the name argument.
+
+ The resolver to use.
+ The contract type to resolve.
+ All resolved dependencies, or an if no services are resolved.
+
+
+
+ Implements to resolve a dependency such that it always returns
+ the same instance.
+
+ The type that defines the contract for the dependency that will be resolved.
+
+ This class is immutable such that instances can be accessed by multiple threads at the same time.
+
+
+
+
+ Constructs a new resolver that will return the given instance for the contract type
+ regardless of the key passed to the Get method.
+
+ The instance to return.
+
+
+
+ Constructs a new resolver that will return the given instance for the contract type
+ if the given key matches exactly the key passed to the Get method.
+
+ The instance to return.
+ Optionally, the key of the dependency to be resolved. This may be null for dependencies that are not differentiated by key.
+
+
+
+ Constructs a new resolver that will return the given instance for the contract type
+ if the given key matches the key passed to the Get method based on the given predicate.
+
+ The instance to return.
+ A predicate that takes the key object and returns true if and only if it matches.
+
+
+
+
+
+
+
+
+
+ Represents contextual information associated with calls to
+ implementations.
+
+
+ Instances of this class are publicly immutable for contextual information. To add
+ contextual information use one of the With... or As... methods to create a new
+ interception context containing the new information.
+
+
+
+
+ Represents contextual information associated with calls to with return type .
+
+ The return type of the target method.
+
+
+
+ Represents contextual information associated with calls with return type .
+
+ The return type of the target method.
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Prevents the operation from being executed if called before the operation has executed.
+
+
+ Thrown if this method is called after the operation has already executed.
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ If execution of the operation completes without throwing, then this property will contain
+ the result of the operation. If the operation was suppressed or did not fail, then this property
+ will always contain the default value for the generic type.
+
+
+ When an operation operation completes without throwing both this property and the
+ property are set. However, the property can be set or changed by interceptors,
+ while this property will always represent the actual result returned by the operation, if any.
+
+
+
+
+ If this property is set before the operation has executed, then execution of the operation will
+ be suppressed and the set result will be returned instead. Otherwise, if the operation succeeds, then
+ this property will be set to the returned result. In either case, interceptors that run
+ after the operation can change this property to change the result that will be returned.
+
+
+ When an operation operation completes without throwing both this property and the
+ property are set. However, this property can be set or changed by interceptors, while the
+ property will always represent the actual result returned by the
+ operation, if any.
+
+
+
+
+ When true, this flag indicates that that execution of the operation has been suppressed by
+ one of the interceptors. This can be done before the operation has executed by calling
+ , by setting an to be thrown, or
+ by setting the operation result using .
+
+
+
+
+ Gets or sets a value containing arbitrary user-specified state information associated with the operation.
+
+
+
+
+ If execution of the operation fails, then this property will contain the exception that was
+ thrown. If the operation was suppressed or did not fail, then this property will always be null.
+
+
+ When an operation fails both this property and the property are set
+ to the exception that was thrown. However, the property can be set or
+ changed by interceptors, while this property will always represent the original exception thrown.
+
+
+
+
+ If this property is set before the operation has executed, then execution of the operation will
+ be suppressed and the set exception will be thrown instead. Otherwise, if the operation fails, then
+ this property will be set to the exception that was thrown. In either case, interceptors that run
+ after the operation can change this property to change the exception that will be thrown, or set this
+ property to null to cause no exception to be thrown at all.
+
+
+ When an operation fails both this property and the property are set
+ to the exception that was thrown. However, the this property can be set or changed by
+ interceptors, while the property will always represent
+ the original exception thrown.
+
+
+
+
+ Set to the status of the after an async operation has finished. Not used for
+ synchronous operations.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the given .
+
+ The isolation level to associate.
+ A new interception context associated with the given isolation level.
+
+
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ The that will be used or has been used to start a transaction.
+
+
+
+
+ This is the default log formatter used when some is set onto the
+ property. A different formatter can be used by creating a class that inherits from this class and overrides
+ some or all methods to change behavior.
+
+
+ To set the new formatter create a code-based configuration for EF using and then
+ set the formatter class to use with .
+ Note that setting the type of formatter to use with this method does change the way command are
+ logged when is used. It is still necessary to set a
+ onto before any commands will be logged.
+ For more low-level control over logging/interception see and
+ .
+ Interceptors can also be registered in the config file of the application.
+ See http://go.microsoft.com/fwlink/?LinkId=260883 for more information about Entity Framework configuration.
+
+
+
+
+ An object that implements this interface can be registered with to
+ receive notifications when Entity Framework executes commands.
+
+
+ Interceptors can also be registered in the config file of the application.
+ See http://go.microsoft.com/fwlink/?LinkId=260883 for more information about Entity Framework configuration.
+
+
+
+
+ This method is called before a call to or
+ one of its async counterparts is made.
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called after a call to or
+ one of its async counterparts is made. The result used by Entity Framework can be changed by setting
+ .
+
+
+ For async operations this method is not called until after the async task has completed
+ or failed.
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called before a call to or
+ one of its async counterparts is made.
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called after a call to or
+ one of its async counterparts is made. The result used by Entity Framework can be changed by setting
+ .
+
+
+ For async operations this method is not called until after the async task has completed
+ or failed.
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called before a call to or
+ one of its async counterparts is made.
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called after a call to or
+ one of its async counterparts is made. The result used by Entity Framework can be changed by setting
+ .
+
+
+ For async operations this method is not called until after the async task has completed
+ or failed.
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ An object that implements this interface can be registered with to
+ receive notifications when Entity Framework performs operations on a .
+
+
+ Interceptors can also be registered in the config file of the application.
+ See http://go.microsoft.com/fwlink/?LinkId=260883 for more information about Entity Framework configuration.
+
+
+
+
+ Called before is invoked.
+
+ The connection beginning the transaction.
+ Contextual information associated with the call.
+
+
+
+ Called after is invoked.
+ The transaction used by Entity Framework can be changed by setting
+ .
+
+ The connection that began the transaction.
+ Contextual information associated with the call.
+
+
+
+ Called before is invoked.
+
+ The connection being closed.
+ Contextual information associated with the call.
+
+
+
+ Called after is invoked.
+
+ The connection that was closed.
+ Contextual information associated with the call.
+
+
+
+ Called before is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called after is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called before is set.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called after is set.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called before is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called after is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called before is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called after is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called before is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called after is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called before is invoked.
+
+ The connection being disposed.
+ Contextual information associated with the call.
+
+
+
+ Called after is invoked.
+
+ The connection that was disposed.
+ Contextual information associated with the call.
+
+
+
+ Called before is invoked.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called after is invoked.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called before or its async counterpart is invoked.
+
+ The connection being opened.
+ Contextual information associated with the call.
+
+
+
+ Called after or its async counterpart is invoked.
+
+ The connection that was opened.
+ Contextual information associated with the call.
+
+
+
+ Called before is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called after is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called before is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called after is retrieved.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ An object that implements this interface can be registered with to
+ receive notifications when Entity Framework commits or rollbacks a transaction.
+
+
+ Interceptors can also be registered in the config file of the application.
+ See http://go.microsoft.com/fwlink/?LinkId=260883 for more information about Entity Framework configuration.
+
+
+
+
+ Called before is retrieved.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+ Called after is retrieved.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+ Called before is retrieved.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+ Called after is retrieved.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+ This method is called before is invoked.
+
+ The transaction being commited.
+ Contextual information associated with the call.
+
+
+
+ This method is called after is invoked.
+
+ The transaction that was commited.
+ Contextual information associated with the call.
+
+
+
+ This method is called before is invoked.
+
+ The transaction being disposed.
+ Contextual information associated with the call.
+
+
+
+ This method is called after is invoked.
+
+ The transaction that was disposed.
+ Contextual information associated with the call.
+
+
+
+ This method is called before is invoked.
+
+ The transaction being rolled back.
+ Contextual information associated with the call.
+
+
+
+ This method is called after is invoked.
+
+ The transaction that was rolled back.
+ Contextual information associated with the call.
+
+
+
+ Creates a formatter that will not filter by any and will instead log every command
+ from any context and also commands that do not originate from a context.
+
+
+ This constructor is not used when a delegate is set on . Instead it can be
+ used by setting the formatter directly using .
+
+ The delegate to which output will be sent.
+
+
+
+ Creates a formatter that will only log commands the come from the given instance.
+
+
+ This constructor must be called by a class that inherits from this class to override the behavior
+ of .
+
+
+ The context for which commands should be logged. Pass null to log every command
+ from any context and also commands that do not originate from a context.
+
+ The delegate to which output will be sent.
+
+
+
+ Writes the given string to the underlying write delegate.
+
+ The string to write.
+
+
+
+ This method is called before a call to or
+ one of its async counterparts is made.
+ The default implementation calls and starts .
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called after a call to or
+ one of its async counterparts is made.
+ The default implementation stops and calls .
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called before a call to or
+ one of its async counterparts is made.
+ The default implementation calls and starts .
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called after a call to or
+ one of its async counterparts is made.
+ The default implementation stops and calls .
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called before a call to or
+ one of its async counterparts is made.
+ The default implementation calls and starts .
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ This method is called after a call to or
+ one of its async counterparts is made.
+ The default implementation stops and calls .
+
+ The command being executed.
+ Contextual information associated with the call.
+
+
+
+ Called whenever a command is about to be executed. The default implementation of this method
+ filters by set into , if any, and then calls
+ . This method would typically only be overridden to change the
+ context filtering behavior.
+
+ The type of the operation's results.
+ The command that will be executed.
+ Contextual information associated with the command.
+
+
+
+ Called whenever a command has completed executing. The default implementation of this method
+ filters by set into , if any, and then calls
+ . This method would typically only be overridden to change the context
+ filtering behavior.
+
+ The type of the operation's results.
+ The command that was executed.
+ Contextual information associated with the command.
+
+
+
+ Called to log a command that is about to be executed. Override this method to change how the
+ command is logged to .
+
+ The type of the operation's results.
+ The command to be logged.
+ Contextual information associated with the command.
+
+
+
+ Called by to log each parameter. This method can be called from an overridden
+ implementation of to log parameters, and/or can be overridden to
+ change the way that parameters are logged to .
+
+ The type of the operation's results.
+ The command being logged.
+ Contextual information associated with the command.
+ The parameter to log.
+
+
+
+ Called to log the result of executing a command. Override this method to change how results are
+ logged to .
+
+ The type of the operation's results.
+ The command being logged.
+ Contextual information associated with the command.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection beginning the transaction.
+ Contextual information associated with the call.
+
+
+
+ Called after is invoked.
+ The default implementation of this method filters by set into
+ , if any, and then logs the event.
+
+ The connection that began the transaction.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection being opened.
+ Contextual information associated with the call.
+
+
+
+ Called after or its async counterpart is invoked.
+ The default implementation of this method filters by set into
+ , if any, and then logs the event.
+
+ The connection that was opened.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection being closed.
+ Contextual information associated with the call.
+
+
+
+ Called after is invoked.
+ The default implementation of this method filters by set into
+ , if any, and then logs the event.
+
+ The connection that was closed.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Called before is invoked.
+ The default implementation of this method filters by set into
+ , if any, and then logs the event.
+
+ The connection being disposed.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection that was disposed.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The transaction being commited.
+ Contextual information associated with the call.
+
+
+
+ This method is called after is invoked.
+ The default implementation of this method filters by set into
+ , if any, and then logs the event.
+
+ The transaction that was commited.
+ Contextual information associated with the call.
+
+
+
+ This method is called before is invoked.
+ The default implementation of this method filters by set into
+ , if any, and then logs the event.
+
+ The transaction being disposed.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The transaction that was disposed.
+ Contextual information associated with the call.
+
+
+
+ Does not write to log unless overridden.
+
+ The transaction being rolled back.
+ Contextual information associated with the call.
+
+
+
+ This method is called after is invoked.
+ The default implementation of this method filters by set into
+ , if any, and then logs the event.
+
+ The transaction that was rolled back.
+ Contextual information associated with the call.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ The context for which commands are being logged, or null if commands from all contexts are
+ being logged.
+
+
+
+
+ The stop watch used to time executions. This stop watch is started at the end of
+ , , and
+ methods and is stopped at the beginning of the , ,
+ and methods. If these methods are overridden and the stop watch is being used
+ then the overrides should either call the base method or start/stop the watch themselves.
+
+
+
+
+ Represents contextual information associated with calls to that don't return any results.
+
+
+
+
+ Represents contextual information associated with calls that don't return any results.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Prevents the operation from being executed if called before the operation has executed.
+
+
+ Thrown if this method is called after the operation has already executed.
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ When true, this flag indicates that that execution of the operation has been suppressed by
+ one of the interceptors. This can be done before the operation has executed by calling
+ or by setting an to be thrown
+
+
+
+
+ If execution of the operation fails, then this property will contain the exception that was
+ thrown. If the operation was suppressed or did not fail, then this property will always be null.
+
+
+ When an operation fails both this property and the property are set
+ to the exception that was thrown. However, the property can be set or
+ changed by interceptors, while this property will always represent the original exception thrown.
+
+
+
+
+ If this property is set before the operation has executed, then execution of the operation will
+ be suppressed and the set exception will be thrown instead. Otherwise, if the operation fails, then
+ this property will be set to the exception that was thrown. In either case, interceptors that run
+ after the operation can change this property to change the exception that will be thrown, or set this
+ property to null to cause no exception to be thrown at all.
+
+
+ When an operation fails both this property and the property are set
+ to the exception that was thrown. However, the this property can be set or changed by
+ interceptors, while the property will always represent
+ the original exception thrown.
+
+
+
+
+ Set to the status of the after an async operation has finished. Not used for
+ synchronous operations.
+
+
+
+
+ Gets or sets a value containing arbitrary user-specified state information associated with the operation.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Represents contextual information associated with calls to property setters of type on a .
+
+ The type of the target property.
+
+
+
+ Represents contextual information associated with calls to property setters of type .
+
+
+ An instance of this class is passed to the dispatch methods and does not contain mutable information such as
+ the result of the operation. This mutable information is obtained from the
+ that is passed to the interceptors. Instances of this class are publicly immutable. To add contextual information
+ use one of the With... or As... methods to create a new interception context containing the new information.
+
+ The type of the target property.
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the given property value.
+
+ The value that will be assigned to the target property.
+ A new interception context associated with the given property value.
+
+
+
+
+
+
+ Prevents the operation from being executed if called before the operation has executed.
+
+
+ Thrown if this method is called after the operation has already executed.
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ The value that will be assigned to the target property.
+
+
+
+
+ Gets or sets a value containing arbitrary user-specified state information associated with the operation.
+
+
+
+
+ When true, this flag indicates that that execution of the operation has been suppressed by
+ one of the interceptors. This can be done before the operation has executed by calling
+ or by setting an to be thrown
+
+
+
+
+ If execution of the operation fails, then this property will contain the exception that was
+ thrown. If the operation was suppressed or did not fail, then this property will always be null.
+
+
+ When an operation fails both this property and the property are set
+ to the exception that was thrown. However, the property can be set or
+ changed by interceptors, while this property will always represent the original exception thrown.
+
+
+
+
+ If this property is set before the operation has executed, then execution of the operation will
+ be suppressed and the set exception will be thrown instead. Otherwise, if the operation fails, then
+ this property will be set to the exception that was thrown. In either case, interceptors that run
+ after the operation can change this property to change the exception that will be thrown, or set this
+ property to null to cause no exception to be thrown at all.
+
+
+ When an operation fails both this property and the property are set
+ to the exception that was thrown. However, the this property can be set or changed by
+ interceptors, while the property will always represent
+ the original exception thrown.
+
+
+
+
+ Set to the status of the after an async operation has finished. Not used for
+ synchronous operations.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the given property value.
+
+ The value that will be assigned to the target property.
+ A new interception context associated with the given property value.
+
+
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Used for dispatching operations to a such that any
+ registered on will be notified before and after the
+ operation executes.
+ Instances of this class are obtained through the the fluent API.
+
+
+ This class is used internally by Entity Framework when executing commands. It is provided publicly so that
+ code that runs outside of the core EF assemblies can opt-in to command interception/tracing. This is
+ typically done by EF providers that are executing commands on behalf of EF.
+
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+
+ Note that the result of executing the command is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The command on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+
+ Note that the result of executing the command is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The command on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+
+ Note that the result of executing the command is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The command on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+
+ Note that the result of executing the command is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The command on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The cancellation token for the asynchronous operation.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+
+ Note that the result of executing the command is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The command on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The cancellation token for the asynchronous operation.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+
+ Note that the result of executing the command is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The command on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The cancellation token for the asynchronous operation.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Represents contextual information associated with calls into
+ implementations.
+
+
+ An instance of this class is passed to the dispatch methods of
+ and does not contain mutable information such as the result of the operation. This mutable information
+ is obtained from the that is passed to the interceptors.
+ Instances of this class are publicly immutable. To add contextual information use one of the
+ With... or As... methods to create a new interception context containing the new information.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the given .
+
+ The command behavior to associate.
+ A new interception context associated with the given command behavior.
+
+
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ The that will be used or has been used to execute the command with a
+ . This property is only used for
+ and its async counterparts.
+
+
+
+
+ Represents contextual information associated with calls into
+ implementations including the result of the operation.
+
+ The type of the operation's results.
+
+ Instances of this class are publicly immutable for contextual information. To add
+ contextual information use one of the With... or As... methods to create a new
+ interception context containing the new information.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Prevents the operation from being executed if called before the operation has executed.
+
+
+ Thrown if this method is called after the operation has already executed.
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the given .
+
+ The command behavior to associate.
+ A new interception context associated with the given command behavior.
+
+
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ If execution of the operation completes without throwing, then this property will contain
+ the result of the operation. If the operation was suppressed or did not fail, then this property
+ will always contain the default value for the generic type.
+
+
+ When an operation operation completes without throwing both this property and the
+ property are set. However, the property can be set or changed by interceptors,
+ while this property will always represent the actual result returned by the operation, if any.
+
+
+
+
+ If this property is set before the operation has executed, then execution of the operation will
+ be suppressed and the set result will be returned instead. Otherwise, if the operation succeeds, then
+ this property will be set to the returned result. In either case, interceptors that run
+ after the operation can change this property to change the result that will be returned.
+
+
+ When an operation operation completes without throwing both this property and the
+ property are set. However, this property can be set or changed by interceptors, while the
+ property will always represent the actual result returned by the
+ operation, if any.
+
+
+
+
+ When true, this flag indicates that that execution of the operation has been suppressed by
+ one of the interceptors. This can be done before the operation has executed by calling
+ , by setting an to be thrown, or
+ by setting the operation result using .
+
+
+
+
+ Gets or sets a value containing arbitrary user-specified state information associated with the operation.
+
+
+
+
+ If execution of the operation fails, then this property will contain the exception that was
+ thrown. If the operation was suppressed or did not fail, then this property will always be null.
+
+
+ When an operation fails both this property and the property are set
+ to the exception that was thrown. However, the property can be set or
+ changed by interceptors, while this property will always represent the original exception thrown.
+
+
+
+
+ If this property is set before the operation has executed, then execution of the operation will
+ be suppressed and the set exception will be thrown instead. Otherwise, if the operation fails, then
+ this property will be set to the exception that was thrown. In either case, interceptors that run
+ after the operation can change this property to change the exception that will be thrown, or set this
+ property to null to cause no exception to be thrown at all.
+
+
+ When an operation fails both this property and the property are set
+ to the exception that was thrown. However, the this property can be set or changed by
+ interceptors, while the property will always represent
+ the original exception thrown.
+
+
+
+
+ Set to the status of the after an async operation has finished. Not used for
+ synchronous operations.
+
+
+
+
+ Base class that implements . This class is a convenience for
+ use when only one or two methods of the interface actually need to have any implementation.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Represents contextual information associated with calls into
+ implementations.
+
+
+ Instances of this class are publicly immutable for contextual information. To add
+ contextual information use one of the With... or As... methods to create a new
+ interception context containing the new information.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ The original tree created by Entity Framework. Interceptors can change the
+ property to change the tree that will be used, but the
+ will always be the tree created by Entity Framework.
+
+
+
+
+ The command tree that will be used by Entity Framework. This starts as the tree contained in the
+ the property but can be set by interceptors to change
+ the tree that will be used by Entity Framework.
+
+
+
+
+ Gets or sets a value containing arbitrary user-specified state information associated with the operation.
+
+
+
+
+ Used for dispatching operations to a such that any
+ registered on will be notified before and after the
+ operation executes.
+ Instances of this class are obtained through the the fluent API.
+
+
+ This class is used internally by Entity Framework when interacting with .
+ It is provided publicly so that code that runs outside of the core EF assemblies can opt-in to command
+ interception/tracing. This is typically done by EF providers that are executing commands on behalf of EF.
+
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+
+ Note that the result of executing the command is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ getting .
+
+
+ Note that the value of the property is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ setting .
+
+ The connection on which the operation will be executed.
+ Information about the context of the call being made, including the value to be set.
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ getting .
+
+
+ Note that the value of the property is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ getting .
+
+
+ Note that the value of the property is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ getting .
+
+
+ Note that the value of the property is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The cancellation token.
+ A task that represents the asynchronous operation.
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ getting .
+
+
+ Note that the value of the property is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ getting .
+
+
+ Note that the value of the property is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The connection on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Provides access to all dispatchers through the the fluent API.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Provides methods for dispatching to interceptors for
+ interception of methods on .
+
+
+
+
+ Provides methods for dispatching to interceptors for
+ interception of methods on .
+
+
+
+
+ Provides methods for dispatching to interceptors for
+ interception of methods on .
+
+
+
+
+ This is the registration point for interceptors. Interceptors
+ receive notifications when EF performs certain operations such as executing commands against
+ the database. For example, see .
+
+
+
+
+ Registers a new to receive notifications. Note that the interceptor
+ must implement some interface that extends from to be useful.
+
+ The interceptor to add.
+
+
+
+ Removes a registered so that it will no longer receive notifications.
+ If the given interceptor is not registered, then this is a no-op.
+
+ The interceptor to remove.
+
+
+
+ This is the entry point for dispatching to interceptors. This is usually only used internally by
+ Entity Framework but it is provided publicly so that other code can make sure that registered
+ interceptors are called when operations are performed on behalf of EF. For example, EF providers
+ a may make use of this when executing commands.
+
+
+
+
+ Used for dispatching operations to a such that any
+ registered on will be notified before and after the
+ operation executes.
+ Instances of this class are obtained through the the fluent API.
+
+
+ This class is used internally by Entity Framework when interacting with .
+ It is provided publicly so that code that runs outside of the core EF assemblies can opt-in to command
+ interception/tracing. This is typically done by EF providers that are executing commands on behalf of EF.
+
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ getting .
+
+
+ Note that the value of the property is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The transaction on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after
+ getting .
+
+
+ Note that the value of the property is returned by this method. The result is not available
+ in the interception context passed into this method since the interception context is cloned before
+ being passed to interceptors.
+
+ The transaction on which the operation will be executed.
+ Optional information about the context of the call being made.
+ The result of the operation, which may have been modified by interceptors.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+ The transaction on which the operation will be executed.
+ Optional information about the context of the call being made.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+ The transaction on which the operation will be executed.
+ Optional information about the context of the call being made.
+
+
+
+ Sends and
+ to any
+ registered on before/after making a
+ call to .
+
+ The transaction on which the operation will be executed.
+ Optional information about the context of the call being made.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Represents contextual information associated with calls to that don't return any results.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The connection on which the transaction was started.
+ A new interception context that also contains the connection on which the transaction was started.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ The connection on which the transaction was started
+
+
+
+
+ Represents contextual information associated with calls to with return type .
+
+ The return type of the target method.
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Represents contextual information associated with calls to
+ implementations.
+
+
+ Instances of this class are publicly immutable for contextual information. To add
+ contextual information use one of the With... or As... methods to create a new
+ interception context containing the new information.
+
+
+
+
+ Constructs a new with no state.
+
+
+
+
+ Creates a new by copying immutable state from the given
+ interception context. Also see
+
+ The context from which to copy state.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the flag set to true.
+
+ A new interception context associated with the async flag set.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context together with the given .
+
+ The transaction to be used in the invocation.
+ A new interception context associated with the given isolation level.
+
+
+
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+ Creates a new that contains all the contextual information in this
+ interception context with the addition of the given .
+
+ The context to associate.
+ A new interception context associated with the given context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ The that will be used or has been used to enlist a connection.
+
+
+
+
+ An object that implements this interface can be registered with to
+ receive notifications when Entity Framework creates command trees.
+
+
+ Interceptors can also be registered in the config file of the application.
+ See http://go.microsoft.com/fwlink/?LinkId=260883 for more information about Entity Framework configuration.
+
+
+
+
+ This method is called after a new has been created.
+ The tree that is used after interception can be changed by setting
+ while intercepting.
+
+
+ Command trees are created for both queries and insert/update/delete commands. However, query
+ command trees are cached by model which means that command tree creation only happens the
+ first time a query is executed and this notification will only happen at that time
+
+ Contextual information associated with the call.
+
+
+
+ Represents a mapping view.
+
+
+
+
+ Creates a instance having the specified entity SQL.
+
+ A string that specifies the entity SQL.
+
+
+
+ Gets the entity SQL.
+
+
+
+
+ Base abstract class for mapping view cache implementations.
+ Derived classes must have a parameterless constructor if used with .
+
+
+
+
+ Gets a view corresponding to the specified extent.
+
+ An that specifies the extent.
+ A that specifies the mapping view,
+ or null if the extent is not associated with a mapping view.
+
+
+
+ Gets a hash value computed over the mapping closure.
+
+
+
+
+ Specifies the means to create concrete instances.
+
+
+
+
+ Creates a generated view cache instance for the container mapping specified by
+ the names of the mapped containers.
+
+ The name of a container in the conceptual model.
+ The name of a container in the store model.
+
+ A that specifies the generated view cache.
+
+
+
+
+ Defines a custom attribute that specifies the mapping view cache type (subclass of )
+ associated with a context type (subclass of or ).
+ The cache type is instantiated at runtime and used to retrieve pre-generated views in the
+ corresponding context.
+
+
+
+
+ Creates a instance that associates a context type
+ with a mapping view cache type.
+
+
+ A subclass of or .
+
+
+ A subclass of .
+
+
+
+
+ Creates a instance that associates a context type
+ with a mapping view cache type.
+
+
+ A subclass of or .
+
+ The assembly qualified full name of the cache type.
+
+
+
+ The base class for interceptors that handle the transaction operations. Derived classes can be registered using
+ or
+ .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ One of the Initialize methods needs to be called before this instance can be used.
+
+
+
+
+ Initializes this instance using the specified context.
+
+ The context for which transaction operations will be handled.
+
+
+
+ Initializes this instance using the specified context.
+
+ The context for which transaction operations will be handled.
+ The connection to use for the initialization.
+
+ This method is called by migrations. It is important that no action is performed on the
+ specified context that causes it to be initialized.
+
+
+
+
+
+
+
+ Releases the resources used by this transaction handler.
+
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+
+
+ Checks whether the supplied interception context contains the target context
+ or the supplied connection is the same as the one used by the target context.
+
+ A connection.
+ An interception context.
+
+ true if the supplied interception context contains the target context or
+ the supplied connection is the same as the one used by the target context if
+ the supplied interception context doesn't contain any contexts; false otherwise.
+
+
+ Note that calling this method will trigger initialization of any DbContext referenced from the
+
+
+
+
+ When implemented in a derived class returns the script to prepare the database
+ for this transaction handler.
+
+ A script to change the database schema for this transaction handler.
+
+
+
+ Can be implemented in a derived class.
+
+ The connection beginning the transaction.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection that began the transaction.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection being closed.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection that was closed.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection being disposed.
+ Contextual information associated with the call.
+
+
+
+ Can be implemented in a derived class.
+
+ The connection that was disposed.
+ Contextual information associated with the call.
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection being opened.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection that was opened.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The connection.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction being commited.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction that was commited.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction being disposed.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction that was disposed.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction being rolled back.
+ Contextual information associated with the call.
+
+
+
+
+ Can be implemented in a derived class.
+
+ The transaction that was rolled back.
+ Contextual information associated with the call.
+
+
+
+
+ Gets the context.
+
+
+ The for which the transaction operations will be handled.
+
+
+
+
+ Gets the context.
+
+
+ The for which the transaction operations will be handled, could be null.
+
+
+
+
+ Gets the connection.
+
+
+ The for which the transaction operations will be handled.
+
+
+ This connection object is only used to determine whether a particular operation needs to be handled
+ in cases where a context is not available.
+
+
+
+
+ Gets or sets a value indicating whether this transaction handler is disposed.
+
+
+ true if disposed; otherwise, false.
+
+
+
+
+ This class is used by to write and read transaction tracing information
+ from the database.
+ To customize the definition of the transaction table you can derive from
+ this class and override . Derived classes can be registered
+ using .
+
+
+ By default EF will poll the resolved to check wether the database schema is compatible and
+ will try to modify it accordingly if it's not. To disable this check call
+ Database.SetInitializer<TTransactionContext>(null)
where TTransactionContext is the type of the resolved context.
+
+
+
+
+ A DbContext instance represents a combination of the Unit Of Work and Repository patterns such that
+ it can be used to query from a database and group together changes that will then be written
+ back to the store as a unit.
+ DbContext is conceptually similar to ObjectContext.
+
+
+ DbContext is usually used with a derived type that contains properties for
+ the root entities of the model. These sets are automatically initialized when the
+ instance of the derived class is created. This behavior can be modified by applying the
+ attribute to either the entire derived context
+ class, or to individual properties on the class.
+ The Entity Data Model backing the context can be specified in several ways. When using the Code First
+ approach, the properties on the derived context are used to build a model
+ by convention. The protected OnModelCreating method can be overridden to tweak this model. More
+ control over the model used for the Model First approach can be obtained by creating a
+ explicitly from a and passing this model to one of the DbContext constructors.
+ When using the Database First or Model First approach the Entity Data Model can be created using the
+ Entity Designer (or manually through creation of an EDMX file) and then this model can be specified using
+ entity connection string or an object.
+ The connection to the database (including the name of the database) can be specified in several ways.
+ If the parameterless DbContext constructor is called from a derived context, then the name of the derived context
+ is used to find a connection string in the app.config or web.config file. If no connection string is found, then
+ the name is passed to the DefaultConnectionFactory registered on the class. The connection
+ factory then uses the context name as the database name in a default connection string. (This default connection
+ string points to .\SQLEXPRESS on the local machine unless a different DefaultConnectionFactory is registered.)
+ Instead of using the derived context name, the connection/database name can also be specified explicitly by
+ passing the name to one of the DbContext constructors that takes a string. The name can also be passed in
+ the form "name=myname", in which case the name must be found in the config file or an exception will be thrown.
+ Note that the connection found in the app.config or web.config file can be a normal database connection
+ string (not a special Entity Framework connection string) in which case the DbContext will use Code First.
+ However, if the connection found in the config file is a special Entity Framework connection string, then the
+ DbContext will use Database/Model First and the model specified in the connection string will be used.
+ An existing or explicitly created DbConnection can also be used instead of the database/connection name.
+ A can be applied to a class derived from DbContext to set the
+ version of conventions used by the context when it creates a model. If no attribute is applied then the
+ latest version of conventions will be used.
+
+
+
+
+ Interface implemented by objects that can provide an instance.
+ The class implements this interface to provide access to the underlying
+ ObjectContext.
+
+
+
+
+ Gets the object context.
+
+ The object context.
+
+
+
+ Constructs a new context instance using conventions to create the name of the database to
+ which a connection will be made. The by-convention name is the full name (namespace + class name)
+ of the derived context class.
+ See the class remarks for how this is used to create a connection.
+
+
+
+
+ Constructs a new context instance using conventions to create the name of the database to
+ which a connection will be made, and initializes it from the given model.
+ The by-convention name is the full name (namespace + class name) of the derived context class.
+ See the class remarks for how this is used to create a connection.
+
+ The model that will back this context.
+
+
+
+ Constructs a new context instance using the given string as the name or connection string for the
+ database to which a connection will be made.
+ See the class remarks for how this is used to create a connection.
+
+ Either the database name or a connection string.
+
+
+
+ Constructs a new context instance using the given string as the name or connection string for the
+ database to which a connection will be made, and initializes it from the given model.
+ See the class remarks for how this is used to create a connection.
+
+ Either the database name or a connection string.
+ The model that will back this context.
+
+
+
+ Constructs a new context instance using the existing connection to connect to a database.
+ The connection will not be disposed when the context is disposed if
+ is false.
+
+ An existing connection to use for the new context.
+
+ If set to true the connection is disposed when the context is disposed, otherwise the caller must dispose the connection.
+
+
+
+
+ Constructs a new context instance using the existing connection to connect to a database,
+ and initializes it from the given model.
+ The connection will not be disposed when the context is disposed if
+ is false.
+
+ An existing connection to use for the new context.
+ The model that will back this context.
+
+ If set to true the connection is disposed when the context is disposed, otherwise the caller must dispose the connection.
+
+
+
+
+ Constructs a new context instance around an existing ObjectContext.
+
+ An existing ObjectContext to wrap with the new context.
+
+ If set to true the ObjectContext is disposed when the DbContext is disposed, otherwise the caller must dispose the connection.
+
+
+
+
+ This method is called when the model for a derived context has been initialized, but
+ before the model has been locked down and used to initialize the context. The default
+ implementation of this method does nothing, but it can be overridden in a derived class
+ such that the model can be further configured before it is locked down.
+
+
+ Typically, this method is called only once when the first instance of a derived context
+ is created. The model for that context is then cached and is for all further instances of
+ the context in the app domain. This caching can be disabled by setting the ModelCaching
+ property on the given ModelBuidler, but note that this can seriously degrade performance.
+ More control over caching is provided through use of the DbModelBuilder and DbContextFactory
+ classes directly.
+
+ The builder that defines the model for the context being created.
+
+
+
+ Returns a instance for access to entities of the given type in the context
+ and the underlying store.
+
+
+ Note that Entity Framework requires that this method return the same instance each time that it is called
+ for a given context instance and entity type. Also, the non-generic returned by the
+ method must wrap the same underlying query and set of entities. These invariants must
+ be maintained if this method is overridden for anything other than creating test doubles for unit testing.
+ See the class for more details.
+
+ The type entity for which a set should be returned.
+ A set for the given entity type.
+
+
+
+ Returns a non-generic instance for access to entities of the given type in the context
+ and the underlying store.
+
+ The type of entity for which a set should be returned.
+ A set for the given entity type.
+
+ Note that Entity Framework requires that this method return the same instance each time that it is called
+ for a given context instance and entity type. Also, the generic returned by the
+ method must wrap the same underlying query and set of entities. These invariants must
+ be maintained if this method is overridden for anything other than creating test doubles for unit testing.
+ See the class for more details.
+
+
+
+
+ Saves all changes made in this context to the underlying database.
+
+
+ The number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An error occurred sending updates to the database.
+
+ A database command did not affect the expected number of rows. This usually indicates an optimistic
+ concurrency violation; that is, a row has been changed in the database since it was queried.
+
+
+ The save was aborted because validation of entity property values failed.
+
+
+ An attempt was made to use unsupported behavior such as executing multiple asynchronous commands concurrently
+ on the same context instance.
+ The context or connection have been disposed.
+
+ Some error occurred attempting to process entities in the context either before or after sending commands
+ to the database.
+
+
+
+
+ Asynchronously saves all changes made in this context to the underlying database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous save operation.
+ The task result contains the number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An error occurred sending updates to the database.
+
+ A database command did not affect the expected number of rows. This usually indicates an optimistic
+ concurrency violation; that is, a row has been changed in the database since it was queried.
+
+
+ The save was aborted because validation of entity property values failed.
+
+
+ An attempt was made to use unsupported behavior such as executing multiple asynchronous commands concurrently
+ on the same context instance.
+ The context or connection have been disposed.
+
+ Some error occurred attempting to process entities in the context either before or after sending commands
+ to the database.
+
+
+
+
+ Asynchronously saves all changes made in this context to the underlying database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous save operation.
+ The task result contains the number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ Thrown if the context has been disposed.
+
+
+
+ Validates tracked entities and returns a Collection of containing validation results.
+
+ Collection of validation results for invalid entities. The collection is never null and must not contain null values or results for valid entities.
+
+ 1. This method calls DetectChanges() to determine states of the tracked entities unless
+ DbContextConfiguration.AutoDetectChangesEnabled is set to false.
+ 2. By default only Added on Modified entities are validated. The user is able to change this behavior
+ by overriding ShouldValidateEntity method.
+
+
+
+
+ Extension point allowing the user to override the default behavior of validating only
+ added and modified entities.
+
+ DbEntityEntry instance that is supposed to be validated.
+ true to proceed with validation; false otherwise.
+
+
+
+ Extension point allowing the user to customize validation of an entity or filter out validation results.
+ Called by .
+
+ DbEntityEntry instance to be validated.
+
+ User-defined dictionary containing additional info for custom validation. It will be passed to
+
+ and will be exposed as
+
+ . This parameter is optional and can be null.
+
+ Entity validation result. Possibly null when overridden.
+
+
+
+ Gets a object for the given entity providing access to
+ information about the entity and the ability to perform actions on the entity.
+
+ The type of the entity.
+ The entity.
+ An entry for the entity.
+
+
+
+ Gets a object for the given entity providing access to
+ information about the entity and the ability to perform actions on the entity.
+
+ The entity.
+ An entry for the entity.
+
+
+
+ Calls the protected Dispose method.
+
+
+
+
+ Disposes the context. The underlying is also disposed if it was created
+ is by this context or ownership was passed to this context when this context was created.
+ The connection to the database ( object) is also disposed if it was created
+ is by this context or ownership was passed to this context when this context was created.
+
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Creates a Database instance for this context that allows for creation/deletion/existence checks
+ for the underlying database.
+
+
+
+
+ Returns the Entity Framework ObjectContext that is underlying this context.
+
+ Thrown if the context has been disposed.
+
+
+
+ Provides access to features of the context that deal with change tracking of entities.
+
+ An object used to access features that deal with change tracking.
+
+
+
+ Provides access to configuration options for the context.
+
+ An object used to access configuration options.
+
+
+
+ Initializes a new instance of the class.
+
+ The connection used by the context for which the transactions will be recorded.
+
+
+
+
+
+
+ Gets or sets a that can be used to read and write instances.
+
+
+
+
+ A transaction handler that allows to gracefully recover from connection failures
+ during transaction commit by storing transaction tracing information in the database.
+ It needs to be registered by using .
+
+
+ This transaction handler uses to store the transaction information
+ the schema used can be configured by creating a class derived from
+ that overrides DbContext.OnModelCreating(DbModelBuilder) and passing it to the constructor of this class.
+
+
+
+
+ Initializes a new instance of the class using the default .
+
+
+ One of the Initialize methods needs to be called before this instance can be used.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The transaction context factory.
+
+ One of the Initialize methods needs to be called before this instance can be used.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Stores the tracking information for the new transaction to the database in the same transaction.
+
+ The connection that began the transaction.
+ Contextual information associated with the call.
+
+
+
+
+ If there was an exception thrown checks the database for this transaction and rethrows it if not found.
+ Otherwise marks the commit as succeeded and queues the transaction information to be deleted.
+
+ The transaction that was commited.
+ Contextual information associated with the call.
+
+
+
+
+ Stops tracking the transaction that was rolled back.
+
+ The transaction that was rolled back.
+ Contextual information associated with the call.
+
+
+
+
+ Stops tracking the transaction that was disposed.
+
+ The transaction that was disposed.
+ Contextual information associated with the call.
+
+
+
+
+ Removes all the transaction history.
+
+
+ This method should only be invoked when there are no active transactions to remove any leftover history
+ that was not deleted due to catastrophic failures
+
+
+
+
+ Asynchronously removes all the transaction history.
+
+
+ This method should only be invoked when there are no active transactions to remove any leftover history
+ that was not deleted due to catastrophic failures
+
+ A task that represents the asynchronous operation.
+
+
+
+ Asynchronously removes all the transaction history.
+
+
+ This method should only be invoked when there are no active transactions to remove any leftover history
+ that was not deleted due to catastrophic failures
+
+ The cancellation token.
+ A task that represents the asynchronous operation.
+
+
+
+ Adds the specified transaction to the list of transactions that can be removed from the database
+
+ The transaction to be removed from the database.
+
+
+
+ Removes the transactions marked for deletion.
+
+
+
+
+ Asynchronously removes the transactions marked for deletion.
+
+ A task that represents the asynchronous operation.
+
+
+
+ Asynchronously removes the transactions marked for deletion.
+
+ The cancellation token.
+ A task that represents the asynchronous operation.
+
+
+
+ Removes the transactions marked for deletion if their number exceeds .
+
+
+ if set to true will remove all the old transactions even if their number does not exceed .
+
+
+ if set to true the operation will be executed using the associated execution strategy
+
+
+
+
+ Removes the transactions marked for deletion if their number exceeds .
+
+
+ if set to true will remove all the old transactions even if their number does not exceed .
+
+
+ if set to true the operation will be executed using the associated execution strategy
+
+ The cancellation token.
+ A task that represents the asynchronous operation.
+
+
+
+ Gets the associated with the if there is one;
+ otherwise returns null.
+
+ The context
+ The associated .
+
+
+
+ Gets the associated with the if there is one;
+ otherwise returns null.
+
+ The context
+ The associated .
+
+
+
+ Gets the transaction context.
+
+
+ The transaction context.
+
+
+
+
+ Gets the number of transactions to be executed on the context before the transaction log will be cleaned.
+ The default value is 20.
+
+
+
+
+ An implementation of this interface is used to initialize the underlying database when
+ an instance of a derived class is used for the first time.
+ This initialization can conditionally create the database and/or seed it with data.
+ The strategy used is set using the static InitializationStrategy property of the
+ class.
+ The following implementations are provided: ,
+ , .
+
+ The type of the context.
+
+
+
+ Executes the strategy to initialize the database for the given context.
+
+ The context.
+
+
+
+ Rrepresents a transaction
+
+
+
+
+
+
+
+
+
+
+ A unique id assigned to a transaction object.
+
+
+
+
+ The local time when the transaction was started.
+
+
+
+
+ Helper class that is used to configure a parameter.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Creates a new parameter definition to pass Binary data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The maximum allowable length of the array data.
+ Value indicating whether or not all data should be padded to the maximum length.
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Boolean data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Byte data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass DateTime data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The precision of the parameter.
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Decimal data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The numeric precision of the parameter.
+ The numeric scale of the parameter.
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Double data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass GUID data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Single data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Short data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Integer data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Long data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass String data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The maximum allowable length of the string data.
+ Value indicating whether or not all data should be padded to the maximum length.
+ Value indicating whether or not the parameter supports Unicode content.
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass Time data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The precision of the parameter.
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass DateTimeOffset data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The precision of the parameter.
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass geography data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+ Creates a new parameter definition to pass geometry data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Constant value to use as the default value for this parameter.
+ SQL expression used as the default value for this parameter.
+ The name of the parameter.
+ Provider specific data type to use for this parameter.
+ A value indicating whether the parameter is an output parameter.
+ The newly constructed parameter definition.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Creates a shallow copy of the current .
+
+ A shallow copy of the current .
+
+
+
+ Represents altering an existing stored procedure.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ A migration operation that affects stored procedures.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Represents an operation to modify a database schema.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the MigrationOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue"
+ }'.
+
+
+
+
+ Gets additional arguments that may be processed by providers.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets an operation that will revert this operation.
+
+
+
+
+ Gets a value indicating if this operation may result in data loss.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the stored procedure.
+ The body of the stored procedure expressed in SQL.
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the stored procedure.
+
+
+ The name of the stored procedure.
+
+
+
+
+ Gets the body of the stored procedure expressed in SQL.
+
+
+ The body of the stored procedure expressed in SQL.
+
+
+
+
+ Gets the parameters of the stored procedure.
+
+
+ The parameters of the stored procedure.
+
+
+
+
+ Gets a value indicating if this operation may result in data loss. Always returns false.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the stored procedure.
+ The body of the stored procedure expressed in SQL.
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets an operation that will revert this operation.
+ Always returns a .
+
+
+
+
+ Represents changes made to custom annotations on a table.
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the AlterTableOperation class.
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Name of the table on which annotations have changed.
+ The custom annotations on the table that have changed.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Gets the name of the table on which annotations have changed.
+
+
+
+
+ Gets the columns to be included in the table for which annotations have changed.
+
+
+
+
+ Gets the custom annotations that have changed on the table.
+
+
+
+
+ Gets an operation that is the inverse of this one such that annotations will be changed back to how
+ they were before this operation was applied.
+
+
+
+
+
+
+
+ Represents renaming an existing index.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the RenameIndexOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Name of the table the index belongs to.
+ Name of the index to be renamed.
+ New name for the index.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table the index belongs to.
+
+
+
+
+ Gets the name of the index to be renamed.
+
+
+
+
+ Gets the new name for the index.
+
+
+
+
+ Gets an operation that reverts the rename.
+
+
+
+
+
+
+
+ Used when scripting an update database operation to store the operations that would have been performed against the database.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The queries used to determine if this migration needs to be applied to the database.
+ This is used to generate an idempotent SQL script that can be run against a database at any version.
+
+
+
+
+ Adds a migration to this update database operation.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The id of the migration.
+ The individual operations applied by the migration.
+
+
+
+ The queries used to determine if this migration needs to be applied to the database.
+ This is used to generate an idempotent SQL script that can be run against a database at any version.
+
+
+
+
+ Gets the migrations applied during the update database operation.
+
+
+ The migrations applied during the update database operation.
+
+
+
+
+ Gets a value indicating if any of the operations may result in data loss.
+
+
+
+
+ Represents a migration to be applied to the database.
+
+
+
+
+ Gets the id of the migration.
+
+
+ The id of the migration.
+
+
+
+
+ Gets the individual operations applied by this migration.
+
+
+ The individual operations applied by this migration.
+
+
+
+
+ Represents moving a stored procedure to a new schema in the database.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the stored procedure to move.
+ The new schema for the stored procedure.
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the stored procedure to move.
+
+
+ The name of the stored procedure to move.
+
+
+
+
+ Gets the new schema for the stored procedure.
+
+
+ The new schema for the stored procedure.
+
+
+
+
+ Gets an operation that will revert this operation.
+
+
+
+
+ Gets a value indicating if this operation may result in data loss. Always returns false.
+
+
+
+
+ Represents renaming a stored procedure in the database.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the stored procedure to rename.
+ The new name for the stored procedure.
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the stored procedure to rename.
+
+
+ The name of the stored procedure to rename.
+
+
+
+
+ Gets the new name for the stored procedure.
+
+
+ The new name for the stored procedure.
+
+
+
+
+ Gets an operation that will revert this operation.
+
+
+
+
+ Gets a value indicating if this operation may result in data loss. Always returns false.
+
+
+
+
+ Represents a migration operation that can not be performed, possibly because it is not supported by the targeted database provider.
+
+
+
+
+ Gets a value indicating if this operation may result in data loss. Always returns false.
+
+
+
+
+ Represents information about a parameter.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Represents information about a property of an entity.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the PropertyModel class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The data type for this property model.
+ Additional details about the data type. This includes details such as maximum length, nullability etc.
+
+
+
+ Gets the data type for this property model.
+
+
+
+
+ Gets additional details about the data type of this property model.
+ This includes details such as maximum length, nullability etc.
+
+
+
+
+ Gets or sets the name of the property model.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets or sets a provider specific data type to use for this property model.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets or sets the maximum length for this property model.
+ Only valid for array data types.
+
+
+
+
+ Gets or sets the precision for this property model.
+ Only valid for decimal data types.
+
+
+
+
+ Gets or sets the scale for this property model.
+ Only valid for decimal data types.
+
+
+
+
+ Gets or sets a constant value to use as the default value for this property model.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets or sets a SQL expression used as the default value for this property model.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets or sets a value indicating if this property model is fixed length.
+ Only valid for array data types.
+
+
+
+
+ Gets or sets a value indicating if this property model supports Unicode characters.
+ Only valid for textual data types.
+
+
+
+
+ Initializes a new instance of the ParameterModel class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The data type for this parameter.
+
+
+
+ Initializes a new instance of the ParameterModel class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The data type for this parameter.
+ Additional details about the data type. This includes details such as maximum length, nullability etc.
+
+
+
+ Gets or sets a value indicating whether this instance is out parameter.
+
+
+ true if this instance is out parameter; otherwise, false.
+
+
+
+
+ Drops a stored procedure from the database.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the stored procedure to drop.
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the stored procedure to drop.
+
+
+ The name of the stored procedure to drop.
+
+
+
+
+ Gets an operation that will revert this operation.
+ Always returns a .
+
+
+
+
+ Gets a value indicating if this operation may result in data loss. Always returns false.
+
+
+
+
+ Allows configuration to be performed for a lightweight convention based on
+ the entity types in a model.
+
+
+
+
+ Filters the entity types that this convention applies to based on a
+ predicate.
+
+ A function to test each entity type for a condition.
+
+ An instance so that multiple calls can be chained.
+
+
+
+
+ Filters the entity types that this convention applies to based on a predicate
+ while capturing a value to use later during configuration.
+
+ Type of the captured value.
+
+ A function to capture a value for each entity type. If the value is null, the
+ entity type will be filtered out.
+
+
+ An instance so that multiple calls can be chained.
+
+
+
+
+ Allows configuration of the entity types that this convention applies to.
+
+
+ An action that performs configuration against a
+
+ .
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Allows configuration to be performed for a lightweight convention based on
+ the entity types in a model that inherit from a common, specified type.
+
+ The common type of the entity types that this convention applies to.
+
+
+
+ Filters the entity types that this convention applies to based on a
+ predicate.
+
+ A function to test each entity type for a condition.
+
+ An instance so that multiple calls can be chained.
+
+
+
+
+ Filters the entity types that this convention applies to based on a predicate
+ while capturing a value to use later during configuration.
+
+ Type of the captured value.
+
+ A function to capture a value for each entity type. If the value is null, the
+ entity type will be filtered out.
+
+
+ An instance so that multiple calls can be chained.
+
+
+
+
+ Allows configuration of the entity types that this convention applies to.
+
+
+ An action that performs configuration against a
+
+ .
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Allows configuration to be performed for a lightweight convention based on
+ the entity types in a model that inherit from a common, specified type and a
+ captured value.
+
+ The common type of the entity types that this convention applies to.
+ Type of the captured value.
+
+
+
+ Allows configuration of the entity types that this convention applies to.
+
+
+ An action that performs configuration against a
+ using a captured value.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Allows configuration to be performed for a lightweight convention based on
+ the entity types in a model and a captured value.
+
+ Type of the captured value.
+
+
+
+ Allows configuration of the entity types that this convention applies to.
+
+
+ An action that performs configuration against a
+ using a captured value.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Allows configuration to be performed for an entity type in a model.
+ This configuration functionality is available via lightweight conventions.
+
+
+
+
+ Configures the entity set name to be used for this entity type.
+ The entity set name can only be configured for the base type in each set.
+
+ The name of the entity set.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Excludes this entity type from the model so that it will not be mapped to the database.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Changes this entity type to a complex type.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Excludes a property from the model so that it will not be mapped to the database.
+
+ The name of the property to be configured.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect if the property does not exist.
+
+
+
+
+ Excludes a property from the model so that it will not be mapped to the database.
+
+ The property to be configured.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect if the property does not exist.
+
+
+
+
+ Configures a property that is defined on this type.
+
+ The name of the property being configured.
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ The property being configured.
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures the primary key property for this entity type.
+
+ The name of the property to be used as the primary key.
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Configures the primary key property for this entity type.
+
+ The property to be used as the primary key.
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Configures the primary key property(s) for this entity type.
+
+ The names of the properties to be used as the primary key.
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Configures the primary key property(s) for this entity type.
+
+ The properties to be used as the primary key.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured or if any
+ property does not exist.
+
+
+
+
+ Configures the table name that this entity type is mapped to.
+
+ The name of the table.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures the table name that this entity type is mapped to.
+
+ The name of the table.
+ The database schema of the table.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Sets an annotation in the model for the table to which this entity is mapped. The annotation
+ value can later be used when processing the table such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Calling this method will have no effect if the
+ annotation with the given name has already been configured.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures this type to use stored procedures for insert, update and delete.
+ The default conventions for procedure and parameter names will be used.
+
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures this type to use stored procedures for insert, update and delete.
+
+
+ Configuration to override the default conventions for procedure and parameter names.
+
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets the of this entity type.
+
+
+
+
+ Allows configuration to be performed for an entity type in a model.
+ This configuration functionality is available via lightweight conventions.
+
+ A type inherited by the entity type.
+
+
+
+ Configures the entity set name to be used for this entity type.
+ The entity set name can only be configured for the base type in each set.
+
+ The name of the entity set.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Excludes this entity type from the model so that it will not be mapped to the database.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Changes this entity type to a complex type.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Excludes a property from the model so that it will not be mapped to the database.
+
+ The type of the property to be ignored.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Configures a property that is defined on this type.
+
+ The type of the property being configured.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures the primary key property(s) for this entity type.
+
+ The type of the key.
+ A lambda expression representing the property to be used as the primary key. C#: t => t.Id VB.Net: Function(t) t.Id If the primary key is made up of multiple properties then specify an anonymous type including the properties. C#: t => new { t.Id1, t.Id2 } VB.Net: Function(t) New With { t.Id1, t.Id2 }
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures the table name that this entity type is mapped to.
+
+ The name of the table.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures the table name that this entity type is mapped to.
+
+ The name of the table.
+ The database schema of the table.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Sets an annotation in the model for the table to which this entity is mapped. The annotation
+ value can later be used when processing the table such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Calling this method will have no effect if the
+ annotation with the given name has already been configured.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures this type to use stored procedures for insert, update and delete.
+ The default conventions for procedure and parameter names will be used.
+
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures this type to use stored procedures for insert, update and delete.
+
+
+ Configuration to override the default conventions for procedure and parameter names.
+
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets the of this entity type.
+
+
+
+
+ Identifies conventions that can be added to or removed from a instance.
+
+
+ Note that implementations of this interface must be immutable.
+
+
+
+
+ A general purpose class for Code First conventions that read attributes from .NET properties
+ and generate column annotations based on those attributes.
+
+ The type of attribute to discover.
+ The type of annotation that will be created.
+
+
+
+ A convention that doesn't override configuration.
+
+
+
+
+ The derived class can use the default constructor to apply a set rule of that change the model configuration.
+
+
+
+
+ Begins configuration of a lightweight convention that applies to all mapped types in
+ the model.
+
+ A configuration object for the convention.
+
+
+
+ Begins configuration of a lightweight convention that applies to all mapped types in
+ the model that derive from or implement the specified type.
+
+ The type of the entities that this convention will apply to.
+ A configuration object for the convention.
+ This method does not add new types to the model.
+
+
+
+ Begins configuration of a lightweight convention that applies to all properties
+ in the model.
+
+ A configuration object for the convention.
+
+
+
+ Begins configuration of a lightweight convention that applies to all primitive
+ properties of the specified type in the model.
+
+ The type of the properties that the convention will apply to.
+ A configuration object for the convention.
+
+ The convention will apply to both nullable and non-nullable properties of the
+ specified type.
+
+
+
+
+ Constructs a convention that will create column annotations with the given name and
+ using the given factory delegate.
+
+ The name of the annotations to create.
+ A factory for creating the annotation on each column.
+
+
+
+ A general purpose class for Code First conventions that read attributes from .NET types
+ and generate table annotations based on those attributes.
+
+ The type of attribute to discover.
+ The type of annotation that will be created.
+
+
+
+ Constructs a convention that will create table annotations with the given name and
+ using the given factory delegate.
+
+ The name of the annotations to create.
+ A factory for creating the annotation on each table.
+
+
+
+ A convention for discovering attributes on properties and generating
+ column annotations in the model.
+
+
+
+
+ Constructs a new instance of the convention.
+
+
+
+
+ Base class for conventions that process CLR attributes found on primitive properties in the model.
+
+ The type of the attribute to look for.
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Applies this convention to a property that has an attribute of type TAttribute applied.
+
+ The configuration for the property that has the attribute.
+ The attribute.
+
+
+
+ Base class for conventions that process CLR attributes found on properties of types in the model.
+
+
+ Note that the derived convention will be applied for any non-static property on the mapped type that has
+ the specified attribute, even if it wasn't included in the model.
+
+ The type of the attribute to look for.
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Applies this convention to a property that has an attribute of type TAttribute applied.
+
+ The member info for the property that has the attribute.
+ The configuration for the class that contains the property.
+ The attribute.
+
+
+
+ Base class for conventions that process CLR attributes found in the model.
+
+ The type of the attribute to look for.
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Applies this convention to a class that has an attribute of type TAttribute applied.
+
+ The configuration for the class that contains the property.
+ The attribute.
+
+
+
+ Used to configure a property in a mapping fragment.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the name of the database column used to store the property, in a mapping fragment.
+
+ The name of the column.
+ The same PropertyMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the database column used to store the property. The annotation
+ value can later be used when processing the column such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same PropertyMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+ Convention to introduce indexes for foreign keys.
+
+
+
+
+ A convention that operates on the database section of the model after the model is created.
+
+ The type of metadata item that this convention operates on.
+
+
+
+ Applies this convention to an item in the model.
+
+ The item to apply the convention to.
+ The model.
+
+
+
+
+
+
+ A convention that operates on the conceptual section of the model after the model is created.
+
+ The type of metadata item that this convention operates on.
+
+
+
+ Applies this convention to an item in the model.
+
+ The item to apply the convention to.
+ The model.
+
+
+
+ Useful extension methods for use with Entity Framework LINQ queries.
+
+
+
+
+ Specifies the related objects to include in the query results.
+
+
+ This extension method calls the Include(String) method of the source object,
+ if such a method exists. If the source does not have a matching method,
+ then this method does nothing. The , ,
+ and types all have an appropriate Include method to call.
+ Paths are all-inclusive. For example, if an include call indicates Include("Orders.OrderLines"), not only will
+ OrderLines be included, but also Orders. When you call the Include method, the query path is only valid on
+ the returned instance of the . Other instances of
+ and the object context itself are not affected. Because the Include method returns the query object,
+ you can call this method multiple times on an to specify multiple paths for the query.
+
+ The type of entity being queried.
+
+ The source on which to call Include.
+
+ The dot-separated list of related objects to return in the query results.
+
+ A new with the defined query path.
+
+
+
+
+ Specifies the related objects to include in the query results.
+
+
+ This extension method calls the Include(String) method of the source object,
+ if such a method exists. If the source does not have a matching method,
+ then this method does nothing. The , ,
+ and types all have an appropriate Include method to call.
+ Paths are all-inclusive. For example, if an include call indicates Include("Orders.OrderLines"), not only will
+ OrderLines be included, but also Orders. When you call the Include method, the query path is only valid on
+ the returned instance of the . Other instances of
+ and the object context itself are not affected. Because the Include method returns the query object,
+ you can call this method multiple times on an to specify multiple paths for the query.
+
+
+ The source on which to call Include.
+
+ The dot-separated list of related objects to return in the query results.
+
+ A new with the defined query path.
+
+
+
+
+ Specifies the related objects to include in the query results.
+
+
+ The path expression must be composed of simple property access expressions together with calls to Select for
+ composing additional includes after including a collection proprty. Examples of possible include paths are:
+ To include a single reference: query.Include(e => e.Level1Reference)
+ To include a single collection: query.Include(e => e.Level1Collection)
+ To include a reference and then a reference one level down: query.Include(e => e.Level1Reference.Level2Reference)
+ To include a reference and then a collection one level down: query.Include(e => e.Level1Reference.Level2Collection)
+ To include a collection and then a reference one level down: query.Include(e => e.Level1Collection.Select(l1 => l1.Level2Reference))
+ To include a collection and then a collection one level down: query.Include(e => e.Level1Collection.Select(l1 => l1.Level2Collection))
+ To include a collection and then a reference one level down: query.Include(e => e.Level1Collection.Select(l1 => l1.Level2Reference))
+ To include a collection and then a collection one level down: query.Include(e => e.Level1Collection.Select(l1 => l1.Level2Collection))
+ To include a collection, a reference, and a reference two levels down: query.Include(e => e.Level1Collection.Select(l1 => l1.Level2Reference.Level3Reference))
+ To include a collection, a collection, and a reference two levels down: query.Include(e => e.Level1Collection.Select(l1 => l1.Level2Collection.Select(l2 => l2.Level3Reference)))
+ This extension method calls the Include(String) method of the source IQueryable object, if such a method exists.
+ If the source IQueryable does not have a matching method, then this method does nothing.
+ The Entity Framework ObjectQuery, ObjectSet, DbQuery, and DbSet types all have an appropriate Include method to call.
+ When you call the Include method, the query path is only valid on the returned instance of the IQueryable<T>. Other
+ instances of IQueryable<T> and the object context itself are not affected. Because the Include method returns the
+ query object, you can call this method multiple times on an IQueryable<T> to specify multiple paths for the query.
+
+ The type of entity being queried.
+ The type of navigation property being included.
+ The source IQueryable on which to call Include.
+ A lambda expression representing the path to include.
+
+ A new IQueryable<T> with the defined query path.
+
+
+
+
+ Returns a new query where the entities returned will not be cached in the
+ or . This method works by calling the AsNoTracking method of the
+ underlying query object. If the underlying query object does not have an AsNoTracking method,
+ then calling this method will have no affect.
+
+ The element type.
+ The source query.
+ A new query with NoTracking applied, or the source query if NoTracking is not supported.
+
+
+
+ Returns a new query where the entities returned will not be cached in the
+ or . This method works by calling the AsNoTracking method of the
+ underlying query object. If the underlying query object does not have an AsNoTracking method,
+ then calling this method will have no affect.
+
+ The source query.
+ A new query with NoTracking applied, or the source query if NoTracking is not supported.
+
+
+
+ Returns a new query that will stream the results instead of buffering. This method works by calling
+ the AsStreaming method of the underlying query object. If the underlying query object does not have
+ an AsStreaming method, then calling this method will have no affect.
+
+
+ The type of the elements of .
+
+
+ An to apply AsStreaming to.
+
+ A new query with AsStreaming applied, or the source query if AsStreaming is not supported.
+
+
+
+ Returns a new query that will stream the results instead of buffering. This method works by calling
+ the AsStreaming method of the underlying query object. If the underlying query object does not have
+ an AsStreaming method, then calling this method will have no affect.
+
+
+ An to apply AsStreaming to.
+
+ A new query with AsStreaming applied, or the source query if AsStreaming is not supported.
+
+
+
+ Enumerates the query such that for server queries such as those of ,
+
+ ,
+ , and others the results of the query will be loaded into the associated
+
+ ,
+ or other cache on the client.
+ This is equivalent to calling ToList and then throwing away the list without the overhead of actually creating the list.
+
+ The source query.
+
+
+
+ Asynchronously enumerates the query such that for server queries such as those of ,
+
+ ,
+ , and others the results of the query will be loaded into the associated
+
+ ,
+ or other cache on the client.
+ This is equivalent to calling ToList and then throwing away the list without the overhead of actually creating the list.
+
+ The source query.
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Asynchronously enumerates the query such that for server queries such as those of ,
+
+ ,
+ , and others the results of the query will be loaded into the associated
+
+ ,
+ or other cache on the client.
+ This is equivalent to calling ToList and then throwing away the list without the overhead of actually creating the list.
+
+ The source query.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Asynchronously enumerates the query results and performs the specified action on each element.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ An to enumerate.
+
+ The action to perform on each element.
+ A task that represents the asynchronous operation.
+
+
+
+ Asynchronously enumerates the query results and performs the specified action on each element.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ An to enumerate.
+
+ The action to perform on each element.
+
+ A to observe while waiting for the task to complete.
+
+ A task that represents the asynchronous operation.
+
+
+
+ Asynchronously enumerates the query results and performs the specified action on each element.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to enumerate.
+
+ The action to perform on each element.
+ A task that represents the asynchronous operation.
+
+
+
+ Asynchronously enumerates the query results and performs the specified action on each element.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to enumerate.
+
+ The action to perform on each element.
+
+ A to observe while waiting for the task to complete.
+
+ A task that represents the asynchronous operation.
+
+
+
+ Creates a from an by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ An to create a from.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains elements from the input sequence.
+
+
+
+
+ Creates a from an by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ An to create a from.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains elements from the input sequence.
+
+
+
+
+ Creates a from an by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to create a from.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains elements from the input sequence.
+
+
+
+
+ Creates a from an by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to create a list from.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains elements from the input sequence.
+
+
+
+
+ Creates an array from an by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to create an array from.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an array that contains elements from the input sequence.
+
+
+
+
+ Creates an array from an by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to create an array from.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an array that contains elements from the input sequence.
+
+
+
+
+ Creates a from an by enumerating it asynchronously
+ according to a specified key selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the key returned by .
+
+
+ An to create a from.
+
+ A function to extract a key from each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains selected keys and values.
+
+
+
+
+ Creates a from an by enumerating it asynchronously
+ according to a specified key selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the key returned by .
+
+
+ An to create a from.
+
+ A function to extract a key from each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains selected keys and values.
+
+
+
+
+ Creates a from an by enumerating it asynchronously
+ according to a specified key selector function and a comparer.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the key returned by .
+
+
+ An to create a from.
+
+ A function to extract a key from each element.
+
+ An to compare keys.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains selected keys and values.
+
+
+
+
+ Creates a from an by enumerating it asynchronously
+ according to a specified key selector function and a comparer.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the key returned by .
+
+
+ An to create a from.
+
+ A function to extract a key from each element.
+
+ An to compare keys.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains selected keys and values.
+
+
+
+
+ Creates a from an by enumerating it asynchronously
+ according to a specified key selector and an element selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the key returned by .
+
+
+ The type of the value returned by .
+
+
+ An to create a from.
+
+ A function to extract a key from each element.
+ A transform function to produce a result element value from each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains values of type
+ selected from the input sequence.
+
+
+
+
+ Creates a from an by enumerating it asynchronously
+ according to a specified key selector and an element selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the key returned by .
+
+
+ The type of the value returned by .
+
+
+ An to create a from.
+
+ A function to extract a key from each element.
+ A transform function to produce a result element value from each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains values of type
+ selected from the input sequence.
+
+
+
+
+ Creates a from an by enumerating it asynchronously
+ according to a specified key selector function, a comparer, and an element selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the key returned by .
+
+
+ The type of the value returned by .
+
+
+ An to create a from.
+
+ A function to extract a key from each element.
+ A transform function to produce a result element value from each element.
+
+ An to compare keys.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains values of type
+ selected from the input sequence.
+
+
+
+
+ Creates a from an by enumerating it asynchronously
+ according to a specified key selector function, a comparer, and an element selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the key returned by .
+
+
+ The type of the value returned by .
+
+
+ An to create a from.
+
+ A function to extract a key from each element.
+ A transform function to produce a result element value from each element.
+
+ An to compare keys.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains values of type
+ selected from the input sequence.
+
+
+
+
+ Asynchronously returns the first element of a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the first element of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the first element in .
+
+
+ is null.
+
+
+ doesn't implement .
+
+ The source sequence is empty.
+
+
+
+ Asynchronously returns the first element of a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the first element of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the first element in .
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+ The source sequence is empty.
+
+
+
+ Asynchronously returns the first element of a sequence that satisfies a specified condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the first element of.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the first element in that passes the test in
+ .
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ No element satisfies the condition in
+
+ .
+
+
+
+
+ Asynchronously returns the first element of a sequence that satisfies a specified condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the first element of.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the first element in that passes the test in
+ .
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ No element satisfies the condition in
+
+ .
+
+
+
+
+ Asynchronously returns the first element of a sequence, or a default value if the sequence contains no elements.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the first element of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains default ( ) if
+ is empty; otherwise, the first element in .
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously returns the first element of a sequence, or a default value if the sequence contains no elements.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the first element of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains default ( ) if
+ is empty; otherwise, the first element in .
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously returns the first element of a sequence that satisfies a specified condition
+ or a default value if no such element is found.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the first element of.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains default ( ) if
+ is empty or if no element passes the test specified by ; otherwise, the first
+ element in that passes the test specified by .
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously returns the first element of a sequence that satisfies a specified condition
+ or a default value if no such element is found.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the first element of.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains default ( ) if
+ is empty or if no element passes the test specified by ; otherwise, the first
+ element in that passes the test specified by .
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ has more than one element.
+
+
+
+
+ Asynchronously returns the only element of a sequence, and throws an exception
+ if there is not exactly one element in the sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the input sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+ The source sequence is empty.
+
+
+
+ Asynchronously returns the only element of a sequence, and throws an exception
+ if there is not exactly one element in the sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the input sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ has more than one element.
+
+ The source sequence is empty.
+
+
+
+ Asynchronously returns the only element of a sequence that satisfies a specified condition,
+ and throws an exception if more than one such element exists.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the the single element of.
+
+ A function to test an element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the input sequence that satisfies the condition in
+ .
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ No element satisfies the condition in
+
+ .
+
+
+ More than one element satisfies the condition in
+
+ .
+
+
+
+
+ Asynchronously returns the only element of a sequence that satisfies a specified condition,
+ and throws an exception if more than one such element exists.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+ A function to test an element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the input sequence that satisfies the condition in
+ .
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ No element satisfies the condition in
+
+ .
+
+
+ More than one element satisfies the condition in
+
+ .
+
+
+
+
+ Asynchronously returns the only element of a sequence, or a default value if the sequence is empty;
+ this method throws an exception if there is more than one element in the sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the input sequence, or default ()
+ if the sequence contains no elements.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ has more than one element.
+
+
+
+
+ Asynchronously returns the only element of a sequence, or a default value if the sequence is empty;
+ this method throws an exception if there is more than one element in the sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the input sequence, or default ()
+ if the sequence contains no elements.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ has more than one element.
+
+
+
+
+ Asynchronously returns the only element of a sequence that satisfies a specified condition or
+ a default value if no such element exists; this method throws an exception if more than one element
+ satisfies the condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+ A function to test an element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the input sequence that satisfies the condition in
+ , or default ( ) if no such element is found.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously returns the only element of a sequence that satisfies a specified condition or
+ a default value if no such element exists; this method throws an exception if more than one element
+ satisfies the condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+ A function to test an element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the input sequence that satisfies the condition in
+ , or default ( ) if no such element is found.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously determines whether a sequence contains a specified element by using the default equality comparer.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+ The object to locate in the sequence.
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the input sequence contains the specified value; otherwise, false.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously determines whether a sequence contains a specified element by using the default equality comparer.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to return the single element of.
+
+ The object to locate in the sequence.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the input sequence contains the specified value; otherwise, false.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously determines whether a sequence contains any elements.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to check for being empty.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the source sequence contains any elements; otherwise, false.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously determines whether a sequence contains any elements.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An to check for being empty.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the source sequence contains any elements; otherwise, false.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously determines whether any element of a sequence satisfies a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An whose elements to test for a condition.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains true if any elements in the source sequence pass the test in the specified predicate; otherwise, false.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously determines whether any element of a sequence satisfies a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An whose elements to test for a condition.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if any elements in the source sequence pass the test in the specified predicate; otherwise, false.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously determines whether all the elements of a sequence satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An whose elements to test for a condition.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains true if every element of the source sequence passes the test in the specified predicate; otherwise, false.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously determines whether all the elements of a sequence satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An whose elements to test for a condition.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if every element of the source sequence passes the test in the specified predicate; otherwise, false.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously returns the number of elements in a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to be counted.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the input sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns the number of elements in a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to be counted.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the input sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns the number of elements in a sequence that satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to be counted.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the sequence that satisfy the condition in the predicate function.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ that satisfy the condition in the predicate function
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns the number of elements in a sequence that satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to be counted.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the sequence that satisfy the condition in the predicate function.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ that satisfy the condition in the predicate function
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns an that represents the total number of elements in a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to be counted.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the input sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns an that represents the total number of elements in a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to be counted.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the input sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns an that represents the number of elements in a sequence
+ that satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to be counted.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the sequence that satisfy the condition in the predicate function.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ that satisfy the condition in the predicate function
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns an that represents the number of elements in a sequence
+ that satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to be counted.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the sequence that satisfy the condition in the predicate function.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ that satisfy the condition in the predicate function
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns the minimum value of a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to determine the minimum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the minimum value in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously returns the minimum value of a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to determine the minimum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the minimum value in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously invokes a projection function on each element of a sequence and returns the minimum resulting value.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the value returned by the function represented by .
+
+
+ An that contains the elements to determine the minimum of.
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the minimum value in the sequence.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously invokes a projection function on each element of a sequence and returns the minimum resulting value.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the value returned by the function represented by .
+
+
+ An that contains the elements to determine the minimum of.
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the minimum value in the sequence.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously returns the maximum value of a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to determine the maximum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the maximum value in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously returns the maximum value of a sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ An that contains the elements to determine the maximum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the maximum value in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously invokes a projection function on each element of a sequence and returns the maximum resulting value.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the value returned by the function represented by .
+
+
+ An that contains the elements to determine the maximum of.
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the maximum value in the sequence.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously invokes a projection function on each element of a sequence and returns the maximum resulting value.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ The type of the value returned by the function represented by .
+
+
+ An that contains the elements to determine the maximum of.
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the maximum value in the sequence.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the sum of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the values in the sequence.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the sum of the sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+
+ A sequence of values of type .
+
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the sum of the projected values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+ The number of elements in
+
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A sequence of nullable values to calculate the average of.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+ contains no elements.
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Asynchronously computes the average of a sequence of nullable values that is obtained
+ by invoking a projection function on each element of the input sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the elements of .
+
+ A sequence of values to calculate the average of.
+ A projection function to apply to each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the average of the sequence of values.
+
+
+
+ or
+
+ is
+ null
+ .
+
+
+
+ doesn't implement
+
+ .
+
+
+
+
+ Bypasses a specified number of elements in a sequence and then returns the remaining elements.
+
+ The type of the elements of source.
+ A sequence to return elements from.
+ An expression that evaluates to the number of elements to skip.
+ A sequence that contains elements that occur after the specified index in the
+ input sequence.
+
+
+
+ Returns a specified number of contiguous elements from the start of a sequence.
+
+ The type of the elements of source.
+ The sequence to return elements from.
+ An expression that evaluates to the number of elements
+ to return.
+ A sequence that contains the specified number of elements from the
+ start of the input sequence.
+
+
+
+ Controls the transaction creation behavior while executing a database command or query.
+
+
+
+
+ If no transaction is present then a new transaction will be used for the operation.
+
+
+
+
+ If an existing transaction is present then use it, otherwise execute the command or query without a transaction.
+
+
+
+
+ Specifies a structural type mapping.
+
+
+
+
+ Adds a property mapping.
+
+ The property mapping to be added.
+
+
+
+ Removes a property mapping.
+
+ The property mapping to be removed.
+
+
+
+ Adds a property mapping condition.
+
+ The property mapping condition to be added.
+
+
+
+ Removes a property mapping condition.
+
+ The property mapping condition to be removed.
+
+
+
+ Gets a read-only collection of property mappings.
+
+
+
+
+ Gets a read-only collection of property mapping conditions.
+
+
+
+
+ Represents the base item class for all the metadata
+
+
+ Represents the base item class for all the metadata
+
+
+
+
+ Adds or updates an annotation with the specified name and value.
+
+
+ If an annotation with the given name already exists then the value of that annotation
+ is updated to the given value. If the given value is null then the annotation will be
+ removed.
+
+ The name of the annotation property.
+ The value of the annotation property.
+
+
+
+ Removes an annotation with the specified name.
+
+ The name of the annotation property.
+ true if an annotation was removed; otherwise, false.
+
+
+
+ Returns a conceptual model built-in type that matches one of the
+
+ values.
+
+
+ An object that represents the built-in type in the EDM.
+
+
+ One of the values.
+
+
+
+ Returns the list of the general facet descriptions for a specified type.
+
+ A object that represents the list of the general facet descriptions for a specified type.
+
+
+
+ Gets the built-in type kind for this type.
+
+ A object that represents the built-in type kind for this type.
+
+
+
+ Gets the list of properties of the current type.
+
+ A collection of type that contains the list of properties of the current type.
+
+
+
+ Gets or sets the documentation associated with this type.
+
+ A object that represents the documentation on this type.
+
+
+
+
+ Indicates that the given method is a proxy for an EDM function.
+
+
+ Note that this attribute has been replaced by the starting with EF6.
+
+
+
+
+ Indicates that the given method is a proxy for an EDM function.
+
+
+ Note that this class was called EdmFunctionAttribute in some previous versions of Entity Framework.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The namespace of the mapped-to function.
+ The name of the mapped-to function.
+
+
+ The namespace of the mapped-to function.
+ The namespace of the mapped-to function.
+
+
+ The name of the mapped-to function.
+ The name of the mapped-to function.
+
+
+
+ Creates a new DbFunctionAttribute instance.
+
+ The namespace name of the EDM function represented by the attributed method.
+ The function name of the EDM function represented by the attributed method.
+
+
+
+ Provides common language runtime (CLR) methods that expose EDM canonical functions
+ for use in or LINQ to Entities queries.
+
+
+ Note that these functions have been moved to the class starting with EF6.
+ The functions are retained here only to help in the migration of older EF apps to EF6.
+
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Left EDM function to return a given
+ number of the leftmost characters in a string.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input string.
+ The number of characters to return
+ A string containing the number of characters asked for from the left of the input string.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Right EDM function to return a given
+ number of the rightmost characters in a string.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input string.
+ The number of characters to return
+ A string containing the number of characters asked for from the right of the input string.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Reverse EDM function to return a given
+ string with the order of the characters reversed.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input string.
+ The input string with the order of the characters reversed.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical GetTotalOffsetMinutes EDM function to
+ return the number of minutes that the given date/time is offset from UTC. This is generally between +780
+ and -780 (+ or - 13 hrs).
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The date/time value to use.
+ The offset of the input from UTC.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical TruncateTime EDM function to return
+ the given date with the time portion cleared.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The date/time value to use.
+ The input date with the time portion cleared.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical TruncateTime EDM function to return
+ the given date with the time portion cleared.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The date/time value to use.
+ The input date with the time portion cleared.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical CreateDateTime EDM function to
+ create a new object.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The year.
+ The month (1-based).
+ The day (1-based).
+ The hours.
+ The minutes.
+ The seconds, including fractional parts of the seconds if desired.
+ The new date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical CreateDateTimeOffset EDM function to
+ create a new object.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The year.
+ The month (1-based).
+ The day (1-based).
+ The hours.
+ The minutes.
+ The seconds, including fractional parts of the seconds if desired.
+ The time zone offset part of the new date.
+ The new date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical CreateTime EDM function to
+ create a new object.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The hours.
+ The minutes.
+ The seconds, including fractional parts of the seconds if desired.
+ The new time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddYears EDM function to
+ add the given number of years to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of years to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddYears EDM function to
+ add the given number of years to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of years to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMonths EDM function to
+ add the given number of months to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of months to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMonths EDM function to
+ add the given number of months to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of months to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddDays EDM function to
+ add the given number of days to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of days to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddDays EDM function to
+ add the given number of days to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of days to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddHours EDM function to
+ add the given number of hours to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of hours to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddHours EDM function to
+ add the given number of hours to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of hours to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddHours EDM function to
+ add the given number of hours to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of hours to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMinutes EDM function to
+ add the given number of minutes to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of minutes to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMinutes EDM function to
+ add the given number of minutes to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of minutes to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMinutes EDM function to
+ add the given number of minutes to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of minutes to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddSeconds EDM function to
+ add the given number of seconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of seconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddSeconds EDM function to
+ add the given number of seconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of seconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddSeconds EDM function to
+ add the given number of seconds to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of seconds to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMilliseconds EDM function to
+ add the given number of milliseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of milliseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMilliseconds EDM function to
+ add the given number of milliseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of milliseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMilliseconds EDM function to
+ add the given number of milliseconds to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of milliseconds to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMicroseconds EDM function to
+ add the given number of microseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of microseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMicroseconds EDM function to
+ add the given number of microseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of microseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMicroseconds EDM function to
+ add the given number of microseconds to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of microseconds to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddNanoseconds EDM function to
+ add the given number of nanoseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of nanoseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddNanoseconds EDM function to
+ add the given number of nanoseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of nanoseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddNanoseconds EDM function to
+ add the given number of nanoseconds to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of nanoseconds to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffYears EDM function to
+ calculate the number of years between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of years between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffYears EDM function to
+ calculate the number of years between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of years between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMonths EDM function to
+ calculate the number of months between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of months between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMonths EDM function to
+ calculate the number of months between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of months between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffDays EDM function to
+ calculate the number of days between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of days between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffDays EDM function to
+ calculate the number of days between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of days between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffHours EDM function to
+ calculate the number of hours between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of hours between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffHours EDM function to
+ calculate the number of hours between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of hours between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffHours EDM function to
+ calculate the number of hours between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of hours between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMinutes EDM function to
+ calculate the number of minutes between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of minutes between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMinutes EDM function to
+ calculate the number of minutes between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of minutes between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMinutes EDM function to
+ calculate the number of minutes between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of minutes between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffSeconds EDM function to
+ calculate the number of seconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of seconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffSeconds EDM function to
+ calculate the number of seconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of seconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffSeconds EDM function to
+ calculate the number of seconds between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of seconds between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMilliseconds EDM function to
+ calculate the number of milliseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of milliseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMilliseconds EDM function to
+ calculate the number of milliseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of milliseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMilliseconds EDM function to
+ calculate the number of milliseconds between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of milliseconds between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMicroseconds EDM function to
+ calculate the number of microseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of microseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMicroseconds EDM function to
+ calculate the number of microseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of microseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMicroseconds EDM function to
+ calculate the number of microseconds between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of microseconds between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffNanoseconds EDM function to
+ calculate the number of nanoseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of nanoseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffNanoseconds EDM function to
+ calculate the number of nanoseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of nanoseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffNanoseconds EDM function to
+ calculate the number of nanoseconds between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of nanoseconds between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Truncate EDM function to
+ truncate the given value to the number of specified digits.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The value to truncate.
+ The number of digits to preserve.
+ The truncated value.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Truncate EDM function to
+ truncate the given value to the number of specified digits.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The value to truncate.
+ The number of digits to preserve.
+ The truncated value.
+
+
+
+ When used as part of a LINQ to Entities query, this method acts as an operator that ensures the input
+ is treated as a Unicode string.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function impacts the way the LINQ query is translated to a query that can be run in the database.
+
+ The input string.
+ The input string treated as a Unicode string.
+
+
+
+ When used as part of a LINQ to Entities query, this method acts as an operator that ensures the input
+ is treated as a non-Unicode string.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function impacts the way the LINQ query is translated to a query that can be run in the database.
+
+ The input string.
+ The input string treated as a non-Unicode string.
+
+
+
+ Options for query execution.
+
+
+
+
+ Creates a new instance of .
+
+ Merge option to use for entity results.
+
+
+
+ Creates a new instance of .
+
+ Merge option to use for entity results.
+ Whether the query is streaming or buffering.
+
+
+ Determines whether the specified objects are equal.
+ true if the two objects are equal; otherwise, false.
+ The left object to compare.
+ The right object to compare.
+
+
+
+ Determines whether the specified objects are not equal.
+
+ The left object to compare.
+ The right object to compare.
+ true if the two objects are not equal; otherwise, false.
+
+
+
+
+
+
+
+
+
+ Merge option to use for entity results.
+
+
+
+
+ Whether the query is streaming or buffering.
+
+
+
+
+ DataRecord interface supporting structured types and rich metadata information.
+
+
+
+
+ Gets a object with the specified index.
+
+
+ A object.
+
+ The index of the row.
+
+
+
+ Returns nested readers as objects.
+
+
+ Nested readers as objects.
+
+ The ordinal of the column.
+
+
+
+ Gets for this
+
+ .
+
+
+ A object.
+
+
+
+
+ DataRecordInfo class providing a simple way to access both the type information and the column information.
+
+
+
+
+ Initializes a new object for a specific type with an enumerable collection of data fields.
+
+
+ The metadata for the type represented by this object, supplied by
+
+ .
+
+
+ An enumerable collection of objects that represent column information.
+
+
+
+
+ Gets for this
+
+ object.
+
+
+ A object.
+
+
+
+
+ Gets type info for this object as a object.
+
+
+ A value.
+
+
+
+
+ A prepared command definition, can be cached and reused to avoid
+ repreparing a command.
+
+
+
+
+ Initializes a new instance of the class using the supplied
+
+ .
+
+
+ The supplied .
+
+ method used to clone the
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Creates and returns a object that can be executed.
+
+ The command for database.
+
+
+
+ Metadata Interface for all CLR types types
+
+
+
+
+ Value to pass to GetInformation to get the StoreSchemaDefinition
+
+
+
+
+ Value to pass to GetInformation to get the StoreSchemaMapping
+
+
+
+
+ Value to pass to GetInformation to get the ConceptualSchemaDefinition
+
+
+
+
+ Value to pass to GetInformation to get the StoreSchemaDefinitionVersion3
+
+
+
+
+ Value to pass to GetInformation to get the StoreSchemaMappingVersion3
+
+
+
+
+ Value to pass to GetInformation to get the ConceptualSchemaDefinitionVersion3
+
+
+
+
+ Name of the MaxLength Facet
+
+
+
+
+ Name of the Unicode Facet
+
+
+
+
+ Name of the FixedLength Facet
+
+
+
+
+ Name of the Precision Facet
+
+
+
+
+ Name of the Scale Facet
+
+
+
+
+ Name of the Nullable Facet
+
+
+
+
+ Name of the DefaultValue Facet
+
+
+
+
+ Name of the Collation Facet
+
+
+
+
+ Name of the SRID Facet
+
+
+
+
+ Name of the IsStrict Facet
+
+
+
+ When overridden in a derived class, returns the set of primitive types supported by the data source.
+ The set of types supported by the data source.
+
+
+ When overridden in a derived class, returns a collection of EDM functions supported by the provider manifest.
+ A collection of EDM functions.
+
+
+ Returns the FacetDescription objects for a particular type.
+ The FacetDescription objects for the specified EDM type.
+ The EDM type to return the facet description for.
+
+
+ When overridden in a derived class, this method maps the specified storage type and a set of facets for that type to an EDM type.
+
+ The instance that describes an EDM type and a set of facets for that type.
+
+ The TypeUsage instance that describes a storage type and a set of facets for that type to be mapped to the EDM type.
+
+
+ When overridden in a derived class, this method maps the specified EDM type and a set of facets for that type to a storage type.
+ The TypeUsage instance that describes a storage type and a set of facets for that type.
+ The TypeUsage instance that describes the EDM type and a set of facets for that type to be mapped to a storage type.
+
+
+ When overridden in a derived class, this method returns provider-specific information.
+ The XmlReader object that represents the mapping to the underlying data store catalog.
+ The type of the information to return.
+
+
+ Gets the provider-specific information.
+ The provider-specific information.
+ The type of the information to return.
+
+
+ Indicates if the provider supports escaping strings to be used as patterns in a Like expression.
+ True if this provider supports escaping strings to be used as patterns in a Like expression; otherwise, false.
+ If the provider supports escaping, the character that would be used as the escape character.
+
+
+ Provider writers should override this method to return the argument with the wildcards and the escape character escaped. This method is only used if SupportsEscapingLikeArgument returns true.
+ The argument with the wildcards and the escape character escaped.
+ The argument to be escaped.
+
+
+
+ Returns a boolean that specifies whether the provider can handle expression trees
+ containing instances of DbInExpression.
+ The default implementation returns false for backwards compatibility. Derived classes can override this method.
+
+
+ false
+
+
+
+
+ Returns a boolean that specifies whether the provider can process expression trees not having DbProjectExpression
+ nodes directly under both Left and Right sides of DbUnionAllExpression and DbIntersectExpression
+
+
+ false
+
+
+
+ Gets the namespace used by this provider manifest.
+ The namespace used by this provider manifest.
+
+
+
+ The factory for building command definitions; use the type of this object
+ as the argument to the IServiceProvider.GetService method on the provider
+ factory;
+
+
+
+
+ Constructs an EF provider that will use the obtained from
+ the app domain Singleton for resolving EF dependencies such
+ as the instance to use.
+
+
+
+
+ Registers a handler to process non-error messages coming from the database provider.
+
+ The connection to receive information for.
+ The handler to process messages.
+
+
+
+ Create a Command Definition object given a command tree.
+
+ command tree for the statement
+ an executable command definition object
+
+ This method simply delegates to the provider's implementation of CreateDbCommandDefinition.
+
+
+
+ Creates command definition from specified manifest and command tree.
+ The created command definition.
+ The manifest.
+ The command tree.
+
+
+ Creates a command definition object for the specified provider manifest and command tree.
+ An executable command definition object.
+ Provider manifest previously retrieved from the store provider.
+ Command tree for the statement.
+
+
+
+ Create the default DbCommandDefinition object based on the prototype command
+ This method is intended for provider writers to build a default command definition
+ from a command.
+ Note: This will clone the prototype
+
+ the prototype command
+ an executable command definition object
+
+
+
+ See issue 2390 - cloning the DesignTimeVisible property on the
+ DbCommand can cause deadlocks. So here allow sub-classes to override.
+
+ the object to clone
+ a clone of the
+
+
+ Returns provider manifest token given a connection.
+ The provider manifest token.
+ Connection to provider.
+
+
+
+ Returns provider manifest token for a given connection.
+
+ Connection to find manifest token from.
+ The provider manifest token for the specified connection.
+
+
+ Returns the provider manifest by using the specified version information.
+ The provider manifest by using the specified version information.
+ The token information associated with the provider manifest.
+
+
+ When overridden in a derived class, returns an instance of a class that derives from the DbProviderManifest.
+ A DbProviderManifest object that represents the provider manifest.
+ The token information associated with the provider manifest.
+
+
+
+ Gets the that will be used to execute methods that use the specified connection.
+
+ The database connection
+
+ A new instance of
+
+
+
+
+ Gets the that will be used to execute methods that use the specified connection.
+ This overload should be used by the derived classes for compatability with wrapping providers.
+
+ The database connection
+ The provider invariant name
+
+ A new instance of
+
+
+
+
+ Gets the spatial data reader for the .
+
+ The spatial data reader.
+ The reader where the spatial data came from.
+ The manifest token associated with the provider manifest.
+
+
+
+ Gets the spatial services for the .
+
+ The spatial services.
+ The token information associated with the provider manifest.
+
+
+ Gets the spatial services for the .
+ The spatial services.
+ Information about the database that the spatial services will be used for.
+
+
+
+ Gets the spatial data reader for the .
+
+ The spatial data reader.
+ The reader where the spatial data came from.
+ The token information associated with the provider manifest.
+
+
+
+ Gets the spatial services for the .
+
+ The spatial services.
+ The token information associated with the provider manifest.
+
+
+
+ Sets the parameter value and appropriate facets for the given .
+
+ The parameter.
+ The type of the parameter.
+ The value of the parameter.
+
+
+
+ Sets the parameter value and appropriate facets for the given .
+
+ The parameter.
+ The type of the parameter.
+ The value of the parameter.
+
+
+ Returns providers given a connection.
+
+ The instanced based on the specified connection.
+
+ Connection to provider.
+
+
+ Retrieves the DbProviderFactory based on the specified DbConnection.
+ The retrieved DbProviderFactory.
+ The connection to use.
+
+
+
+ Return an XML reader which represents the CSDL description
+
+ The name of the CSDL description.
+ An XmlReader that represents the CSDL description
+
+
+ Generates a data definition language (DDL script that creates schema objects (tables, primary keys, foreign keys) based on the contents of the StoreItemCollection parameter and targeted for the version of the database corresponding to the provider manifest token.
+
+ Individual statements should be separated using database-specific DDL command separator.
+ It is expected that the generated script would be executed in the context of existing database with
+ sufficient permissions, and it should not include commands to create the database, but it may include
+ commands to create schemas and other auxiliary objects such as sequences, etc.
+
+ A DDL script that creates schema objects based on the contents of the StoreItemCollection parameter and targeted for the version of the database corresponding to the provider manifest token.
+ The provider manifest token identifying the target version.
+ The structure of the database.
+
+
+
+ Generates a data definition language (DDL) script that creates schema objects
+ (tables, primary keys, foreign keys) based on the contents of the StoreItemCollection
+ parameter and targeted for the version of the database corresponding to the provider manifest token.
+
+
+ Individual statements should be separated using database-specific DDL command separator.
+ It is expected that the generated script would be executed in the context of existing database with
+ sufficient permissions, and it should not include commands to create the database, but it may include
+ commands to create schemas and other auxiliary objects such as sequences, etc.
+
+ The provider manifest token identifying the target version.
+ The structure of the database.
+
+ A DDL script that creates schema objects based on the contents of the StoreItemCollection parameter
+ and targeted for the version of the database corresponding to the provider manifest token.
+
+
+
+
+ Creates a database indicated by connection and creates schema objects
+ (tables, primary keys, foreign keys) based on the contents of storeItemCollection.
+
+ Connection to a non-existent database that needs to be created and populated with the store objects indicated with the storeItemCollection parameter.
+ Execution timeout for any commands needed to create the database.
+ The collection of all store items based on which the script should be created.
+
+
+ Creates a database indicated by connection and creates schema objects (tables, primary keys, foreign keys) based on the contents of a StoreItemCollection.
+ Connection to a non-existent database that needs to be created and populated with the store objects indicated with the storeItemCollection parameter.
+ Execution timeout for any commands needed to create the database.
+ The collection of all store items based on which the script should be created.
+
+
+ Returns a value indicating whether a given database exists on the server.
+ True if the provider can deduce the database only based on the connection.
+ Connection to a database whose existence is checked by this method.
+ Execution timeout for any commands needed to determine the existence of the database.
+ The collection of all store items from the model. This parameter is no longer used for determining database existence.
+
+
+ Returns a value indicating whether a given database exists on the server.
+ True if the provider can deduce the database only based on the connection.
+ Connection to a database whose existence is checked by this method.
+ Execution timeout for any commands needed to determine the existence of the database.
+ The collection of all store items from the model. This parameter is no longer used for determining database existence.
+
+
+ Returns a value indicating whether a given database exists on the server.
+ True if the provider can deduce the database only based on the connection.
+ Connection to a database whose existence is checked by this method.
+ Execution timeout for any commands needed to determine the existence of the database.
+ The collection of all store items from the model. This parameter is no longer used for determining database existence.
+
+
+ Returns a value indicating whether a given database exists on the server.
+ True if the provider can deduce the database only based on the connection.
+ Connection to a database whose existence is checked by this method.
+ Execution timeout for any commands needed to determine the existence of the database.
+ The collection of all store items from the model. This parameter is no longer used for determining database existence.
+ Override this method to avoid creating the store item collection if it is not needed. The default implementation evaluates the Lazy and calls the other overload of this method.
+
+
+ Deletes the specified database.
+ Connection to an existing database that needs to be deleted.
+ Execution timeout for any commands needed to delete the database.
+ The collection of all store items from the model. This parameter is no longer used for database deletion.
+
+
+ Deletes the specified database.
+ Connection to an existing database that needs to be deleted.
+ Execution timeout for any commands needed to delete the database.
+ The collection of all store items from the model. This parameter is no longer used for database deletion.
+
+
+
+ Expands |DataDirectory| in the given path if it begins with |DataDirectory| and returns the expanded path,
+ or returns the given string if it does not start with |DataDirectory|.
+
+ The path to expand.
+ The expanded path.
+
+
+
+ Adds an that will be used to resolve additional default provider
+ services when a derived type is registered as an EF provider either using an entry in the application's
+ config file or through code-based registration in .
+
+ The resolver to add.
+
+
+
+ Called to resolve additional default provider services when a derived type is registered as an
+ EF provider either using an entry in the application's config file or through code-based
+ registration in . The implementation of this method in this
+ class uses the resolvers added with the AddDependencyResolver method to resolve
+ dependencies.
+
+
+ Use this method to set, add, or change other provider-related services. Note that this method
+ will only be called for such services if they are not already explicitly configured in some
+ other way by the application. This allows providers to set default services while the
+ application is still able to override and explicitly configure each service if required.
+ See and for more details.
+
+ The type of the service to be resolved.
+ An optional key providing additional information for resolving the service.
+ An instance of the given type, or null if the service could not be resolved.
+
+
+
+ Called to resolve additional default provider services when a derived type is registered as an
+ EF provider either using an entry in the application's config file or through code-based
+ registration in . The implementation of this method in this
+ class uses the resolvers added with the AddDependencyResolver method to resolve
+ dependencies.
+
+ The type of the service to be resolved.
+ An optional key providing additional information for resolving the service.
+ All registered services that satisfy the given type and key, or an empty enumeration if there are none.
+
+
+
+ A specialization of the ProviderManifest that accepts an XmlReader
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ An object that provides access to the XML data in the provider manifest file.
+
+
+
+ Returns the list of facet descriptions for the specified Entity Data Model (EDM) type.
+
+ A collection of type that contains the list of facet descriptions for the specified EDM type.
+
+
+ An for which the facet descriptions are to be retrieved.
+
+
+
+ Returns the list of primitive types supported by the storage provider.
+
+ A collection of type that contains the list of primitive types supported by the storage provider.
+
+
+
+ Returns the list of provider-supported functions.
+
+ A collection of type that contains the list of provider-supported functions.
+
+
+
+ Gets the namespace name supported by this provider manifest.
+ The namespace name supported by this provider manifest.
+
+
+ Gets the best mapped equivalent Entity Data Model (EDM) type for a specified storage type name.
+ The best mapped equivalent EDM type for a specified storage type name.
+
+
+ Gets the best mapped equivalent storage primitive type for a specified storage type name.
+ The best mapped equivalent storage primitive type for a specified storage type name.
+
+
+
+ Class for representing a collection of items.
+ Most of the implementation for actual maintenance of the collection is
+ done by MetadataCollection
+
+
+
+
+ Class representing a read-only wrapper around MetadataCollection
+
+ The type of items in this collection
+
+
+ Retrieves an item from this collection by using the specified identity.
+ An item from this collection.
+ The identity of the item to be searched for.
+ true to perform the case-insensitive search; otherwise, false.
+
+
+ Determines whether the collection contains an item with the specified identity.
+ true if the collection contains the item to be searched for; otherwise, false. The default is false.
+ The identity of the item.
+
+
+ Retrieves an item from this collection by using the specified identity.
+ true if there is an item that matches the search criteria; otherwise, false.
+ The identity of the item to be searched for.
+ true to perform the case-insensitive search; otherwise, false.
+ When this method returns, this output parameter contains an item from the collection. If there is no matched item, this output parameter contains null.
+
+
+ Returns an enumerator that can iterate through this collection.
+
+ A that can be used to iterate through this
+
+ .
+
+
+
+ Returns the index of the specified value in this collection.
+ The index of the specified value in this collection.
+ A value to seek.
+
+
+ Gets a value indicating whether this collection is read-only.
+ true if this collection is read-only; otherwise, false.
+
+
+ Gets an item from this collection by using the specified identity.
+ An item from this collection.
+ The identity of the item to be searched for.
+
+
+
+ The enumerator for MetadataCollection
+
+
+
+ Disposes of this enumerator.
+
+
+
+ Moves to the next member in the collection of type
+
+ .
+
+
+ true if the enumerator is moved in the collection of type
+
+ ; otherwise, false.
+
+
+
+
+ Positions the enumerator before the first position in the collection of type
+
+ .
+
+
+
+ Gets the member at the current position.
+ The member at the current position.
+
+
+
+ Gets the member at the current position
+
+
+
+
+ Returns a strongly typed object by using the specified identity.
+
+ The item that is specified by the identity.
+ The identity of the item.
+ The type returned by the method.
+
+
+
+ Returns a strongly typed object by using the specified identity from this item collection.
+
+ true if there is an item that matches the search criteria; otherwise, false.
+ The identity of the item.
+
+ When this method returns, the output parameter contains a
+
+ object. If there is no global item with the specified identity in the item collection, this output parameter contains null.
+
+ The type returned by the method.
+
+
+
+ Returns a strongly typed object by using the specified identity from this item collection.
+
+ true if there is an item that matches the search criteria; otherwise, false.
+ The identity of the item.
+ true to perform the case-insensitive search; otherwise, false.
+
+ When this method returns, the output parameter contains a
+
+ object. If there is no global item with the specified identity in the item collection, this output parameter contains null.
+
+ The type returned by the method.
+
+
+
+ Returns a strongly typed object by using the specified identity with either case-sensitive or case-insensitive search.
+
+ The item that is specified by the identity.
+ The identity of the item.
+ true to perform the case-insensitive search; otherwise, false.
+ The type returned by the method.
+
+
+ Returns all the items of the specified type from this item collection.
+
+ A collection of type that contains all the items of the specified type.
+
+ The type returned by the method.
+
+
+
+ Returns an object by using the specified type name and the namespace name in this item collection.
+
+
+ An object that represents the type that matches the specified type name and the namespace name in this item collection. If there is no matched type, this method returns null.
+
+ The name of the type.
+ The namespace of the type.
+
+
+
+ Returns an object by using the specified type name and the namespace name from this item collection.
+
+ true if there is a type that matches the search criteria; otherwise, false.
+ The name of the type.
+ The namespace of the type.
+
+ When this method returns, this output parameter contains an
+
+ object. If there is no type with the specified name and namespace name in this item collection, this output parameter contains null.
+
+
+
+
+ Returns an object by using the specified type name and the namespace name from this item collection.
+
+
+ An object that represents the type that matches the specified type name and the namespace name in this item collection. If there is no matched type, this method returns null.
+
+ The name of the type.
+ The namespace of the type.
+ true to perform the case-insensitive search; otherwise, false.
+
+
+
+ Returns an object by using the specified type name and the namespace name from this item collection.
+
+ true if there is a type that matches the search criteria; otherwise, false.
+ The name of the type.
+ The namespace of the type.
+ true to perform the case-insensitive search; otherwise, false.
+
+ When this method returns, this output parameter contains an
+
+ object. If there is no type with the specified name and namespace name in this item collection, this output parameter contains null.
+
+
+
+ Returns all the overloads of the functions by using the specified name from this item collection.
+
+ A collection of type that contains all the functions that have the specified name.
+
+ The full name of the function.
+
+
+ Returns all the overloads of the functions by using the specified name from this item collection.
+
+ A collection of type that contains all the functions that have the specified name.
+
+ The full name of the function.
+ true to perform the case-insensitive search; otherwise, false.
+
+
+ Returns all the overloads of the functions by using the specified name from this item collection.
+ A collection of type ReadOnlyCollection that contains all the functions that have the specified name.
+ A dictionary of functions.
+ The full name of the function.
+ true to perform the case-insensitive search; otherwise, false.
+
+
+
+ Returns an object by using the specified entity container name.
+
+ If there is no entity container, this method returns null; otherwise, it returns the first one.
+ The name of the entity container.
+
+
+
+ Returns an object by using the specified entity container name. If there is no entity container, the output parameter contains null; otherwise, it contains the first entity container.
+
+ true if there is an entity container that matches the search criteria; otherwise, false.
+ The name of the entity container.
+
+ When this method returns, it contains an object. If there is no entity container, this output parameter contains null; otherwise, it contains the first entity container.
+
+
+
+
+ Returns an object by using the specified entity container name.
+
+ If there is no entity container, this method returns null; otherwise, it returns the first entity container.
+ The name of the entity container.
+ true to perform the case-insensitive search; otherwise, false.
+
+
+
+ Returns an object by using the specified entity container name. If there is no entity container, this output parameter contains null; otherwise, it contains the first entity container.
+
+ true if there is an entity container that matches the search criteria; otherwise, false.
+ The name of the entity container.
+ true to perform the case-insensitive search; otherwise, false.
+
+ When this method returns, it contains an object. If there is no entity container, this output parameter contains null; otherwise, it contains the first entity container.
+
+
+
+ Gets the data model associated with this item collection.
+ The data model associated with this item collection.
+
+
+
+ EntityRecordInfo class providing a simple way to access both the type information and the column information.
+
+
+
+
+ Initializes a new instance of the class of a specific entity type with an enumerable collection of data fields and with specific key and entity set information.
+
+
+ The of the entity represented by the
+
+ described by this
+
+ object.
+
+
+ An enumerable collection of objects that represent column information.
+
+ The key for the entity.
+ The entity set to which the entity belongs.
+
+
+
+ Gets the for the entity.
+
+ The key for the entity.
+
+
+
+ Public Entity SQL Parser class.
+
+
+
+ Parse the specified query with the specified parameters.
+
+ The containing
+
+ and information describing inline function definitions if any.
+
+ The EntitySQL query to be parsed.
+ The optional query parameters.
+
+
+
+ Parse a specific query with a specific set variables and produce a
+
+ .
+
+
+ The containing
+
+ and information describing inline function definitions if any.
+
+ The query to be parsed.
+ The optional query variables.
+
+
+
+ Entity SQL query inline function definition, returned as a part of .
+
+
+
+ Function name.
+
+
+ Function body and parameters.
+
+
+ Start position of the function definition in the eSQL query text.
+
+
+ End position of the function definition in the eSQL query text.
+
+
+
+ Entity SQL Parser result information.
+
+
+
+ A command tree produced during parsing.
+
+
+
+ List of objects describing query inline function definitions.
+
+
+
+
+ Compares objects using reference equality.
+
+
+
+
+ Gets the default instance.
+
+
+
+
+ Wraps access to the transaction object on the underlying store connection and ensures that the
+ Entity Framework executes commands on the database within the context of that transaction.
+ An instance of this class is retrieved by calling BeginTransaction() on the
+
+ object.
+
+
+
+
+ Commits the underlying store transaction
+
+
+
+
+ Rolls back the underlying store transaction
+
+
+
+
+ Cleans up this transaction object and ensures the Entity Framework
+ is no longer using that transaction.
+
+
+
+
+ Releases the resources used by this transaction object
+
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the database (store) transaction that is underlying this context transaction.
+
+
+
+
+ A service for obtaining the correct from a given
+ .
+
+
+ On .NET 4.5 the provider is publicly accessible from the connection. On .NET 4 the
+ default implementation of this service uses some heuristics to find the matching
+ provider. If these fail then a new implementation of this service can be registered
+ on to provide an appropriate resolution.
+
+
+
+
+ Returns the for the given connection.
+
+ The connection.
+ The provider factory for the connection.
+
+
+
+ Explicitly implemented by to prevent certain members from showing up
+ in the IntelliSense of scaffolded migrations.
+
+
+
+
+ Adds a custom to the migration.
+ Custom operation implementors are encouraged to create extension methods on
+ that provide a fluent-style API for adding new operations.
+
+ The operation to add.
+
+
+
+ A default implementation of that uses the
+ underlying provider to get the manifest token.
+ Note that to avoid multiple queries, this implementation using caching based on the actual type of
+ instance, the property,
+ and the property.
+
+
+
+
+ A service for getting a provider manifest token given a connection.
+ The class is used by default and makes use of the
+ underlying provider to get the token which often involves opening the connection.
+ A different implementation can be used instead by adding an
+ to that may use any information in the connection to return
+ the token. For example, if the connection is known to point to a SQL Server 2008 database then
+ "2008" can be returned without opening the connection.
+
+
+
+
+ Returns the manifest token to use for the given connection.
+
+ The connection for which a manifest token is required.
+ The manifest token to use.
+
+
+
+
+
+
+ A strategy that is used to execute a command or query against the database, possibly with logic to retry when a failure occurs.
+
+
+
+
+ Executes the specified operation.
+
+ A delegate representing an executable operation that doesn't return any results.
+
+
+
+ Executes the specified operation and returns the result.
+
+
+ The return type of .
+
+
+ A delegate representing an executable operation that returns the result of type .
+
+ The result from the operation.
+
+
+
+ Executes the specified asynchronous operation.
+
+ A function that returns a started task.
+
+ A cancellation token used to cancel the retry operation, but not operations that are already in flight
+ or that already completed successfully.
+
+
+ A task that will run to completion if the original task completes successfully (either the
+ first time or after retrying transient failures). If the task fails with a non-transient error or
+ the retry limit is reached, the returned task will become faulted and the exception must be observed.
+
+
+
+
+ Executes the specified asynchronous operation and returns the result.
+
+
+ The result type of the returned by .
+
+
+ A function that returns a started task of type .
+
+
+ A cancellation token used to cancel the retry operation, but not operations that are already in flight
+ or that already completed successfully.
+
+
+ A task that will run to completion if the original task completes successfully (either the
+ first time or after retrying transient failures). If the task fails with a non-transient error or
+ the retry limit is reached, the returned task will become faulted and the exception must be observed.
+
+
+
+
+ Indicates whether this might retry the execution after a failure.
+
+
+
+
+ Provides the base implementation of the retry mechanism for unreliable operations and transient conditions that uses
+ exponentially increasing delays between retries.
+
+
+ A new instance will be created each time an operation is executed.
+ The following formula is used to calculate the delay after retryCount number of attempts:
+ min(random(1, 1.1) * (2 ^ retryCount - 1), maxDelay)
+ The retryCount starts at 0.
+ The random factor distributes uniformly the retry attempts from multiple simultaneous operations failing simultaneously.
+
+
+
+
+ Creates a new instance of .
+
+
+ The default retry limit is 5, which means that the total amount of time spent between retries is 26 seconds plus the random factor.
+
+
+
+
+ Creates a new instance of with the specified limits for number of retries and the delay between retries.
+
+ The maximum number of retry attempts.
+ The maximum delay in milliseconds between retries.
+
+
+
+ Repetitively executes the specified operation while it satisfies the current retry policy.
+
+ A delegate representing an executable operation that doesn't return any results.
+ if the retry delay strategy determines the operation shouldn't be retried anymore
+ if an existing transaction is detected and the execution strategy doesn't support it
+ if this instance was already used to execute an operation
+
+
+
+ Repetitively executes the specified operation while it satisfies the current retry policy.
+
+ The type of result expected from the executable operation.
+
+ A delegate representing an executable operation that returns the result of type .
+
+ The result from the operation.
+ if the retry delay strategy determines the operation shouldn't be retried anymore
+ if an existing transaction is detected and the execution strategy doesn't support it
+ if this instance was already used to execute an operation
+
+
+
+ Repetitively executes the specified asynchronous operation while it satisfies the current retry policy.
+
+ A function that returns a started task.
+
+ A cancellation token used to cancel the retry operation, but not operations that are already in flight
+ or that already completed successfully.
+
+
+ A task that will run to completion if the original task completes successfully (either the
+ first time or after retrying transient failures). If the task fails with a non-transient error or
+ the retry limit is reached, the returned task will become faulted and the exception must be observed.
+
+ if the retry delay strategy determines the operation shouldn't be retried anymore
+ if an existing transaction is detected and the execution strategy doesn't support it
+ if this instance was already used to execute an operation
+
+
+
+ Repeatedly executes the specified asynchronous operation while it satisfies the current retry policy.
+
+
+ The result type of the returned by .
+
+
+ A function that returns a started task of type .
+
+
+ A cancellation token used to cancel the retry operation, but not operations that are already in flight
+ or that already completed successfully.
+
+
+ A task that will run to completion if the original task completes successfully (either the
+ first time or after retrying transient failures). If the task fails with a non-transient error or
+ the retry limit is reached, the returned task will become faulted and the exception must be observed.
+
+ if the retry delay strategy determines the operation shouldn't be retried anymore
+ if an existing transaction is detected and the execution strategy doesn't support it
+ if this instance was already used to execute an operation
+
+
+
+ Determines whether the operation should be retried and the delay before the next attempt.
+
+ The exception thrown during the last execution attempt.
+
+ Returns the delay indicating how long to wait for before the next execution attempt if the operation should be retried;
+ null otherwise
+
+
+
+
+ Recursively gets InnerException from as long as it's an
+ , or
+ and passes it to
+
+ The type of the unwrapped exception.
+ The exception to be unwrapped.
+ A delegate that will be called with the unwrapped exception.
+
+ The result from .
+
+
+
+
+ Determines whether the specified exception represents a transient failure that can be compensated by a retry.
+
+ The exception object to be verified.
+
+ true if the specified exception is considered as transient, otherwise false.
+
+
+
+
+ Returns true to indicate that might retry the execution after a failure.
+
+
+
+
+ A key used for resolving . It consists of the ADO.NET provider invariant name
+ and the database server name as specified in the connection string.
+
+
+
+
+ Initializes a new instance of
+
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this execution strategy will be used.
+
+ A string that will be matched against the server name in the connection string.
+
+
+
+
+
+
+
+
+
+ The ADO.NET provider invariant name indicating the type of ADO.NET connection for which this execution strategy will be used.
+
+
+
+
+ A string that will be matched against the server name in the connection string.
+
+
+
+
+ Implement this interface on your context to use custom logic to calculate the key used to lookup an already created model in the cache.
+ This interface allows you to have a single context type that can be used with different models in the same AppDomain,
+ or multiple context types that use the same model.
+
+
+
+ Gets the cached key associated with the provider.
+ The cached key associated with the provider.
+
+
+
+ Used by and when resolving
+ a provider invariant name from a .
+
+
+
+ Gets the name of the provider.
+ The name of the provider.
+
+
+
+ Represents a custom pluralization term to be used by the
+
+
+
+
+ Create a new instance
+
+ A non null or empty string representing the singular.
+ A non null or empty string representing the plural.
+
+
+
+ Get the singular.
+
+
+
+
+ Get the plural.
+
+
+
+
+ Default pluralization service implementation to be used by Entity Framework. This pluralization
+ service is based on English locale.
+
+
+
+
+ Pluralization services to be used by the EF runtime implement this interface.
+ By default the is used, but the pluralization service to use
+ can be set in a class derived from .
+
+
+
+
+ Pluralize a word using the service.
+
+ The word to pluralize.
+ The pluralized word
+
+
+
+ Singularize a word using the service.
+
+ The word to singularize.
+ The singularized word.
+
+
+
+ Constructs a new instance of default pluralization service
+ used in Entity Framework.
+
+
+
+
+ Constructs a new instance of default pluralization service
+ used in Entity Framework.
+
+
+ A collection of user dictionary entries to be used by this service.These inputs
+ can customize the service according the user needs.
+
+
+
+ Returns the plural form of the specified word.
+ The plural form of the input parameter.
+ The word to be made plural.
+
+
+ Returns the singular form of the specified word.
+ The singular form of the input parameter.
+ The word to be made singular.
+
+
+
+ The exception that is thrown when the action failed again after being retried the configured number of times.
+
+
+
+
+ Provider exception - Used by the entity client.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of the class.
+
+ The error message that explains the reason for the exception.
+ The exception that caused the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of the class.
+
+
+ The that holds the serialized object data about the exception being thrown.
+
+
+ The that contains contextual information about the source or destination.
+
+
+
+
+ Initializes a new instance of the class with no error message.
+
+
+
+
+ Initializes a new instance of the class with a specified error message.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of the class.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception.
+
+
+
+ An that doesn't retry operations if they fail.
+
+
+
+
+ Executes the specified operation once.
+
+ A delegate representing an executable operation that doesn't return any results.
+
+
+
+ Executes the specified operation once and returns the result.
+
+
+ The return type of .
+
+
+ A delegate representing an executable operation that returns the result of type .
+
+ The result from the operation.
+
+
+
+ Executes the specified asynchronous operation once, without retrying on failure.
+
+ A function that returns a started task.
+
+ A cancellation token used to cancel the retry operation, but not operations that are already in flight
+ or that already completed successfully.
+
+
+ A task that will run to completion if the original task completes successfully.
+
+
+
+
+ Executes the specified asynchronous operation once, without retrying on failure.
+
+
+ The result type of the returned by .
+
+ A function that returns a started task.
+
+ A cancellation token used to cancel the retry operation, but not operations that are already in flight
+ or that already completed successfully.
+
+
+ A task that will run to completion if the original task completes successfully.
+
+
+
+
+ Returns false to indicate that will not retry the execution after a failure.
+
+
+
+
+ Asynchronous version of the interface that allows elements to be retrieved asynchronously.
+ This interface is used to interact with Entity Framework queries and shouldn't be implemented by custom classes.
+
+
+
+
+ Gets an enumerator that can be used to asynchronously enumerate the sequence.
+
+ Enumerator for asynchronous enumeration over the sequence.
+
+
+
+ Asynchronous version of the interface that allows elements of the enumerable sequence to be retrieved asynchronously.
+ This interface is used to interact with Entity Framework queries and shouldn't be implemented by custom classes.
+
+ The type of objects to enumerate.
+
+
+
+ Gets an enumerator that can be used to asynchronously enumerate the sequence.
+
+ Enumerator for asynchronous enumeration over the sequence.
+
+
+
+ Represents a SQL query for entities that is created from a
+ and is executed using the connection from that context.
+ Instances of this class are obtained from the instance for the
+ entity type. The query is not executed when this object is created; it is executed
+ each time it is enumerated, for example by using foreach.
+ SQL queries for non-entities are created using .
+ See for a generic version of this class.
+
+
+
+
+ Represents a SQL query for non-entities that is created from a
+ and is executed using the connection from that context.
+ Instances of this class are obtained from the instance.
+ The query is not executed when this object is created; it is executed
+ each time it is enumerated, for example by using foreach.
+ SQL queries for entities are created using .
+ See for a generic version of this class.
+
+
+
+
+ Returns a new query that will stream the results instead of buffering.
+
+ A new query with AsStreaming applied.
+
+
+
+ Returns an which when enumerated will execute the SQL query against the database.
+
+
+ An object that can be used to iterate through the elements.
+
+
+
+
+ Returns an which when enumerated will execute the SQL query against the database.
+
+
+ An object that can be used to iterate through the elements.
+
+
+
+
+ Asynchronously enumerates the query results and performs the specified action on each element.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The action to perform on each element.
+ A task that represents the asynchronous operation.
+
+
+
+ Asynchronously enumerates the query results and performs the specified action on each element.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The action to perform on each element.
+
+ A to observe while waiting for the task to complete.
+
+ A task that represents the asynchronous operation.
+
+
+
+ Creates a from the query by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains elements from the query.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains elements from the query.
+
+
+
+
+ Returns a that contains the SQL string that was set
+ when the query was created. The parameters are not included.
+
+
+ A that represents this instance.
+
+
+
+
+ Throws an exception indicating that binding directly to a store query is not supported.
+
+ Never returns; always throws.
+
+
+
+
+
+
+
+
+
+
+
+
+ Returns false.
+
+
+ false .
+
+
+
+
+ Creates an instance of a when called from the constructor of a derived
+ type that will be used as a test double for . Methods and properties
+ that will be used by the test double must be implemented by the test double except AsNoTracking
+ and AsStreaming where the default implementation is a no-op.
+
+
+
+
+ Returns a new query where the results of the query will not be tracked by the associated
+ .
+
+ A new query with NoTracking applied.
+
+
+
+ Returns a new query that will stream the results instead of buffering.
+
+ A new query with AsStreaming applied.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Represents a SQL query for entities that is created from a
+ and is executed using the connection from that context.
+ Instances of this class are obtained from the instance for the
+ entity type. The query is not executed when this object is created; it is executed
+ each time it is enumerated, for example by using foreach.
+ SQL queries for non-entities are created using .
+ See for a non-generic version of this class.
+
+ The type of entities returned by the query.
+
+
+
+ Represents a SQL query for non-entities that is created from a
+ and is executed using the connection from that context.
+ Instances of this class are obtained from the instance.
+ The query is not executed when this object is created; it is executed
+ each time it is enumerated, for example by using foreach.
+ SQL queries for entities are created using .
+ See for a non-generic version of this class.
+
+ The type of elements returned by the query.
+
+
+
+ Returns a new query that will stream the results instead of buffering.
+
+ A new query with AsStreaming applied.
+
+
+
+ Returns an which when enumerated will execute the SQL query against the database.
+
+
+ An object that can be used to iterate through the elements.
+
+
+
+
+ Returns an which when enumerated will execute the SQL query against the database.
+
+
+ An object that can be used to iterate through the elements.
+
+
+
+
+ Returns an which when enumerated will execute the SQL query against the database.
+
+
+ An object that can be used to iterate through the elements.
+
+
+
+
+ Returns an which when enumerated will execute the SQL query against the database.
+
+
+ An object that can be used to iterate through the elements.
+
+
+
+
+ Asynchronously enumerates the query results and performs the specified action on each element.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The action to be executed.
+ A task that represents the asynchronous operation.
+
+
+
+ Asynchronously enumerates the query results and performs the specified action on each element.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The action to be executed.
+
+ A to observe while waiting for the task to complete.
+
+ A task that represents the asynchronous operation.
+
+
+
+ Creates a from the query by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains elements from the input sequence.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains elements from the input sequence.
+
+
+
+
+ Creates an array from the query by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an array that contains elements from the input sequence.
+
+
+
+
+ Creates an array from the query by enumerating it asynchronously.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an array that contains elements from the input sequence.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously
+ according to a specified key selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the key returned by .
+
+ A function to extract a key from each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains selected keys and values.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously
+ according to a specified key selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the key returned by .
+
+ A function to extract a key from each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains selected keys and values.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously
+ according to a specified key selector function and a comparer.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the key returned by .
+
+ A function to extract a key from each element.
+
+ An to compare keys.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains selected keys and values.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously
+ according to a specified key selector function and a comparer.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the key returned by .
+
+ A function to extract a key from each element.
+
+ An to compare keys.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains selected keys and values.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously
+ according to a specified key selector and an element selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the key returned by .
+
+
+ The type of the value returned by .
+
+ A function to extract a key from each element.
+ A transform function to produce a result element value from each element.
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains values of type
+ selected from the query.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously
+ according to a specified key selector and an element selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the key returned by .
+
+
+ The type of the value returned by .
+
+ A function to extract a key from each element.
+ A transform function to produce a result element value from each element.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains values of type
+ selected from the query.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously
+ according to a specified key selector function, a comparer, and an element selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the key returned by .
+
+
+ The type of the value returned by .
+
+ A function to extract a key from each element.
+ A transform function to produce a result element value from each element.
+
+ An to compare keys.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains values of type
+ selected from the input sequence.
+
+
+
+
+ Creates a from the query by enumerating it asynchronously
+ according to a specified key selector function, a comparer, and an element selector function.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The type of the key returned by .
+
+
+ The type of the value returned by .
+
+ A function to extract a key from each element.
+ A transform function to produce a result element value from each element.
+
+ An to compare keys.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains a that contains values of type
+ selected from the input sequence.
+
+
+
+
+ Asynchronously returns the first element of the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the first element in the query result.
+
+ The query result is empty.
+
+
+
+ Asynchronously returns the first element of the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the first element in the query result.
+
+ The query result is empty.
+
+
+
+ Asynchronously returns the first element of the query that satisfies a specified condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the first element in the query result that satisfies a specified condition.
+
+
+
+ is
+ null
+ .
+
+ The query result is empty.
+
+
+
+ Asynchronously returns the first element of the query that satisfies a specified condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the first element in the query result that satisfies a specified condition.
+
+
+
+ is
+ null
+ .
+
+ The query result is empty.
+
+
+
+ Asynchronously returns the first element of the query, or a default value if the the query result contains no elements.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains default ( ) if query result is empty;
+ otherwise, the first element in the query result.
+
+
+
+
+ Asynchronously returns the first element of the query, or a default value if the the query result contains no elements.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains default ( ) if query result is empty;
+ otherwise, the first element in the query result.
+
+
+
+
+ Asynchronously returns the first element of the query that satisfies a specified condition
+ or a default value if no such element is found.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains default ( ) if query result is empty
+ or if no element passes the test specified by ; otherwise, the first element
+ in the query result that passes the test specified by .
+
+
+
+ is
+ null
+ .
+
+
+
+
+ Asynchronously returns the first element of the query that satisfies a specified condition
+ or a default value if no such element is found.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains default ( ) if query result is empty
+ or if no element passes the test specified by ; otherwise, the first element
+ in the query result that passes the test specified by .
+
+
+
+ is
+ null
+ .
+
+
+
+
+ Asynchronously returns the only element of the query, and throws an exception
+ if there is not exactly one element in the sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the query result.
+
+ The query result has more than one element.
+ The query result is empty.
+
+
+
+ Asynchronously returns the only element of the query, and throws an exception
+ if there is not exactly one element in the sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the query result.
+
+ The query result has more than one element.
+ The query result is empty.
+
+
+
+ Asynchronously returns the only element of the query that satisfies a specified condition,
+ and throws an exception if more than one such element exists.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the query result that satisfies the condition in
+ .
+
+
+
+ is
+ null
+ .
+
+
+ No element satisfies the condition in
+
+ .
+
+
+ More than one element satisfies the condition in
+
+ .
+
+
+
+
+ Asynchronously returns the only element of the query that satisfies a specified condition,
+ and throws an exception if more than one such element exists.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the query result that satisfies the condition in
+ .
+
+
+
+ is
+ null
+ .
+
+
+ No element satisfies the condition in
+
+ .
+
+
+ More than one element satisfies the condition in
+
+ .
+
+
+
+
+ Asynchronously returns the only element of a sequence, or a default value if the sequence is empty;
+ this method throws an exception if there is more than one element in the sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the query result, or default ()
+ if the sequence contains no elements.
+
+ The query result has more than one element.
+
+
+
+ Asynchronously returns the only element of a sequence, or a default value if the sequence is empty;
+ this method throws an exception if there is more than one element in the sequence.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the query result, or default ()
+ if the sequence contains no elements.
+
+ The query result has more than one element.
+
+
+
+ Asynchronously returns the only element of the query that satisfies a specified condition or
+ a default value if no such element exists; this method throws an exception if more than one element
+ satisfies the condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the query result that satisfies the condition in
+ , or default ( ) if no such element is found.
+
+
+
+ is
+ null
+ .
+
+
+ More than one element satisfies the condition in
+
+ .
+
+
+
+
+ Asynchronously returns the only element of the query that satisfies a specified condition or
+ a default value if no such element exists; this method throws an exception if more than one element
+ satisfies the condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the single element of the query result that satisfies the condition in
+ , or default ( ) if no such element is found.
+
+
+
+ is
+ null
+ .
+
+
+ More than one element satisfies the condition in
+
+ .
+
+
+
+
+ Asynchronously determines whether the query contains a specified element by using the default equality comparer.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The object to locate in the query result.
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the query result contains the specified value; otherwise, false.
+
+
+
+
+ Asynchronously determines whether the query contains a specified element by using the default equality comparer.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The object to locate in the query result.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the query result contains the specified value; otherwise, false.
+
+
+
+
+ Asynchronously determines whether the query contains any elements.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the query result contains any elements; otherwise, false.
+
+
+
+
+ Asynchronously determines whether the query contains any elements.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the query result contains any elements; otherwise, false.
+
+
+
+
+ Asynchronously determines whether any element of the query satisfies a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains true if any elements in the query result pass the test in the specified predicate; otherwise, false.
+
+
+
+
+ Asynchronously determines whether any element of the query satisfies a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if any elements in the query result pass the test in the specified predicate; otherwise, false.
+
+
+
+
+ Asynchronously determines whether all the elements of the query satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains true if every element of the query result passes the test in the specified predicate; otherwise, false.
+
+
+
+ is
+ null
+ .
+
+
+
+
+ Asynchronously determines whether all the elements of the query satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if every element of the query result passes the test in the specified predicate; otherwise, false.
+
+
+
+ is
+ null
+ .
+
+
+
+
+ Asynchronously returns the number of elements in the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the query result.
+
+
+ The number of elements in the query result is larger than
+
+ .
+
+
+
+
+ Asynchronously returns the number of elements in the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the query result.
+
+
+ The number of elements in the query result is larger than
+
+ .
+
+
+
+
+ Asynchronously returns the number of elements in the query that satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the query result that satisfy the condition in the predicate function.
+
+
+ The number of elements in the query result that satisfy the condition in the predicate function
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns the number of elements in the query that satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the query result that satisfy the condition in the predicate function.
+
+
+ The number of elements in the query result that satisfy the condition in the predicate function
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns an that represents the total number of elements in the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the query result.
+
+
+ The number of elements in the query result is larger than
+
+ .
+
+
+
+
+ Asynchronously returns an that represents the total number of elements in the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the query result.
+
+
+ The number of elements in the query result is larger than
+
+ .
+
+
+
+
+ Asynchronously returns an that represents the number of elements in the query
+ that satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the query result that satisfy the condition in the predicate function.
+
+
+ The number of elements in the query result that satisfy the condition in the predicate function
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns an that represents the number of elements in the query
+ that satisfy a condition.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ A function to test each element for a condition.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of elements in the query result that satisfy the condition in the predicate function.
+
+
+ The number of elements in the query result that satisfy the condition in the predicate function
+ is larger than
+
+ .
+
+
+
+
+ Asynchronously returns the minimum value of the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the minimum value in the query result.
+
+
+
+
+ Asynchronously returns the minimum value of the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the minimum value in the query result.
+
+
+
+
+ Asynchronously returns the maximum value of the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the maximum value in the query result.
+
+
+
+
+ Asynchronously returns the maximum value of the query.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the maximum value in the query result.
+
+
+
+
+ Returns a that contains the SQL string that was set
+ when the query was created. The parameters are not included.
+
+
+ A that represents this instance.
+
+
+
+
+ Throws an exception indicating that binding directly to a store query is not supported.
+
+ Never returns; always throws.
+
+
+
+
+
+
+
+
+
+
+
+
+ Returns false.
+
+
+ false .
+
+
+
+
+ Creates an instance of a when called from the constructor of a derived
+ type that will be used as a test double for . Methods and properties
+ that will be used by the test double must be implemented by the test double except AsNoTracking and
+ AsStreaming where the default implementation is a no-op.
+
+
+
+
+ Returns a new query where the entities returned will not be cached in the .
+
+ A new query with NoTracking applied.
+
+
+
+ Returns a new query that will stream the results instead of buffering.
+
+ A new query with AsStreaming applied.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Asynchronous version of the interface that allows elements to be retrieved asynchronously.
+ This interface is used to interact with Entity Framework queries and shouldn't be implemented by custom classes.
+
+
+
+
+ Advances the enumerator to the next element in the sequence, returning the result asynchronously.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if the enumerator was successfully advanced to the next element; false if the enumerator has passed the end of the sequence.
+
+
+
+
+ Gets the current element in the iteration.
+
+
+
+
+ Defines methods to create and asynchronously execute queries that are described by an
+ object.
+ This interface is used to interact with Entity Framework queries and shouldn't be implemented by custom classes.
+
+
+
+
+ Asynchronously executes the query represented by a specified expression tree.
+
+ An expression tree that represents a LINQ query.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the value that results from executing the specified query.
+
+
+
+
+ Asynchronously executes the strongly-typed query represented by a specified expression tree.
+
+ The type of the value that results from executing the query.
+ An expression tree that represents a LINQ query.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the value that results from executing the specified query.
+
+
+
+
+ Asynchronous version of the interface that allows elements to be retrieved asynchronously.
+ This interface is used to interact with Entity Framework queries and shouldn't be implemented by custom classes.
+
+ The type of objects to enumerate.
+
+
+
+ Gets the current element in the iteration.
+
+
+
+
+ Represents a key value that uniquely identifies an Entity Framework model that has been loaded into memory.
+
+
+
+ Determines whether the current cached model key is equal to the specified cached model key.
+ true if the current cached model key is equal to the specified cached model key; otherwise, false.
+ The cached model key to compare to the current cached model key.
+
+
+ Returns the hash function for this cached model key.
+ The hash function for this cached model key.
+
+
+
+ Thrown when an operation can't be performed because there are existing migrations that have not been applied to the database.
+
+
+
+
+ Represents errors that occur inside the Code First Migrations pipeline.
+
+
+
+
+ Initializes a new instance of the MigrationsException class.
+
+
+
+
+ Initializes a new instance of the MigrationsException class.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of the MigrationsException class.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of the MigrationsException class with serialized data.
+
+
+ The that holds the serialized object data about the exception being thrown.
+
+
+ The that contains contextual information about the source or destination.
+
+
+
+
+ Initializes a new instance of the MigrationsPendingException class.
+
+
+
+
+ Initializes a new instance of the MigrationsPendingException class.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of the MigrationsPendingException class.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ A migration operation to add a new stored procedure to the database.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the stored procedure.
+ The body of the stored procedure expressed in SQL.
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets an operation to drop the stored procedure.
+
+
+
+
+ Allows configuration to be performed for a lightweight convention based on
+ the properties in a model.
+
+
+
+
+ Filters the properties that this convention applies to based on a predicate.
+
+ A function to test each property for a condition.
+
+ A instance so that multiple calls can be chained.
+
+
+
+
+ Filters the properties that this convention applies to based on a predicate
+ while capturing a value to use later during configuration.
+
+ Type of the captured value.
+
+ A function to capture a value for each property. If the value is null, the
+ property will be filtered out.
+
+
+ A instance so that multiple calls can be chained.
+
+
+
+
+ Allows configuration of the properties that this convention applies to.
+
+
+ An action that performs configuration against a
+
+ .
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Allows configuration to be performed for a lightweight convention based on
+ the properties of entity types in a model and a captured value.
+
+ The type of the captured value.
+
+
+
+ Allows configuration of the properties that this convention applies to.
+
+
+ An action that performs configuration against a
+ using a captured value.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Allows configuration to be performed for a stored procedure that is used to modify a relationship.
+
+ The type of the entity that the relationship is being configured from.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+ The type of the property.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+ The type of the property.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+
+ Creates a convention that configures stored procedures to be used to delete entities in the database.
+
+
+
+
+ Creates a convention that configures stored procedures to be used to modify entities in the database.
+
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+ The schema name.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The name of the property to configure the parameter for.
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The property to configure the parameter for.
+ The name of the parameter.
+
+
+ Configures the output parameter that returns the rows affected by this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The name of the parameter.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Creates a convention that configures stored procedures to be used to insert entities in the database.
+
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+ The schema name.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The name of the property to configure the parameter for.
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The property to configure the parameter for.
+ The name of the parameter.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ The name of the property to configure the result for.
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ The property to configure the result for.
+ The name of the result column.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Creates a convention that configures stored procedures to be used to modify entities in the database.
+
+
+
+ Configures stored procedure used to insert entities.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression that performs configuration for the stored procedure.
+
+
+ Configures stored procedure used to update entities.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression that performs configuration for the stored procedure.
+
+
+ Configures stored procedure used to delete entities.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression that performs configuration for the stored procedure.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Creates a convention that configures stored procedures to be used to update entities in the database.
+
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+ The schema name.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The name of the property to configure the parameter for.
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The property to configure the parameter for.
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The name of the property to configure the parameter for.
+ The current value parameter name.
+ The original value parameter name.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The property to configure the parameter for.
+ The current value parameter name.
+ The original value parameter name.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ The name of the property to configure the result for.
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ The property to configure the result for.
+ The name of the result column.
+
+
+ Configures the output parameter that returns the rows affected by this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The name of the parameter.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Allows configuration to be performed for a stored procedure that is used to modify a many to many relationship.
+
+ The type of the entity that the relationship is being configured from.
+ The type of the entity that the other end of the relationship targets.
+
+
+
+ Performs configuration of a stored procedure uses to modify an entity in the database.
+
+
+
+
+ Sets the name of the stored procedure.
+
+ Name of the procedure.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Sets the name of the stored procedure.
+
+ Name of the procedure.
+ Name of the schema.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the parameter for the left key value(s).
+
+ The type of the property to configure.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ Name of the parameter.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the parameter for the left key value(s).
+
+ The type of the property to configure.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ Name of the parameter.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the parameter for the left key value(s).
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ Name of the parameter.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the parameter for the left key value(s).
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ Name of the parameter.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the parameter for the right key value(s).
+
+ The type of the property to configure.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ Name of the parameter.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the parameter for the right key value(s).
+
+ The type of the property to configure.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ Name of the parameter.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the parameter for the right key value(s).
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ Name of the parameter.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the parameter for the right key value(s).
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ Name of the parameter.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Allows configuration to be performed for a stored procedure that is used to modify a many to many relationship.
+
+ The type of the entity that the relationship is being configured from.
+ The type of the entity that the other end of the relationship targets.
+
+
+ Configures stored procedure used to insert relationships.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression that performs configuration for the stored procedure.
+
+
+ Configures stored procedure used to delete relationships.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression that performs configuration for the stored procedure.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Allows configuration to be performed for a stored procedure that is used to delete entities.
+
+ The type of the entity that the stored procedure can be used to delete.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+ The schema name.
+
+
+ Configures a parameter for this stored procedure.
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures the output parameter that returns the rows affected by this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The name of the parameter.
+
+
+ Configures parameters for a relationship where the foreign key property is not included in the class.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A lambda expression that performs the configuration.
+ The type of the principal entity in the relationship.
+
+
+ Configures parameters for a relationship where the foreign key property is not included in the class.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A lambda expression that performs the configuration.
+ The type of the principal entity in the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Allows configuration to be performed for a stored procedure that is used to insert entities.
+
+ The type of the entity that the stored procedure can be used to insert.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+ The schema name.
+
+
+ Configures a parameter for this stored procedure.
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+ Configures parameters for a relationship where the foreign key property is not included in the class.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A lambda expression that performs the configuration.
+ The type of the principal entity in the relationship.
+
+
+ Configures parameters for a relationship where the foreign key property is not included in the class.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A lambda expression that performs the configuration.
+ The type of the principal entity in the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Allows configuration to be performed for a stored procedure that is used to update entities.
+
+ The type of the entity that the stored procedure can be used to update.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+
+
+ Configures the name of the stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The stored procedure name.
+ The schema name.
+
+
+ Configures a parameter for this stored procedure.
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the parameter.
+
+
+ Configures a parameter for this stored procedure.
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The current value parameter name.
+ The original value parameter name.
+
+
+ Configures a parameter for this stored procedure.
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The current value parameter name.
+ The original value parameter name.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The current value parameter name.
+ The original value parameter name.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The current value parameter name.
+ The original value parameter name.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The current value parameter name.
+ The original value parameter name.
+
+
+ Configures a parameter for this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the parameter for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The current value parameter name.
+ The original value parameter name.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The type of the property to configure.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+
+ Configures a column of the result for this stored procedure to map to a property.
+ This is used for database generated columns.
+
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the property to configure the result for. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The name of the result column.
+
+
+ Configures the output parameter that returns the rows affected by this stored procedure.
+ The same configuration instance so that multiple calls can be chained.
+ The name of the parameter.
+
+
+ Configures parameters for a relationship where the foreign key property is not included in the class.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A lambda expression that performs the configuration.
+ The type of the principal entity in the relationship.
+
+
+ Configures parameters for a relationship where the foreign key property is not included in the class.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A lambda expression that performs the configuration.
+ The type of the principal entity in the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Allows configuration to be performed for a stored procedure that is used to modify entities.
+
+ The type of the entity that the stored procedure can be used to modify.
+
+
+ Configures stored procedure used to insert entities.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression that performs configuration for the stored procedure.
+
+
+ Configures stored procedure used to update entities.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression that performs configuration for the stored procedure.
+
+
+ Configures stored procedure used to delete entities.
+ The same configuration instance so that multiple calls can be chained.
+ A lambda expression that performs configuration for the stored procedure.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Used to configure a primitive property of an entity type or complex type.
+ This configuration functionality is available via lightweight conventions.
+
+
+
+
+ Configures the name of the database column used to store the property.
+
+ The name of the column.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Sets an annotation in the model for the database column used to store the property. The annotation
+ value can later be used when processing the column such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Calling this method will have no effect if the
+ annotation with the given name has already been configured.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the parameter used in stored procedures for this property.
+
+ Name of the parameter.
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+ Configures the order of the database column used to store the property.
+ This method is also used to specify key ordering when an entity type has a composite key.
+
+ The order that this column should appear in the database table.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures the data type of the database column used to store the property.
+
+ Name of the database provider specific data type.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures the property to be used as an optimistic concurrency token.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures whether or not the property is to be used as an optimistic concurrency token.
+
+ Value indicating if the property is a concurrency token or not.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures how values for the property are generated by the database.
+
+ The pattern used to generate values for the property in the database.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures the property to be optional.
+ The database column used to store this property will be nullable.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures the property to be required.
+ The database column used to store this property will be non-nullable.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+
+
+
+
+ Configures the property to support Unicode string content.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method throws if the property is not a .
+
+
+
+
+ Configures whether or not the property supports Unicode string content.
+
+ Value indicating if the property supports Unicode string content or not.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method throws if the property is not a .
+
+
+
+
+ Configures the property to be fixed length.
+ Use HasMaxLength to set the length that the property is fixed to.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method throws if the property does not have length facets.
+
+
+
+
+ Configures the property to be variable length.
+ Properties are variable length by default.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method throws if the property does not have length facets.
+
+
+
+
+ Configures the property to have the specified maximum length.
+
+ The maximum length for the property.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method throws if the property does not have length facets.
+
+
+
+
+ Configures the property to allow the maximum length supported by the database provider.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method throws if the property does not have length facets.
+
+
+
+
+ Configures the precision of the property.
+ If the database provider does not support precision for the data type of the column then the value is ignored.
+
+ Precision of the property.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method will throw if the property is not a .
+
+
+
+
+ Configures the precision and scale of the property.
+
+ The precision of the property.
+ The scale of the property.
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method will throw if the property is not a .
+
+
+
+
+ Configures the property to be a row version in the database.
+ The actual data type will vary depending on the database provider being used.
+ Setting the property to be a row version will automatically configure it to be an
+ optimistic concurrency token.
+
+
+ The same instance so that multiple calls can be chained.
+
+
+ Calling this will have no effect once it has been configured.
+ This method throws if the property is not a .
+
+
+
+
+ Configures this property to be part of the entity type's primary key.
+
+
+ The same instance so that
+ multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets the for this property.
+
+
+
+
+ An implementation of that does nothing. Using this
+ initializer disables database initialization for the given context type. Passing an instance
+ of this class to is equivalent to passing null.
+ When is being used to resolve initializers an instance of
+ this class must be used to disable initialization.
+
+ The type of the context.
+
+
+
+
+
+
+ FieldMetadata class providing the correlation between the column ordinals and MemberMetadata.
+
+
+
+
+ Initializes a new object with the specified ordinal value and field type.
+
+ An integer specified the location of the metadata.
+ The field type.
+
+
+
+ Gets the type of field for this object.
+
+
+ The type of field for this object.
+
+
+
+
+ Gets the ordinal for this object.
+
+ An integer representing the ordinal value.
+
+
+
+ Class representing a parameter collection used in EntityCommand
+
+
+
+
+ Adds the specified object to the .
+
+
+ The index of the new object.
+
+
+ An .
+
+
+
+
+ Adds an array of values to the end of the
+
+ .
+
+
+ The values to add.
+
+
+
+
+ Removes all the objects from the
+
+ .
+
+
+
+
+ Determines whether the specified is in this
+
+ .
+
+
+ true if the contains the value; otherwise false.
+
+
+ The value.
+
+
+
+
+ Copies all the elements of the current to the specified one-dimensional
+
+ starting at the specified destination index.
+
+
+ The one-dimensional that is the destination of the elements copied from the current
+
+ .
+
+
+ A 32-bit integer that represents the index in the at which copying starts.
+
+
+
+
+ Returns an enumerator that iterates through the
+
+ .
+
+
+ An for the
+
+ .
+
+
+
+
+
+
+
+
+
+
+ Gets the location of the specified with the specified name.
+
+
+ The zero-based location of the specified with the specified case-sensitive name. Returns -1 when the object does not exist in the
+
+ .
+
+
+ The case-sensitive name of the to find.
+
+
+
+
+ Gets the location of the specified in the collection.
+
+
+ The zero-based location of the specified that is a
+
+ in the collection. Returns -1 when the object does not exist in the
+
+ .
+
+
+ The to find.
+
+
+
+
+ Inserts an into the
+
+ at the specified index.
+
+ The zero-based index at which value should be inserted.
+
+ An to be inserted in the
+
+ .
+
+
+
+ Removes the specified parameter from the collection.
+
+ A object to remove from the collection.
+
+
+
+
+ Removes the from the
+
+ at the specified index.
+
+
+ The zero-based index of the object to remove.
+
+
+
+
+ Removes the from the
+
+ at the specified parameter name.
+
+
+ The name of the to remove.
+
+
+
+
+
+
+
+
+
+
+ Adds the specified object to the
+
+ .
+
+
+ A new object.
+
+
+ The to add to the collection.
+
+
+ The specified in the value parameter is already added to this or another
+
+ .
+
+
+ The parameter passed was not a .
+
+ The value parameter is null.
+
+
+
+ Adds a value to the end of the .
+
+
+ A object.
+
+ The name of the parameter.
+ The value to be added.
+
+
+
+ Adds a to the
+
+ given the parameter name and the data type.
+
+
+ A new object.
+
+ The name of the parameter.
+
+ One of the values.
+
+
+
+
+ Adds a to the
+
+ with the parameter name, the data type, and the column length.
+
+
+ A new object.
+
+ The name of the parameter.
+
+ One of the values.
+
+ The column length.
+
+
+
+ Adds an array of values to the end of the
+
+ .
+
+
+ The values to add.
+
+
+
+
+ Determines whether the specified is in this
+
+ .
+
+
+ true if the contains the value; otherwise false.
+
+
+ The value.
+
+
+
+
+ Copies all the elements of the current to the specified
+
+ starting at the specified destination index.
+
+
+ The that is the destination of the elements copied from the current
+
+ .
+
+
+ A 32-bit integer that represents the index in the
+
+ at which copying starts.
+
+
+
+
+ Gets the location of the specified in the collection.
+
+
+ The zero-based location of the specified that is a
+
+ in the collection. Returns -1 when the object does not exist in the
+
+ .
+
+
+ The to find.
+
+
+
+
+ Inserts a object into the
+
+ at the specified index.
+
+ The zero-based index at which value should be inserted.
+
+ A object to be inserted in the
+
+ .
+
+
+
+
+ Removes the specified from the collection.
+
+
+ A object to remove from the collection.
+
+
+ The parameter is not a .
+
+ The parameter does not exist in the collection.
+
+
+
+ Gets an Integer that contains the number of elements in the
+
+ .
+
+
+ The number of elements in the as an Integer.
+
+
+
+
+ Gets a value that indicates whether the
+
+ has a fixed size.
+
+
+ Returns true if the has a fixed size; otherwise false.
+
+
+
+
+ Gets a value that indicates whether the
+
+ is read-only.
+
+
+ Returns true if the is read only; otherwise false.
+
+
+
+
+ Gets a value that indicates whether the
+
+ is synchronized.
+
+
+ Returns true if the is synchronized; otherwise false.
+
+
+
+
+ Gets an object that can be used to synchronize access to the
+
+ .
+
+
+ An object that can be used to synchronize access to the
+
+ .
+
+
+
+
+ Gets the at the specified index.
+
+
+ The at the specified index.
+
+ The zero-based index of the parameter to retrieve.
+ The specified index does not exist.
+
+
+
+ Gets the with the specified name.
+
+
+ The with the specified name.
+
+ The name of the parameter to retrieve.
+ The specified name does not exist.
+
+
+
+ Class representing a command for the conceptual layer
+
+
+
+
+ Initializes a new instance of the class using the specified values.
+
+
+
+
+ Initializes a new instance of the class with the specified statement.
+
+ The text of the command.
+
+
+
+ Constructs the EntityCommand object with the given eSQL statement and the connection object to use
+
+ The eSQL command text to execute
+ The connection object
+ Resolver used to resolve DbProviderServices
+
+
+
+ Initializes a new instance of the class with the specified statement and connection.
+
+ The text of the command.
+ A connection to the data source.
+
+
+
+ Initializes a new instance of the class with the specified statement, connection and transaction.
+
+ The text of the command.
+ A connection to the data source.
+ The transaction in which the command executes.
+
+
+
+ Cancels the execution of an .
+
+
+
+
+ Creates a new instance of an object.
+
+
+ A new instance of an object.
+
+
+
+
+ Create and return a new parameter object representing a parameter in the eSQL statement
+
+ The parameter object.
+
+
+ Executes the command and returns a data reader.
+
+ The that contains the results.
+
+
+
+
+ Compiles the into a command tree and passes it to the underlying store provider for execution, then builds an
+
+ out of the produced result set using the specified
+
+ .
+
+
+ The that contains the results.
+
+
+ One of the values.
+
+
+
+
+ Asynchronously executes the command and returns a data reader for reading the results. May only
+ be called on CommandType.CommandText (otherwise, use the standard Execute* methods)
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an EntityDataReader object.
+
+
+ For stored procedure commands, if called
+ for anything but an entity collection result
+
+
+
+
+ Asynchronously executes the command and returns a data reader for reading the results. May only
+ be called on CommandType.CommandText (otherwise, use the standard Execute* methods)
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an EntityDataReader object.
+
+
+ For stored procedure commands, if called
+ for anything but an entity collection result
+
+
+
+
+ Asynchronously executes the command and returns a data reader for reading the results. May only
+ be called on CommandType.CommandText (otherwise, use the standard Execute* methods)
+
+ The behavior to use when executing the command
+
+ A task that represents the asynchronous operation.
+ The task result contains an EntityDataReader object.
+
+
+ For stored procedure commands, if called
+ for anything but an entity collection result
+
+
+
+
+ Asynchronously executes the command and returns a data reader for reading the results. May only
+ be called on CommandType.CommandText (otherwise, use the standard Execute* methods)
+
+ The behavior to use when executing the command
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an EntityDataReader object.
+
+
+ For stored procedure commands, if called
+ for anything but an entity collection result
+
+
+
+
+ Executes the command and returns a data reader for reading the results
+
+ The behavior to use when executing the command
+ A DbDataReader object
+
+
+
+ Asynchronously executes the command and returns a data reader for reading the results
+
+ The behavior to use when executing the command
+ The token to monitor for cancellation requests
+
+ A task that represents the asynchronous operation.
+ The task result contains a DbDataReader object.
+
+
+
+ Executes the current command.
+ The number of rows affected.
+
+
+
+ Asynchronously executes the command and discard any results returned from the command
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of rows affected.
+
+
+
+ Executes the command, and returns the first column of the first row in the result set. Additional columns or rows are ignored.
+ The first column of the first row in the result set, or a null reference (Nothing in Visual Basic) if the result set is empty.
+
+
+ Compiles the entity-level command and creates a prepared version of the command.
+
+
+ Compiles the entity-level command and returns the store command text.
+ The store command text.
+
+
+
+ Gets or sets the used by the
+
+ .
+
+ The connection used by the entity command.
+
+
+
+ The connection object used for executing the command
+
+
+
+ Gets or sets an Entity SQL statement that specifies a command or stored procedure to execute.
+ The Entity SQL statement that specifies a command or stored procedure to execute.
+
+
+ Gets or sets the command tree to execute; only one of the command tree or the command text can be set, not both.
+ The command tree to execute.
+
+
+ Gets or sets the amount of time to wait before timing out.
+ The time in seconds to wait for the command to execute.
+
+
+
+ Gets or sets a value that indicates how the
+
+ property is to be interpreted.
+
+
+ One of the enumeration values.
+
+
+
+ Gets the parameters of the Entity SQL statement or stored procedure.
+ The parameters of the Entity SQL statement or stored procedure.
+
+
+
+ The collection of parameters for this command
+
+
+
+
+ Gets or sets the transaction within which the executes.
+
+
+ The transaction within which the executes.
+
+
+
+
+ The transaction that this command executes in
+
+
+
+ Gets or sets how command results are applied to rows being updated.
+
+ One of the values.
+
+
+
+ Gets or sets a value that indicates whether the command object should be visible in a Windows Form Designer control.
+ true if the command object should be visible in a Windows Form Designer control; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the query plan caching is enabled.
+ true if the query plan caching is enabled; otherwise, false.
+
+
+
+ Class representing a connection for the conceptual layer. An entity connection may only
+ be initialized once (by opening the connection). It is subsequently not possible to change
+ the connection string, attach a new store connection, or change the store connection string.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class, based on the connection string.
+
+ The provider-specific connection string.
+ An invalid connection string keyword has been provided, or a required connection string keyword has not been provided.
+
+
+
+ Initializes a new instance of the class with a specified
+ and
+ .
+
+
+ A to be associated with this
+ .
+
+
+ The underlying data source connection for this object.
+
+ The workspace or connection parameter is null.
+ The conceptual model is missing from the workspace.-or-The mapping file is missing from the workspace.-or-The storage model is missing from the workspace.-or-The connection is not in a closed state.
+ The connection is not from an ADO.NET Entity Framework-compatible provider.
+
+
+
+ Constructs the EntityConnection from Metadata loaded in memory
+
+ Workspace containing metadata information.
+ Store connection.
+ If set to true the store connection is disposed when the entity connection is disposed, otherwise the caller must dispose the store connection.
+
+
+
+ Returns the associated with this
+
+ .
+
+
+ The associated with this
+
+ .
+
+ The inline connection string contains an invalid Metadata keyword value.
+
+
+ Establishes a connection to the data source by calling the underlying data provider's Open method.
+ An error occurs when you open the connection, or the name of the underlying data provider is not known.
+ The inline connection string contains an invalid Metadata keyword value.
+
+
+
+ Asynchronously establishes a connection to the data store by calling the Open method on the underlying data provider
+
+
+ A to observe while waiting for the task to complete.
+
+ A task that represents the asynchronous operation.
+
+
+
+ Creates a new instance of an , with the
+
+ set to this
+
+ .
+
+
+ An object.
+
+ The name of the underlying data provider is not known.
+
+
+
+ Create a new command object that uses this connection object
+
+ The command object.
+
+
+ Closes the connection to the database.
+ An error occurred when closing the connection.
+
+
+ Not supported.
+ Not supported.
+ When the method is called.
+
+
+ Begins a transaction by using the underlying provider.
+
+ A new . The returned
+
+ instance can later be associated with the
+
+ to execute the command under that transaction.
+
+
+ The underlying provider is not known.-or-The call to
+
+ was made on an
+
+ that already has a current transaction.-or-The state of the
+
+ is not
+
+ .
+
+
+
+ Begins a transaction with the specified isolation level by using the underlying provider.
+
+ A new . The returned
+
+ instance can later be associated with the
+
+ to execute the command under that transaction.
+
+ The isolation level of the transaction.
+
+ The underlying provider is not known.-or-The call to
+
+ was made on an
+
+ that already has a current transaction.-or-The state of the
+
+ is not
+
+ .
+
+
+
+
+ Begins a database transaction
+
+ The isolation level of the transaction
+ An object representing the new transaction
+
+
+
+ Enlists this in the specified transaction.
+
+ The transaction object to enlist into.
+
+ The state of the is not
+
+ .
+
+
+
+
+ Cleans up this connection object
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources
+
+
+
+ Gets or sets the connection string.
+
+ The connection string required to establish the initial connection to a data source. The default value is an empty string. On a closed connection, the currently set value is returned. If no value has been set, an empty string is returned.
+
+ An attempt was made to set the property after the
+
+ ’s was initialized. The
+
+ is initialized either when the instance is constructed through the overload that takes a
+
+ as a parameter, or when the
+
+ instance has been opened.
+
+ An invalid connection string keyword has been provided or a required connection string keyword has not been provided.
+
+
+ Gets the number of seconds to wait when attempting to establish a connection before ending the attempt and generating an error.
+ The time (in seconds) to wait for a connection to open. The default value is the underlying data provider's default time-out.
+ The value set is less than 0.
+
+
+ Gets the name of the current database, or the database that will be used after a connection is opened.
+ The value of the Database property of the underlying data provider.
+ The underlying data provider is not known.
+
+
+
+ Gets the state of the EntityConnection, which is set up to track the state of the underlying
+ database connection that is wrapped by this EntityConnection.
+
+
+
+ Gets the name or network address of the data source to connect to.
+ The name of the data source. The default value is an empty string.
+ The underlying data provider is not known.
+
+
+ Gets a string that contains the version of the data source to which the client is connected.
+ The version of the data source that is contained in the provider connection string.
+ The connection is closed.
+
+
+
+ Gets the provider factory associated with EntityConnection
+
+
+
+
+ Provides access to the underlying data source connection that is used by the
+
+ object.
+
+
+ The for the data source connection.
+
+
+
+
+ Gets the current transaction that this connection is enlisted in. May be null.
+
+
+
+
+ Class representing a connection string builder for the entity client provider
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class using the supplied connection string.
+
+ A provider-specific connection string to the underlying data source.
+
+
+
+ Clears the contents of the instance.
+
+
+
+
+ Determines whether the contains a specific key.
+
+
+ Returns true if the contains an element that has the specified key; otherwise, false.
+
+
+ The key to locate in the .
+
+
+
+
+ Retrieves a value corresponding to the supplied key from this
+
+ .
+
+ Returns true if keyword was found in the connection string; otherwise, false.
+ The key of the item to retrieve.
+ The value corresponding to keyword.
+ keyword contains a null value (Nothing in Visual Basic).
+
+
+
+ Removes the entry with the specified key from the
+
+ instance.
+
+ Returns true if the key existed in the connection string and was removed; false if the key did not exist.
+
+ The key of the keyword/value pair to be removed from the connection string in this
+
+ .
+
+ keyword is null (Nothing in Visual Basic)
+
+
+ Gets or sets the name of a section as defined in a configuration file.
+ The name of a section in a configuration file.
+
+
+ Gets or sets the name of the underlying .NET Framework data provider in the connection string.
+ The invariant name of the underlying .NET Framework data provider.
+
+
+ Gets or sets the metadata locations in the connection string.
+ Gets or sets the metadata locations in the connection string.
+
+
+ Gets or sets the inner, provider-specific connection string.
+ The inner, provider-specific connection string.
+
+
+
+ Gets a value that indicates whether the
+
+ has a fixed size.
+
+
+ Returns true in every case, because the
+
+ supplies a fixed-size collection of keyword/value pairs.
+
+
+
+
+ Gets an that contains the keys in the
+
+ .
+
+
+ An that contains the keys in the
+
+ .
+
+
+
+ Gets or sets the value associated with the specified key. In C#, this property is the indexer.
+ The value associated with the specified key.
+ The key of the item to get or set.
+ keyword is a null reference (Nothing in Visual Basic).
+ Tried to add a key that does not exist in the available keys.
+ Invalid value in the connection string (specifically, a Boolean or numeric value was expected but not supplied).
+
+
+
+ A data reader class for the entity client provider
+
+
+
+
+ Closes the object.
+
+
+
+
+ Releases the resources consumed by this and calls
+
+ .
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Gets the value of the specified column as a Boolean.
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the value of the specified column as a byte.
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Reads a stream of bytes from the specified column, starting at location indicated by dataIndex , into the buffer, starting at the location indicated by bufferIndex .
+ The actual number of bytes read.
+ The zero-based column ordinal.
+ The index within the row from which to begin the read operation.
+ The buffer into which to copy the data.
+ The index with the buffer to which the data will be copied.
+ The maximum number of characters to read.
+
+
+ Gets the value of the specified column as a single character.
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Reads a stream of characters from the specified column, starting at location indicated by dataIndex , into the buffer, starting at the location indicated by bufferIndex .
+ The actual number of characters read.
+ The zero-based column ordinal.
+ The index within the row from which to begin the read operation.
+ The buffer into which to copy the data.
+ The index with the buffer to which the data will be copied.
+ The maximum number of characters to read.
+
+
+ Gets the name of the data type of the specified column.
+ The name of the data type.
+ The zero-based column ordinal.
+
+
+
+ Gets the value of the specified column as a object.
+
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+
+ Returns a object for the requested column ordinal that can be overridden with a provider-specific implementation.
+
+ A data reader.
+ The zero-based column ordinal.
+
+
+
+ Gets the value of the specified column as a object.
+
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the value of the specified column as a double-precision floating point number.
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the data type of the specified column.
+ The data type of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the value of the specified column as a single-precision floating point number.
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the value of the specified column as a globally-unique identifier (GUID).
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the value of the specified column as a 16-bit signed integer.
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the value of the specified column as a 32-bit signed integer.
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the value of the specified column as a 64-bit signed integer.
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the name of the column, given the zero-based column ordinal.
+ The name of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets the column ordinal given the name of the column.
+ The zero-based column ordinal.
+ The name of the column.
+ The name specified is not a valid column name.
+
+
+ Returns the provider-specific field type of the specified column.
+
+ The object that describes the data type of the specified column.
+
+ The zero-based column ordinal.
+
+
+
+ Gets the value of the specified column as an instance of .
+
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Gets all provider-specific attribute columns in the collection for the current row.
+
+ The number of instances of in the array.
+
+
+ An array of into which to copy the attribute columns.
+
+
+
+
+ Returns a that describes the column metadata of the
+
+ .
+
+
+ A that describes the column metadata.
+
+
+
+
+ Gets the value of the specified column as an instance of .
+
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+
+ Gets the value of the specified column as an instance of .
+
+ The value of the specified column.
+ The zero-based column ordinal.
+
+
+ Populates an array of objects with the column values of the current row.
+
+ The number of instances of in the array.
+
+
+ An array of into which to copy the attribute columns.
+
+
+
+ Gets a value that indicates whether the column contains nonexistent or missing values.
+
+ true if the specified column is equivalent to ; otherwise, false.
+
+ The zero-based column ordinal.
+
+
+ Advances the reader to the next result when reading the results of a batch of statements.
+ true if there are more result sets; otherwise, false.
+
+
+
+ Asynchronously moves the reader to the next result set when reading a batch of statements
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if there are more result sets; false otherwise.
+
+
+
+ Advances the reader to the next record in a result set.
+ true if there are more rows; otherwise, false.
+
+
+
+ Asynchronously moves the reader to the next row of the current result set
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains true if there are more rows; false otherwise.
+
+
+
+
+ Returns an that can be used to iterate through the rows in the data reader.
+
+
+ An that can be used to iterate through the rows in the data reader.
+
+
+
+
+ Returns a nested .
+
+ The nested data record.
+ The number of the DbDataRecord to return.
+
+
+
+ Returns nested readers as objects.
+
+
+ The nested readers as objects.
+
+ The ordinal of the column.
+
+
+ Gets a value indicating the depth of nesting for the current row.
+ The depth of nesting for the current row.
+
+
+ Gets the number of columns in the current row.
+ The number of columns in the current row.
+
+
+
+ Gets a value that indicates whether this contains one or more rows.
+
+
+ true if the contains one or more rows; otherwise, false.
+
+
+
+
+ Gets a value indicating whether the is closed.
+
+
+ true if the is closed; otherwise, false.
+
+
+
+ Gets the number of rows changed, inserted, or deleted by execution of the SQL statement.
+ The number of rows changed, inserted, or deleted. Returns -1 for SELECT statements; 0 if no rows were affected or the statement failed.
+
+
+
+ Gets the value of the specified column as an instance of .
+
+ The value of the specified column.
+ The zero-based column ordinal
+
+
+
+ Gets the value of the specified column as an instance of .
+
+ The value of the specified column.
+ The name of the column.
+
+
+
+ Gets the number of fields in the that are not hidden.
+
+ The number of fields that are not hidden.
+
+
+
+ Gets for this
+
+ .
+
+ The information of a data record.
+
+
+
+ Class representing a parameter used in EntityCommand
+
+
+
+
+ Initializes a new instance of the class using the default values.
+
+
+
+
+ Initializes a new instance of the class using the specified parameter name and data type.
+
+ The name of the parameter.
+
+ One of the values.
+
+
+
+
+ Initializes a new instance of the class using the specified parameter name, data type and size.
+
+ The name of the parameter.
+
+ One of the values.
+
+ The size of the parameter.
+
+
+
+ Initializes a new instance of the class using the specified properties.
+
+ The name of the parameter.
+
+ One of the values.
+
+ The size of the parameter.
+ The name of the source column.
+
+
+
+ Initializes a new instance of the class using the specified properties.
+
+ The name of the parameter.
+
+ One of the values.
+
+ The size of the parameter.
+
+ One of the values.
+
+ true to indicate that the parameter accepts null values; otherwise, false.
+ The number of digits used to represent the value.
+ The number of decimal places to which value is resolved.
+ The name of the source column.
+
+ One of the values.
+
+ The value of the parameter.
+
+
+
+ Resets the type associated with the .
+
+
+
+ Returns a string representation of the parameter.
+ A string representation of the parameter.
+
+
+ Gets or sets the name of the entity parameter.
+ The name of the entity parameter.
+
+
+
+ Gets or sets the of the parameter.
+
+
+ One of the values.
+
+
+
+ Gets or sets the type of the parameter, expressed as an EdmType.
+ The type of the parameter, expressed as an EdmType.
+
+
+
+ Gets or sets the number of digits used to represent the
+
+ property.
+
+ The number of digits used to represent the value.
+
+
+
+ Gets or sets the number of decimal places to which
+
+ is resolved.
+
+ The number of decimal places to which value is resolved.
+
+
+ Gets or sets the value of the parameter.
+ The value of the parameter.
+
+
+ Gets or sets the direction of the parameter.
+
+ One of the values.
+
+
+
+ Gets or sets a value that indicates whether the parameter accepts null values.
+ true if null values are accepted; otherwise, false.
+
+
+ Gets or sets the maximum size of the data within the column.
+ The maximum size of the data within the column.
+
+
+
+ Gets or sets the name of the source column mapped to the and used for loading or returning the
+
+ .
+
+ The name of the source column mapped to the dataset and used for loading or returning the value.
+
+
+ Gets or sets a value that indicates whether source column is nullable.
+ true if source column is nullable; otherwise, false.
+
+
+
+ Gets or sets the to use when loading the value.
+
+
+ One of the values.
+
+
+
+
+ Class representing a provider factory for the entity client provider
+
+
+
+
+ A singleton object for the entity client provider factory object.
+ This remains a public field (not property) because DbProviderFactory expects a field.
+
+
+
+
+ Returns a new instance of the provider's class that implements the
+
+ class.
+
+
+ A new instance of .
+
+
+
+
+ Throws a . This method is currently not supported.
+
+ This method is currently not supported.
+
+
+
+ Returns a new instance of the provider's class that implements the
+
+ class.
+
+
+ A new instance of .
+
+
+
+
+ Returns a new instance of the provider's class that implements the
+
+ class.
+
+
+ A new instance of .
+
+
+
+
+ Throws a . This method is currently not supported.
+
+ This method is currently not supported.
+
+
+
+ Returns a new instance of the provider's class that implements the
+
+ class.
+
+
+ A new instance of .
+
+
+
+
+ Throws a . This method is currently not supported.
+
+ This method is currently not supported.
+ This method is currently not supported.
+
+
+
+ Returns the requested class.
+
+
+ A new instance of . The supported types are
+
+ ,
+
+ , and
+
+ . Returns null (or Nothing in Visual Basic) for every other type.
+
+
+ The to return.
+
+
+
+
+ Class representing a transaction for the conceptual layer
+
+
+
+ Commits the underlying transaction.
+
+
+ Rolls back the underlying transaction.
+
+
+
+ Cleans up this transaction object
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources
+
+
+
+ Gets for this
+
+ .
+
+
+ An to the underlying data source.
+
+
+
+
+ The connection object owning this transaction object
+
+
+
+
+ Gets the isolation level of this .
+
+
+ An enumeration value that represents the isolation level of the underlying transaction.
+
+
+
+
+ Gets the DbTransaction for the underlying provider transaction.
+
+
+
+
+ Represents a failure while trying to prepare or execute a CommandCompilation
+ This exception is intended to provide a common exception that people can catch to
+ hold provider exceptions (SqlException, OracleException) when using the EntityCommand
+ to execute statements.
+
+
+
+
+ Initializes a new instance of .
+
+
+
+
+ Initializes a new instance of .
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of .
+
+ The error message that explains the reason for the exception.
+ The exception that caused the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Represents a failure while trying to prepare or execute a CommandExecution
+ This exception is intended to provide a common exception that people can catch to
+ hold provider exceptions (SqlException, OracleException) when using the EntityCommand
+ to execute statements.
+
+
+
+
+ Initializes a new instance of .
+
+
+
+
+ Initializes a new instance of .
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of .
+
+ The error message that explains the reason for the exception.
+ The exception that caused the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ An identifier for an entity.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class with an entity set name and a generic
+
+ collection.
+
+
+ A that is the entity set name qualified by the entity container name.
+
+
+ A generic collection.Each key/value pair has a property name as the key and the value of that property as the value. There should be one pair for each property that is part of the
+
+ . The order of the key/value pairs is not important, but each key property should be included. The property names are simple names that are not qualified with an entity type name or the schema name.
+
+
+
+
+ Initializes a new instance of the class with an entity set name and an
+
+ collection of
+
+ objects.
+
+
+ A that is the entity set name qualified by the entity container name.
+
+
+ An collection of
+
+ objects with which to initialize the key.
+
+
+
+
+ Initializes a new instance of the class with an entity set name and specific entity key pair.
+
+
+ A that is the entity set name qualified by the entity container name.
+
+
+ A that is the name of the key.
+
+
+ An that is the key value.
+
+
+
+ Gets the entity set for this entity key from the given metadata workspace.
+
+ The for the entity key.
+
+ The metadata workspace that contains the entity.
+ The entity set could not be located in the specified metadata workspace.
+
+
+ Returns a value that indicates whether this instance is equal to a specified object.
+ true if this instance and obj have equal values; otherwise, false.
+
+ An to compare with this instance.
+
+
+
+
+ Returns a value that indicates whether this instance is equal to a specified
+
+ .
+
+ true if this instance and other have equal values; otherwise, false.
+
+ An object to compare with this instance.
+
+
+
+
+ Serves as a hash function for the current object.
+
+ is suitable for hashing algorithms and data structures such as a hash table.
+
+
+ A hash code for the current .
+
+
+
+
+ Compares two objects.
+
+ true if the key1 and key2 values are equal; otherwise, false.
+
+ A to compare.
+
+
+ A to compare.
+
+
+
+
+ Compares two objects.
+
+ true if the key1 and key2 values are not equal; otherwise, false.
+
+ A to compare.
+
+
+ A to compare.
+
+
+
+
+ Helper method that is used to deserialize an .
+
+ Describes the source and destination of a given serialized stream, and provides an additional caller-defined context.
+
+
+
+ Helper method that is used to deserialize an .
+
+ Describes the source and destination of a given serialized stream and provides an additional caller-defined context.
+
+
+
+ Gets a singleton EntityKey by which a read-only entity is identified.
+
+
+
+
+ Gets a singleton EntityKey identifying an entity resulted from a failed TREAT.
+
+
+
+ Gets or sets the name of the entity set.
+
+ A value that is the name of the entity set for the entity to which the
+
+ belongs.
+
+
+
+ Gets or sets the name of the entity container.
+
+ A value that is the name of the entity container for the entity to which the
+
+ belongs.
+
+
+
+
+ Gets or sets the key values associated with this .
+
+
+ A of key values for this
+
+ .
+
+
+
+
+ Gets a value that indicates whether the is temporary.
+
+
+ true if the is temporary; otherwise, false.
+
+
+
+
+ Information about a key that is part of an EntityKey.
+ A key member contains the key name and value.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class with the specified entity key pair.
+
+ The name of the key.
+ The key value.
+
+
+ Returns a string representation of the entity key.
+ A string representation of the entity key.
+
+
+ Gets or sets the name of the entity key.
+ The key name.
+
+
+ Gets or sets the value of the entity key.
+ The key value.
+
+
+
+ Kind of collection (applied to Properties)
+
+
+
+
+ Property is not a Collection
+
+
+
+
+ Collection has Bag semantics( unordered and duplicates ok)
+
+
+
+
+ Collection has List semantics
+ (Order is deterministic and duplicates ok)
+
+
+
+
+ The concurrency mode for properties.
+
+
+
+
+ Default concurrency mode: the property is never validated
+ at write time
+
+
+
+
+ Fixed concurrency mode: the property is always validated at
+ write time
+
+
+
+
+ The pattern for Server Generated Properties.
+
+
+
+
+ Not a Server Generated Property. This is the default.
+
+
+
+
+ A value is generated on INSERT, and remains unchanged on update.
+
+
+
+
+ A value is generated on both INSERT and UPDATE.
+
+
+
+
+ Represents an eSQL Query compilation exception;
+ The class of exceptional conditions that may cause this exception to be raised are mainly:
+ 1) Syntax Errors: raised during query text parsing and when a given query does not conform to eSQL formal grammar;
+ 2) Semantic Errors: raised when semantic rules of eSQL language are not met such as metadata or schema information
+ not accurate or not present, type validation errors, scoping rule violations, user of undefined variables, etc.
+ For more information, see eSQL Language Spec.
+
+
+
+
+ Initializes a new instance of .
+
+
+
+
+ Initializes a new instance of with a specialized error message.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of the class that uses a specified error message and a reference to the inner exception that is the cause of this exception.
+
+ The error message that explains the reason for the exception.
+ The exception that caused the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+ Gets a description of the error.
+ A string that describes the error.
+
+
+ Gets the approximate context where the error occurred, if available.
+ A string that describes the approximate context where the error occurred, if available.
+
+
+ Gets the approximate line number where the error occurred.
+ An integer that describes the line number where the error occurred.
+
+
+ Gets the approximate column number where the error occurred.
+ An integer that describes the column number where the error occurred.
+
+
+
+ Thrown to indicate that a command tree is invalid.
+
+
+
+
+ Initializes a new instance of the class with a default message.
+
+
+
+
+ Initializes a new instance of the class with the specified message.
+
+ The exception message.
+
+
+
+ Initializes a new instance of the class with the specified message and inner exception.
+
+ The exception message.
+
+ The exception that is the cause of this .
+
+
+
+
+ Mapping exception class. Note that this class has state - so if you change even
+ its internals, it can be a breaking change
+
+
+
+
+ Initializes a new instance of .
+
+
+
+
+ Initializes a new instance of with a specialized error message.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of that uses a specified error message and a reference to the inner exception.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Class for representing a collection of mapping items in Edm space.
+
+
+
+
+ Base class for the type created at design time to store the generated views.
+
+
+
+ Returns the key/value pair at the specified index, which contains the view and its key.
+ The key/value pair at index , which contains the view and its key.
+ The index of the view.
+
+
+
+ Gets or sets the name of .
+
+ The container name.
+
+
+
+ Gets or sets in storage schema.
+
+ Container name.
+
+
+ Hash value.
+ Hash value.
+
+
+ Hash value of views.
+ Hash value.
+
+
+ Gets or sets view count.
+ View count.
+
+
+
+ Attribute to mark the assemblies that contain the generated views type.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The view type.
+
+
+ Gets the T:System.Type of the view.
+ The T:System.Type of the view.
+
+
+
+ Represents a complex type mapping for a function import result.
+
+
+
+
+ Specifies a function import structural type mapping.
+
+
+
+
+ Gets the property mappings for the result type of a function import.
+
+
+
+
+ Initializes a new FunctionImportComplexTypeMapping instance.
+
+ The return type.
+ The property mappings for the result type of a function import.
+
+
+
+ Ges the return type.
+
+
+
+
+ Represents a function import entity type mapping.
+
+
+
+
+ Initializes a new FunctionImportEntityTypeMapping instance.
+
+ The entity types at the base of
+ the type hierarchies to be mapped.
+ The entity types to be mapped.
+ The property mappings for the result types of a function import.
+ The mapping conditions.
+
+
+
+ Gets the entity types being mapped.
+
+
+
+
+ Gets the entity types at the base of the hierarchies being mapped.
+
+
+
+
+ Gets the mapping conditions.
+
+
+
+
+ Represents a mapping condition for a function import result.
+
+
+
+
+
+
+
+ Gets the name of the column used to evaluate the condition.
+
+
+
+
+ Represents a mapping condition for the result of a function import
+ evaluated by checking null or not null.
+
+
+
+
+ Initializes a new FunctionImportEntityTypeMappingConditionIsNull instance.
+
+ The name of the column used to evaluate the condition.
+ Flag that indicates whether a null or not null check is performed.
+
+
+
+ Gets a flag that indicates whether a null or not null check is performed.
+
+
+
+
+ Represents a mapping condition for the result of a function import,
+ evaluated by comparison with a specified value.
+
+
+
+
+ Initializes a new FunctionImportEntityTypeMappingConditionValue instance.
+
+ The name of the column used to evaluate the condition.
+ The value to compare with.
+
+
+
+ Gets the value used for comparison.
+
+
+
+
+ Represents a mapping from a model function import to a store composable or non-composable function.
+
+
+
+
+ Gets model function (or source of the mapping)
+
+
+
+
+ Gets store function (or target of the mapping)
+
+
+
+
+ Represents a mapping from a model function import to a store composable function.
+
+
+
+
+ Initializes a new FunctionImportMappingComposable instance.
+
+ The model function import.
+ The store composable function.
+ The result mapping for the function import.
+ The parent container mapping.
+
+
+
+ Gets the result mapping for the function import.
+
+
+
+
+ Represents a mapping from a model function import to a store non-composable function.
+
+
+
+
+ Initializes a new FunctionImportMappingNonComposable instance.
+
+ The model function import.
+ The store non-composable function.
+ The function import result mappings.
+ The parent container mapping.
+
+
+
+ Gets the function import result mappings.
+
+
+
+
+ Base class for mapping a property of a function import return type.
+
+
+
+
+ Maps a function import return type property to a table column.
+
+
+
+
+ Initializes a new FunctionImportReturnTypeScalarPropertyMapping instance.
+
+ The mapped property name.
+ The mapped column name.
+
+
+
+ Gets the mapped property name.
+
+
+
+
+ Gets the mapped column name.
+
+
+
+
+ Represents the base item class for all the mapping metadata
+
+
+
+
+ Represents the base item class for all the metadata
+
+
+
+
+ Describes modification function mappings for an association set.
+
+
+
+
+ Initalizes a new AssociationSetModificationFunctionMapping instance.
+
+ An association set.
+ A delete function mapping.
+ An insert function mapping.
+
+
+
+
+
+
+ Gets the association set.
+
+
+
+
+ Gets the delete function mapping.
+
+
+
+
+ Gets the insert function mapping.
+
+
+
+
+ Describes modification function mappings for an entity type within an entity set.
+
+
+
+
+ Initializes a new EntityTypeModificationFunctionMapping instance.
+
+ An entity type.
+ A delete function mapping.
+ An insert function mapping.
+ An updated function mapping.
+
+
+
+
+
+
+ Gets the entity type.
+
+
+
+
+ Gets the delete function mapping.
+
+
+
+
+ Gets the insert function mapping.
+
+
+
+
+ Gets hte update function mapping.
+
+
+
+
+ Describes the location of a member within an entity or association type structure.
+
+
+
+
+ Initializes a new ModificationFunctionMemberPath instance.
+
+ Gets the members in the path from the leaf (the member being bound)
+ to the root of the structure.
+ Gets the association set to which we are navigating
+ via this member. If the value is null, this is not a navigation member path.
+
+
+
+
+
+
+ Gets the members in the path from the leaf (the member being bound)
+ to the Root of the structure.
+
+
+
+
+ Gets the association set to which we are navigating via this member. If the value
+ is null, this is not a navigation member path.
+
+
+
+
+ Binds a modification function parameter to a member of the entity or association being modified.
+
+
+
+
+ Initializes a new ModificationFunctionParameterBinding instance.
+
+ The parameter taking the value.
+ The path to the entity or association member defining the value.
+ A flag indicating whether the current or original member value is being bound.
+
+
+
+
+
+
+ Gets the parameter taking the value.
+
+
+
+
+ Gets the path to the entity or association member defining the value.
+
+
+
+
+ Gets a flag indicating whether the current or original
+ member value is being bound.
+
+
+
+
+ Defines a binding from a named result set column to a member taking the value.
+
+
+
+
+ Initializes a new ModificationFunctionResultBinding instance.
+
+ The name of the column to bind from the function result set.
+ The property to be set on the entity.
+
+
+
+
+
+
+ Gets the name of the column to bind from the function result set.
+
+
+
+
+ Gets the property to be set on the entity.
+
+
+
+
+ Represents the Mapping metadata for an AssociationSet in CS space.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityTypeMapping
+ --MappingFragment
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ This class represents the metadata for the AssociationSetMapping elements in the
+ above example. And it is possible to access the AssociationTypeMap underneath it.
+ There will be only one TypeMap under AssociationSetMap.
+
+
+
+
+ Represents the Mapping metadata for an Extent in CS space.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityTypeMapping
+ --MappingFragment
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ This class represents the metadata for all the extent map elements in the
+ above example namely EntitySetMapping, AssociationSetMapping and CompositionSetMapping.
+ The EntitySetBaseMapping elements that are children of the EntityContainerMapping element
+ can be accessed through the properties on this type.
+
+
+
+
+ Gets the parent container mapping.
+
+
+
+
+ Gets or sets the query view associated with this mapping.
+
+
+
+
+ Initializes a new AssociationSetMapping instance.
+
+ The association set to be mapped.
+ The store entity set to be mapped.
+ The parent container mapping.
+
+
+
+ Adds a property mapping condition.
+
+ The condition to add.
+
+
+
+ Removes a property mapping condition.
+
+ The property mapping condition to remove.
+
+
+
+ Gets the association set that is mapped.
+
+
+
+
+ Gets the contained association type mapping.
+
+
+
+
+ Gets or sets the corresponding function mapping. Can be null.
+
+
+
+
+ Gets the store entity set that is mapped.
+
+
+
+
+ Gets or sets the source end property mapping.
+
+
+
+
+ Gets or sets the target end property mapping.
+
+
+
+
+ Gets the property mapping conditions.
+
+
+
+
+ Represents the Mapping metadata for an association type map in CS space.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap
+ --ScalarPropertyMap
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap
+ --ComplexPropertyMap
+ --ComplexTypeMap
+ --ScalarPropertyMap
+ --ScalarProperyMap
+ --ScalarPropertyMap
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap
+ --ScalarProperyMap
+ --EndPropertyMap
+ --ScalarPropertyMap
+ This class represents the metadata for all association Type map elements in the
+ above example. Users can access the table mapping fragments under the
+ association type mapping through this class.
+
+
+
+
+ Represents the Mapping metadata for a type map in CS space.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap
+ --ScalarPropertyMap
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap
+ --ComplexPropertyMap
+ --ScalarPropertyMap
+ --ScalarProperyMap
+ --ScalarPropertyMap
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap
+ --ScalarProperyMap
+ --EndPropertyMap
+ --ScalarPropertyMap
+ This class represents the metadata for all the Type map elements in the
+ above example namely EntityTypeMapping, AssociationTypeMapping and CompositionTypeMapping.
+ The TypeMapping elements contain TableMappingFragments which in turn contain the property maps.
+
+
+
+
+ Creates an AssociationTypeMapping instance.
+
+ The AssociationSetMapping that
+ the contains this AssociationTypeMapping.
+
+
+
+ Gets the AssociationSetMapping that contains this AssociationTypeMapping.
+
+
+
+
+ Gets the association type being mapped.
+
+
+
+
+ Gets the single mapping fragment.
+
+
+
+
+ Mapping metadata for Complex properties.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ComplexPropertyMap
+ --ComplexTypeMapping
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --DiscriminatorProperyMap ( constant value-->SMemberMetadata )
+ --ComplexTypeMapping
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --DiscriminatorProperyMap ( constant value-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ This class represents the metadata for all the complex property map elements in the
+ above example. ComplexPropertyMaps contain ComplexTypeMaps which define mapping based
+ on the type of the ComplexProperty in case of inheritance.
+
+
+
+
+ Construct a new Complex Property mapping object
+
+ The MemberMetadata object that represents this Complex member
+
+
+
+ Adds a type mapping corresponding to a nested complex type.
+
+ The complex type mapping to be added.
+
+
+
+ Removes a type mapping corresponding to a nested complex type.
+
+ The complex type mapping to be removed.
+
+
+
+ Gets a read only collections of type mappings corresponding to the
+ nested complex types.
+
+
+
+
+ Mapping metadata for Complex Types.
+
+
+
+
+ Creates a ComplexTypeMapping instance.
+
+ The ComplexType being mapped.
+
+
+
+ Adds a property mapping.
+
+ The property mapping to be added.
+
+
+
+ Removes a property mapping.
+
+ The property mapping to be removed.
+
+
+
+ Adds a property mapping condition.
+
+ The property mapping condition to be added.
+
+
+
+ Removes a property mapping condition.
+
+ The property mapping condition to be removed.
+
+
+
+ Gets the ComplexType being mapped.
+
+
+
+
+ Gets a read-only collection of property mappings.
+
+
+
+
+ Gets a read-only collection of property mapping conditions.
+
+
+
+
+ Mapping metadata for End property of an association.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ComplexPropertyMap
+ --ComplexTypeMapping
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --DiscriminatorProperyMap ( constant value-->SMemberMetadata )
+ --ComplexTypeMapping
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --DiscriminatorProperyMap ( constant value-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ This class represents the metadata for all the end property map elements in the
+ above example. EndPropertyMaps provide mapping for each end of the association.
+
+
+
+
+ Creates an association end property mapping.
+
+ An AssociationEndMember that specifies
+ the association end to be mapped.
+
+
+
+ Adds a child property-column mapping.
+
+ A ScalarPropertyMapping that specifies
+ the property-column mapping to be added.
+
+
+
+ Removes a child property-column mapping.
+
+ A ScalarPropertyMapping that specifies
+ the property-column mapping to be removed.
+
+
+
+ Gets an AssociationEndMember that specifies the mapped association end.
+
+
+
+
+ Gets a ReadOnlyCollection of ScalarPropertyMapping that specifies the children
+ of this association end property mapping.
+
+
+
+
+ Represents the Mapping metadata for the EntityContainer map in CS space.
+ Only one EntityContainerMapping element is allowed in the MSL file for CS mapping.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ ---Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --AssociationSetMapping
+ The type represents the metadata for EntityContainerMapping element in the above example.
+ The EntitySetBaseMapping elements that are children of the EntityContainerMapping element
+ can be accessed through the properties on this type.
+
+
+ We currently assume that an Entity Container on the C side
+ is mapped to a single Entity Container in the S - space.
+
+
+
+
+ Initializes a new EntityContainerMapping instance.
+
+ The conceptual entity container to be mapped.
+ The store entity container to be mapped.
+ The parent mapping item collection.
+ Flag indicating whether to generate update views.
+
+
+
+ Adds an entity set mapping.
+
+ The entity set mapping to add.
+
+
+
+ Removes an association set mapping.
+
+ The association set mapping to remove.
+
+
+
+ Adds an association set mapping.
+
+ The association set mapping to add.
+
+
+
+ Removes an association set mapping.
+
+ The association set mapping to remove.
+
+
+
+ Adds a function import mapping.
+
+ The function import mapping to add.
+
+
+
+ Removes a function import mapping.
+
+ The function import mapping to remove.
+
+
+
+ Gets the parent mapping item collection.
+
+
+
+
+ Gets the type kind for this item
+
+
+
+
+ Gets the conceptual entity container.
+
+
+
+
+ Gets the store entity container.
+
+
+
+
+ Gets the entity set mappings.
+
+
+
+
+ Gets the association set mappings.
+
+
+
+
+ Gets the function import mappings.
+
+
+
+
+ Gets a flag that indicates whether to generate the update views or not.
+
+
+
+
+ Represents the Mapping metadata for an EnitytSet in CS space.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityTypeMapping
+ --MappingFragment
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ This class represents the metadata for the EntitySetMapping elements in the
+ above example. And it is possible to access the EntityTypeMaps underneath it.
+
+
+
+
+ Initialiazes a new EntitySetMapping instance.
+
+ The entity set to be mapped.
+ The parent container mapping.
+
+
+
+ Adds a type mapping.
+
+ The type mapping to add.
+
+
+
+ Removes a type mapping.
+
+ The type mapping to remove.
+
+
+
+ Adds a function mapping.
+
+ The function mapping to add.
+
+
+
+ Removes a function mapping.
+
+ The function mapping to remove.
+
+
+
+ Gets the entity set that is mapped.
+
+
+
+
+ Gets the contained entity type mappings.
+
+
+
+
+ Gets the corresponding function mappings.
+
+
+
+
+ Mapping metadata for Entity type.
+ If an EntitySet represents entities of more than one type, than we will have
+ more than one EntityTypeMapping for an EntitySet( For ex : if
+ PersonSet Entity extent represents entities of types Person and Customer,
+ than we will have two EntityType Mappings under mapping for PersonSet).
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap
+ --ScalarPropertyMap
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap
+ --ComplexPropertyMap
+ --ScalarPropertyMap
+ --ScalarProperyMap
+ --ScalarPropertyMap
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap
+ --ScalarProperyMap
+ --EndPropertyMap
+ --ScalarPropertyMap
+ This class represents the metadata for all entity Type map elements in the
+ above example. Users can access the table mapping fragments under the
+ entity type mapping through this class.
+
+
+
+
+ Creates an EntityTypeMapping instance.
+
+ The EntitySetMapping that contains this EntityTypeMapping.
+
+
+
+ Adds an entity type to the mapping.
+
+ The EntityType to be added.
+
+
+
+ Removes an entity type from the mapping.
+
+ The EntityType to be removed.
+
+
+
+ Adds an entity type hierarchy to the mapping.
+ The hierarchy is represented by the specified root entity type.
+
+ The root EntityType of the hierarchy to be added.
+
+
+
+ Removes an entity type hierarchy from the mapping.
+ The hierarchy is represented by the specified root entity type.
+
+ The root EntityType of the hierarchy to be removed.
+
+
+
+ Adds a mapping fragment.
+
+ The mapping fragment to be added.
+
+
+
+ Removes a mapping fragment.
+
+ The mapping fragment to be removed.
+
+
+
+ Gets the EntitySetMapping that contains this EntityTypeMapping.
+
+
+
+
+ Gets the single EntityType being mapped. Throws exception in case of hierarchy type mapping.
+
+
+
+
+ Gets a flag that indicates whether this is a type hierarchy mapping.
+
+
+
+
+ Gets a read-only collection of mapping fragments.
+
+
+
+
+ Gets the mapped entity types.
+
+
+
+
+ Gets the mapped base types for a hierarchy mapping.
+
+
+
+
+ Represents the metadata for mapping fragment.
+ A set of mapping fragments makes up the Set mappings( EntitySet, AssociationSet or CompositionSet )
+ Each MappingFragment provides mapping for those properties of a type that map to a single table.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ComplexPropertyMap
+ --ComplexTypeMapping
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --DiscriminatorProperyMap ( constant value-->SMemberMetadata )
+ --ComplexTypeMapping
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --DiscriminatorProperyMap ( constant value-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ This class represents the metadata for all the mapping fragment elements in the
+ above example. Users can access all the top level constructs of
+ MappingFragment element like EntityKey map, Property Maps, Discriminator
+ property through this mapping fragment class.
+
+
+
+
+ Creates a MappingFragment instance.
+
+ The EntitySet corresponding to the table of view being mapped.
+ The TypeMapping that contains this MappingFragment.
+ Flag that indicates whether to include 'DISTINCT' when generating queries.
+
+
+
+ Adds a property mapping.
+
+ The property mapping to be added.
+
+
+
+ Removes a property mapping.
+
+ The property mapping to be removed.
+
+
+
+ Adds a property mapping condition.
+
+ The property mapping condition to be added.
+
+
+
+ Removes a property mapping condition.
+
+ The property mapping condition to be removed.
+
+
+
+ Gets the EntitySet corresponding to the table or view being mapped.
+
+
+
+
+ Gets the TypeMapping that contains this MappingFragment.
+
+
+
+
+ Gets a flag that indicates whether to include 'DISTINCT' when generating queries.
+
+
+
+
+ Gets a read-only collection of property mappings.
+
+
+
+
+ Gets a read-only collection of property mapping conditions.
+
+
+
+
+ Represents a collection of items in Storage Mapping (CS Mapping) space.
+
+
+
+ Initializes a new instance of the class using the specified , and a collection of string indicating the metadata file paths.
+ The that this mapping is to use.
+ The that this mapping is to use.
+ The file paths that this mapping is to use.
+
+
+ Initializes a new instance of the class using the specified , and XML readers.
+ The that this mapping is to use.
+ The that this mapping is to use.
+ The XML readers that this mapping is to use.
+
+
+
+ Computes a hash value for the container mapping specified by the names of the mapped containers.
+
+ The name of a container in the conceptual model.
+ The name of a container in the store model.
+ A string that specifies the computed hash value.
+
+
+
+ Computes a hash value for the single container mapping in the collection.
+
+ A string that specifies the computed hash value.
+
+
+
+ Creates a dictionary of (extent, generated view) for a container mapping specified by
+ the names of the mapped containers.
+
+ The name of a container in the conceptual model.
+ The name of a container in the store model.
+ A list that accumulates potential errors.
+
+ A dictionary of (, ) that specifies the generated views.
+
+
+
+
+ Creates a dictionary of (extent, generated view) for the single container mapping
+ in the collection.
+
+ A list that accumulates potential errors.
+
+ A dictionary of (, ) that specifies the generated views.
+
+
+
+
+ Factory method that creates a .
+
+
+ The edm metadata collection to map. Must not be null.
+
+
+ The store metadata collection to map. Must not be null.
+
+
+ MSL artifacts to load. Must not be null.
+
+
+ Paths to MSL artifacts. Used in error messages. Can be null in which case
+ the base Uri of the XmlReader will be used as a path.
+
+
+ The collection of errors encountered while loading.
+
+
+ instance if no errors encountered. Otherwise null.
+
+
+
+
+ Gets or sets a for creating instances
+ that are used to retrieve pre-generated mapping views.
+
+
+
+ Gets the version of this represents.
+ The version of this represents.
+
+
+
+ Describes modification function binding for change processing of entities or associations.
+
+
+
+
+ Initializes a new ModificationFunctionMapping instance.
+
+ The entity or association set.
+ The entity or association type.
+ The metadata of function to which we should bind.
+ Bindings for function parameters.
+ The output parameter producing number of rows affected.
+ Bindings for the results of function evaluation
+
+
+
+
+
+
+ Gets output parameter producing number of rows affected. May be null.
+
+
+
+
+ Gets Metadata of function to which we should bind.
+
+
+
+
+ Gets bindings for function parameters.
+
+
+
+
+ Gets bindings for the results of function evaluation.
+
+
+
+
+ Mapping metadata for scalar properties.
+
+
+ For Example if conceptually you could represent the CS MSL file as following
+ --Mapping
+ --EntityContainerMapping ( CNorthwind-->SNorthwind )
+ --EntitySetMapping
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --EntityTypeMapping
+ --MappingFragment
+ --EntityKey
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ComplexPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --AssociationSetMapping
+ --AssociationTypeMapping
+ --MappingFragment
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ --ScalarProperyMap ( CMemberMetadata-->SMemberMetadata )
+ --EndPropertyMap
+ --ScalarPropertyMap ( CMemberMetadata-->SMemberMetadata )
+ This class represents the metadata for all the scalar property map elements in the
+ above example.
+
+
+
+
+ Creates a mapping between a simple property and a column.
+
+ The property to be mapped.
+ The column to be mapped.
+
+
+
+ Gets an EdmProperty that specifies the mapped column.
+
+
+
+
+ metadata exception class
+
+
+
+
+ Initializes a new instance of the class with a default message.
+
+
+
+
+ Initializes a new instance of the class with the specified message.
+
+ The exception message.
+
+
+
+ Initializes a new instance of the class with the specified message and inner exception.
+
+ The exception message.
+
+ The exception that is the cause of this .
+
+
+
+
+ DataSpace
+
+
+
+
+ OSpace indicates the item in the clr space
+
+
+
+
+ CSpace indicates the item in the CSpace - edm primitive types +
+ types defined in csdl
+
+
+
+
+ SSpace indicates the item in the SSpace
+
+
+
+
+ Mapping between OSpace and CSpace
+
+
+
+
+ Mapping between CSpace and SSpace
+
+
+
+
+ This class encapsulates the error information for a generic EDM error.
+
+
+
+ Gets the error message.
+ The error message.
+
+
+
+ Class for representing a collection of items in Edm space.
+
+
+
+
+ Initializes a new instance of the class by using the collection of the XMLReader objects where the conceptual schema definition language (CSDL) files exist.
+
+ The collection of the XMLReader objects where the conceptual schema definition language (CSDL) files exist.
+
+
+ Initializes a new instance of the class.
+ The entity data model.
+
+
+
+ Initializes a new instance of the class by using the paths where the conceptual schema definition language (CSDL) files exist.
+
+ The paths where the conceptual schema definition language (CSDL) files exist.
+
+
+
+ Returns a collection of the objects.
+
+
+ A ReadOnlyCollection object that represents a collection of the
+
+ objects.
+
+
+
+
+ Returns a collection of the objects with the specified conceptual model version.
+
+
+ A ReadOnlyCollection object that represents a collection of the
+
+ objects.
+
+ The conceptual model version.
+
+
+
+ Factory method that creates an .
+
+
+ CSDL artifacts to load. Must not be null.
+
+
+ Paths to CSDL artifacts. Used in error messages. Can be null in which case
+ the base Uri of the XmlReader will be used as a path.
+
+
+ The collection of errors encountered while loading.
+
+
+ instance if no errors encountered. Otherwise null.
+
+
+
+ Gets the conceptual model version for this collection.
+ The conceptual model version for this collection.
+
+
+
+ This class encapsulates the error information for a schema error that was encountered.
+
+
+
+
+ Constructs a EdmSchemaError object.
+
+ The explanation of the error.
+ The code associated with this error.
+ The severity of the error.
+
+
+ Returns the error message.
+ The error message.
+
+
+ Gets the error code.
+ The error code.
+
+
+ Gets the severity level of the error.
+
+ One of the values. The default is
+
+ .
+
+
+
+ Gets the line number where the error occurred.
+ The line number where the error occurred.
+
+
+ Gets the column where the error occurred.
+ The column where the error occurred.
+
+
+ Gets the location of the schema that contains the error. This string also includes the name of the schema at the end.
+ The location of the schema that contains the error.
+
+
+ Gets the name of the schema that contains the error.
+ The name of the schema that contains the error.
+
+
+ Gets a string representation of the stack trace at the time the error occurred.
+ A string representation of the stack trace at the time the error occurred.
+
+
+
+ Defines the different severities of errors that can occur when validating an Entity Framework model.
+
+
+
+
+ A warning that does not prevent the model from being used.
+
+
+
+
+ An error that prevents the model from being used.
+
+
+
+
+ Represents a end of a Association Type
+
+
+
+
+ Initializes a new instance of the RelationshipEndMember class
+
+
+
+
+ Represents the edm member class
+
+
+
+ Returns the name of this member.
+ The name of this member.
+
+
+
+ Gets or sets the name of the property. Setting this from a store-space model-convention will change the name of the database
+ column for this property. In the conceptual model, this should align with the corresponding property from the entity class
+ and should not be changed.
+
+ The name of this member.
+
+
+ Gets the type on which this member is declared.
+
+ A object that represents the type on which this member is declared.
+
+
+
+
+ Gets the instance of the class that contains both the type of the member and facets for the type.
+
+
+ A object that contains both the type of the member and facets for the type.
+
+
+
+
+ Tells whether this member is marked as a Computed member in the EDM definition
+
+
+
+
+ Tells whether this member's Store generated pattern is marked as Identity in the EDM definition
+
+
+
+ Access the EntityType of the EndMember in an association.
+ The EntityType of the EndMember in an association.
+
+
+ Gets the operational behavior of this relationship end member.
+
+ One of the values. The default is
+
+ .
+
+
+
+ Gets the multiplicity of this relationship end member.
+
+ One of the values.
+
+
+
+
+ Creates a read-only AssociationEndMember instance.
+
+ The name of the association end member.
+ The reference type for the end.
+ The multiplicity of the end.
+ Flag that indicates the delete behavior of the end.
+ Metadata properties to be associated with the instance.
+ The newly created AssociationEndMember instance.
+ The specified name is null or empty.
+ The specified reference type is null.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Class for representing an Association set
+
+
+
+
+ Class for representing a relationship set
+
+
+
+
+ Class for representing a entity set
+
+
+
+ Returns the name of the current entity or relationship set.
+ The name of the current entity or relationship set.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets escaped provider specific SQL describing this entity set.
+
+
+
+
+ Gets or sets the name of the current entity or relationship set.
+ If this property is changed from store-space, the mapping layer must also be updated to reflect the new name.
+ To change the table name of a store space use the Table property.
+
+ The name of the current entity or relationship set.
+ Thrown if the setter is called when EntitySetBase instance is in ReadOnly state
+
+
+ Gets the entity container of the current entity or relationship set.
+
+ An object that represents the entity container of the current entity or relationship set.
+
+ Thrown if the setter is called when the EntitySetBase instance or the EntityContainer passed into the setter is in ReadOnly state
+
+
+
+ Gets the entity type of this .
+
+
+ An object that represents the entity type of this
+
+ .
+
+ Thrown if the setter is called when EntitySetBase instance is in ReadOnly state
+
+
+
+ Gets or sets the database table name for this entity set.
+
+ if value passed into setter is null
+ Thrown if the setter is called when EntitySetBase instance is in ReadOnly state
+
+
+
+ Gets or sets the database schema for this entity set.
+
+ if value passed into setter is null
+ Thrown if the setter is called when EntitySetBase instance is in ReadOnly state
+
+
+
+ Gets the relationship type of this .
+
+
+ An object that represents the relationship type of this
+
+ .
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Creates a read-only AssociationSet instance from the specified parameters.
+
+ The name of the association set.
+ The association type of the elements in the association set.
+ The entity set for the source association set end.
+ The entity set for the target association set end.
+ Metadata properties to be associated with the instance.
+ The newly created AssociationSet instance.
+ The specified name is null or empty.
+ The specified association type is null.
+
+ The entity type of one of the ends of the specified
+ association type does not match the entity type of the corresponding entity set end.
+
+
+
+
+ Gets the association related to this .
+
+
+ An object that represents the association related to this
+
+ .
+
+
+
+
+ Gets the ends of this .
+
+
+ A collection of type that contains the ends of this
+
+ .
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents built-in type kind for this
+
+ .
+
+
+
+
+ Class representing a AssociationSet End
+
+
+
+
+ Returns the name of the End role for this .
+
+
+ The name of the End role for this .
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the parent association set of this .
+
+
+ An object that represents the parent association set of this
+
+ .
+
+ Thrown if Setter is called when the AssociationSetEnd instance is in ReadOnly state
+
+
+
+ Gets the End member that this object corresponds to.
+
+
+ An object that represents the End member that this
+
+ object corresponds to.
+
+ Thrown if Setter is called when the AssociationSetEnd instance is in ReadOnly state
+
+
+
+ Gets the name of the End for this .
+
+
+ The name of the End for this .
+
+
+
+
+ Gets the name of the End role for this .
+
+
+ The name of the End role for this .
+
+ Thrown if Setter is called when the AssociationSetEnd instance is in ReadOnly state
+
+
+ Gets the entity set referenced by this End role.
+
+ An object that represents the entity set referred by this End role.
+
+
+
+
+ Describes an association/relationship between two entities in the conceptual model or a foreign key relationship
+ between two tables in the store model. In the conceptual model the dependant class may or may not define a foreign key property.
+ If a foreign key is defined the property will be true and the property will contain details of the foreign keys
+
+
+
+
+ Represents the Relationship type
+
+
+
+
+ Represents the Entity Type
+
+
+
+
+ Represents the Structural Type
+
+
+
+
+ Base EdmType class for all the model types
+
+
+
+ Returns the full name of this type.
+ The full name of this type.
+
+
+
+ Returns an instance of the whose element type is this type.
+
+
+ The object whose element type is this type.
+
+
+
+ Gets the name of this type.
+ The name of this type.
+
+
+ Gets the namespace of this type.
+ The namespace of this type.
+
+
+ Gets a value indicating whether this type is abstract or not.
+ true if this type is abstract; otherwise, false.
+ Thrown if the setter is called on instance that is in ReadOnly state
+
+
+ Gets the base type of this type.
+ The base type of this type.
+ Thrown if the setter is called on instance that is in ReadOnly state
+ Thrown if the value passed in for setter will create a loop in the inheritance chain
+
+
+ Gets the full name of this type.
+ The full name of this type.
+
+
+
+ Adds a member to this type
+
+ The member to add
+
+
+ Removes a member from this type.
+ The member to remove.
+
+
+ Gets the list of members on this type.
+
+ A collection of type that contains a set of members on this type.
+
+
+
+
+ Adds the specified property to the list of keys for the current entity.
+
+ The property to add.
+ if member argument is null
+ Thrown if the EntityType has a base type of another EntityTypeBase. In this case KeyMembers should be added to the base type
+ If the EntityType instance is in ReadOnly state
+
+
+ Removes the specified key member from the collection.
+ The key member to remove.
+
+
+ Gets the list of all the key members for the current entity or relationship type.
+
+ A object that represents the list of key members for the current entity or relationship type.
+
+
+
+ Gets the list of all the key properties for this entity type.
+ The list of all the key properties for this entity type.
+
+
+ Gets the list of ends for this relationship type.
+
+ A collection of type that contains the list of Ends for this relationship type.
+
+
+
+
+ Creates a read-only AssociationType instance from the specified parameters.
+
+ The name of the association type.
+ The namespace of the association type.
+ Flag that indicates a foreign key (FK) relationship.
+ The data space for the association type.
+ The source association end member.
+ The target association end member.
+ A referential constraint.
+ Metadata properties to be associated with the instance.
+ The newly created AssociationType instance.
+ The specified name is null or empty.
+ The specified namespace is null or empty.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the list of ends for this .
+
+
+ A collection of type that contains the list of ends for this
+
+ .
+
+
+
+ Gets or sets the referential constraint.
+ The referential constraint.
+
+
+
+ Gets the list of constraints for this .
+
+
+ A collection of type that contains the list of constraints for this
+
+ .
+
+
+
+ Gets the Boolean property value that specifies whether the column is a foreign key.
+ A Boolean value that specifies whether the column is a foreign key. If true, the column is a foreign key. If false (default), the column is not a foreign key.
+
+
+
+ Represents the structure of an . In the conceptual-model this represents the shape and structure
+ of an entity. In the store model this represents the structure of a table. To change the Schema and Table name use EntitySet.
+
+
+
+
+ Returns a object that references this
+
+ .
+
+
+ A object that references this
+
+ .
+
+
+
+
+ The factory method for constructing the EntityType object.
+
+ The name of the entity type.
+ The namespace of the entity type.
+ The dataspace in which the EntityType belongs to.
+ Name of key members for the type.
+ Members of the entity type (primitive and navigation properties).
+ Metadata properties to be associated with the instance.
+ The EntityType object.
+ Thrown if either name, namespace arguments are null.
+ The newly created EntityType will be read only.
+
+
+
+ The factory method for constructing the EntityType object.
+
+ The name of the entity type.
+ The namespace of the entity type.
+ The dataspace in which the EntityType belongs to.
+ The base type.
+ Name of key members for the type.
+ Members of the entity type (primitive and navigation properties).
+ Metadata properties to be associated with the instance.
+ The EntityType object.
+ Thrown if either name, namespace arguments are null.
+ The newly created EntityType will be read only.
+
+
+
+ Adds the specified navigation property to the members of this type.
+ The navigation property is added regardless of the read-only flag.
+
+ The navigation property to be added.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+ Gets the declared navigation properties associated with the entity type.
+ The declared navigation properties associated with the entity type.
+
+
+
+ Gets the navigation properties of this .
+
+
+ A collection of type that contains the list of navigation properties on this
+
+ .
+
+
+
+ Gets the list of declared properties for the entity type.
+ The declared properties for the entity type.
+
+
+ Gets the collection of declared members for the entity type.
+ The collection of declared members for the entity type.
+
+
+
+ Gets the list of properties for this .
+
+
+ A collection of type that contains the list of properties for this
+
+ .
+
+
+
+
+ Represents an enumeration type.
+
+
+
+
+ Class representing a simple type
+
+
+
+
+ Creates a read-only EnumType instance.
+
+ The name of the enumeration type.
+ The namespace of the enumeration type.
+ The underlying type of the enumeration type.
+ Indicates whether the enumeration type can be treated as a bit field; that is, a set of flags.
+ The members of the enumeration type.
+ Metadata properties to be associated with the enumeration type.
+ The newly created EnumType instance.
+ underlyingType is null.
+
+ name is null or empty.
+ -or-
+ namespaceName is null or empty.
+ -or-
+ underlyingType is not a supported underlying type.
+ -or-
+ The specified members do not have unique names.
+ -or-
+ The value of a specified member is not in the range of the underlying type.
+
+
+
+ Returns the kind of the type
+
+
+ Gets a collection of enumeration members for this enumeration type.
+
+
+ Gets a value indicating whether the enum type is defined as flags (i.e. can be treated as a bit field)
+
+
+ Gets the underlying type for this enumeration type.
+
+
+
+ Specifies the kinds of item attributes in the conceptual model.
+
+
+
+
+ An enumeration member indicating that an item attribute is System
+
+
+
+
+ An enumeration member indicating that an item attribute is Extended.
+
+
+
+
+ List of all the built in types
+
+
+
+
+ Association Type Kind
+
+
+
+
+ AssociationSetEnd Kind
+
+
+
+
+ AssociationSet Kind
+
+
+
+
+ Association Type Kind
+
+
+
+
+ EntitySetBase Kind
+
+
+
+
+ Entity Type Base Kind
+
+
+
+
+ Collection Type Kind
+
+
+
+
+ Collection Kind
+
+
+
+
+ Complex Type Kind
+
+
+
+
+ Documentation Kind
+
+
+
+
+ DeleteAction Type Kind
+
+
+
+
+ Edm Type Kind
+
+
+
+
+ Entity Container Kind
+
+
+
+
+ Entity Set Kind
+
+
+
+
+ Entity Type Kind
+
+
+
+
+ Enumeration Type Kind
+
+
+
+
+ Enum Member Kind
+
+
+
+
+ Facet Kind
+
+
+
+
+ EdmFunction Kind
+
+
+
+
+ Function Parameter Kind
+
+
+
+
+ Global Item Type Kind
+
+
+
+
+ Metadata Property Kind
+
+
+
+
+ Navigation Property Kind
+
+
+
+
+ Metadata Item Type Kind
+
+
+
+
+ EdmMember Type Kind
+
+
+
+
+ Parameter Mode Kind
+
+
+
+
+ Primitive Type Kind
+
+
+
+
+ Primitive Type Kind Kind
+
+
+
+
+ EdmProperty Type Kind
+
+
+
+
+ ProviderManifest Type Kind
+
+
+
+
+ Referential Constraint Type Kind
+
+
+
+
+ Ref Type Kind
+
+
+
+
+ RelationshipEnd Type Kind
+
+
+
+
+ Relationship Multiplicity Type Kind
+
+
+
+
+ Relationship Set Type Kind
+
+
+
+
+ Relationship Type
+
+
+
+
+ Row Type Kind
+
+
+
+
+ Simple Type Kind
+
+
+
+
+ Structural Type Kind
+
+
+
+
+ Type Information Kind
+
+
+
+
+ Represents the Edm Collection Type
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the instance of the class that contains the type of the element that this current
+
+ object includes and facets for that type.
+
+
+ The instance of the class that contains the type of the element that this current
+
+ object includes and facets for that type.
+
+
+
+
+ Represents the Edm Complex Type. This can be used to configure complex types
+ from a conceptual-space model-based convention. Complex types are not supported in the store model.
+
+
+
+
+ Creates a new instance of the type.
+
+ The name of the complex type.
+ The namespace of the complex type.
+ The dataspace to which the complex type belongs to.
+ Members of the complex type.
+ Metadata properties to be associated with the instance.
+ Thrown if either name, namespace or members argument is null.
+
+ A new instance a the type.
+
+
+ The newly created will be read only.
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the list of properties for this .
+
+
+ A collection of type that contains the list of properties for this
+
+ .
+
+
+
+
+ Class representing the Documentation associated with an item
+
+
+
+
+ Initializes a new Documentation instance.
+
+ A summary string.
+ A long description string.
+
+
+
+ Returns the summary for this .
+
+
+ The summary for this .
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the summary for this .
+
+
+ The summary for this .
+
+
+
+
+ Gets the long description for this .
+
+
+ The long description for this .
+
+
+
+
+ Gets a value indicating whether this object contains only a null or an empty
+
+ and a
+
+ .
+
+
+ true if this object contains only a null or an empty
+
+ and a
+
+ ; otherwise, false.
+
+
+
+
+ Class for representing a function
+
+
+
+
+ Adds a parameter to this function.
+
+ The parameter to be added.
+
+
+
+ The factory method for constructing the object.
+
+ The name of the function.
+ The namespace of the function.
+ The namespace the function belongs to.
+ Additional function attributes and properties.
+ Metadata properties that will be added to the function. Can be null.
+
+ A new, read-only instance of the type.
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ One of the enumeration values of the enumeration.
+
+
+
+ Returns the full name (namespace plus name) of this type.
+ The full name of the type.
+
+
+
+ Gets the parameters of this .
+
+
+ A collection of type that contains the parameters of this
+
+ .
+
+
+
+
+ Gets the return parameter of this .
+
+
+ A object that represents the return parameter of this
+
+ .
+
+
+
+
+ Gets the return parameters of this .
+
+
+ A collection of type that represents the return parameters of this
+
+ .
+
+
+
+ Gets the store function name attribute of this function.
+
+
+ Gets the parameter type semantics attribute of this function.
+
+
+ Gets the aggregate attribute of this function.
+
+
+
+ Gets a value indicating whether built in attribute is present on this function.
+
+
+ true if the attribute is present; otherwise, false.
+
+
+
+
+ Gets a value indicating whether this instance is from the provider manifest.
+
+
+ true if this instance is from the provider manifest; otherwise, false.
+
+
+
+
+ Gets a value indicating whether the is a niladic function (a function that accepts no arguments).
+
+
+ true if the function is niladic; otherwise, false.
+
+
+
+ Gets whether this instance is mapped to a function or to a stored procedure.
+ true if this instance is mapped to a function; false if this instance is mapped to a stored procedure.
+
+
+ Gets a query in the language that is used by the database management system or storage model.
+
+ A string value in the syntax used by the database management system or storage model that contains the query or update statement of the
+
+ .
+
+
+
+ Gets or sets the schema associated with the function.
+ The schema associated with the function.
+
+
+
+ In conceptual-space, EdmProperty represents a property on an Entity.
+ In store-space, EdmProperty represents a column in a table.
+
+
+
+ Creates a new primitive property.
+ The newly created property.
+ The name of the property.
+ The type of the property.
+
+
+ Creates a new enum property.
+ The newly created property.
+ The name of the property.
+ The type of the property.
+
+
+ Creates a new complex property.
+ The newly created property.
+ The name of the property.
+ The type of the property.
+
+
+
+ Creates a new instance of EdmProperty type.
+
+ Name of the property.
+
+ Property
+
+ A new instance of EdmProperty type
+
+
+ Sets the metadata properties.
+ The metadata properties to be set.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets a value indicating whether this can have a null value.
+
+
+ Nullability in the conceptual model and store model is a simple indication of whether or not
+ the property is considered nullable. Nullability in the object model is more complex.
+ When using convention based mapping (as usually happens with POCO entities), a property in the
+ object model is considered nullable if and only if the underlying CLR type is nullable and
+ the property is not part of the primary key.
+ When using attribute based mapping (usually used with entities that derive from the EntityObject
+ base class), a property is considered nullable if the IsNullable flag is set to true in the
+ attribute. This flag can
+ be set to true even if the underlying type is not nullable, and can be set to false even if the
+ underlying type is nullable. The latter case happens as part of default code generation when
+ a non-nullable property in the conceptual model is mapped to a nullable CLR type such as a string.
+ In such a case, the Entity Framework treats the property as non-nullable even though the CLR would
+ allow null to be set.
+ There is no good reason to set a non-nullable CLR type as nullable in the object model and this
+ should not be done even though the attribute allows it.
+
+
+ true if this can have a null value; otherwise, false.
+
+ Thrown if the setter is called when the EdmProperty instance is in ReadOnly state
+
+
+ Gets the type name of the property.
+ The type name of the property.
+
+
+
+ Gets the default value for this .
+
+
+ The default value for this .
+
+ Thrown if the setter is called when the EdmProperty instance is in ReadOnly state
+
+
+ Gets whether the property is a collection type property.
+ true if the property is a collection type property; otherwise, false.
+
+
+ Gets whether this property is a complex type property.
+ true if this property is a complex type property; otherwise, false.
+
+
+ Gets whether this property is a primitive type.
+ true if this property is a primitive type; otherwise, false.
+
+
+ Gets whether this property is an enumeration type property.
+ true if this property is an enumeration type property; otherwise, false.
+
+
+ Gets whether this property is an underlying primitive type.
+ true if this property is an underlying primitive type; otherwise, false.
+
+
+ Gets the complex type information for this property.
+ The complex type information for this property.
+
+
+ Gets the primitive type information for this property.
+ The primitive type information for this property.
+
+
+ Gets the enumeration type information for this property.
+ The enumeration type information for this property.
+
+
+ Gets the underlying primitive type information for this property.
+ The underlying primitive type information for this property.
+
+
+ Gets or sets the concurrency mode for the property.
+ The concurrency mode for the property.
+
+
+ Gets or sets the database generation method for the database column associated with this property
+ The store generated pattern for the property.
+
+
+ Gets or sets the kind of collection for this model.
+ The kind of collection for this model.
+
+
+ Gets whether the maximum length facet is constant for the database provider.
+ true if the facet is constant; otherwise, false.
+
+
+ Gets or sets the maximum length of the property.
+ The maximum length of the property.
+
+
+ Gets or sets whether this property uses the maximum length supported by the provider.
+ true if this property uses the maximum length supported by the provider; otherwise, false.
+
+
+ Gets whether the fixed length facet is constant for the database provider.
+ true if the facet is constant; otherwise, false.
+
+
+ Gets or sets whether the length of this property is fixed.
+ true if the length of this property is fixed; otherwise, false.
+
+
+ Gets whether the Unicode facet is constant for the database provider.
+ true if the facet is constant; otherwise, false.
+
+
+ Gets or sets whether this property is a Unicode property.
+ true if this property is a Unicode property; otherwise, false.
+
+
+ Gets whether the precision facet is constant for the database provider.
+ true if the facet is constant; otherwise, false.
+
+
+ Gets or sets the precision of this property.
+ The precision of this property.
+
+
+ Gets whether the scale facet is constant for the database provider.
+ true if the facet is constant; otherwise, false.
+
+
+ Gets or sets the scale of this property.
+ The scale of this property.
+
+
+
+ Class for representing an entity container
+
+
+
+
+ Creates an entity container with the specified name and data space.
+
+ The entity container name.
+ The entity container data space.
+ Thrown if the name argument is null.
+ Thrown if the name argument is empty string.
+
+
+
+ Returns an object by using the specified name for the entity set.
+
+
+ An object that represents the entity set that has the specified name.
+
+ The name of the entity set that is searched for.
+ true to perform the case-insensitive search; otherwise, false.
+
+
+
+ Returns an object by using the specified name for the entity set.
+
+ true if there is an entity set that matches the search criteria; otherwise, false.
+ The name of the entity set that is searched for.
+ true to perform the case-insensitive search; otherwise, false.
+
+ When this method returns, contains an object. If there is no entity set, this output parameter contains null.
+
+
+
+
+ Returns a object by using the specified name for the relationship set.
+
+
+ An object that represents the relationship set that has the specified name.
+
+ The name of the relationship set that is searched for.
+ true to perform the case-insensitive search; otherwise, false.
+
+
+
+ Returns a object by using the specified name for the relationship set.
+
+ true if there is a relationship set that matches the search criteria; otherwise, false.
+ The name of the relationship set that is searched for.
+ true to perform the case-insensitive search; otherwise, false.
+
+ When this method returns, contains a object.
+
+
+
+
+ Returns the name of this .
+
+
+ The name of this .
+
+
+
+
+ Adds the specified entity set to the container.
+
+ The entity set to add.
+
+
+ Removes a specific entity set from the container.
+ The entity set to remove.
+
+
+
+ Adds a function import to the container.
+
+ The function import to add.
+
+
+
+ The factory method for constructing the EntityContainer object.
+
+ The name of the entity container to be created.
+ DataSpace in which this entity container belongs to.
+ Entity sets that will be included in the new container. Can be null.
+ Functions that will be included in the new container. Can be null.
+ Metadata properties to be associated with the instance.
+ The EntityContainer object.
+ Thrown if the name argument is null or empty string.
+ The newly created EntityContainer will be read only.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the name of this .
+
+
+ The name of this .
+
+
+
+
+ Gets a list of entity sets and association sets that this
+
+ includes.
+
+
+ A object that contains a list of entity sets and association sets that this
+
+ includes.
+
+
+
+ Gets the association sets for this entity container.
+ The association sets for this entity container .
+
+
+ Gets the entity sets for this entity container.
+ The entity sets for this entity container .
+
+
+
+ Specifies a collection of elements. Each function contains the details of a stored procedure that exists in the database or equivalent CommandText that is mapped to an entity and its properties.
+
+
+ A that contains
+
+ elements.
+
+
+
+
+ Represents a particular usage of a structure defined in EntityType. In the conceptual-model, this represents a set that can
+ query and persist entities. In the store-model it represents a table.
+ From a store-space model-convention it can be used to configure
+ table name with property and table schema with property.
+
+
+
+
+ The factory method for constructing the EntitySet object.
+
+ The name of the EntitySet.
+ The db schema. Can be null.
+ The db table. Can be null.
+
+ The provider specific query that should be used to retrieve data for this EntitySet. Can be null.
+
+ The entity type of the entities that this entity set type contains.
+
+ Metadata properties that will be added to the newly created EntitySet. Can be null.
+
+ The EntitySet object.
+ Thrown if the name argument is null or empty string.
+ The newly created EntitySet will be read only.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the entity type of this .
+
+
+ An object that represents the entity type of this
+
+ .
+
+
+
+
+ Represents an enumeration member.
+
+
+
+ Overriding System.Object.ToString to provide better String representation for this type.
+ The name of this enumeration member.
+
+
+
+ Creates a read-only EnumMember instance.
+
+ The name of the enumeration member.
+ The value of the enumeration member.
+ Metadata properties to be associated with the enumeration member.
+ The newly created EnumMember instance.
+ name is null or empty.
+
+
+
+ Creates a read-only EnumMember instance.
+
+ The name of the enumeration member.
+ The value of the enumeration member.
+ Metadata properties to be associated with the enumeration member.
+ The newly created EnumMember instance.
+ name is null or empty.
+
+
+
+ Creates a read-only EnumMember instance.
+
+ The name of the enumeration member.
+ The value of the enumeration member.
+ Metadata properties to be associated with the enumeration member.
+ The newly created EnumMember instance.
+ name is null or empty.
+
+
+
+ Creates a read-only EnumMember instance.
+
+ The name of the enumeration member.
+ The value of the enumeration member.
+ Metadata properties to be associated with the enumeration member.
+ The newly created EnumMember instance.
+ name is null or empty.
+
+
+
+ Creates a read-only EnumMember instance.
+
+ The name of the enumeration member.
+ The value of the enumeration member.
+ Metadata properties to be associated with the enumeration member.
+ The newly created EnumMember instance.
+ name is null or empty.
+
+
+ Gets the kind of this type.
+
+
+ Gets the name of this enumeration member.
+
+
+ Gets the value of this enumeration member.
+
+
+
+ Class for representing a Facet object
+ This object is Immutable (not just set to readonly) and
+ some parts of the system are depending on that behavior
+
+
+
+
+ Returns the name of this .
+
+
+ The name of this .
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the description of this .
+
+
+ The object that represents the description of this
+
+ .
+
+
+
+
+ Gets the name of this .
+
+
+ The name of this .
+
+
+
+
+ Gets the type of this .
+
+
+ The object that represents the type of this
+
+ .
+
+
+
+
+ Gets the value of this .
+
+
+ The value of this .
+
+ Thrown if the Facet instance is in ReadOnly state
+
+
+ Gets a value indicating whether the value of the facet is unbounded.
+ true if the value of the facet is unbounded; otherwise, false.
+
+
+
+ Class for representing a FacetDescription object
+
+
+
+ Returns the name of this facet.
+ The name of this facet.
+
+
+ Gets the name of this facet.
+ The name of this facet.
+
+
+ Gets the type of this facet.
+
+ An object that represents the type of this facet.
+
+
+
+ Gets the minimum value for this facet.
+ The minimum value for this facet.
+
+
+ Gets the maximum value for this facet.
+ The maximum value for this facet.
+
+
+ Gets the default value of a facet with this facet description.
+ The default value of a facet with this facet description.
+
+
+ Gets a value indicating whether the value of this facet is a constant.
+ true if this facet is a constant; otherwise, false.
+
+
+ Gets a value indicating whether this facet is a required facet.
+ true if this facet is a required facet; otherwise, false.
+
+
+
+ Class representing a function parameter
+
+
+
+
+ Returns the name of this .
+
+
+ The name of this .
+
+
+
+
+ The factory method for constructing the object.
+
+ The name of the parameter.
+ The EdmType of the parameter.
+
+ The of the parameter.
+
+
+ A new, read-only instance of the type.
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the mode of this .
+
+
+ One of the values.
+
+ Thrown if the FunctionParameter instance is in ReadOnly state
+
+
+
+ Gets the name of this .
+
+
+ The name of this .
+
+
+
+
+ Gets the instance of the class that contains both the type of the parameter and facets for the type.
+
+
+ A object that contains both the type of the parameter and facets for the type.
+
+
+
+ Gets the type name of this parameter.
+ The type name of this parameter.
+
+
+ Gets whether the max length facet is constant for the database provider.
+ true if the facet is constant; otherwise, false.
+
+
+ Gets the maximum length of the parameter.
+ The maximum length of the parameter.
+
+
+ Gets whether the parameter uses the maximum length supported by the database provider.
+ true if parameter uses the maximum length supported by the database provider; otherwise, false.
+
+
+ Gets whether the precision facet is constant for the database provider.
+ true if the facet is constant; otherwise, false.
+
+
+ Gets the precision value of the parameter.
+ The precision value of the parameter.
+
+
+ Gets whether the scale facet is constant for the database provider.
+ true if the facet is constant; otherwise, false.
+
+
+ Gets the scale value of the parameter.
+ The scale value of the parameter.
+
+
+
+ Gets the on which this parameter is declared.
+
+
+ A object that represents the function on which this parameter is declared.
+
+
+
+
+ Class representing a metadata attribute for an item
+
+
+
+
+ The factory method for constructing the MetadataProperty object.
+
+ The name of the metadata property.
+ The type usage of the metadata property.
+ The value of the metadata property.
+ The MetadataProperty object.
+
+ Thrown is null.
+
+ The newly created MetadataProperty will be read only.
+
+
+
+ Creates a metadata annotation having the specified name and value.
+
+ The annotation name.
+ The annotation value.
+ A MetadataProperty instance representing the created annotation.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the name of this .
+
+
+ The name of this .
+
+
+
+
+ Gets the value of this .
+
+
+ The value of this .
+
+ Thrown if the MetadataProperty instance is in readonly state
+
+
+
+ Gets the instance of the class that contains both the type of this
+
+ and facets for the type.
+
+
+ A object that contains both the type of this
+
+ and facets for the type.
+
+ Thrown if the MetadataProperty instance is in readonly state
+
+
+
+ Gets the value of this .
+
+
+ The value of this .
+
+
+
+
+ Gets a boolean that indicates whether the metadata property is an annotation.
+
+
+
+
+ Represent the edm navigation property class
+
+
+
+
+ Where the given navigation property is on the dependent end of a referential constraint,
+ returns the foreign key properties. Otherwise, returns an empty set. We will return the members in the order
+ of the principal end key properties.
+
+ A collection of the foreign key properties.
+
+
+
+ Creates a NavigationProperty instance from the specified parameters.
+
+ The name of the navigation property.
+ Specifies the navigation property type and its facets.
+ The relationship type for the navigation.
+ The source end member in the navigation.
+ The target end member in the navigation.
+ The metadata properties of the navigation property.
+ The newly created NavigationProperty instance.
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+ Gets the relationship type that this navigation property operates on.
+ The relationship type that this navigation property operates on.
+ Thrown if the NavigationProperty instance is in ReadOnly state
+
+
+ Gets the "to" relationship end member of this navigation.
+ The "to" relationship end member of this navigation.
+ Thrown if the NavigationProperty instance is in ReadOnly state
+
+
+ Gets the "from" relationship end member in this navigation.
+ The "from" relationship end member in this navigation.
+ Thrown if the NavigationProperty instance is in ReadOnly state
+
+
+
+ Represents the list of possible actions for delete operation
+
+
+
+
+ no action
+
+
+
+
+ Cascade to other ends
+
+
+
+
+ The enumeration defining the mode of a parameter
+
+
+
+
+ In parameter
+
+
+
+
+ Out parameter
+
+
+
+
+ Both in and out parameter
+
+
+
+
+ Return Parameter
+
+
+
+
+ Class representing a primitive type
+
+
+
+
+ Returns the equivalent of this
+
+ .
+
+
+ For example if this instance is nvarchar and it's
+ base type is Edm String then the return type is Edm String.
+ If the type is actually already a model type then the
+ return type is "this".
+
+
+ An object that is an equivalent of this
+
+ .
+
+
+
+ Returns the list of primitive types.
+
+ A collection of type that contains the list of primitive types.
+
+
+
+
+ Returns the equivalent of a
+
+ .
+
+
+ An object that is an equivalent of a specified
+
+ .
+
+
+ A value of type .
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets a enumeration value that indicates a primitive type of this
+
+ .
+
+
+ A enumeration value that indicates a primitive type of this
+
+ .
+
+
+
+
+ Gets the list of facet descriptions for this .
+
+
+ A collection of type that contains the list of facet descriptions for this
+
+ .
+
+
+
+
+ Returns an equivalent common language runtime (CLR) type of this
+
+ . Note that the
+
+ property always returns a non-nullable type value.
+
+
+ A object that represents an equivalent common language runtime (CLR) type of this
+
+ .
+
+
+
+
+ Primitive Types as defined by EDM
+
+
+
+
+ Binary Type Kind
+
+
+
+
+ Boolean Type Kind
+
+
+
+
+ Byte Type Kind
+
+
+
+
+ DateTime Type Kind
+
+
+
+
+ Decimal Type Kind
+
+
+
+
+ Double Type Kind
+
+
+
+
+ Guid Type Kind
+
+
+
+
+ Single Type Kind
+
+
+
+
+ SByte Type Kind
+
+
+
+
+ Int16 Type Kind
+
+
+
+
+ Int32 Type Kind
+
+
+
+
+ Int64 Type Kind
+
+
+
+
+ String Type Kind
+
+
+
+
+ Time Type Kind
+
+
+
+
+ DateTimeOffset Type Kind
+
+
+
+
+ Geometry Type Kind
+
+
+
+
+ Geography Type Kind
+
+
+
+
+ Geometric point type kind
+
+
+
+
+ Geometric linestring type kind
+
+
+
+
+ Geometric polygon type kind
+
+
+
+
+ Geometric multi-point type kind
+
+
+
+
+ Geometric multi-linestring type kind
+
+
+
+
+ Geometric multi-polygon type kind
+
+
+
+
+ Geometric collection type kind
+
+
+
+
+ Geographic point type kind
+
+
+
+
+ Geographic linestring type kind
+
+
+
+
+ Geographic polygon type kind
+
+
+
+
+ Geographic multi-point type kind
+
+
+
+
+ Geographic multi-linestring type kind
+
+
+
+
+ Geographic multi-polygon type kind
+
+
+
+
+ Geographic collection type kind
+
+
+
+
+ This class represents a referential constraint between two entities specifying the "to" and "from" ends of the relationship.
+
+
+
+
+ Constructs a new constraint on the relationship
+
+ role from which the relationship originates
+ role to which the relationship is linked/targeted to
+ properties on entity type of to role which take part in the constraint
+ properties on entity type of from role which take part in the constraint
+ Argument Null exception if any of the arguments is null
+
+
+
+ Returns the combination of the names of the
+
+ and the
+
+ .
+
+
+ The combination of the names of the
+
+ and the
+
+ .
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the "from role" that takes part in this
+
+ .
+
+
+ A object that represents the "from role" that takes part in this
+
+ .
+
+ Thrown if value passed into setter is null
+ Thrown if the ReferentialConstraint instance is in ReadOnly state
+
+
+
+ Gets the "to role" that takes part in this .
+
+
+ A object that represents the "to role" that takes part in this
+
+ .
+
+ Thrown if value passed into setter is null
+ Thrown if the ReferentialConstraint instance is in ReadOnly state
+
+
+
+ Gets the list of properties for the "from role" on which this
+
+ is defined.
+
+
+ A collection of type that contains the list of properties for "from role" on which this
+
+ is defined.
+
+
+
+
+ Gets the list of properties for the "to role" on which this
+
+ is defined.
+
+
+ A collection of type that contains the list of properties for the "to role" on which this
+
+ is defined.
+
+
+
+
+ Class representing a ref type
+
+
+
+
+
+
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the entity type referenced by this .
+
+
+ An object that represents the entity type referenced by this
+
+ .
+
+
+
+
+ Represents the multiplicity information about the end of a relationship type
+
+
+
+
+ Lower Bound is Zero and Upper Bound is One
+
+
+
+
+ Both lower bound and upper bound is one
+
+
+
+
+ Lower bound is zero and upper bound is null
+
+
+
+
+ Represents the Edm Row Type
+
+
+
+
+ The factory method for constructing the object.
+
+ Properties of the row type object.
+ Metadata properties that will be added to the function. Can be null.
+
+ A new, read-only instance of the object.
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the list of properties on this .
+
+
+ A collection of type that contains the list of properties on this
+
+ .
+
+
+
+ Gets a collection of the properties defined by the current type.
+ A collection of the properties defined by the current type.
+
+
+
+ Class representing a type information for an item
+
+
+
+
+ Factory method for creating a TypeUsage with specified EdmType and facets
+
+ EdmType for which to create a type usage
+ facets to be copied into the new TypeUsage
+ new TypeUsage instance
+
+
+
+ Creates a object with the specified conceptual model type.
+
+
+ A object with the default facet values for the specified
+
+ .
+
+
+ A for which the
+
+ object is created.
+
+
+
+
+ Creates a object to describe a string type by using the specified facet values.
+
+
+ A object describing a string type by using the specified facet values.
+
+
+ A for which the
+
+ object is created.
+
+ true to set the character-encoding standard of the string type to Unicode; otherwise, false.
+ true to set the character-encoding standard of the string type to Unicode; otherwise, false.
+ true to set the length of the string type to fixed; otherwise, false.
+
+
+
+ Creates a object to describe a string type by using the specified facet values and unbounded MaxLength.
+
+
+ A object describing a string type by using the specified facet values and unbounded MaxLength.
+
+
+ A for which the
+
+ object is created.
+
+ true to set the character-encoding standard of the string type to Unicode; otherwise, false.
+ true to set the length of the string type to fixed; otherwise, false
+
+
+
+ Creates a object to describe a binary type by using the specified facet values.
+
+
+ A object describing a binary type by using the specified facet values.
+
+
+ A for which the
+
+ object is created.
+
+ true to set the length of the binary type to fixed; otherwise, false.
+ The maximum length of the binary type.
+
+
+
+ Creates a object to describe a binary type by using the specified facet values.
+
+
+ A object describing a binary type by using the specified facet values.
+
+
+ A for which the
+
+ object is created.
+
+ true to set the length of the binary type to fixed; otherwise, false.
+
+
+
+ Creates a object of the type that the parameters describe.
+
+
+ A object.
+
+
+ The simple type that defines the units of measurement of the DateTime object.
+
+
+ The degree of granularity of the DateTimeOffset in fractions of a second, based on the number of decimal places supported. For example a precision of 3 means the granularity supported is milliseconds.
+
+
+
+
+ Creates a object of the type that the parameters describe.
+
+
+ A object.
+
+ The simple type that defines the units of measurement of the offset.
+
+ The degree of granularity of the DateTimeOffset in fractions of a second, based on the number of decimal places supported. For example a precision of 3 means the granularity supported is milliseconds.
+
+
+
+
+ Creates a object of the type that the parameters describe.
+
+
+ A object.
+
+
+ The simple type that defines the units of measurement of the DateTime object.
+
+
+ The degree of granularity of the DateTimeOffset in fractions of a second, based on the number of decimal places supported. For example a precision of 3 means the granularity supported is milliseconds.
+
+
+
+
+ Creates a object to describe a decimal type by using the specified facet values.
+
+
+ A object describing a decimal type by using the specified facet values.
+
+
+ A for which the
+
+ object is created.
+
+
+ The precision of the decimal type as type .
+
+
+ The scale of the decimal type as type .
+
+
+
+
+ Creates a object to describe a decimal type with unbounded precision and scale facet values.
+
+
+ A object describing a decimal type with unbounded precision and scale facet values.
+
+
+ A for which the
+
+ object is created.
+
+
+
+
+ Checks whether this is a subtype of the specified
+
+ .
+
+
+ true if this is a subtype of the specified
+
+ ; otherwise, false.
+
+
+ The object to be checked.
+
+
+
+
+ Returns the full name of the type described by this .
+
+
+ The full name of the type described by this as string.
+
+
+
+
+ Gets the built-in type kind for this .
+
+
+ A object that represents the built-in type kind for this
+
+ .
+
+
+
+
+ Gets the type information described by this .
+
+
+ An object that represents the type information described by this
+
+ .
+
+
+
+
+ Gets the list of facets for the type that is described by this
+
+ .
+
+
+ A collection of type that contains the list of facets for the type that is described by this
+
+ .
+
+
+
+
+ Returns a Model type usage for a provider type
+
+ Model (CSpace) type usage
+
+
+
+ Do not perform any extension check
+
+
+
+
+ Check the extension against a specific value
+
+
+
+
+ Check the extension against the set of acceptable extensions
+
+
+
+
+ Runtime Metadata Workspace
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Constructs a with loaders for all item collections ()
+ needed by EF except the o/c mapping which will be created automatically based on the given o-space and c-space
+ loaders. The item collection delegates are executed lazily when a given collection is used for the first
+ time. It is acceptable to pass a delegate that returns null if the collection will never be used, but this
+ is rarely done, and any attempt by EF to use the collection in such cases will result in an exception.
+
+ Delegate to return the c-space (CSDL) item collection.
+ Delegate to return the s-space (SSDL) item collection.
+ Delegate to return the c/s mapping (MSL) item collection.
+ Delegate to return the o-space item collection.
+
+
+
+ Constructs a with loaders for all item collections ()
+ that come from traditional EDMX mapping. Default o-space and o/c mapping collections will be used.
+ The item collection delegates are executed lazily when a given collection is used for the first
+ time. It is acceptable to pass a delegate that returns null if the collection will never be used, but this
+ is rarely done, and any attempt by EF to use the collection in such cases will result in an exception.
+
+ Delegate to return the c-space (CSDL) item collection.
+ Delegate to return the s-space (SSDL) item collection.
+ Delegate to return the c/s mapping (MSL) item collection.
+
+
+
+ Initializes a new instance of the class using the specified paths and assemblies.
+
+ The paths to workspace metadata.
+ The names of assemblies used to construct workspace.
+
+
+
+ Creates an configured to use the
+
+ data space.
+
+ The created parser object.
+
+
+
+ Creates a new bound to this metadata workspace based on the specified query expression.
+
+
+ A new with the specified expression as it's
+
+ property.
+
+
+ A that defines the query.
+
+
+ If
+
+ is null
+
+
+ If
+
+ contains metadata that cannot be resolved in this metadata workspace
+
+
+ If
+
+ is not structurally valid because it contains unresolvable variable references
+
+
+
+
+ Gets items.
+
+
+ The items.
+
+
+ The from which to retrieve items.
+
+
+
+ Registers the item collection with each associated data model.
+ The output parameter collection that needs to be filled up.
+
+
+ Loads metadata from the given assembly.
+ The assembly from which the metadata will be loaded.
+
+
+ Loads metadata from the given assembly.
+ The assembly from which the metadata will be loaded.
+ The delegate for logging the load messages.
+
+
+ Returns an item by using the specified identity and the data model.
+ The item that matches the given identity in the specified data model.
+ The identity of the item.
+ The conceptual model in which the item is searched.
+ The type returned by the method.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+ Returns an item by using the specified identity and the data model.
+ true if there is an item that matches the search criteria; otherwise, false.
+ The conceptual model on which the item is searched.
+ The conceptual model on which the item is searched.
+
+ When this method returns, contains a object. This parameter is passed uninitialized.
+
+ The type returned by the method.
+
+
+ Returns an item by using the specified identity and the data model.
+ The item that matches the given identity in the specified data model.
+ The identity of the item.
+ true to perform the case-insensitive search; otherwise, false.
+ The conceptual model on which the item is searched.
+ The type returned by the method.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+ Returns an item by using the specified identity and the data model.
+ true if there is an item that matches the search criteria; otherwise, false.
+ The conceptual model on which the item is searched.
+ true to perform the case-insensitive search; otherwise, false.
+ The conceptual model on which the item is searched.
+
+ When this method returns, contains a object. This parameter is passed uninitialized.
+
+ The type returned by the method.
+
+
+ Gets all the items in the specified data model.
+
+ A collection of type that contains all the items in the specified data model.
+
+ The conceptual model for which the list of items is needed.
+ The type returned by the method.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+
+ Returns an object by using the specified type name, namespace name, and data model.
+
+
+ An object that represents the type that matches the given type name and the namespace name in the specified data model. If there is no matched type, this method returns null.
+
+ The name of the type.
+ The namespace of the type.
+ The conceptual model on which the type is searched.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+
+ Returns an object by using the specified type name, namespace name, and data model.
+
+ true if there is a type that matches the search criteria; otherwise, false.
+ The name of the type.
+ The namespace of the type.
+ The conceptual model on which the type is searched.
+
+ When this method returns, contains an object. This parameter is passed uninitialized.
+
+
+
+
+ Returns an object by using the specified type name, namespace name, and data model.
+
+
+ An object.
+
+ The name of the type.
+ The namespace of the type.
+ true to perform the case-insensitive search; otherwise, false.
+ The conceptual model on which the type is searched.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+
+ Returns an object by using the specified type name, namespace name, and data model.
+
+ true if there is a type that matches the search criteria; otherwise, false.
+ The name of the type.
+ The namespace of the type.
+ true to perform the case-insensitive search; otherwise, false.
+ The conceptual model on which the type is searched.
+
+ When this method returns, contains an object. This parameter is passed uninitialized.
+
+
+
+
+ Returns an object by using the specified entity container name and the data model.
+
+ If there is no entity container, this method returns null; otherwise, it returns the first entity container.
+ The name of the entity container.
+ The conceptual model on which the entity container is searched.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+
+ Returns an object by using the specified entity container name and the data model.
+
+ true if there is an entity container that matches the search criteria; otherwise, false.
+ The name of the entity container.
+ The conceptual model on which the entity container is searched.
+
+ When this method returns, contains an object. If there is no entity container, this output parameter contains null; otherwise, it returns the first entity container. This parameter is passed uninitialized.
+
+
+
+
+ Returns an object by using the specified entity container name and the data model.
+
+ If there is no entity container, this method returns null; otherwise, it returns the first entity container.
+ The name of the entity container.
+ true to perform the case-insensitive search; otherwise, false.
+ The conceptual model on which the entity container is searched.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+
+ Returns an object by using the specified entity container name and the data model.
+
+ true if there is an entity container that matches the search criteria; otherwise, false.
+ The name of the entity container.
+ true to perform the case-insensitive search; otherwise, false.
+ The conceptual model on which the entity container is searched.
+
+ When this method returns, contains an object. If there is no entity container, this output parameter contains null; otherwise, it returns the first entity container. This parameter is passed uninitialized.
+
+
+
+ Returns all the overloads of the functions by using the specified name, namespace name, and data model.
+
+ A collection of type that contains all the functions that match the specified name in a given namespace and a data model.
+
+ The name of the function.
+ The namespace of the function.
+ The conceptual model in which the functions are searched.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+ Returns all the overloads of the functions by using the specified name, namespace name, and data model.
+
+ A collection of type that contains all the functions that match the specified name in a given namespace and a data model.
+
+ The name of the function.
+ The namespace of the function.
+ The conceptual model in which the functions are searched.
+ true to perform the case-insensitive search; otherwise, false.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+ Returns the list of primitive types in the specified data model.
+
+ A collection of type that contains all the primitive types in the specified data model.
+
+ The data model for which you need the list of primitive types.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+ Gets all the items in the specified data model.
+
+ A collection of type that contains all the items in the specified data model.
+
+ The conceptual model for which the list of items is needed.
+ Thrown if the space is not a valid space. Valid space is either C, O, CS or OCSpace
+
+
+
+ Tests the retrieval of .
+
+ true if the retrieval was successful; otherwise, false.
+
+ The from which to attempt retrieval of
+
+ .
+
+ When this method returns, contains the item collection. This parameter is passed uninitialized.
+
+
+
+ Returns a object that represents the object space type that matches the type supplied by the parameter edmSpaceType .
+
+
+ A object that represents the Object space type. If there is no matched type, this method returns null.
+
+
+ A object that represents the
+
+ .
+
+
+
+
+ Returns a object via the out parameter objectSpaceType that represents the type that matches the
+
+ supplied by the parameter edmSpaceType .
+
+ true if there is a type that matches the search criteria; otherwise, false.
+
+ A object that represents the
+
+ .
+
+
+ When this method returns, contains a object that represents the Object space type. This parameter is passed uninitialized.
+
+
+
+
+ Returns a object that represents the object space type that matches the type supplied by the parameter edmSpaceType .
+
+
+ A object that represents the Object space type. If there is no matched type, this method returns null.
+
+
+ A object that represents the
+
+ .
+
+
+
+
+ Returns a object via the out parameter objectSpaceType that represents the type that matches the
+
+ supplied by the parameter edmSpaceType .
+
+ true if there is a type that matches the search criteria; otherwise, false.
+
+ A object that represents the
+
+ .
+
+
+ When this method returns, contains a object that represents the Object space type. This parameter is passed uninitialized.
+
+
+
+
+ Returns a object that represents the
+
+ that matches the type supplied by the parameter objectSpaceType .
+
+
+ A object that represents the
+
+ . If there is no matched type, this method returns null.
+
+
+ A that supplies the type in the object space.
+
+
+
+
+ Returns a object via the out parameter edmSpaceType that represents the
+
+ that matches the type supplied by the parameter objectSpaceType .
+
+ true if there is a type that matches the search criteria; otherwise, false.
+
+ A object that represents the object space type.
+
+
+ When this method returns, contains a object that represents the
+
+ . This parameter is passed uninitialized.
+
+
+
+
+ Returns a object that represents the
+
+ that matches the type supplied by the parameter objectSpaceType .
+
+
+ A object that represents the
+
+ . If there is no matched type, this method returns null.
+
+
+ A that supplies the type in the object space.
+
+
+
+
+ Returns a object via the out parameter edmSpaceType that represents the
+
+ that matches the type supplied by the parameter objectSpaceType .
+
+ true on success, false on failure.
+
+ A object that represents the object space type.
+
+
+ When this method returns, contains a object that represents the
+
+ . This parameter is passed uninitialized.
+
+
+
+ Clears all the metadata cache entries.
+
+
+ Gets original value members from an entity set and entity type.
+ The original value members from an entity set and entity type.
+ The entity set from which to retrieve original values.
+ The entity type of which to retrieve original values.
+
+
+
+ Returns members of a given /
+
+ for which original values are needed when modifying an entity.
+
+
+ The s for which original value is required.
+
+
+ An belonging to the C-Space.
+
+
+ An that participates in the given
+
+ .
+
+ true if entities may be updated partially; otherwise, false.
+
+
+
+ The Max EDM version thats going to be supported by the runtime.
+
+
+
+
+ Class for representing a collection of items for the object layer.
+ Most of the implementation for actual maintenance of the collection is
+ done by ItemCollection
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+ Loads metadata from the given assembly.
+ The assembly from which the metadata will be loaded.
+
+
+ Loads metadata from the given assembly.
+ The assembly from which the metadata will be loaded.
+ The EDM metadata source for the O space metadata.
+ The delegate to which log messages are sent.
+
+
+ Loads metadata from the specified assembly.
+ The assembly from which the metadata will be loaded.
+ The EDM metadata source for the O space metadata.
+
+
+ Returns a collection of primitive type objects.
+ A collection of primitive type objects.
+
+
+
+ Returns the CLR type that corresponds to the supplied by the objectSpaceType parameter.
+
+ The CLR type of the OSpace argument.
+
+ A that represents the object space type.
+
+
+
+
+ Returns a CLR type corresponding to the supplied by the objectSpaceType parameter.
+
+ true if there is a type that matches the search criteria; otherwise, false.
+
+ A that represents the object space type.
+
+ The CLR type.
+
+
+ The method returns the underlying CLR type for the specified OSpace type argument. If the DataSpace of the parameter is not OSpace, an ArgumentException is thrown.
+ The CLR type of the OSpace argument.
+ The OSpace type to look up.
+
+
+ Returns the underlying CLR type for the specified OSpace enum type argument. If the DataSpace of the parameter is not OSpace, the method returns false and sets the out parameter to null.
+ true on success, false on failure
+ The OSpace enum type to look up
+ The CLR enum type of the OSpace argument
+
+
+ Returns all the items of the specified type from this item collection.
+
+ A collection of type that contains all items of the specified type.
+
+ The type returned by the method.
+
+
+
+ The enumeration defining the type semantics used to resolve function overloads.
+ These flags are defined in the provider manifest per function definition.
+
+
+
+
+ Allow Implicit Conversion between given and formal argument types (default).
+
+
+
+
+ Allow Type Promotion between given and formal argument types.
+
+
+
+
+ Use strict Equivalence only.
+
+
+
+
+ Class for representing a collection of items in Store space.
+
+
+
+
+ Initializes a new instance of the class using the specified XMLReader.
+
+ The XMLReader used to create metadata.
+
+
+ Initializes a new instances of the class.
+ The model of the .
+
+
+
+ Initializes a new instance of the class using the specified file paths.
+
+ The file paths used to create metadata.
+
+
+
+ Returns a collection of the objects.
+
+
+ A object that represents the collection of the
+
+ objects.
+
+
+
+
+ Factory method that creates a .
+
+
+ SSDL artifacts to load. Must not be null.
+
+
+ Paths to SSDL artifacts. Used in error messages. Can be null in which case
+ the base Uri of the XmlReader will be used as a path.
+
+
+ Custom resolver. Currently used to resolve DbProviderServices implementation. If null
+ the default resolver will be used.
+
+
+ The collection of errors encountered while loading.
+
+
+ instance if no errors encountered. Otherwise null.
+
+
+
+ Gets the provider factory of the StoreItemCollection.
+ The provider factory of the StoreItemCollection.
+
+
+ Gets the provider manifest of the StoreItemCollection.
+ The provider manifest of the StoreItemCollection.
+
+
+ Gets the manifest token of the StoreItemCollection.
+ The manifest token of the StoreItemCollection.
+
+
+ Gets the invariant name of the StoreItemCollection.
+ The invariant name of the StoreItemCollection.
+
+
+ Gets the version of the store schema for this collection.
+ The version of the store schema for this collection.
+
+
+
+ This exception is thrown when a requested object is not found in the store.
+
+
+
+
+ Initializes a new instance of .
+
+
+
+
+ Initializes a new instance of with a specialized error message.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of class that uses a specified error message and a reference to the inner exception.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Caches an ELinq query
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg8 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg9 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg10 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg11 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg12 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg13 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg14 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg15 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg8 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg9 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg10 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg11 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg12 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg13 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg14 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg8 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg9 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg10 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg11 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg12 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg13 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg8 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg9 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg10 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg11 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg12 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg8 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg9 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg10 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg11 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg8 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg9 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg10 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg8 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg9 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg8 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg7 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg6 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg5 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg4 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg3 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg2 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+ Represents the type of the parameter that has to be passed in when executing the delegate returned by this method. TArg1 must be a primitive type.
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+ Creates a new delegate that represents the compiled LINQ to Entities query.
+
+ , a generic delegate that represents the compiled LINQ to Entities query.
+
+ The lambda expression to compile.
+
+ A type derived from .
+
+
+ The type T of the query results returned by executing the delegate returned by the
+
+ method.
+
+
+
+
+ The values currently assigned to the properties of an entity.
+
+
+
+
+ Provides access to the original values of object data. The DbUpdatableDataRecord implements methods that allow updates to the original values of an object.
+
+
+
+ Retrieves the field value as a Boolean.
+ The field value as a Boolean.
+ The ordinal of the field.
+
+
+ Retrieves the field value as a byte.
+ The field value as a byte.
+ The ordinal of the field.
+
+
+ Retrieves the field value as a byte array.
+ The number of bytes copied.
+ The ordinal of the field.
+ The index at which to start copying data.
+ The destination buffer where data is copied.
+ The index in the destination buffer where copying will begin.
+ The number of bytes to copy.
+
+
+ Retrieves the field value as a char.
+ The field value as a char.
+ The ordinal of the field.
+
+
+ Retrieves the field value as a char array.
+ The number of characters copied.
+ The ordinal of the field.
+ The index at which to start copying data.
+ The destination buffer where data is copied.
+ The index in the destination buffer where copying will begin.
+ The number of characters to copy.
+
+
+
+ Retrieves the field value as an .
+
+
+ The field value as an .
+
+ The ordinal of the field.
+
+
+
+ Retrieves the field value as a
+
+
+ The field value as a .
+
+ The ordinal of the field.
+
+
+ Retrieves the name of the field data type.
+ The name of the field data type.
+ The ordinal of the field.
+
+
+
+ Retrieves the field value as a .
+
+
+ The field value as a .
+
+ The ordinal of the field.
+
+
+ Retrieves the field value as a decimal.
+ The field value as a decimal.
+ The ordinal of the field.
+
+
+ Retrieves the field value as a double.
+ The field value as a double.
+ The ordinal of the field.
+
+
+ Retrieves the type of a field.
+ The field type.
+ The ordinal of the field.
+
+
+ Retrieves the field value as a float.
+ The field value as a float.
+ The ordinal of the field.
+
+
+
+ Retrieves the field value as a .
+
+
+ The field value as a .
+
+ The ordinal of the field.
+
+
+
+ Retrieves the field value as an .
+
+
+ The field value as an .
+
+ The ordinal of the field.
+
+
+
+ Retrieves the field value as an .
+
+
+ The field value as an .
+
+ The ordinal of the field.
+
+
+
+ Retrieves the field value as an .
+
+
+ The field value as an .
+
+ The ordinal of the field.
+
+
+ Retrieves the name of a field.
+ The name of the field.
+ The ordinal of the field.
+
+
+ Retrieves the ordinal of a field by using the name of the field.
+ The ordinal of the field.
+ The name of the field.
+
+
+ Retrieves the field value as a string.
+ The field value.
+ The ordinal of the field.
+
+
+ Retrieves the value of a field.
+ The field value.
+ The ordinal of the field.
+
+
+ Retrieves the value of a field.
+ The field value.
+ The ordinal of the field.
+
+
+ Populates an array of objects with the field values of the current record.
+ The number of field values returned.
+ An array of objects to store the field values.
+
+
+
+ Returns whether the specified field is set to .
+
+
+ true if the field is set to ; otherwise false.
+
+ The ordinal of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Sets field values in a record.
+ The number of the fields that were set.
+ The values of the field.
+
+
+
+ Sets a field to the value.
+
+ The ordinal of the field.
+
+
+
+ Retrieves a field value as a .
+
+
+ A field value as a .
+
+ The ordinal of the field.
+
+
+
+ Retrieves the field value as a .
+
+
+ The field value as a .
+
+ The ordinal of the field.
+
+
+ Sets the value of a field in a record.
+ The ordinal of the field.
+ The value of the field.
+
+
+ Gets the number of fields in the record.
+ An integer value that is the field count.
+
+
+ Returns a value that has the given field ordinal.
+ The value that has the given field ordinal.
+ The ordinal of the field.
+
+
+ Gets a value that has the given field name.
+ The field value.
+ The name of the field.
+
+
+ Gets data record information.
+
+ A object.
+
+
+
+
+ This is the interface that represent the minimum interface required
+ to be an entity in ADO.NET.
+
+
+
+
+ This class contains the common methods need for an date object.
+
+
+
+
+ Public constant name used for change tracking
+ Providing this definition allows users to use this constant instead of
+ hard-coding the string. This helps to ensure the property name is correct
+ and allows faster comparisons in places where we are looking for this specific string.
+ Users can still use the case-sensitive string directly instead of the constant,
+ it will just be slightly slower on comparison.
+ Including the dash (-) character around the name ensures that this will not conflict with
+ a real data property, because -EntityKey- is not a valid identifier name
+
+
+
+
+ Raises the event.
+
+ The name of the changed property.
+
+
+
+ Raises the event.
+
+ The name of the property changing.
+
+
+ Returns the minimum date time value supported by the data source.
+
+ A value that is the minimum date time that is supported by the data source.
+
+
+
+ Raises an event that is used to report that a property change is pending.
+ The name of the changing property.
+
+
+ Raises an event that is used to report that a property change has occurred.
+ The name for the changed property.
+
+
+ Returns a complex type for the specified property.
+
+ Unlike most of the other helper methods in this class, this one is not static
+ because it references the SetValidValue for complex objects, which is also not static
+ because it needs a reference to this.
+
+ A complex type object for the property.
+ A complex object that inherits from complex object.
+ The name of the complex property that is the complex object.
+ Indicates whether the type supports null values.
+ Indicates whether the type is initialized.
+ The type of the complex object being requested.
+
+
+ Determines whether the specified byte arrays contain identical values.
+ true if both arrays are of the same length and contain the same byte values or if both arrays are null; otherwise, false.
+ The first byte array value to compare.
+ The second byte array to compare.
+
+
+ Returns a copy of the current byte value.
+
+ A copy of the current value.
+
+ The current byte array value.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being validated.
+
+ The value passed into the property setter.
+ Flag indicating if this property is allowed to be null.
+ The name of the property that is being validated.
+ If value is null for a non nullable value.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ A value being set.
+
+ The value being set.
+ Indicates whether the property is nullable.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+ The Boolean value.
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+ The Boolean value.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ A that is set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value that is set.
+
+ The value that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ A value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+ Makes sure the Single value being set for a property is valid.
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+ Makes sure the Single value being set for a property is valid.
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ Name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The nullable value being set.
+
+
+ The nullable value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+ Makes sure the UInt16 value being set for a property is valid.
+ The nullable UInt16 value being set.
+ The nullable UInt16 value.
+ The name of the property that is being validated.
+
+
+ Makes sure the UInt16 value being set for a property is valid.
+ The nullable UInt16 value being set.
+ The nullable UInt16 value.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+ Makes sure the UInt32 value being set for a property is valid.
+ The nullable UInt32 value being set.
+ The nullable UInt32 value.
+ The name of the property that is being validated.
+
+
+ Makes sure the UInt32 value being set for a property is valid.
+ The nullable UInt32 value being set.
+ The nullable UInt32 value.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+
+ The value being set.
+
+
+ The value.
+
+
+
+
+ Makes sure the value being set for a property is valid.
+
+ The nullable UInt64 value being set.
+ The nullable UInt64 value.
+ The name of the property that is being validated.
+
+
+
+ Makes sure the value being set for a property is valid.
+
+ The nullable UInt64 value being set.
+ The nullable UInt64 value.
+
+
+ Validates that the property is not null, and throws if it is.
+ The validated property.
+ The string value to be checked.
+ Flag indicating if this property is allowed to be null.
+ The name of the property that is being validated.
+ The string value is null for a non-nullable string.
+
+
+ Validates that the property is not null, and throws if it is.
+
+ The validated value.
+
+ The string value to be checked.
+ Flag indicating if this property is allowed to be null.
+
+
+ Validates that the property is not null, and throws if it is.
+
+ The value being set.
+
+
+ The value to be checked.
+
+ Flag indicating if this property is allowed to be null.
+ Name of the property that is being validated.
+ The value is null for a non-nullable property.
+
+
+ Validates that the property is not null, and throws if it is.
+
+ The value being set.
+
+
+ value to be checked.
+
+ Flag indicating if this property is allowed to be null.
+ The value is null for a non-nullable property.
+
+
+ Validates that the property is not null, and throws if it is.
+
+ The value being set.
+
+
+ value to be checked.
+
+ Flag indicating if this property is allowed to be null.
+ The name of the property that is being validated.
+ The value is null for a non-nullable property.
+
+
+ Validates that the property is not null, and throws if it is.
+
+ The value being set.
+
+
+ The value to be checked.
+
+ Flag indicating if this property is allowed to be null.
+ The value is null for a non-nullable property.
+
+
+ Sets a complex object for the specified property.
+ A complex type that derives from complex object.
+ The original complex object for the property, if any.
+ The complex object is being set.
+ The complex property that is being set to the complex object.
+ The type of the object being replaced.
+
+
+ Verifies that a complex object is not null.
+ The complex object being validated.
+ The complex object that is being validated.
+ The complex property on the parent object that is associated with complexObject .
+ The type of the complex object being verified.
+
+
+
+ Notification that a property has been changed.
+
+
+ The PropertyChanged event can indicate all properties on the
+ object have changed by using either a null reference
+ (Nothing in Visual Basic) or String.Empty as the property name
+ in the PropertyChangedEventArgs.
+
+
+
+
+ Notification that a property is about to be changed.
+
+
+ The PropertyChanging event can indicate all properties on the
+ object are changing by using either a null reference
+ (Nothing in Visual Basic) or String.Empty as the property name
+ in the PropertyChangingEventArgs.
+
+
+
+ Notifies the change tracker that a property change is pending on a complex object.
+ The name of the changing property.
+ property is null.
+
+
+ Notifies the change tracker that a property of a complex object has changed.
+ The name of the changed property.
+ property is null.
+
+
+
+ Attribute for complex properties
+ Implied default AttributeUsage properties Inherited=True, AllowMultiple=False,
+ The metadata system expects this and will only look at the first of each of these attributes, even if there are more.
+
+
+
+
+ Base attribute for properties mapped to store elements.
+ Implied default AttributeUsage properties Inherited=True, AllowMultiple=False,
+ The metadata system expects this and will only look at the first of each of these attributes, even if there are more.
+
+
+
+
+ attribute for complex types
+
+
+
+
+ Base attribute for schematized types
+
+
+
+ The name of the type in the conceptual schema that maps to the class to which this attribute is applied.
+
+ A that is the name.
+
+
+
+ The namespace name of the entity object type or complex type in the conceptual schema that maps to this type.
+
+ A that is the namespace name.
+
+
+
+
+ Attribute identifying the Edm base class
+
+
+
+
+ Attribute indicating an enum type.
+
+
+
+
+ Attribute identifying the Ends defined for a RelationshipSet
+ Implied default AttributeUsage properties Inherited=True, AllowMultiple=False,
+ The metadata system expects this and will only look at the first of each of these attributes, even if there are more.
+
+
+
+
+ Initializes a new instance of the
+
+ class.
+
+ The namespace name of the relationship property.
+ The name of the relationship. The relationship name is not namespace qualified.
+ The role name at the other end of the relationship.
+
+
+ The namespace name of the navigation property.
+
+ A that is the namespace name.
+
+
+
+ Gets the unqualified relationship name.
+ The relationship name.
+
+
+ Gets the role name at the other end of the relationship.
+ The target role name is specified by the Role attribute of the other End element in the association that defines this relationship in the conceptual model. For more information, see Association (EDM).
+
+
+
+ Defines a relationship between two entity types based on an association in the conceptual model.
+
+
+
+
+ Creates an instance of the class.
+
+ The name of the namespace for the association in which this entity participates.
+ The name of a relationship in which this entity participates.
+ Name of the role for the type at one end of the association.
+
+ A value of that indicates the multiplicity at one end of the association, such as one or many.
+
+ The type of the entity at one end of the association.
+ Name of the role for the type at the other end of the association.
+
+ A value of that indicates the multiplicity at the other end of the association, such as one or many.
+
+ The type of the entity at the other end of the association.
+
+
+
+ Initializes a new instance of the
+
+ class.
+
+ The name of the namespace for the association in which this entity participates.
+ The name of a relationship in which this entity participates.
+ Name of the role for the type at one end of the association.
+
+ A value of that indicates the multiplicity at one end of the association, such as one or many.
+
+ The type of the entity at one end of the association.
+ Name of the role for the type at the other end of the association.
+
+ A value of that indicates the multiplicity at the other end of the association, such as one or many.
+
+ The type of the entity at the other end of the association.
+ A value that indicates whether the relationship is based on the foreign key value.
+
+
+ The namespace for the relationship.
+
+ A that is the namespace for the relationship.
+
+
+
+ Name of the relationship.
+
+ A that is the name of a relationship that is defined by this
+
+ .
+
+
+
+ Name of the role at one end of the relationship.
+
+ A that is the name of the role.
+
+
+
+ Multiplicity at one end of the relationship.
+
+ A value that indicates the multiplicity.
+
+
+
+ Type of the entity at one end of the relationship.
+
+ A that is the type of the object at this end of the association.
+
+
+
+ Name of the role at the other end of the relationship.
+
+ A that is the name of the role.
+
+
+
+ Multiplicity at the other end of the relationship.
+
+ A value that indicates the multiplicity.
+
+
+
+ Type of the entity at the other end of the relationship.
+
+ A that is the type of the object t the other end of the association.
+
+
+
+ Gets a Boolean value that indicates whether the relationship is based on the foreign key value.
+ true if the relationship is based on the foreign key value; otherwise false.
+
+
+
+ Attribute for scalar properties in an IEntity.
+ Implied default AttributeUsage properties Inherited=True, AllowMultiple=False,
+ The metadata system expects this and will only look at the first of each of these attributes, even if there are more.
+
+
+
+ Gets or sets the value that indicates whether the property can have a null value.
+ The value that indicates whether the property can have a null value.
+
+
+ Gets or sets the value that indicates whether the property is part of the entity key.
+ The value that indicates whether the property is part of the entity key.
+
+
+
+ Attribute for static types
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class with a unique value for each model referenced by the assembly.
+
+
+ Setting this parameter to a unique value for each model file in a Visual Basic
+ assembly will prevent the following error:
+ "'System.Data.Entity.Core.Objects.DataClasses.EdmSchemaAttribute' cannot be specified more than once in this project, even with identical parameter values."
+
+ A string that is a unique GUID value for the model in the assembly.
+
+
+
+ Collection of entities modeling a particular EDM construct
+ which can either be all entities of a particular type or
+ entities participating in a particular relationship.
+
+ The type of entities in this collection.
+
+
+
+ Base class for EntityCollection and EntityReference
+
+
+
+
+ Represents one end of a relationship.
+
+
+
+ Loads the related object or objects into this related end with the default merge option.
+
+
+ Asynchronously loads the related object or objects into this related end with the default merge option.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+ Loads the related object or objects into the related end with the specified merge option.
+
+ The to use when merging objects into an existing
+ .
+
+
+
+ Asynchronously loads the related object or objects into the related end with the specified merge option.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The to use when merging objects into an existing
+ .
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+ Adds an object to the related end.
+
+ An object to add to the collection. entity must implement
+
+ .
+
+
+
+ Adds an object to the related end.
+ An object to add to the collection.
+
+
+ Removes an object from the collection of objects at the related end.
+
+ true if entity was successfully removed, false if entity was not part of the
+
+ .
+
+
+ The object to remove from the collection. entity must implement
+
+ .
+
+
+
+ Removes an object from the collection of objects at the related end.
+
+ true if entity was successfully removed; false if entity was not part of the
+
+ .
+
+ An object to remove from the collection.
+
+
+ Defines a relationship between two attached objects.
+
+ The object being attached. entity must implement
+
+ .
+
+
+
+ Defines a relationship between two attached objects.
+ The object being attached.
+
+
+
+ Returns an that represents the objects that belong to the related end.
+
+
+ An that represents the objects that belong to the related end.
+
+
+
+
+ Returns an that iterates through the collection of related objects.
+
+
+ An that iterates through the collection of related objects.
+
+
+
+
+ Gets or sets a value indicating whether the entity (for an or all entities
+ in the collection (for an have been loaded from the database.
+
+
+ Loading the related entities from the database either using lazy-loading, as part of a query, or explicitly
+ with one of the Load methods will set the IsLoaded flag to true.
+ IsLoaded can be explicitly set to true to prevent the related entities from being lazy-loaded.
+ This can be useful if the application has caused a subset of related entities to be loaded
+ and wants to prevent any other entities from being loaded automatically.
+ Note that explicit loading using will load all related entities from the database
+ regardless of whether or not IsLoaded is true.
+ When any related entity is detached the IsLoaded flag is reset to false indicating that not all related entities
+ are now loaded.
+
+
+ True if all the related entities are loaded or the IsLoaded has been explicitly set to true; otherwise false.
+
+
+
+ Gets the name of the relationship in which this related end participates.
+
+ The name of the relationship in which this is participating. The relationship name is not namespace qualified.
+
+
+
+ Gets the role name at the source end of the relationship.
+ The role name at the source end of the relationship.
+
+
+ Gets the role name at the target end of the relationship.
+ The role name at the target end of the relationship.
+
+
+ Returns a reference to the metadata for the related end.
+
+ A object that contains metadata for the end of a relationship.
+
+
+
+
+ Returns an that represents the objects that belong to the related end.
+
+
+ An that represents the objects that belong to the related end.
+
+
+
+
+ Loads the related object or objects into the related end with the default merge option.
+
+
+ When the source object was retrieved by using a query
+ and the is not
+ or the related objects are already loaded
+ or when the source object is not attached to the
+ or when the source object is being tracked but is in the
+ or state
+ or the
+ used for
+ is .
+
+
+
+
+ Asynchronously loads the related object or objects into the related end with the default merge option.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+ When the source object was retrieved by using a query
+ and the is not
+ or the related objects are already loaded
+ or when the source object is not attached to the
+ or when the source object is being tracked but is in the
+ or state
+ or the
+ used for
+ is .
+
+
+
+
+ Loads an object or objects from the related end with the specified merge option.
+
+
+ The to use when merging objects into an existing
+ .
+
+
+ When the source object was retrieved by using a query
+ and the
+ is not
+ or the related objects are already loaded
+ or when the source object is not attached to the
+ or when the source object is being tracked but is in the
+ or state
+ or the
+ used for
+ is .
+
+
+
+
+ Asynchronously loads an object or objects from the related end with the specified merge option.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The to use when merging objects into an existing
+ .
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+ When the source object was retrieved by using a query
+ and the
+ is not
+ or the related objects are already loaded
+ or when the source object is not attached to the
+ or when the source object is being tracked but is in the
+ or state
+ or the
+ used for
+ is .
+
+
+
+
+ Attaches an entity to the related end. This method works in exactly the same way as Attach(object).
+ It is maintained for backward compatibility with previous versions of IRelatedEnd.
+
+ The entity to attach to the related end
+
+ Thrown when
+
+ is null.
+
+ Thrown when the entity cannot be related via the current relationship end.
+
+
+
+ Attaches an entity to the related end. If the related end is already filled
+ or partially filled, this merges the existing entities with the given entity. The given
+ entity is not assumed to be the complete set of related entities.
+ Owner and all entities passed in must be in Unchanged or Modified state.
+ Deleted elements are allowed only when the state manager is already tracking the relationship
+ instance.
+
+ The entity to attach to the related end
+
+ Thrown when
+
+ is null.
+
+ Thrown when the entity cannot be related via the current relationship end.
+
+
+
+ Adds an entity to the related end. This method works in exactly the same way as Add(object).
+ It is maintained for backward compatibility with previous versions of IRelatedEnd.
+
+ Entity instance to add to the related end
+
+
+
+ Adds an entity to the related end. If the owner is
+ attached to a cache then the all the connected ends are
+ added to the object cache and their corresponding relationships
+ are also added to the ObjectStateManager. The RelatedEnd of the
+ relationship is also fixed.
+
+ Entity instance to add to the related end
+
+
+
+ Removes an entity from the related end. This method works in exactly the same way as Remove(object).
+ It is maintained for backward compatibility with previous versions of IRelatedEnd.
+
+ Entity instance to remove from the related end
+ Returns true if the entity was successfully removed, false if the entity was not part of the RelatedEnd.
+
+
+
+ Removes an entity from the related end. If owner is
+ attached to a cache, marks relationship for deletion and if
+ the relationship is composition also marks the entity for deletion.
+
+ Entity instance to remove from the related end
+ Returns true if the entity was successfully removed, false if the entity was not part of the RelatedEnd.
+
+
+
+ Returns an that iterates through the collection of related objects.
+
+
+ An that iterates through the collection of related objects.
+
+
+
+
+ Used internally to deserialize entity objects along with the
+
+ instances.
+
+ The serialized stream.
+
+
+ Occurs when a change is made to a related end.
+
+
+ Gets the name of the relationship in which this related end participates.
+
+ The name of the relationship in which this participates. The relationship name is not namespace qualified.
+
+
+
+ Gets the role name at the source end of the relationship.
+
+ A that is the role name.
+
+
+
+ Gets the role name at the target end of the relationship.
+
+ A that is the role name.
+
+
+
+ Gets a reference to the metadata for the related end.
+
+ A object that contains metadata for the end of a relationship.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Returns the collection as an used for data binding.
+
+
+ An of entity objects.
+
+
+
+ Loads related objects into the collection, using the specified merge option.
+
+ Specifies how the objects in this collection should be merged with the objects that might have been returned from previous queries against the same
+
+ .
+
+
+
+
+
+
+ Defines relationships between an object and a collection of related objects in an object context.
+
+ Loads related entities into the local collection. If the collection is already filled
+ or partially filled, merges existing entities with the given entities. The given
+ entities are not assumed to be the complete set of related entities.
+ Owner and all entities passed in must be in Unchanged or Modified state. We allow
+ deleted elements only when the state manager is already tracking the relationship
+ instance.
+
+ Collection of objects in the object context that are related to the source object.
+ entities collection is null.
+
+ The source object or an object in the entities collection is null or is not in an
+
+ or state.-or-The relationship cannot be defined based on the EDM metadata. This can occur when the association in the conceptual schema does not support a relationship between the two types.
+
+
+
+ Defines a relationship between two attached objects in an object context.
+ The object being attached.
+ When the entity is null.
+
+ When the entity cannot be related to the source object. This can occur when the association in the conceptual schema does not support a relationship between the two types.-or-When either object is null or is not in an
+
+ or state.
+
+
+
+ Adds an object to the collection.
+
+ An object to add to the collection. entity must implement
+
+ .
+
+ entity is null.
+
+
+ Removes an object from the collection and marks the relationship for deletion.
+ true if item was successfully removed; otherwise, false.
+ The object to remove from the collection.
+ entity object is null.
+ The entity object is not attached to the same object context.-or-The entity object does not have a valid relationship manager.
+
+
+ Returns an enumerator that is used to iterate through the objects in the collection.
+
+ An that iterates through the set of values cached by
+
+ .
+
+
+
+
+ Returns an enumerator that is used to iterate through the set of values cached by
+
+ .
+
+
+ An that iterates through the set of values cached by
+
+ .
+
+
+
+ Removes all entities from the collection.
+
+
+ Determines whether a specific object exists in the collection.
+
+ true if the object is found in the ; otherwise, false.
+
+
+ The object to locate in the .
+
+
+
+ Copies all the contents of the collection to an array, starting at the specified index of the target array.
+ The array to copy to.
+ The zero-based index in the array at which copying begins.
+
+
+ Used internally to serialize entity objects.
+ The streaming context.
+
+
+ Used internally to deserialize entity objects.
+ The streaming context.
+
+
+ Returns an object query that, when it is executed, returns the same set of objects that exists in the current collection.
+
+ An that represents the entity collection.
+
+
+ When the object is in an state
+ or when the object is in a
+ state with a
+ other than
+ .
+
+
+
+ Gets the number of objects that are contained in the collection.
+
+ The number of elements that are contained in the
+
+ .
+
+
+
+
+ Gets a value that indicates whether the
+
+ is read-only.
+
+ Always returns false.
+
+
+
+ IListSource.ContainsListCollection implementation. Always returns false.
+ This means that the IList we return is the one which contains our actual data,
+ it is not a list of collections.
+
+
+
+
+ This is the class is the basis for all perscribed EntityObject classes.
+
+
+
+
+ Interface that defines an entity containing a key.
+
+
+
+
+ Gets or sets the for instances of entity types that implement this interface.
+
+
+ If an object is being managed by a change tracker, it is expected that
+ IEntityChangeTracker methods EntityMemberChanging and EntityMemberChanged will be
+ used to report changes on EntityKey. This allows the change tracker to validate the
+ EntityKey's new value and to verify if the change tracker is in a state where it can
+ allow updates to the EntityKey.
+
+
+ The for instances of entity types that implement this interface.
+
+
+
+
+ Minimum interface that a data class must implement in order to be managed by a change tracker.
+
+
+
+
+ Gets or sets the used to report changes.
+
+
+ The used to report changes.
+
+
+
+
+ Interface that a data class must implement if exposes relationships
+
+
+
+ Returns the relationship manager that manages relationships for an instance of an entity type.
+
+ Classes that expose relationships must implement this property
+ by constructing and setting RelationshipManager in their constructor.
+ The implementation of this property should use the static method RelationshipManager.Create
+ to create a new RelationshipManager when needed. Once created, it is expected that this
+ object will be stored on the entity and will be provided through this property.
+
+
+ The for this entity.
+
+
+
+
+ Used by the ObjectStateManager to attach or detach this EntityObject to the cache.
+
+ Reference to the ObjectStateEntry that contains this entity
+
+
+ Notifies the change tracker that a property change is pending.
+ The name of the changing property.
+ property is null.
+
+
+ Notifies the change tracker that a property has changed.
+ The name of the changed property.
+ property is null.
+
+
+ Gets the entity state of the object.
+
+ The of this object.
+
+
+
+ Gets or sets the key for this object.
+
+ The for this object.
+
+
+
+
+ Returns the container for the lazily created relationship
+ navigation property objects, collections and refs.
+
+
+
+
+ This interface is implemented by a change tracker and is used by data classes to report changes
+
+
+
+ Notifies the change tracker of a pending change to a property of an entity type.
+ The name of the property that is changing.
+
+
+ Notifies the change tracker that a property of an entity type has changed.
+ The name of the property that has changed.
+
+
+ Notifies the change tracker of a pending change to a complex property.
+ The name of the top-level entity property that is changing.
+ The complex type that contains the property that is changing.
+ The name of the property that is changing on complex type.
+
+
+ Notifies the change tracker that a property of a complex type has changed.
+ The name of the complex property of the entity type that has changed.
+ The complex type that contains the property that changed.
+ The name of the property that changed on complex type.
+
+
+ Gets current state of a tracked object.
+
+ An that is the state of the tracked object.For more information, see Identity Resolution, State Managment, and Change Tracking and Tracking Changes in POCO Entities.
+
+
+
+
+ Models a relationship end with multiplicity 1.
+
+
+
+ Returns the key for the related object.
+
+ Returns the EntityKey of the target entity associated with this EntityReference.
+ Is non-null in the following scenarios:
+ (a) Entities are tracked by a context and an Unchanged or Added client-side relationships exists for this EntityReference's owner with the
+ same RelationshipName and source role. This relationship could have been created explicitly by the user (e.g. by setting
+ the EntityReference.Value, setting this property directly, or by calling EntityCollection.Add) or automatically through span queries.
+ (b) If the EntityKey was non-null before detaching an entity from the context, it will still be non-null after detaching, until any operation
+ occurs that would set it to null, as described below.
+ (c) Entities are detached and the EntityKey is explicitly set to non-null by the user.
+ (d) Entity graph was created using a NoTracking query with full span
+ Is null in the following scenarios:
+ (a) Entities are tracked by a context but there is no Unchanged or Added client-side relationship for this EntityReference's owner with the
+ same RelationshipName and source role.
+ (b) Entities are tracked by a context and a relationship exists, but the target entity has a temporary key (i.e. it is Added) or the key
+ is one of the special keys
+ (c) Entities are detached and the relationship was explicitly created by the user.
+
+
+ An that is the key of the related object.
+
+
+
+
+ Models a relationship end with multiplicity 1.
+
+ The type of the entity being referenced.
+
+
+
+ Creates a new instance of .
+
+
+ The default constructor is required for some serialization scenarios. It should not be used to
+ create new EntityReferences. Use the GetRelatedReference or GetRelatedEnd methods on the RelationshipManager
+ class instead.
+
+
+
+
+ Loads the related object for this with the specified merge option.
+
+
+ Specifies how the object should be returned if it already exists in the
+
+ .
+
+
+ The source of the is null
+ or a query returned more than one related end
+ or a query returned zero related ends, and one related end was expected.
+
+
+
+
+
+
+ Creates a many-to-one or one-to-one relationship between two objects in the object context.
+ The object being attached.
+ When the entity is null.
+ When the entity cannot be related to the current related end. This can occur when the association in the conceptual schema does not support a relationship between the two types.
+
+
+ Creates an equivalent object query that returns the related object.
+
+ An that returns the related object.
+
+
+ When the object is in an state
+ or when the object is in a
+ state with a
+ other than .
+
+
+
+ This method is used internally to serialize related entity objects.
+ The serialized stream.
+
+
+ This method is used internally to serialize related entity objects.
+ The serialized stream.
+
+
+
+ Gets or sets the related object returned by this
+
+ .
+
+
+ The object returned by this .
+
+
+
+
+ Identifies the kind of a relationship
+
+
+
+
+ The relationship is an Association
+
+
+
+
+ Container for the lazily created relationship navigation
+ property objects (collections and refs).
+
+
+
+
+ Creates a new object.
+
+
+ Used by data classes that support relationships. If the change tracker
+ requests the RelationshipManager property and the data class does not
+ already have a reference to one of these objects, it calls this method
+ to create one, then saves a reference to that object. On subsequent accesses
+ to that property, the data class should return the saved reference.
+ The reason for using a factory method instead of a public constructor is to
+ emphasize that this is not something you would normally call outside of a data class.
+ By requiring that these objects are created via this method, developers should
+ give more thought to the operation, and will generally only use it when
+ they explicitly need to get an object of this type. It helps define the intended usage.
+
+
+ The requested .
+
+ Reference to the entity that is calling this method.
+
+
+
+ Returns either an or
+
+ of the correct type for the specified target role in a relationship.
+
+
+ representing the
+
+ or
+
+ that was retrieved.
+
+ Name of the relationship in which targetRoleName is defined. The relationship name is not namespace qualified.
+ Target role to use to retrieve the other end of relationshipName .
+ relationshipName or targetRoleName is null.
+ The source type does not match the type of the owner.
+ targetRoleName is invalid or unable to find the relationship type in the metadata.
+
+
+
+ Takes an existing EntityReference that was created with the default constructor and initializes it using the provided relationship and target role names.
+ This method is designed to be used during deserialization only, and will throw an exception if the provided EntityReference has already been initialized,
+ if the relationship manager already contains a relationship with this name and target role, or if the relationship manager is already attached to a ObjectContext.W
+
+ The relationship name.
+ The role name of the related end.
+
+ The to initialize.
+
+
+ The type of the being initialized.
+
+
+ When the provided
+ is already initialized.-or-When the relationship manager is already attached to an
+
+ or when the relationship manager already contains a relationship with this name and target role.
+
+
+
+
+ Takes an existing EntityCollection that was created with the default constructor and initializes it using the provided relationship and target role names.
+ This method is designed to be used during deserialization only, and will throw an exception if the provided EntityCollection has already been initialized,
+ or if the relationship manager is already attached to a ObjectContext.
+
+ The relationship name.
+ The target role name.
+ An existing EntityCollection.
+ Type of the entity represented by targetRoleName
+
+
+
+ Gets an of related objects with the specified relationship name and target role name.
+
+
+ The of related objects.
+
+ Name of the relationship to navigate. The relationship name is not namespace qualified.
+ Name of the target role for the navigation. Indicates the direction of navigation across the relationship.
+
+ The type of the returned .
+
+
+ The specified role returned an instead of an
+
+ .
+
+
+
+
+ Gets the for a related object by using the specified combination of relationship name and target role name.
+
+
+ The of a related object.
+
+ Name of the relationship to navigate. The relationship name is not namespace qualified.
+ Name of the target role for the navigation. Indicates the direction of navigation across the relationship.
+
+ The type of the returned .
+
+
+ The specified role returned an instead of an
+
+ .
+
+
+
+ Returns an enumeration of all the related ends managed by the relationship manager.
+
+ An of objects that implement
+
+ . An empty enumeration is returned when the relationships have not yet been populated.
+
+
+
+
+ Called by Object Services to prepare an for binary serialization with a serialized relationship.
+
+ Describes the source and destination of a given serialized stream, and provides an additional caller-defined context.
+
+
+
+ Used internally to deserialize entity objects along with the
+
+ instances.
+
+ The serialized stream.
+
+
+
+ Represents either a entity, entity stub or relationship
+
+
+
+
+ Gets the updatable version of original values of the object associated with this
+
+ .
+
+ The updatable original values of object data.
+
+
+ Accepts the current values as original values.
+
+
+ Marks an entity as deleted.
+
+
+
+ Returns the names of an object’s properties that have changed since the last time
+
+ was called.
+
+
+ An collection of names as string.
+
+
+
+ Sets the state of the object or relationship to modify.
+ If State is not Modified or Unchanged
+
+
+ Marks the specified property as modified.
+ The name of the property.
+ If State is not Modified or Unchanged
+
+
+ Rejects any changes made to the property with the given name since the property was last loaded, attached, saved, or changes were accepted. The orginal value of the property is stored and the property will no longer be marked as modified.
+ The name of the property to change.
+
+
+ Uses DetectChanges to determine whether or not the current value of the property with the given name is different from its original value. Note that this may be different from the property being marked as modified since a property which has not changed can still be marked as modified.
+
+ Note that this property always returns the same result as the modified state of the property for change tracking
+ proxies and entities that derive from the EntityObject base class. This is because original values are not tracked
+ for these entity types and hence there is no way to know if the current value is really different from the
+ original value.
+
+ true if the property has changed; otherwise, false.
+ The name of the property.
+
+
+
+ Changes state of the entry to the specified value.
+
+
+ The value to set for the
+
+ property of the entry.
+
+
+
+ Sets the current values of the entry to match the property values of a supplied object.
+ The detached object that has updated values to apply to the object. currentEntity can also be the object’s entity key.
+
+
+ Sets the original values of the entry to match the property values of a supplied object.
+ The detached object that has original values to apply to the object. originalEntity can also be the object’s entity key.
+
+
+
+ Used to report that a scalar entity property is about to change
+ The current value of the specified property is cached when this method is called.
+
+ The name of the entity property that is changing
+
+
+
+ Used to report that a scalar entity property has been changed
+ The property value that was cached during EntityMemberChanging is now
+ added to OriginalValues
+
+ The name of the entity property that has changing
+
+
+
+ Used to report that a complex property is about to change
+ The current value of the specified property is cached when this method is called.
+
+ The name of the top-level entity property that is changing
+ The complex object that contains the property that is changing
+ The name of the property that is changing on complexObject
+
+
+
+ Used to report that a complex property has been changed
+ The property value that was cached during EntityMemberChanging is now added to OriginalValues
+
+ The name of the top-level entity property that has changed
+ The complex object that contains the property that changed
+ The name of the property that changed on complexObject
+
+
+
+ Gets the for the
+
+ .
+
+
+ The for the
+
+ .
+
+
+
+
+ Gets the for the object or relationship.
+
+
+ The for the object or relationship.
+
+
+
+
+ Gets the state of the .
+
+
+ The state of the .
+
+
+
+ Gets the entity object.
+ The entity object.
+
+
+ Gets the entity key.
+ The entity key.
+
+
+
+ Gets a value that indicates whether the represents a relationship.
+
+
+ true if the represents a relationship; otherwise, false.
+
+
+
+ Gets the read-only version of original values of the object or relationship.
+ The read-only version of original values of the relationship set entry or entity.
+
+
+
+ Gets the current property values of the object or relationship associated with this
+
+ .
+
+
+ A that contains the current values of the object or relationship associated with this
+
+ .
+
+
+
+
+ Gets the instance for the object represented by entry.
+
+
+ The object.
+
+ The entry is a stub or represents a relationship
+
+
+
+ Returns the EntityState from the ObjectStateEntry
+
+
+
+
+ Defines behavior for implementations of IQueryable that allow modifications to the membership of the resulting set.
+
+ Type of entities returned from the queryable.
+
+
+ Notifies the set that an object that represents a new entity must be added to the set.
+
+ Depending on the implementation, the change to the set may not be visible in an enumeration of the set
+ until changes to that set have been persisted in some manner.
+
+ The new object to add to the set.
+
+
+ Notifies the set that an object that represents an existing entity must be added to the set.
+
+ Depending on the implementation, the change to the set may not be visible in an enumeration of the set
+ until changes to that set have been persisted in some manner.
+
+ The existing object to add to the set.
+
+
+ Notifies the set that an object that represents an existing entity must be deleted from the set.
+
+ Depending on the implementation, the change to the set may not be visible in an enumeration of the set
+ until changes to that set have been persisted in some manner.
+
+ The existing object to delete from the set.
+
+
+ Notifies the set that an object that represents an existing entity must be detached from the set.
+
+ Depending on the implementation, the change to the set may not be visible in an enumeration of the set
+ until changes to that set have been persisted in some manner.
+
+ The object to detach from the set.
+
+
+
+ The different ways that new objects loaded from the database can be merged with existing objects already in memory.
+
+
+
+
+ Will only append new (top level-unique) rows. This is the default behavior.
+
+
+
+
+ Same behavior as LoadOption.OverwriteChanges.
+
+
+
+
+ Same behavior as LoadOption.PreserveChanges.
+
+
+
+
+ Will not modify cache.
+
+
+
+
+ ObjectContext is the top-level object that encapsulates a connection between the CLR and the database,
+ serving as a gateway for Create, Read, Update, and Delete operations.
+
+
+
+
+ Initializes a new instance of the class with the given connection. During construction, the metadata workspace is extracted from the
+
+ object.
+
+
+ An that contains references to the model and to the data source connection.
+
+ The connection is null.
+ The connection is invalid or the metadata workspace is invalid.
+
+
+
+ Creates an ObjectContext with the given connection and metadata workspace.
+
+ connection to the store
+ If set to true the connection is disposed when the context is disposed, otherwise the caller must dispose the connection.
+
+
+
+ Initializes a new instance of the class with the given connection string and default entity container name.
+
+ The connection string, which also provides access to the metadata information.
+ The connectionString is null.
+ The connectionString is invalid or the metadata workspace is not valid.
+
+
+
+ Initializes a new instance of the class with a given connection string and entity container name.
+
+ The connection string, which also provides access to the metadata information.
+ The name of the default entity container. When the defaultContainerName is set through this method, the property becomes read-only.
+ The connectionString is null.
+ The connectionString , defaultContainerName , or metadata workspace is not valid.
+
+
+
+ Initializes a new instance of the class with a given connection and entity container name.
+
+
+ An that contains references to the model and to the data source connection.
+
+ The name of the default entity container. When the defaultContainerName is set through this method, the property becomes read-only.
+ The connection is null.
+ The connection , defaultContainerName , or metadata workspace is not valid.
+
+
+ Accepts all changes made to objects in the object context.
+
+
+ Adds an object to the object context.
+ Represents the entity set name, which may optionally be qualified by the entity container name.
+
+ The to add.
+
+ The entity parameter is null or the entitySetName does not qualify.
+
+
+ Explicitly loads an object related to the supplied object by the specified navigation property and using the default merge option.
+ The entity for which related objects are to be loaded.
+ The name of the navigation property that returns the related objects to be loaded.
+
+ The entity is in a ,
+
+ or state or the entity is attached to another instance of
+
+ .
+
+
+
+ Explicitly loads an object that is related to the supplied object by the specified navigation property and using the specified merge option.
+ The entity for which related objects are to be loaded.
+ The name of the navigation property that returns the related objects to be loaded.
+
+ The value to use when you load the related objects.
+
+
+ The entity is in a ,
+
+ or state or the entity is attached to another instance of
+
+ .
+
+
+
+ Explicitly loads an object that is related to the supplied object by the specified LINQ query and by using the default merge option.
+ The type of the entity.
+ The source object for which related objects are to be loaded.
+ A LINQ expression that defines the related objects to be loaded.
+ selector does not supply a valid input parameter.
+ selector is null.
+
+ The entity is in a ,
+
+ or state or the entity is attached to another instance of
+
+ .
+
+
+
+ Explicitly loads an object that is related to the supplied object by the specified LINQ query and by using the specified merge option.
+ The type of the entity.
+ The source object for which related objects are to be loaded.
+ A LINQ expression that defines the related objects to be loaded.
+
+ The value to use when you load the related objects.
+
+ selector does not supply a valid input parameter.
+ selector is null.
+
+ The entity is in a ,
+
+ or state or the entity is attached to another instance of
+
+ .
+
+
+
+ Applies property changes from a detached object to an object already attached to the object context.
+ The name of the entity set to which the object belongs.
+ The detached object that has property updates to apply to the original object.
+ When entitySetName is null or an empty string or when changed is null.
+
+ When the from entitySetName does not match the
+
+ of the object
+
+ or when the entity is in a state other than
+
+ or
+
+ or the original object is not attached to the context.
+
+ When the type of the changed object is not the same type as the original object.
+
+
+
+ Copies the scalar values from the supplied object into the object in the
+
+ that has the same key.
+
+ The updated object.
+ The name of the entity set to which the object belongs.
+
+ The detached object that has property updates to apply to the original object. The entity key of currentEntity must match the
+
+ property of an entry in the
+
+ .
+
+ The entity type of the object.
+ entitySetName or current is null.
+
+ The from entitySetName does not match the
+
+ of the object
+
+ or the object is not in the
+
+ or it is in a
+
+ state or the entity key of the supplied object is invalid.
+
+ entitySetName is an empty string.
+
+
+
+ Copies the scalar values from the supplied object into set of original values for the object in the
+
+ that has the same key.
+
+ The updated object.
+ The name of the entity set to which the object belongs.
+
+ The detached object that has original values to apply to the object. The entity key of originalEntity must match the
+
+ property of an entry in the
+
+ .
+
+ The type of the entity object.
+ entitySetName or original is null.
+
+ The from entitySetName does not match the
+
+ of the object
+
+ or an
+
+ for the object cannot be found in the
+
+ or the object is in an
+
+ or a
+
+ state or the entity key of the supplied object is invalid or has property changes.
+
+ entitySetName is an empty string.
+
+
+ Attaches an object or object graph to the object context in a specific entity set.
+ Represents the entity set name, which may optionally be qualified by the entity container name.
+
+ The to attach.
+
+ The entity is null.
+
+ Invalid entity set or the object has a temporary key or the object has an
+
+ and the
+
+ does not match with the entity set passed in as an argument of the method or the object does not have an
+
+ and no entity set is provided or any object from the object graph has a temporary
+
+ or any object from the object graph has an invalid
+
+ (for example, values in the key do not match values in the object) or the entity set could not be found from a given entitySetName name and entity container name or any object from the object graph already exists in another state manager.
+
+
+
+ Attaches an object or object graph to the object context when the object has an entity key.
+ The object to attach.
+ The entity is null.
+ Invalid entity key.
+
+
+ Creates the entity key for a specific object, or returns the entity key if it already exists.
+
+ The of the object.
+
+ The fully qualified name of the entity set to which the entity object belongs.
+ The object for which the entity key is being retrieved.
+ When either parameter is null.
+ When entitySetName is empty or when the type of the entity object does not exist in the entity set or when the entitySetName is not fully qualified.
+ When the entity key cannot be constructed successfully based on the supplied parameters.
+
+
+
+ Creates a new instance that is used to query, add, modify, and delete objects of the specified entity type.
+
+
+ The new instance.
+
+
+ Entity type of the requested .
+
+
+ The property is not set on the
+
+ or the specified type belongs to more than one entity set.
+
+
+
+
+ Creates a new instance that is used to query, add, modify, and delete objects of the specified type and with the specified entity set name.
+
+
+ The new instance.
+
+
+ Name of the entity set for the returned . The string must be qualified by the default container name if the
+
+ property is not set on the
+
+ .
+
+
+ Entity type of the requested .
+
+
+ The from entitySetName does not match the
+
+ of the object
+
+ or the
+
+ property is not set on the
+
+ and the name is not qualified as part of the entitySetName parameter or the specified type belongs to more than one entity set.
+
+
+
+
+ Creates an in the current object context by using the specified query string.
+
+
+ An of the specified type.
+
+ The query string to be executed.
+ Parameters to pass to the query.
+
+ The entity type of the returned .
+
+ The queryString or parameters parameter is null.
+
+
+ Marks an object for deletion.
+
+ An object that specifies the entity to delete. The object can be in any state except
+
+ .
+
+
+
+ Removes the object from the object context.
+
+ Object to be detached. Only the entity is removed; if there are any related objects that are being tracked by the same
+
+ , those will not be detached automatically.
+
+ The entity is null.
+
+ The entity is not associated with this (for example, was newly created and not associated with any context yet, or was obtained through some other context, or was already detached).
+
+
+
+
+ Finalizes an instance of the class.
+
+
+
+ Releases the resources used by the object context.
+
+
+
+ Releases the resources used by the object context.
+
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+
+ Returns an object that has the specified entity key.
+
+ An that is an instance of an entity type.
+
+ The key of the object to be found.
+ The key parameter is null.
+
+ The object is not found in either the or the data source.
+
+
+
+ Updates a collection of objects in the object context with data from the database.
+
+ A value that indicates whether
+ property changes in the object context are overwritten with property values from the database.
+
+
+ An collection of objects to refresh.
+
+ collection is null.
+ refreshMode is not valid.
+ collection is empty or an object is not attached to the context.
+
+
+ Updates an object in the object context with data from the database.
+
+ A value that indicates whether
+ property changes in the object context are overwritten with property values from the database.
+
+ The object to be refreshed.
+ entity is null.
+ refreshMode is not valid.
+ entity is not attached to the context.
+
+
+ Asynchronously updates a collection of objects in the object context with data from the database.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A value that indicates whether
+ property changes in the object context are overwritten with property values from the database.
+
+
+ An collection of objects to refresh.
+
+
+ A task that represents the asynchronous operation.
+
+ collection is null.
+ refreshMode is not valid.
+ collection is empty or an object is not attached to the context.
+
+
+ Asynchronously updates a collection of objects in the object context with data from the database.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A value that indicates whether
+ property changes in the object context are overwritten with property values from the database.
+
+
+ An collection of objects to refresh.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+ collection is null.
+ refreshMode is not valid.
+ collection is empty or an object is not attached to the context.
+
+
+ Asynchronously updates an object in the object context with data from the database.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A value that indicates whether
+ property changes in the object context are overwritten with property values from the database.
+
+ The object to be refreshed.
+
+ A task that represents the asynchronous operation.
+
+ entity is null.
+ refreshMode is not valid.
+ entity is not attached to the context.
+
+
+ Asynchronously updates an object in the object context with data from the database.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A value that indicates whether
+ property changes in the object context are overwritten with property values from the database.
+
+ The object to be refreshed.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+ entity is null.
+ refreshMode is not valid.
+ entity is not attached to the context.
+
+
+ Persists all updates to the database and resets change tracking in the object context.
+
+ The number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An optimistic concurrency violation has occurred while saving changes.
+
+
+ Asynchronously persists all updates to the database and resets change tracking in the object context.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous save operation.
+ The task result contains the number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An optimistic concurrency violation has occurred while saving changes.
+
+
+ Asynchronously persists all updates to the database and resets change tracking in the object context.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous save operation.
+ The task result contains the number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An optimistic concurrency violation has occurred while saving changes.
+
+
+ Persists all updates to the database and optionally resets change tracking in the object context.
+
+ This parameter is needed for client-side transaction support. If true, the change tracking on all objects is reset after
+
+ finishes. If false, you must call the
+ method after .
+
+
+ The number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An optimistic concurrency violation has occurred while saving changes.
+
+
+ Persists all updates to the database and optionally resets change tracking in the object context.
+
+ A value that determines the behavior of the operation.
+
+
+ The number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An optimistic concurrency violation has occurred while saving changes.
+
+
+ Asynchronously persists all updates to the database and optionally resets change tracking in the object context.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A value that determines the behavior of the operation.
+
+
+ A task that represents the asynchronous save operation.
+ The task result contains the number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An optimistic concurrency violation has occurred while saving changes.
+
+
+ Asynchronously persists all updates to the database and optionally resets change tracking in the object context.
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A value that determines the behavior of the operation.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous save operation.
+ The task result contains the number of state entries written to the underlying database. This can include
+ state entries for entities and/or relationships. Relationship state entries are created for
+ many-to-many relationships and relationships where there is no foreign key property
+ included in the entity class (often referred to as independent associations).
+
+ An optimistic concurrency violation has occurred while saving changes.
+
+
+
+ Ensures that changes are synchronized with changes in all objects that are tracked by the
+
+ .
+
+
+
+ Returns an object that has the specified entity key.
+ true if the object was retrieved successfully. false if the key is temporary, the connection is null, or the value is null.
+ The key of the object to be found.
+ When this method returns, contains the object.
+ Incompatible metadata for key .
+ key is null.
+
+
+
+ Executes a stored procedure or function that is defined in the data source and mapped in the conceptual model, with the specified parameters. Returns a typed
+
+ .
+
+
+ An for the data that is returned by the stored procedure.
+
+ The name of the stored procedure or function. The name can include the container name, such as <Container Name>.<Function Name>. When the default container name is known, only the function name is required.
+
+ An array of objects. If output parameters are used,
+ their values will not be available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ The entity type of the returned when the function is executed against the data source. This type must implement
+
+ .
+
+ function is null or empty or function is not found.
+ The entity reader does not support this function or there is a type mismatch on the reader and the function .
+
+
+
+ Executes the given stored procedure or function that is defined in the data source and expressed in the conceptual model, with the specified parameters, and merge option. Returns a typed
+
+ .
+
+
+ An for the data that is returned by the stored procedure.
+
+ The name of the stored procedure or function. The name can include the container name, such as <Container Name>.<Function Name>. When the default container name is known, only the function name is required.
+
+ The to use when executing the query.
+
+
+ An array of objects. If output parameters are used,
+ their values will not be available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ The entity type of the returned when the function is executed against the data source. This type must implement
+
+ .
+
+ function is null or empty or function is not found.
+ The entity reader does not support this function or there is a type mismatch on the reader and the function .
+
+
+
+ Executes the given function on the default container.
+
+ Element type for function results.
+
+ Name of function. May include container (e.g. ContainerName.FunctionName) or just function name when DefaultContainerName is known.
+
+ The options for executing this function.
+
+ The parameter values to use for the function. If output parameters are used, their values
+ will not be available until the results have been read completely. This is due to the underlying
+ behavior of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+ An object representing the result of executing this function.
+ If function is null or empty
+
+ If function is invalid (syntax,
+ does not exist, refers to a function with return type incompatible with T)
+
+
+
+ Executes a stored procedure or function that is defined in the data source and expressed in the conceptual model; discards any results returned from the function; and returns the number of rows affected by the execution.
+ The number of rows affected.
+ The name of the stored procedure or function. The name can include the container name, such as <Container Name>.<Function Name>. When the default container name is known, only the function name is required.
+
+ An array of objects. If output parameters are used,
+ their values will not be available until the results have been read completely. This is due to the underlying
+ behavior of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+ function is null or empty or function is not found.
+ The entity reader does not support this function or there is a type mismatch on the reader and the function .
+
+
+ Generates an equivalent type that can be used with the Entity Framework for each type in the supplied enumeration.
+
+ An enumeration of objects that represent custom data classes that map to the conceptual model.
+
+
+
+ Returns all the existing proxy types.
+
+ An of all the existing proxy types.
+
+
+
+ Returns the entity type of the POCO entity associated with a proxy object of a specified type.
+
+ The of the associated POCO entity.
+
+
+ The of the proxy object.
+
+
+
+ Creates and returns an instance of the requested type .
+ An instance of the requested type T , or an instance of a derived type that enables T to be used with the Entity Framework. The returned object is either an instance of the requested type or an instance of a derived type that enables the requested type to be used with the Entity Framework.
+ Type of object to be returned.
+
+
+
+ Executes an arbitrary command directly against the data source using the existing connection.
+ The command is specified using the server's native query language, such as SQL.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreCommand("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreCommand("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ If there isn't an existing local transaction a new transaction will be used
+ to execute the command.
+
+ The command specified in the server's native query language.
+ The parameter values to use for the query.
+ The number of rows affected.
+
+
+
+ Executes an arbitrary command directly against the data source using the existing connection.
+ The command is specified using the server's native query language, such as SQL.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreCommand("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreCommand("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ Controls the creation of a transaction for this command.
+ The command specified in the server's native query language.
+ The parameter values to use for the query.
+ The number of rows affected.
+
+
+
+ Asynchronously executes an arbitrary command directly against the data source using the existing connection.
+ The command is specified using the server's native query language, such as SQL.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ If there isn't an existing local transaction a new transaction will be used
+ to execute the command.
+
+ The command specified in the server's native query language.
+ The parameter values to use for the query.
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of rows affected.
+
+
+
+
+ Asynchronously executes an arbitrary command directly against the data source using the existing connection.
+ The command is specified using the server's native query language, such as SQL.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ Controls the creation of a transaction for this command.
+ The command specified in the server's native query language.
+ The parameter values to use for the query.
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of rows affected.
+
+
+
+
+ Asynchronously executes an arbitrary command directly against the data source using the existing connection.
+ The command is specified using the server's native query language, such as SQL.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ If there isn't an existing local transaction a new transaction will be used
+ to execute the command.
+
+ The command specified in the server's native query language.
+
+ A to observe while waiting for the task to complete.
+
+ The parameter values to use for the query.
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of rows affected.
+
+
+
+
+ Asynchronously executes an arbitrary command directly against the data source using the existing connection.
+ The command is specified using the server's native query language, such as SQL.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ Controls the creation of a transaction for this command.
+ The command specified in the server's native query language.
+
+ A to observe while waiting for the task to complete.
+
+ The parameter values to use for the query.
+
+ A task that represents the asynchronous operation.
+ The task result contains the number of rows affected.
+
+
+
+
+ Executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ Results are not tracked by the context, use the overload that specifies an entity set name to track results.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ An enumeration of objects of type .
+
+
+
+
+ Executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ Results are not tracked by the context, use the overload that specifies an entity set name to track results.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+ The options for executing this query.
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior of
+ DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ An enumeration of objects of type .
+
+
+
+
+ Executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ If an entity set name is specified, results are tracked by the context.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+ The entity set of the TResult type. If an entity set name is not provided, the results are not going to be tracked.
+
+ The to use when executing the query. The default is
+ .
+
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ An enumeration of objects of type .
+
+
+
+
+ Executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ If an entity set name is specified, results are tracked by the context.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+ The entity set of the TResult type. If an entity set name is not provided, the results are not going to be tracked.
+ The options for executing this query.
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ An enumeration of objects of type .
+
+
+
+
+ Asynchronously executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ Results are not tracked by the context, use the overload that specifies an entity set name to track results.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an enumeration of objects of type .
+
+
+
+
+ Asynchronously executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ Results are not tracked by the context, use the overload that specifies an entity set name to track results.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+
+ A to observe while waiting for the task to complete.
+
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an enumeration of objects of type .
+
+
+
+
+ Asynchronously executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ Results are not tracked by the context, use the overload that specifies an entity set name to track results.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+ The options for executing this query.
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an enumeration of objects of type .
+
+
+
+
+ Asynchronously executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ Results are not tracked by the context, use the overload that specifies an entity set name to track results.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+ The options for executing this query.
+
+ A to observe while waiting for the task to complete.
+
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an enumeration of objects of type .
+
+
+
+
+ Asynchronously executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ If an entity set name is specified, results are tracked by the context.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+ The entity set of the TResult type. If an entity set name is not provided, the results are not going to be tracked.
+ The options for executing this query.
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an enumeration of objects of type .
+
+
+
+
+ Asynchronously executes a query directly against the data source and returns a sequence of typed results.
+ The query is specified using the server's native query language, such as SQL.
+ If an entity set name is specified, results are tracked by the context.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.ExecuteStoreQueryAsync<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The element type of the result sequence.
+ The query specified in the server's native query language.
+ The entity set of the TResult type. If an entity set name is not provided, the results are not going to be tracked.
+ The options for executing this query.
+
+ A to observe while waiting for the task to complete.
+
+
+ The parameter values to use for the query. If output parameters are used, their values will not be
+ available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an enumeration of objects of type .
+
+
+
+
+ Translates a that contains rows of entity data to objects of the requested entity type.
+
+ The entity type.
+ An enumeration of objects of type TResult .
+
+ The that contains entity data to translate into entity objects.
+
+ When reader is null.
+
+
+
+ Translates a that contains rows of entity data to objects of the requested entity type, in a specific entity set, and with the specified merge option.
+
+ The entity type.
+ An enumeration of objects of type TResult .
+
+ The that contains entity data to translate into entity objects.
+
+ The entity set of the TResult type.
+
+ The to use when translated objects are added to the object context. The default is
+
+ .
+
+ When reader is null.
+
+ When the supplied mergeOption is not a valid value.
+
+ When the supplied entitySetName is not a valid entity set for the TResult type.
+
+
+
+ Creates the database by using the current data source connection and the metadata in the
+
+ .
+
+
+
+ Deletes the database that is specified as the database in the current data source connection.
+
+
+
+ Checks if the database that is specified as the database in the current store connection exists on the store. Most of the actual work
+ is done by the DbProviderServices implementation for the current store connection.
+
+ true if the database exists; otherwise, false.
+
+
+
+ Generates a data definition language (DDL) script that creates schema objects (tables, primary keys, foreign keys) for the metadata in the
+
+ . The
+
+ loads metadata from store schema definition language (SSDL) files.
+
+
+ A DDL script that creates schema objects for the metadata in the
+
+ .
+
+
+
+ Gets the connection used by the object context.
+
+ A object that is the connection.
+
+
+ When the instance has been disposed.
+
+
+
+ Gets or sets the default container name.
+
+ A that is the default container name.
+
+
+
+ Gets the metadata workspace used by the object context.
+
+ The object associated with this
+
+ .
+
+
+
+ Gets the object state manager used by the object context to track object changes.
+
+ The used by this
+
+ .
+
+
+
+ Gets or sets the timeout value, in seconds, for all object context operations. A null value indicates that the default value of the underlying provider will be used.
+
+ An value that is the timeout value, in seconds.
+
+ The timeout value is less than 0.
+
+
+ Gets the LINQ query provider associated with this object context.
+
+ The instance used by this object context.
+
+
+
+
+ Gets the instance that contains options that affect the behavior of the
+
+ .
+
+
+ The instance that contains options that affect the behavior of the
+
+ .
+
+
+
+
+ Returns itself. ObjectContext implements to provide a common
+ interface for and ObjectContext both of which will return the underlying
+ ObjectContext.
+
+
+
+
+ Gets the transaction handler in use by this context. May be null if no transaction have been started.
+
+
+ The transaction handler.
+
+
+
+
+ Returns the being used for this context.
+
+
+
+ Occurs when changes are saved to the data source.
+
+
+ Occurs when a new entity object is created from data in the data source as part of a query or load operation.
+
+
+
+ Defines options that affect the behavior of the ObjectContext.
+
+
+
+
+ Gets or sets the value that determines whether SQL functions and commands should be always executed in a transaction.
+
+
+ This flag determines whether a new transaction will be started when methods such as
+ and are executed outside of a transaction.
+ Note that this does not change the behavior of .
+
+
+ The default transactional behavior.
+
+
+
+ Gets or sets a Boolean value that determines whether related objects are loaded automatically when a navigation property is accessed.
+ true if lazy loading is enabled; otherwise, false.
+
+
+ Gets or sets a Boolean value that determines whether proxy instances are created for custom data classes that are persistence ignorant.
+ true if proxies are created; otherwise, false. The default value is true.
+
+
+ Gets or sets a Boolean value that determines whether to use the legacy PreserveChanges behavior.
+ true if the legacy PreserveChanges behavior should be used; otherwise, false.
+
+
+ Gets or sets a Boolean value that determines whether to use the consistent NullReference behavior.
+
+ If this flag is set to false then setting the Value property of the for an
+ FK relationship to null when it is already null will have no effect. When this flag is set to true, then
+ setting the value to null will always cause the FK to be nulled and the relationship to be deleted
+ even if the value is currently null. The default value is false when using ObjectContext and true
+ when using DbContext.
+
+ true if the consistent NullReference behavior should be used; otherwise, false.
+
+
+ Gets or sets a Boolean value that determines whether to use the C# NullComparison behavior.
+
+ This flag determines whether C# behavior should be exhibited when comparing null values in LinqToEntities.
+ If this flag is set, then any equality comparison between two operands, both of which are potentially
+ nullable, will be rewritten to show C# null comparison semantics. As an example:
+ (operand1 = operand2) will be rewritten as
+ (((operand1 = operand2) AND NOT (operand1 IS NULL OR operand2 IS NULL)) || (operand1 IS NULL && operand2 IS NULL))
+ The default value is false when using .
+
+ true if the C# NullComparison behavior should be used; otherwise, false.
+
+
+
+ EventArgs for the ObjectMaterialized event.
+
+
+
+ Gets the entity object that was created.
+ The entity object that was created.
+
+
+
+ Delegate for the ObjectMaterialized event.
+
+ The ObjectContext responsable for materializing the object.
+ EventArgs containing a reference to the materialized object.
+
+
+
+ This class represents a query parameter at the object layer, which consists
+ of a Name, a Type and a Value.
+
+
+
+
+ Initializes a new instance of the class with the specified name and type.
+
+ The parameter name. This name should not include the "@" parameter marker that is used in the Entity SQL statements, only the actual name. The first character of the expression must be a letter. Any successive characters in the expression must be either letters, numbers, or an underscore (_) character.
+ The common language runtime (CLR) type of the parameter.
+ If the value of either argument is null.
+ If the value of the name argument is invalid. Parameter names must start with a letter and can only contain letters, numbers, and underscores.
+
+
+
+ Initializes a new instance of the class with the specified name and value.
+
+ The parameter name. This name should not include the "@" parameter marker that is used in Entity SQL statements, only the actual name. The first character of the expression must be a letter. Any successive characters in the expression must be either letters, numbers, or an underscore (_) character.
+ The initial value (and inherently, the type) of the parameter.
+ If the value of either argument is null.
+ If the value of the name argument is not valid. Parameter names must start with a letter and can only contain letters, numbers, and underscores.
+
+
+ Gets the parameter name, which can only be set through a constructor.
+ The parameter name, which can only be set through a constructor.
+
+
+ Gets the parameter type.
+
+ The of the parameter.
+
+
+
+ Gets or sets the parameter value.
+ The parameter value.
+
+
+
+ This class represents a collection of query parameters at the object layer.
+
+
+
+
+ Adds the specified to the collection.
+
+ The parameter to add to the collection.
+ The parameter argument is null.
+
+ The parameter argument already exists in the collection. This behavior differs from that of most collections that allow duplicate entries. -or-Another parameter with the same name as the parameter argument already exists in the collection. Note that the lookup is case-insensitive. This behavior differs from that of most collections, and is more like that of a
+
+ .
+
+ The type of the parameter is not valid.
+
+
+
+ Deletes all instances from the collection.
+
+
+
+
+ Checks for the existence of a specified in the collection by reference.
+
+ Returns true if the parameter object was found in the collection; otherwise, false.
+
+ The to find in the collection.
+
+ The parameter argument is null.
+
+
+
+ Determines whether an with the specified name is in the collection.
+
+ Returns true if a parameter with the specified name was found in the collection; otherwise, false.
+ The name of the parameter to look for in the collection. This name should not include the "@" parameter marker that is used in the Entity SQL statements, only the actual name.
+ The name parameter is null.
+
+
+ Allows the parameters in the collection to be copied into a supplied array, starting with the object at the specified index.
+ The array into which to copy the parameters.
+ The index in the array at which to start copying the parameters.
+
+
+
+ Removes an instance of an from the collection by reference if it exists in the collection.
+
+ Returns true if the parameter object was found and removed from the collection; otherwise, false.
+ An object to remove from the collection.
+ The parameter argument is null.
+
+
+
+ These methods return enumerator instances, which allow the collection to
+ be iterated through and traversed.
+
+ An object that can be used to iterate through the collection.
+
+
+ Returns an untyped enumerator over the collection.
+
+ An instance.
+
+
+
+ Gets the number of parameters currently in the collection.
+
+ The number of objects that are currently in the collection.
+
+
+
+
+ This collection is read-write - parameters may be added, removed
+ and [somewhat] modified at will (value only) - provided that the
+ implementation the collection belongs to has not locked its parameters
+ because it's command definition has been prepared.
+
+
+
+ Provides an indexer that allows callers to retrieve parameters by name.
+
+ The instance.
+
+ The name of the parameter to find. This name should not include the "@" parameter marker that is used in the Entity SQL statements, only the actual name.
+ No parameter with the specified name is found in the collection.
+
+
+
+ This class implements untyped queries at the object-layer.
+
+
+
+ Returns the commands to execute against the data source.
+ A string that represents the commands that the query executes against the data source.
+
+
+ Returns information about the result type of the query.
+
+ A value that contains information about the result type of the query.
+
+
+
+ Executes the untyped object query with the specified merge option.
+
+ The to use when executing the query.
+ The default is .
+
+
+ An that contains a collection of entity objects returned by the query.
+
+
+
+
+ Asynchronously executes the untyped object query with the specified merge option.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The to use when executing the query.
+ The default is .
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an an
+ that contains a collection of entity objects returned by the query.
+
+
+
+
+ Asynchronously executes the untyped object query with the specified merge option.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The to use when executing the query.
+ The default is .
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an an
+ that contains a collection of entity objects returned by the query.
+
+
+
+
+ Returns the collection as an used for data binding.
+
+
+ An of entity objects.
+
+
+
+ Returns an enumerator that iterates through a collection.
+
+ An that can be used to iterate through the collection.
+
+
+
+
+ Returns an which when enumerated will execute the given SQL query against the database.
+
+ The query results.
+
+
+ Returns the command text for the query.
+ A string value.
+
+
+ Gets the object context associated with this object query.
+
+ The associated with this
+
+ instance.
+
+
+
+ Gets or sets how objects returned from a query are added to the object context.
+
+ The query .
+
+
+
+
+ Whether the query is streaming or buffering
+
+
+
+ Gets the parameter collection for this object query.
+
+ The parameter collection for this .
+
+
+
+ Gets or sets a value that indicates whether the query plan should be cached.
+ A value that indicates whether the query plan should be cached.
+
+
+
+ Gets the result element type for this query instance.
+
+
+
+
+ Gets the expression describing this query. For queries built using
+ LINQ builder patterns, returns a full LINQ expression tree; otherwise,
+ returns a constant expression wrapping this query. Note that the
+ default expression is not cached. This allows us to differentiate
+ between LINQ and Entity-SQL queries.
+
+
+
+
+ Gets the associated with this query instance.
+
+
+
+
+ ObjectQuery implements strongly-typed queries at the object-layer.
+ Queries are specified using Entity-SQL strings and may be created by calling
+ the Entity-SQL-based query builder methods declared by ObjectQuery.
+
+ The result type of this ObjectQuery
+
+
+
+ Creates a new instance using the specified Entity SQL command as the initial query.
+
+ The Entity SQL query.
+
+ The on which to execute the query.
+
+
+
+
+ Creates a new instance using the specified Entity SQL command as the initial query and the specified merge option.
+
+ The Entity SQL query.
+
+ The on which to execute the query.
+
+
+ Specifies how the entities that are retrieved through this query should be merged with the entities that have been returned from previous queries against the same
+
+ .
+
+
+
+ Executes the object query with the specified merge option.
+
+ The to use when executing the query.
+ The default is .
+
+
+ An that contains a collection of entity objects returned by the query.
+
+
+
+
+ Asynchronously executes the object query with the specified merge option.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The to use when executing the query.
+ The default is .
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an
+ that contains a collection of entity objects returned by the query.
+
+
+
+
+ Asynchronously executes the object query with the specified merge option.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ The to use when executing the query.
+ The default is .
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains an
+ that contains a collection of entity objects returned by the query.
+
+
+
+ Specifies the related objects to include in the query results.
+
+ A new with the defined query path.
+
+ Dot-separated list of related objects to return in the query results.
+ path is null.
+ path is empty.
+
+
+ Limits the query to unique results.
+
+ A new instance that is equivalent to the original instance with SELECT DISTINCT applied.
+
+
+
+
+ This query-builder method creates a new query whose results are all of
+ the results of this query, except those that are also part of the other
+ query specified.
+
+ A query representing the results to exclude.
+ a new ObjectQuery instance.
+ If the query parameter is null.
+
+
+ Groups the query results by the specified criteria.
+
+ A new instance of type
+
+ that is equivalent to the original instance with GROUP BY applied.
+
+ The key columns by which to group the results.
+ The list of selected properties that defines the projection.
+ Zero or more parameters that are used in this method.
+ The query parameter is null or an empty string
+ or the projection parameter is null or an empty string.
+
+
+
+ This query-builder method creates a new query whose results are those that
+ are both in this query and the other query specified.
+
+ A query representing the results to intersect with.
+ a new ObjectQuery instance.
+ If the query parameter is null.
+
+
+ Limits the query to only results of a specific type.
+
+ A new instance that is equivalent to the original instance with OFTYPE applied.
+
+
+ The type of the returned when the query is executed with the applied filter.
+
+ The type specified is not valid.
+
+
+ Orders the query results by the specified criteria.
+
+ A new instance that is equivalent to the original instance with ORDER BY applied.
+
+ The key columns by which to order the results.
+ Zero or more parameters that are used in this method.
+ The keys or parameters parameter is null.
+ The key is an empty string.
+
+
+ Limits the query results to only the properties that are defined in the specified projection.
+
+ A new instance of type
+
+ that is equivalent to the original instance with SELECT applied.
+
+ The list of selected properties that defines the projection.
+ Zero or more parameters that are used in this method.
+ projection is null or parameters is null.
+ The projection is an empty string.
+
+
+ Limits the query results to only the property specified in the projection.
+
+ A new instance of a type compatible with the specific projection. The returned
+
+ is equivalent to the original instance with SELECT VALUE applied.
+
+ The projection list.
+ An optional set of query parameters that should be in scope when parsing.
+
+ The type of the returned by the
+
+ method.
+
+ projection is null or parameters is null.
+ The projection is an empty string.
+
+
+ Orders the query results by the specified criteria and skips a specified number of results.
+
+ A new instance that is equivalent to the original instance with both ORDER BY and SKIP applied.
+
+ The key columns by which to order the results.
+ The number of results to skip. This must be either a constant or a parameter reference.
+ An optional set of query parameters that should be in scope when parsing.
+ Any argument is null.
+ keys is an empty string or count is an empty string.
+
+
+ Limits the query results to a specified number of items.
+
+ A new instance that is equivalent to the original instance with TOP applied.
+
+ The number of items in the results as a string.
+ An optional set of query parameters that should be in scope when parsing.
+ count is null.
+ count is an empty string.
+
+
+
+ This query-builder method creates a new query whose results are all of
+ the results of this query, plus all of the results of the other query,
+ without duplicates (i.e., results are unique).
+
+ A query representing the results to add.
+ a new ObjectQuery instance.
+ If the query parameter is null.
+
+
+
+ This query-builder method creates a new query whose results are all of
+ the results of this query, plus all of the results of the other query,
+ including any duplicates (i.e., results are not necessarily unique).
+
+ A query representing the results to add.
+ a new ObjectQuery instance.
+ If the query parameter is null.
+
+
+ Limits the query to results that match specified filtering criteria.
+
+ A new instance that is equivalent to the original instance with WHERE applied.
+
+ The filter predicate.
+ Zero or more parameters that are used in this method.
+ predicate is null or parameters is null.
+ The predicate is an empty string.
+
+
+
+ Returns an which when enumerated will execute the given SQL query against the database.
+
+ The query results.
+
+
+
+ Returns an which when enumerated will execute the given SQL query against the database.
+
+ The query results.
+
+
+ Gets or sets the name of this object query.
+
+ A string value that is the name of this .
+
+ The value specified on set is not valid.
+
+
+
+ This class implements IEnumerable and IDisposable. Instance of this class
+ is returned from ObjectQuery.Execute method.
+
+
+
+
+ This constructor is intended only for use when creating test doubles that will override members
+ with mocked or faked behavior. Use of this constructor for other purposes may result in unexpected
+ behavior including but not limited to throwing .
+
+
+
+
+
+
+ Returns an enumerator that iterates through the query results.
+ An enumerator that iterates through the query results.
+
+
+ Returns the results in a format useful for data binding.
+
+ An of entity objects.
+
+
+
+ Performs tasks associated with freeing, releasing, or resetting resources.
+
+
+ Releases the resources used by the object result.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Gets the next result set of a stored procedure.
+ An ObjectResult that enumerates the values of the next result set. Null, if there are no more, or if the ObjectResult is not the result of a stored procedure call.
+ The type of the element.
+
+
+
+ IListSource.ContainsListCollection implementation. Always returns false.
+
+
+
+
+ When overridden in a derived class, gets the type of the generic
+
+ .
+
+
+ The type of the generic .
+
+
+
+
+ This class represents the result of the method.
+
+ The type of the result.
+
+
+
+ This constructor is intended only for use when creating test doubles that will override members
+ with mocked or faked behavior. Use of this constructor for other purposes may result in unexpected
+ behavior including but not limited to throwing .
+
+
+
+ Returns an enumerator that iterates through the query results.
+ An enumerator that iterates through the query results.
+
+
+
+
+
+ Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release managed and unmanaged resources; false to release only unmanaged resources.
+
+
+
+ Gets the type of the .
+
+
+ A that is the type of the .
+
+
+
+
+ Represents a typed entity set that is used to perform create, read, update, and delete operations.
+
+ The type of the entity.
+
+
+ Adds an object to the object context in the current entity set.
+ The object to add.
+
+
+ Attaches an object or object graph to the object context in the current entity set.
+ The object to attach.
+
+
+ Marks an object for deletion.
+
+ An object that represents the entity to delete. The object can be in any state except
+
+ .
+
+
+
+ Removes the object from the object context.
+
+ Object to be detached. Only the entity is removed; if there are any related objects that are being tracked by the same
+
+ , those will not be detached automatically.
+
+
+
+
+ Copies the scalar values from the supplied object into the object in the
+
+ that has the same key.
+
+ The updated object.
+
+ The detached object that has property updates to apply to the original object. The entity key of currentEntity must match the
+
+ property of an entry in the
+
+ .
+
+
+
+
+ Sets the property of an
+
+ to match the property values of a supplied object.
+
+ The updated object.
+
+ The detached object that has property updates to apply to the original object. The entity key of originalEntity must match the
+
+ property of an entry in the
+
+ .
+
+
+
+ Creates a new entity type object.
+ The new entity type object, or an instance of a proxy type that corresponds to the entity type.
+
+
+ Creates an instance of the specified type.
+ An instance of the requested type T , or an instance of a proxy type that corresponds to the type T .
+ Type of object to be returned.
+
+
+
+ Gets the metadata of the entity set represented by this instance.
+
+
+ An object.
+
+
+
+
+ The original values of the properties of an entity when it was retrieved from the database.
+
+
+
+
+ Maintains object state and identity management for entity type instances and relationship instances.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The , which supplies mapping and metadata information.
+
+
+
+
+ Returns a collection of objects for objects or relationships with the given state.
+
+
+ A collection of objects in the given
+
+ .
+
+
+ An used to filter the returned
+
+ objects.
+
+
+ When state is .
+
+
+
+
+ Changes state of the for a specific object to the specified entityState .
+
+
+ The for the supplied entity .
+
+ The object for which the state must be changed.
+ The new state of the object.
+ When entity is null.
+
+ When the object is not detached and does not have an entry in the state manager
+ or when you try to change the state to
+ from any other
+ or when state is not a valid value.
+
+
+
+ Changes the state of the relationship between two entity objects that is specified based on the two related objects and the name of the navigation property.
+
+ The for the relationship that was changed.
+
+
+ The object instance or of the source entity at one end of the relationship.
+
+
+ The object instance or of the target entity at the other end of the relationship.
+
+ The name of the navigation property on source that returns the specified target .
+
+ The requested of the specified relationship.
+
+ When source or target is null.
+
+ When trying to change the state of the relationship to a state other than
+ or
+ when either source or target is in a state
+ or when you try to change the state of the relationship to a state other than
+ or
+ when either source or target is in an state
+ or when state is not a valid value
+
+
+
+ Changes the state of the relationship between two entity objects that is specified based on the two related objects and a LINQ expression that defines the navigation property.
+
+ The for the relationship that was changed.
+
+
+ The object instance or of the source entity at one end of the relationship.
+
+
+ The object instance or of the target entity at the other end of the relationship.
+
+ A LINQ expression that selects the navigation property on source that returns the specified target .
+
+ The requested of the specified relationship.
+
+ The entity type of the source object.
+ When source , target , or selector is null.
+ selector is malformed or cannot return a navigation property.
+
+ When you try to change the state of the relationship to a state other than
+ or
+ when either source or target is in a
+ state
+ or when you try to change the state of the relationship to a state other than
+ or
+ when either source or target is in an state
+ or when state is not a valid value.
+
+
+
+ Changes the state of the relationship between two entity objects that is specified based on the two related objects and the properties of the relationship.
+
+ The for the relationship that was changed.
+
+
+ The object instance or of the source entity at one end of the relationship.
+
+
+ The object instance or of the target entity at the other end of the relationship.
+
+ The name of the relationship.
+ The role name at the target end of the relationship.
+
+ The requested of the specified relationship.
+
+ When source or target is null.
+
+ When you try to change the state of the relationship to a state other than
+ or
+ when either source or target is in a state
+ or when you try to change the state of the relationship to a state other than
+ or
+ when either source or target is in an
+ state
+ or when state is not a valid value.
+
+
+
+
+ Returns an for the object or relationship entry with the specified key.
+
+
+ The corresponding for the given
+
+ .
+
+
+ The .
+
+ When key is null.
+ When the specified key cannot be found in the state manager.
+
+ No entity with the specified exists in the
+
+ .
+
+
+
+
+ Returns an for the specified object.
+
+
+ The corresponding for the given
+
+ .
+
+
+ The to which the retrieved
+
+ belongs.
+
+
+ No entity for the specified exists in the
+
+ .
+
+
+
+
+ Tries to retrieve the corresponding for the specified
+
+ .
+
+
+ A Boolean value that is true if there is a corresponding
+
+ for the given object; otherwise, false.
+
+
+ The to which the retrieved
+
+ belongs.
+
+
+ When this method returns, contains the for the given
+
+ This parameter is passed uninitialized.
+
+
+
+
+ Tries to retrieve the corresponding for the object or relationship with the specified
+
+ .
+
+
+ A Boolean value that is true if there is a corresponding
+
+ for the given
+
+ ; otherwise, false.
+
+
+ The given .
+
+
+ When this method returns, contains an for the given
+
+ This parameter is passed uninitialized.
+
+ A null (Nothing in Visual Basic) value is provided for key .
+
+
+
+ Returns the that is used by the specified object.
+
+
+ The for the specified object.
+
+
+ The object for which to return the .
+
+
+ The entity does not implement IEntityWithRelationships and is not tracked by this ObjectStateManager
+
+
+
+
+ Returns the that is used by the specified object.
+
+
+ true if a instance was returned for the supplied entity ; otherwise false.
+
+
+ The object for which to return the .
+
+
+ When this method returns, contains the
+
+ for the entity .
+
+
+
+
+ Gets the associated with this state manager.
+
+
+ The associated with this
+
+ .
+
+
+
+ Occurs when entities are added to or removed from the state manager.
+
+
+
+ A DataContractResolver that knows how to resolve proxy types created for persistent
+ ignorant classes to their base types. This is used with the DataContractSerializer.
+
+
+
+ During deserialization, maps any xsi:type information to the actual type of the persistence-ignorant object.
+ Returns the type that the xsi:type is mapped to. Returns null if no known type was found that matches the xsi:type.
+ The xsi:type information to map.
+ The namespace of the xsi:type.
+ The declared type.
+
+ An instance of .
+
+
+
+ During serialization, maps actual types to xsi:type information.
+ true if the type was resolved; otherwise, false.
+ The actual type of the persistence-ignorant object.
+ The declared type.
+
+ An instance of .
+
+ When this method returns, contains a list of xsi:type declarations.
+ When this method returns, contains a list of namespaces used.
+
+
+
+ Defines the different ways to handle modified properties when refreshing in-memory data from the database.
+
+
+
+
+ For unmodified client objects, same behavior as StoreWins. For modified client
+ objects, Refresh original values with store value, keeping all values on client
+ object. The next time an update happens, all the client change units will be
+ considered modified and require updating.
+
+
+
+
+ Discard all changes on the client and refresh values with store values.
+ Client original values is updated to match the store.
+
+
+
+
+ Flags used to modify behavior of ObjectContext.SaveChanges()
+
+
+
+
+ Changes are saved without the DetectChanges or the AcceptAllChangesAfterSave methods being called.
+
+
+
+
+ After changes are saved, the AcceptAllChangesAfterSave method is called, which resets change tracking in the ObjectStateManager.
+
+
+
+
+ Before changes are saved, the DetectChanges method is called to synchronize the property values of objects that are attached to the object context with data in the ObjectStateManager.
+
+
+
+
+ This exception is thrown when a update operation violates the concurrency constraint.
+
+
+
+
+ Exception during save changes to store
+
+
+
+
+ Initializes a new instance of .
+
+
+
+
+ Initializes a new instance of with a specialized error message.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of the class that uses a specified error message and a reference to the inner exception that is the cause of this exception.
+
+ The error message that explains the reason for the exception.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of the class that uses a specified error message, a reference to the inner exception, and an enumerable collection of
+
+ objects.
+
+ The error message that explains the reason for the exception.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+ The collection of objects.
+
+
+
+
+ Initializes a new instance of with serialized data.
+
+
+ The that holds the serialized object data about the exception being thrown.
+
+
+ The that contains contextual information about the source or destination.
+
+
+
+
+ Gets the objects for this
+
+ .
+
+
+ A collection of objects comprised of either a single entity and 0 or more relationships, or 0 entities and 1 or more relationships.
+
+
+
+
+ Initializes a new instance of .
+
+
+
+
+ Initializes a new instance of with a specialized error message.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of that uses a specified error message and a reference to the inner exception.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of that uses a specified error message, a reference to the inner exception, and an enumerable collection of
+
+ objects.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+ The enumerable collection of objects.
+
+
+
+
+ Property constraint exception class. Note that this class has state - so if you change even
+ its internals, it can be a breaking change
+
+
+
+
+ Initializes a new instance of the class with default message.
+
+
+
+
+ Initializes a new instance of the class with supplied message.
+
+ A localized error message.
+
+
+
+ Initializes a new instance of the class with supplied message and inner exception.
+
+ A localized error message.
+ The inner exception.
+
+
+
+ Initializes a new instance of the class.
+
+ A localized error message.
+ The name of the property.
+
+
+
+ Initializes a new instance of the class.
+
+ A localized error message.
+ The name of the property.
+ The inner exception.
+
+
+ Gets the name of the property that violated the constraint.
+ The name of the property that violated the constraint.
+
+
+
+ This exception is thrown when the store provider exhibits a behavior incompatible with the entity client provider
+
+
+
+
+ Initializes a new instance of .
+
+
+
+
+ Initializes a new instance of with a specialized error message.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of that uses a specified error message.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Provides common language runtime (CLR) methods that expose EDM canonical functions
+ for use in or LINQ to Entities queries.
+
+
+ Note that this class was called EntityFunctions in some previous versions of Entity Framework.
+
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDev EDM function to calculate
+ the standard deviation of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical StDevP EDM function to calculate
+ the standard deviation for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The standard deviation for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Var EDM function to calculate
+ the variance of the collection.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical VarP EDM function to calculate
+ the variance for the population.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The collection over which to perform the calculation.
+ The variance for the population.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Left EDM function to return a given
+ number of the leftmost characters in a string.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input string.
+ The number of characters to return
+ A string containing the number of characters asked for from the left of the input string.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Right EDM function to return a given
+ number of the rightmost characters in a string.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input string.
+ The number of characters to return
+ A string containing the number of characters asked for from the right of the input string.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Reverse EDM function to return a given
+ string with the order of the characters reversed.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input string.
+ The input string with the order of the characters reversed.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical GetTotalOffsetMinutes EDM function to
+ return the number of minutes that the given date/time is offset from UTC. This is generally between +780
+ and -780 (+ or - 13 hrs).
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The date/time value to use.
+ The offset of the input from UTC.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical TruncateTime EDM function to return
+ the given date with the time portion cleared.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The date/time value to use.
+ The input date with the time portion cleared.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical TruncateTime EDM function to return
+ the given date with the time portion cleared.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The date/time value to use.
+ The input date with the time portion cleared.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical CreateDateTime EDM function to
+ create a new object.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The year.
+ The month (1-based).
+ The day (1-based).
+ The hours.
+ The minutes.
+ The seconds, including fractional parts of the seconds if desired.
+ The new date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical CreateDateTimeOffset EDM function to
+ create a new object.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The year.
+ The month (1-based).
+ The day (1-based).
+ The hours.
+ The minutes.
+ The seconds, including fractional parts of the seconds if desired.
+ The time zone offset part of the new date.
+ The new date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical CreateTime EDM function to
+ create a new object.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The hours.
+ The minutes.
+ The seconds, including fractional parts of the seconds if desired.
+ The new time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddYears EDM function to
+ add the given number of years to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of years to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddYears EDM function to
+ add the given number of years to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of years to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMonths EDM function to
+ add the given number of months to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of months to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMonths EDM function to
+ add the given number of months to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of months to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddDays EDM function to
+ add the given number of days to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of days to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddDays EDM function to
+ add the given number of days to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of days to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddHours EDM function to
+ add the given number of hours to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of hours to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddHours EDM function to
+ add the given number of hours to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of hours to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddHours EDM function to
+ add the given number of hours to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of hours to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMinutes EDM function to
+ add the given number of minutes to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of minutes to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMinutes EDM function to
+ add the given number of minutes to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of minutes to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMinutes EDM function to
+ add the given number of minutes to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of minutes to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddSeconds EDM function to
+ add the given number of seconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of seconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddSeconds EDM function to
+ add the given number of seconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of seconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddSeconds EDM function to
+ add the given number of seconds to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of seconds to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMilliseconds EDM function to
+ add the given number of milliseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of milliseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMilliseconds EDM function to
+ add the given number of milliseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of milliseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMilliseconds EDM function to
+ add the given number of milliseconds to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of milliseconds to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMicroseconds EDM function to
+ add the given number of microseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of microseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMicroseconds EDM function to
+ add the given number of microseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of microseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddMicroseconds EDM function to
+ add the given number of microseconds to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of microseconds to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddNanoseconds EDM function to
+ add the given number of nanoseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of nanoseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddNanoseconds EDM function to
+ add the given number of nanoseconds to a date/time.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of nanoseconds to add.
+ A resulting date/time.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical AddNanoseconds EDM function to
+ add the given number of nanoseconds to a time span.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The input date/time.
+ The number of nanoseconds to add.
+ A resulting time span.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffYears EDM function to
+ calculate the number of years between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of years between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffYears EDM function to
+ calculate the number of years between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of years between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMonths EDM function to
+ calculate the number of months between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of months between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMonths EDM function to
+ calculate the number of months between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of months between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffDays EDM function to
+ calculate the number of days between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of days between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffDays EDM function to
+ calculate the number of days between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of days between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffHours EDM function to
+ calculate the number of hours between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of hours between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffHours EDM function to
+ calculate the number of hours between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of hours between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffHours EDM function to
+ calculate the number of hours between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of hours between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMinutes EDM function to
+ calculate the number of minutes between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of minutes between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMinutes EDM function to
+ calculate the number of minutes between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of minutes between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMinutes EDM function to
+ calculate the number of minutes between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of minutes between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffSeconds EDM function to
+ calculate the number of seconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of seconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffSeconds EDM function to
+ calculate the number of seconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of seconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffSeconds EDM function to
+ calculate the number of seconds between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of seconds between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMilliseconds EDM function to
+ calculate the number of milliseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of milliseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMilliseconds EDM function to
+ calculate the number of milliseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of milliseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMilliseconds EDM function to
+ calculate the number of milliseconds between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of milliseconds between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMicroseconds EDM function to
+ calculate the number of microseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of microseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMicroseconds EDM function to
+ calculate the number of microseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of microseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffMicroseconds EDM function to
+ calculate the number of microseconds between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of microseconds between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffNanoseconds EDM function to
+ calculate the number of nanoseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of nanoseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffNanoseconds EDM function to
+ calculate the number of nanoseconds between two date/times.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first date/time.
+ The second date/time.
+ The number of nanoseconds between the first and second date/times.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical DiffNanoseconds EDM function to
+ calculate the number of nanoseconds between two time spans.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The first time span.
+ The second time span.
+ The number of nanoseconds between the first and second time spans.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Truncate EDM function to
+ truncate the given value to the number of specified digits.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The value to truncate.
+ The number of digits to preserve.
+ The truncated value.
+
+
+
+ When used as part of a LINQ to Entities query, this method invokes the canonical Truncate EDM function to
+ truncate the given value to the number of specified digits.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function is translated to a corresponding function in the database.
+
+ The value to truncate.
+ The number of digits to preserve.
+ The truncated value.
+
+
+
+ When used as part of a LINQ to Entities query, this method acts as an operator that ensures the input
+ is treated as a Unicode string.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function impacts the way the LINQ query is translated to a query that can be run in the database.
+
+ The input string.
+ The input string treated as a Unicode string.
+
+
+
+ When used as part of a LINQ to Entities query, this method acts as an operator that ensures the input
+ is treated as a non-Unicode string.
+
+
+ You cannot call this function directly. This function can only appear within a LINQ to Entities query.
+ This function impacts the way the LINQ query is translated to a query that can be run in the database.
+
+ The input string.
+ The input string treated as a non-Unicode string.
+
+
+
+ Describes the state of an entity.
+
+
+
+
+ The entity is not being tracked by the context.
+ An entity is in this state immediately after it has been created with the new operator
+ or with one of the Create methods.
+
+
+
+
+ The entity is being tracked by the context and exists in the database, and its property
+ values have not changed from the values in the database.
+
+
+
+
+ The entity is being tracked by the context but does not yet exist in the database.
+
+
+
+
+ The entity is being tracked by the context and exists in the database, but has been marked
+ for deletion from the database the next time SaveChanges is called.
+
+
+
+
+ The entity is being tracked by the context and exists in the database, and some or all of its
+ property values have been modified.
+
+
+
+
+ Represents information about a database connection.
+
+
+
+
+ Creates a new instance of DbConnectionInfo representing a connection that is specified in the application configuration file.
+
+ The name of the connection string in the application configuration.
+
+
+
+ Creates a new instance of DbConnectionInfo based on a connection string.
+
+ The connection string to use for the connection.
+ The name of the provider to use for the connection. Use 'System.Data.SqlClient' for SQL Server.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Instances of this class are used to create DbConnection objects for
+ SQL Server LocalDb based on a given database name or connection string.
+
+
+ An instance of this class can be set on the class or in the
+ app.config/web.config for the application to cause all DbContexts created with no
+ connection information or just a database name to use SQL Server LocalDb by default.
+ This class is immutable since multiple threads may access instances simultaneously
+ when creating connections.
+
+
+
+
+ Implementations of this interface are used to create DbConnection objects for
+ a type of database server based on a given database name.
+ An Instance is set on the class to
+ cause all DbContexts created with no connection information or just a database
+ name or connection string to use a certain type of database server by default.
+ Two implementations of this interface are provided:
+ is used to create connections to Microsoft SQL Server, including EXPRESS editions.
+ is used to create connections to Microsoft SQL
+ Server Compact Editions.
+ Other implementations for other database servers can be added as needed.
+ Note that implementations should be thread safe or immutable since they may
+ be accessed by multiple threads at the same time.
+
+
+
+
+ Creates a connection based on the given database name or connection string.
+
+ The database name or connection string.
+ An initialized DbConnection.
+
+
+
+ Creates a new instance of the connection factory for the given version of LocalDb.
+ For SQL Server 2012 LocalDb use "v11.0".
+ For SQL Server 2014 and later LocalDb use "mssqllocaldb".
+
+ The LocalDb version to use.
+
+
+
+ Creates a new instance of the connection factory for the given version of LocalDb.
+ For SQL Server 2012 LocalDb use "v11.0".
+ For SQL Server 2014 and later LocalDb use "mssqllocaldb".
+
+ The LocalDb version to use.
+ The connection string to use for options to the database other than the 'Initial Catalog', 'Data Source', and 'AttachDbFilename'. The 'Initial Catalog' and 'AttachDbFilename' will be prepended to this string based on the database name when CreateConnection is called. The 'Data Source' will be set based on the LocalDbVersion argument.
+
+
+
+ Creates a connection for SQL Server LocalDb based on the given database name or connection string.
+ If the given string contains an '=' character then it is treated as a full connection string,
+ otherwise it is treated as a database name only.
+
+ The database name or connection string.
+ An initialized DbConnection.
+
+
+
+ The connection string to use for options to the database other than the 'Initial Catalog',
+ 'Data Source', and 'AttachDbFilename'.
+ The 'Initial Catalog' and 'AttachDbFilename' will be prepended to this string based on the
+ database name when CreateConnection is called.
+ The 'Data Source' will be set based on the LocalDbVersion argument.
+ The default is 'Integrated Security=True;'.
+
+
+
+
+ An implementation of that will use Code First Migrations
+ to update the database to the latest version.
+
+ The type of the context.
+ The type of the migrations configuration to use during initialization.
+
+
+
+ Initializes a new instance of the MigrateDatabaseToLatestVersion class that will use
+ the connection information from a context constructed using the default constructor
+ or registered factory if applicable
+
+
+
+
+ Initializes a new instance of the MigrateDatabaseToLatestVersion class specifying whether to
+ use the connection information from the context that triggered initialization to perform the migration.
+
+
+ If set to true the initializer is run using the connection information from the context that
+ triggered initialization. Otherwise, the connection information will be taken from a context constructed
+ using the default constructor or registered factory if applicable.
+
+
+
+
+ Initializes a new instance of the MigrateDatabaseToLatestVersion class specifying whether to
+ use the connection information from the context that triggered initialization to perform the migration.
+ Also allows specifying migrations configuration to use during initialization.
+
+
+ If set to true the initializer is run using the connection information from the context that
+ triggered initialization. Otherwise, the connection information will be taken from a context constructed
+ using the default constructor or registered factory if applicable.
+
+ Migrations configuration to use during initialization.
+
+
+
+ Initializes a new instance of the MigrateDatabaseToLatestVersion class that will
+ use a specific connection string from the configuration file to connect to
+ the database to perform the migration.
+
+ The name of the connection string to use for migration.
+
+
+
+
+
+
+ Helper class that is used to configure a column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Creates a new column definition to store Binary data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ The maximum allowable length of the array data.
+ Value indicating whether or not all data should be padded to the maximum length.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ Value indicating whether or not this column should be configured as a timestamp.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Boolean data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Byte data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Value indicating whether or not the database will generate values for this column during insert.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store DateTime data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ The precision of the column.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Decimal data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ The numeric precision of the column.
+ The numeric scale of the column.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Value indicating whether or not the database will generate values for this column during insert.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Double data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store GUID data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Value indicating whether or not the database will generate values for this column during insert.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Single data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Short data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Value indicating whether or not the database will generate values for this column during insert.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Integer data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Value indicating whether or not the database will generate values for this column during insert.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Long data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Value indicating whether or not the database will generate values for this column during insert.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store String data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ The maximum allowable length of the string data.
+ Value indicating whether or not all data should be padded to the maximum length.
+ Value indicating whether or not the column supports Unicode content.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store Time data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ The precision of the column.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store DateTimeOffset data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ The precision of the column.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store geography data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+ Creates a new column definition to store geometry data.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Value indicating whether or not the column allows null values.
+ Constant value to use as the default value for this column.
+ SQL expression used as the default value for this column.
+ The name of the column.
+ Provider specific data type to use for this column.
+ Custom annotations usually from the Code First model.
+ The newly constructed column definition.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Creates a shallow copy of the current .
+
+ A shallow copy of the current .
+
+
+
+ Helper class that is used to further configure a table being created from a CreateTable call on
+
+ .
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The type that represents the table's columns.
+
+
+
+ Initializes a new instance of the TableBuilder class.
+
+ The table creation operation to be further configured.
+ The migration the table is created in.
+
+
+
+ Specifies a primary key for the table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ A lambda expression representing the property to be used as the primary key. C#: t => t.Id VB.Net: Function(t) t.Id If the primary key is made up of multiple properties then specify an anonymous type including the properties. C#: t => new { t.Id1, t.Id2 } VB.Net: Function(t) New With { t.Id1, t.Id2 }
+ The name of the primary key. If null is supplied, a default name will be generated.
+ A value indicating whether or not this is a clustered primary key.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+ Itself, so that multiple calls can be chained.
+
+
+
+ Specifies an index to be created on the table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ A lambda expression representing the property to be indexed. C#: t => t.PropertyOne VB.Net: Function(t) t.PropertyOne If multiple properties are to be indexed then specify an anonymous type including the properties. C#: t => new { t.PropertyOne, t.PropertyTwo } VB.Net: Function(t) New With { t.PropertyOne, t.PropertyTwo }
+ The name of the index.
+ A value indicating whether or not this is a unique index.
+ A value indicating whether or not this is a clustered index.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+ Itself, so that multiple calls can be chained.
+
+
+
+ Specifies a foreign key constraint to be created on the table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Name of the table that the foreign key constraint targets.
+ A lambda expression representing the properties of the foreign key. C#: t => t.PropertyOne VB.Net: Function(t) t.PropertyOne If multiple properties make up the foreign key then specify an anonymous type including the properties. C#: t => new { t.PropertyOne, t.PropertyTwo } VB.Net: Function(t) New With { t.PropertyOne, t.PropertyTwo }
+ A value indicating whether or not cascade delete should be configured on the foreign key constraint.
+ The name of this foreign key constraint. If no name is supplied, a default name will be calculated.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+ Itself, so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Creates a shallow copy of the current .
+
+ A shallow copy of the current .
+
+
+
+ Base class for code-based migrations.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Operations to be performed during the upgrade process.
+
+
+
+
+ Operations to be performed during the downgrade process.
+
+
+
+
+ Adds an operation to create a new stored procedure.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the stored procedure. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+ The body of the stored procedure.
+
+ The additional arguments that may be processed by providers. Use anonymous type syntax
+ to specify arguments. For example, 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to create a new stored procedure.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the stored procedure. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+ The action that specifies the parameters of the stored procedure.
+ The body of the stored procedure.
+
+ The additional arguments that may be processed by providers. Use anonymous type syntax
+ to specify arguments. For example, 'new { SampleArgument = "MyValue" }'.
+
+
+ The parameters in this create stored procedure operation. You do not need to specify this
+ type, it will be inferred from the parameter you supply.
+
+
+
+
+ Adds an operation to alter a stored procedure.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the stored procedure. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+ The body of the stored procedure.
+
+ The additional arguments that may be processed by providers. Use anonymous type syntax
+ to specify arguments. For example, 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to alter a stored procedure.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The parameters in this alter stored procedure operation. You do not need to specify this
+ type, it will be inferred from the parameter you supply.
+
+
+ The name of the stored procedure. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+ The action that specifies the parameters of the stored procedure.
+ The body of the stored procedure.
+
+ The additional arguments that may be processed by providers. Use anonymous type syntax
+ to specify arguments. For example, 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop an existing stored procedure with the specified name.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the procedure to drop. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+
+ The additional arguments that may be processed by providers. Use anonymous type syntax
+ to specify arguments. For example, 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to create a new table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The columns in this create table operation. You do not need to specify this type, it will
+ be inferred from the columnsAction parameter you supply.
+
+ The name of the table. Schema name is optional, if no schema is specified then dbo is assumed.
+
+ An action that specifies the columns to be included in the table. i.e. t => new { Id =
+ t.Int(identity: true), Name = t.String() }
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+ An object that allows further configuration of the table creation operation.
+
+
+
+ Adds an operation to create a new table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The columns in this create table operation. You do not need to specify this type, it will
+ be inferred from the columnsAction parameter you supply.
+
+ The name of the table. Schema name is optional, if no schema is specified then dbo is assumed.
+
+ An action that specifies the columns to be included in the table. i.e. t => new { Id =
+ t.Int(identity: true), Name = t.String() }
+
+ Custom annotations that exist on the table to be created. May be null or empty.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+ An object that allows further configuration of the table creation operation.
+
+
+
+ Adds an operation to handle changes in the annotations defined on tables.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The columns in this operation. You do not need to specify this type, it will
+ be inferred from the columnsAction parameter you supply.
+
+ The name of the table. Schema name is optional, if no schema is specified then dbo is assumed.
+
+ An action that specifies the columns to be included in the table. i.e. t => new { Id =
+ t.Int(identity: true), Name = t.String() }
+
+ The custom annotations on the table that have changed.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to create a new foreign key constraint.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the foreign key column. Schema name is optional, if no schema is
+ specified then dbo is assumed.
+
+ The foreign key column.
+
+ The table that contains the column this foreign key references. Schema name is optional,
+ if no schema is specified then dbo is assumed.
+
+
+ The column this foreign key references. If no value is supplied the primary key of the
+ principal table will be referenced.
+
+
+ A value indicating if cascade delete should be configured for the foreign key
+ relationship. If no value is supplied, cascade delete will be off.
+
+
+ The name of the foreign key constraint in the database. If no value is supplied a unique name will
+ be generated.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to create a new foreign key constraint.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the foreign key columns. Schema name is optional, if no schema is
+ specified then dbo is assumed.
+
+ The foreign key columns.
+
+ The table that contains the columns this foreign key references. Schema name is optional,
+ if no schema is specified then dbo is assumed.
+
+
+ The columns this foreign key references. If no value is supplied the primary key of the
+ principal table will be referenced.
+
+
+ A value indicating if cascade delete should be configured for the foreign key
+ relationship. If no value is supplied, cascade delete will be off.
+
+
+ The name of the foreign key constraint in the database. If no value is supplied a unique name will
+ be generated.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop a foreign key constraint based on its name.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the foreign key column. Schema name is optional, if no schema is
+ specified then dbo is assumed.
+
+ The name of the foreign key constraint in the database.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop a foreign key constraint based on the column it targets.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the foreign key column. Schema name is optional, if no schema is
+ specified then dbo is assumed.
+
+ The foreign key column.
+
+ The table that contains the column this foreign key references. Schema name is optional,
+ if no schema is specified then dbo is assumed.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop a foreign key constraint based on the column it targets.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the foreign key column.
+ Schema name is optional, if no schema is specified then dbo is assumed.
+
+ The foreign key column.
+
+ The table that contains the column this foreign key references.
+ Schema name is optional, if no schema is specified then dbo is assumed.
+
+ The columns this foreign key references.
+
+ Additional arguments that may be processed by providers.
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop a foreign key constraint based on the columns it targets.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the foreign key columns. Schema name is optional, if no schema is
+ specified then dbo is assumed.
+
+ The foreign key columns.
+
+ The table that contains the columns this foreign key references. Schema name is optional,
+ if no schema is specified then dbo is assumed.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to be dropped. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to be dropped. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+ Custom annotations that exist on columns of the table that is being dropped. May be null or empty.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to be dropped. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+ Custom annotations that exist on the table that is being dropped. May be null or empty.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to be dropped. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+ Custom annotations that exist on the table that is being dropped. May be null or empty.
+ Custom annotations that exist on columns of the table that is being dropped. May be null or empty.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to move a table to a new schema.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to be moved. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+ The schema the table is to be moved to.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to move a stored procedure to a new schema.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the stored procedure to be moved. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The schema the stored procedure is to be moved to.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to rename a table. To change the schema of a table use MoveTable.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to be renamed. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+
+ The new name for the table. Schema name is optional, if no schema is specified then dbo is
+ assumed.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to rename a stored procedure. To change the schema of a stored procedure use MoveStoredProcedure
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the stored procedure to be renamed. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+
+ The new name for the stored procedure. Schema name is optional, if no schema is specified then
+ dbo is assumed.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to rename a column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table that contains the column to be renamed. Schema name is optional, if no
+ schema is specified then dbo is assumed.
+
+ The name of the column to be renamed.
+ The new name for the column.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to add a column to an existing table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to add the column to. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the column to be added.
+
+ An action that specifies the column to be added. i.e. c => c.Int(nullable: false,
+ defaultValue: 3)
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop an existing column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to drop the column from. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the column to be dropped.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop an existing column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to drop the column from. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the column to be dropped.
+ Custom annotations that exist on the column that is being dropped. May be null or empty.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to alter the definition of an existing column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table the column exists in. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the column to be changed.
+
+ An action that specifies the new definition for the column. i.e. c => c.String(nullable:
+ false, defaultValue: "none")
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to create a new primary key.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the primary key column. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The primary key column.
+
+ The name of the primary key in the database. If no value is supplied a unique name will be
+ generated.
+
+ A value indicating whether or not this is a clustered primary key.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to create a new primary key based on multiple columns.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the primary key columns. Schema name is optional, if no schema is
+ specified then dbo is assumed.
+
+ The primary key columns.
+
+ The name of the primary key in the database. If no value is supplied a unique name will be
+ generated.
+
+ A value indicating whether or not this is a clustered primary key.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop an existing primary key that does not have the default name.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the primary key column. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the primary key to be dropped.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop an existing primary key that was created with the default name.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The table that contains the primary key column. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to create an index on a single column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to create the index on. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the column to create the index on.
+
+ A value indicating if this is a unique index. If no value is supplied a non-unique index will be
+ created.
+
+
+ The name to use for the index in the database. If no value is supplied a unique name will be
+ generated.
+
+ A value indicating whether or not this is a clustered index.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to create an index on multiple columns.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to create the index on. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the columns to create the index on.
+
+ A value indicating if this is a unique index. If no value is supplied a non-unique index will be
+ created.
+
+
+ The name to use for the index in the database. If no value is supplied a unique name will be
+ generated.
+
+ A value indicating whether or not this is a clustered index.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop an index based on its name.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to drop the index from. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the index to be dropped.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to drop an index based on the columns it targets.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table to drop the index from. Schema name is optional, if no schema is specified
+ then dbo is assumed.
+
+ The name of the column(s) the index targets.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to rename an index.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The name of the table that contains the index to be renamed. Schema name is optional, if no
+ schema is specified then dbo is assumed.
+
+ The name of the index to be renamed.
+ The new name for the index.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to execute a SQL command or set of SQL commands.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The SQL to be executed.
+
+ A value indicating if the SQL should be executed outside of the transaction being
+ used for the migration process. If no value is supplied the SQL will be executed within the transaction.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to execute a SQL file.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The SQL file to be executed. Relative paths are assumed to be relative to the current AppDomain's BaseDirectory.
+
+
+ A value indicating if the SQL should be executed outside of the transaction being
+ used for the migration process. If no value is supplied the SQL will be executed within the transaction.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Adds an operation to execute a SQL resource file.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The manifest resource name of the SQL resource file to be executed.
+
+ The assembly containing the resource file. The calling assembly is assumed if not provided.
+
+
+ A value indicating if the SQL should be executed outside of the transaction being
+ used for the migration process. If no value is supplied the SQL will be executed within the transaction.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Configuration relating to the use of migrations for a given model.
+ You will typically create a configuration class that derives
+ from rather than
+ using this class.
+
+
+
+
+ The default directory that migrations are stored in.
+
+
+
+
+ Initializes a new instance of the DbMigrationsConfiguration class.
+
+
+
+
+ Adds a new SQL generator to be used for a given database provider.
+
+ Name of the database provider to set the SQL generator for.
+ The SQL generator to be used.
+
+
+
+ Gets the SQL generator that is set to be used with a given database provider.
+
+ Name of the database provider to get the SQL generator for.
+ The SQL generator that is set for the database provider.
+
+
+
+ Adds a new factory for creating instances to be used for a given database provider.
+
+ Name of the database provider to set the SQL generator for.
+
+ A factory for creating instances for a given and
+ representing the default schema.
+
+
+
+
+ Gets the history context factory that is set to be used with a given database provider.
+
+ Name of the database provider to get thefactory for.
+ The history context factory that is set for the database provider.
+
+
+
+ Gets or sets a value indicating if automatic migrations can be used when migrating the database.
+
+
+
+
+ Gets or sets the string used to distinguish migrations belonging to this configuration
+ from migrations belonging to other configurations using the same database.
+ This property enables migrations from multiple different models to be applied to applied to a single database.
+
+
+
+
+ Gets or sets a value indicating if data loss is acceptable during automatic migration.
+ If set to false an exception will be thrown if data loss may occur as part of an automatic migration.
+
+
+
+
+ Gets or sets the derived DbContext representing the model to be migrated.
+
+
+
+
+ Gets or sets the namespace used for code-based migrations.
+
+
+
+
+ Gets or sets the sub-directory that code-based migrations are stored in.
+ Note that this property must be set to a relative path for a sub-directory under the
+ Visual Studio project root; it cannot be set to an absolute path.
+
+
+
+
+ Gets or sets the code generator to be used when scaffolding migrations.
+
+
+
+
+ Gets or sets the assembly containing code-based migrations.
+
+
+
+
+ Gets or sets a value to override the connection of the database to be migrated.
+
+
+
+
+ Gets or sets the timeout value used for the individual commands within a
+ migration. A null value indicates that the default value of the underlying
+ provider will be used.
+
+
+
+
+ Configuration relating to the use of migrations for a given model.
+
+ The context representing the model that this configuration applies to.
+
+
+
+ Initializes a new instance of the DbMigrationsConfiguration class.
+
+
+
+
+ Runs after upgrading to the latest migration to allow seed data to be updated.
+
+
+ Note that the database may already contain seed data when this method runs. This means that
+ implementations of this method must check whether or not seed data is present and/or up-to-date
+ and then only make changes if necessary and in a non-destructive way. The
+
+ can be used to help with this, but for seeding large amounts of data it may be necessary to do less
+ granular checks if performance is an issue.
+ If the database
+ initializer is being used, then this method will be called each time that the initializer runs.
+ If one of the , ,
+ or initializers is being used, then this method will not be
+ called and the Seed method defined in the initializer should be used instead.
+
+ Context to be used for updating seed data.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ DbMigrator is used to apply existing migrations to a database.
+ DbMigrator can be used to upgrade and downgrade to any given migration.
+ To scaffold migrations based on changes to your model use
+
+
+
+
+ Base class for decorators that wrap the core
+
+
+
+
+ Initializes a new instance of the MigratorBase class.
+
+ The migrator that this decorator is wrapping.
+
+
+
+ Gets a list of the pending migrations that have not been applied to the database.
+
+ List of migration Ids
+
+
+
+ Updates the target database to the latest migration.
+
+
+
+
+ Updates the target database to a given migration.
+
+ The migration to upgrade/downgrade to.
+
+
+
+ Gets a list of the migrations that are defined in the assembly.
+
+ List of migration Ids
+
+
+
+ Gets a list of the migrations that have been applied to the database.
+
+ List of migration Ids
+
+
+
+ Gets the configuration being used for the migrations process.
+
+
+
+
+ Migration Id representing the state of the database before any migrations are applied.
+
+
+
+
+ Initializes a new instance of the DbMigrator class.
+
+ Configuration to be used for the migration process.
+
+
+
+ Gets all migrations that are defined in the configured migrations assembly.
+
+ The list of migrations.
+
+
+
+ Gets all migrations that have been applied to the target database.
+
+ The list of migrations.
+
+
+
+ Gets all migrations that are defined in the assembly but haven't been applied to the target database.
+
+ The list of migrations.
+
+
+
+ Updates the target database to a given migration.
+
+ The migration to upgrade/downgrade to.
+
+
+
+ Gets the configuration that is being used for the migration process.
+
+
+
+
+ A set of extension methods for
+
+
+
+
+ Adds or updates entities by key when SaveChanges is called. Equivalent to an "upsert" operation
+ from database terminology.
+ This method can useful when seeding data using Migrations.
+
+ The type of entities to add or update.
+ The set to which the entities belong.
+ The entities to add or update.
+
+ When the parameter is a custom or fake IDbSet implementation, this method will
+ attempt to locate and invoke a public, instance method with the same signature as this extension method.
+
+
+
+
+ Adds or updates entities by a custom identification expression when SaveChanges is called.
+ Equivalent to an "upsert" operation from database terminology.
+ This method can useful when seeding data using Migrations.
+
+ The type of entities to add or update.
+ The set to which the entities belong.
+ An expression specifying the properties that should be used when determining whether an Add or Update operation should be performed.
+ The entities to add or update.
+
+ When the parameter is a custom or fake IDbSet implementation, this method will
+ attempt to locate and invoke a public, instance method with the same signature as this extension method.
+
+
+
+
+ Generates C# code for a code-based migration.
+
+
+
+
+ Base class for providers that generate code for code-based migrations.
+
+
+
+
+ Generates the code that should be added to the users project.
+
+ Unique identifier of the migration.
+ Operations to be performed by the migration.
+ Source model to be stored in the migration metadata.
+ Target model to be stored in the migration metadata.
+ Namespace that code should be generated in.
+ Name of the class that should be generated.
+ The generated code.
+
+
+
+ Gets the namespaces that must be output as "using" or "Imports" directives to handle
+ the code generated by the given operations.
+
+ The operations for which code is going to be generated.
+ An ordered list of namespace names.
+
+
+
+ Gets the default namespaces that must be output as "using" or "Imports" directives for
+ any code generated.
+
+ A value indicating if this class is being generated for a code-behind file.
+ An ordered list of namespace names.
+
+
+
+ Gets the instances that are being used.
+
+
+
+
+
+
+
+ Generates the primary code file that the user can view and edit.
+
+ Operations to be performed by the migration.
+ Namespace that code should be generated in.
+ Name of the class that should be generated.
+ The generated code.
+
+
+
+ Generates the code behind file with migration metadata.
+
+ Unique identifier of the migration.
+ Source model to be stored in the migration metadata.
+ Target model to be stored in the migration metadata.
+ Namespace that code should be generated in.
+ Name of the class that should be generated.
+ The generated code.
+
+
+
+ Generates a property to return the source or target model in the code behind file.
+
+ Name of the property.
+ Value to be returned.
+ Text writer to add the generated code to.
+
+
+
+ Generates class attributes.
+
+ Text writer to add the generated code to.
+ A value indicating if this class is being generated for a code-behind file.
+
+
+
+ Generates a namespace, using statements and class definition.
+
+ Namespace that code should be generated in.
+ Name of the class that should be generated.
+ Text writer to add the generated code to.
+ Base class for the generated class.
+ A value indicating if this class is being generated for a code-behind file.
+ Namespaces for which using directives will be added. If null, then the namespaces returned from GetDefaultNamespaces will be used.
+
+
+
+ Generates the closing code for a class that was started with WriteClassStart.
+
+ Namespace that code should be generated in.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code for to re-create the given dictionary of annotations for use when passing
+ these annotations as a parameter of a . call.
+
+ The annotations to generate.
+ The writer to which generated code should be written.
+
+
+
+ Generates code for to re-create the given dictionary of annotations for use when passing
+ these annotations as a parameter of a . call.
+
+ The annotations to generate.
+ The writer to which generated code should be written.
+
+
+
+ Generates code for the given annotation value, which may be null. The default behavior is to use an
+ if one is registered, otherwise call ToString on the annotation value.
+
+
+ Note that a can be registered to generate code for custom annotations
+ without the need to override the entire code generator.
+
+ The name of the annotation for which code is needed.
+ The annotation value to generate.
+ The writer to which generated code should be written.
+
+
+ Generates code to perform a .
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+ Generates code to perform a .
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+ Generates code to specify the definition for a .
+ The parameter definition to generate code for.
+ Text writer to add the generated code to.
+ A value indicating whether to include the column name in the definition.
+
+
+ Generates code to perform a .
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code for an .
+
+ The operation for which code should be generated.
+ The writer to which generated code should be written.
+
+
+
+ Generates code to perform an as part of a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an as part of a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a as part of a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to specify a set of column names using a lambda expression.
+
+ The columns to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to specify the definition for a .
+
+ The column definition to generate code for.
+ Text writer to add the generated code to.
+ A value indicating whether to include the column name in the definition.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column of unknown data type.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Removes any invalid characters from the name of an database artifact.
+
+ The name to be scrubbed.
+ The scrubbed name.
+
+
+
+ Gets the type name to use for a column of the given data type.
+
+ The data type to translate.
+ The type name to use in the generated migration.
+
+
+
+ Quotes an identifier using appropriate escaping to allow it to be stored in a string.
+
+ The identifier to be quoted.
+ The quoted identifier.
+
+
+
+ Scaffolds code-based migrations to apply pending model changes to the database.
+
+
+
+
+ Initializes a new instance of the MigrationScaffolder class.
+
+ Configuration to be used for scaffolding.
+
+
+
+ Scaffolds a code based migration to apply any pending model changes to the database.
+
+ The name to use for the scaffolded migration.
+ The scaffolded migration.
+
+
+
+ Scaffolds a code based migration to apply any pending model changes to the database.
+
+ The name to use for the scaffolded migration.
+ Whether or not to include model changes.
+ The scaffolded migration.
+
+
+
+ Scaffolds the initial code-based migration corresponding to a previously run database initializer.
+
+ The scaffolded migration.
+
+
+
+ Gets or sets the namespace used in the migration's generated code.
+ By default, this is the same as MigrationsNamespace on the migrations
+ configuration object passed into the constructor. For VB.NET projects, this
+ will need to be updated to take into account the project's root namespace.
+
+
+
+
+ Represents a code-based migration that has been scaffolded and is ready to be written to a file.
+
+
+
+
+ Gets or sets the unique identifier for this migration.
+ Typically used for the file name of the generated code.
+
+
+
+
+ Gets or sets the scaffolded migration code that the user can edit.
+
+
+
+
+ Gets or sets the scaffolded migration code that should be stored in a code behind file.
+
+
+
+
+ Gets or sets the programming language used for this migration.
+ Typically used for the file extension of the generated code.
+
+
+
+
+ Gets or sets the subdirectory in the user's project that this migration should be saved in.
+
+
+
+
+ Gets a dictionary of string resources to add to the migration resource file.
+
+
+
+
+ Gets or sets whether the migration was re-scaffolded.
+
+
+
+
+ Helper class that is used by design time tools to run migrations related
+ commands that need to interact with an application that is being edited
+ in Visual Studio.
+ Because the application is being edited the assemblies need to
+ be loaded in a separate AppDomain to ensure the latest version
+ is always loaded.
+ The App/Web.config file from the startup project is also copied
+ to ensure that any configuration is applied.
+
+
+
+
+ Initializes a new instance of the ToolingFacade class.
+
+ The name of the assembly that contains the migrations configuration to be used.
+ The name of the assembly that contains the DbContext to be used.
+ The namespace qualified name of migrations configuration to be used.
+ The working directory containing the compiled assemblies.
+ The path of the config file from the startup project.
+ The path of the application data directory from the startup project. Typically the App_Data directory for web applications or the working directory for executables.
+ The connection to the database to be migrated. If null is supplied, the default connection for the context will be used.
+
+
+
+ Releases all unmanaged resources used by the facade.
+
+
+
+
+ Gets the fully qualified name of all types deriving from .
+
+ All context types found.
+
+
+
+ Gets the fully qualified name of a type deriving from .
+
+ The name of the context type. If null, the single context type found in the assembly will be returned.
+ The context type found.
+
+
+
+ Gets a list of all migrations that have been applied to the database.
+
+ Ids of applied migrations.
+
+
+
+ Gets a list of all migrations that have not been applied to the database.
+
+ Ids of pending migrations.
+
+
+
+ Updates the database to the specified migration.
+
+ The Id of the migration to migrate to. If null is supplied, the database will be updated to the latest migration.
+ Value indicating if data loss during automatic migration is acceptable.
+
+
+
+ Generates a SQL script to migrate between two migrations.
+
+ The migration to update from. If null is supplied, a script to update the current database will be produced.
+ The migration to update to. If null is supplied, a script to update to the latest migration will be produced.
+ Value indicating if data loss during automatic migration is acceptable.
+ The generated SQL script.
+
+
+
+ Scaffolds a code-based migration to apply any pending model changes.
+
+ The name for the generated migration.
+ The programming language of the generated migration.
+ The root namespace of the project the migration will be added to.
+ Whether or not to include model changes.
+ The scaffolded migration.
+
+
+
+ Scaffolds the initial code-based migration corresponding to a previously run database initializer.
+
+ The programming language of the generated migration.
+ The root namespace of the project the migration will be added to.
+ The scaffolded migration.
+
+
+
+
+
+
+ Releases all resources used by the facade.
+
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+
+
+ Gets or sets an action to be run to log information.
+
+
+
+
+ Gets or sets an action to be run to log warnings.
+
+
+
+
+ Gets or sets an action to be run to log verbose information.
+
+
+
+
+ Base class for loggers that can be used for the migrations process.
+
+
+
+
+ Logs an informational message.
+
+ The message to be logged.
+
+
+
+ Logs a warning that the user should be made aware of.
+
+ The message to be logged.
+
+
+
+ Logs some additional information that should only be presented to the user if they request verbose output.
+
+ The message to be logged.
+
+
+
+ Generates VB.Net code for a code-based migration.
+
+
+
+
+
+
+
+ Generates the primary code file that the user can view and edit.
+
+ Operations to be performed by the migration.
+ Namespace that code should be generated in.
+ Name of the class that should be generated.
+ The generated code.
+
+
+
+ Generates the code behind file with migration metadata.
+
+ Unique identifier of the migration.
+ Source model to be stored in the migration metadata.
+ Target model to be stored in the migration metadata.
+ Namespace that code should be generated in.
+ Name of the class that should be generated.
+ The generated code.
+
+
+
+ Generates a property to return the source or target model in the code behind file.
+
+ Name of the property.
+ Value to be returned.
+ Text writer to add the generated code to.
+
+
+
+ Generates class attributes.
+
+ Text writer to add the generated code to.
+ A value indicating if this class is being generated for a code-behind file.
+
+
+
+ Generates a namespace, using statements and class definition.
+
+ Namespace that code should be generated in.
+ Name of the class that should be generated.
+ Text writer to add the generated code to.
+ Base class for the generated class.
+ A value indicating if this class is being generated for a code-behind file.
+ Namespaces for which Imports directives will be added. If null, then the namespaces returned from GetDefaultNamespaces will be used.
+
+
+
+ Generates the closing code for a class that was started with WriteClassStart.
+
+ Namespace that code should be generated in.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code for to re-create the given dictionary of annotations for use when passing
+ these annotations as a parameter of a . call.
+
+ The annotations to generate.
+ The writer to which generated code should be written.
+
+
+
+ Generates code for to re-create the given dictionary of annotations for use when passing
+ these annotations as a parameter of a . call.
+
+ The annotations to generate.
+ The writer to which generated code should be written.
+
+
+
+ Generates code for the given annotation value, which may be null. The default behavior is to use an
+ if one is registered, otherwise call ToString on the annotation value.
+
+
+ Note that a can be registered to generate code for custom annotations
+ without the need to override the entire code generator.
+
+ The name of the annotation for which code is needed.
+ The annotation value to generate.
+ The writer to which generated code should be written.
+
+
+ Generates code to perform a .
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+ Generates code to perform a .
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+ Generates code to perform a .
+ The parameter model definition to generate code for.
+ Text writer to add the generated code to.
+ true to include the column name in the definition; otherwise, false.
+
+
+ Generates code to perform a .
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code for an .
+
+ The operation for which code should be generated.
+ The writer to which generated code should be written.
+
+
+
+ Generates code to perform an as part of a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an as part of a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a as part of a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to specify a set of column names using a lambda expression.
+
+ The columns to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform an .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to specify the definition for a .
+
+ The column definition to generate code for.
+ Text writer to add the generated code to.
+ A value indicating whether to include the column name in the definition.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to specify the default value for a column of unknown data type.
+
+ The value to be used as the default.
+ Code representing the default value.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Generates code to perform a .
+
+ The operation to generate code for.
+ Text writer to add the generated code to.
+
+
+
+ Removes any invalid characters from the name of an database artifact.
+
+ The name to be scrubbed.
+ The scrubbed name.
+
+
+
+ Gets the type name to use for a column of the given data type.
+
+ The data type to translate.
+ The type name to use in the generated migration.
+
+
+
+ Quotes an identifier using appropriate escaping to allow it to be stored in a string.
+
+ The identifier to be quoted.
+ The quoted identifier.
+
+
+
+ Contains extension methods for the class.
+
+
+
+
+ Configures an awaiter used to await this to avoid
+ marshalling the continuation
+ back to the original context, but preserve the current culture and UI culture.
+
+
+ The type of the result produced by the associated .
+
+ The task to be awaited on.
+ An object used to await this task.
+
+
+
+ Configures an awaiter used to await this to avoid
+ marshalling the continuation
+ back to the original context, but preserve the current culture and UI culture.
+
+ The task to be awaited on.
+ An object used to await this task.
+
+
+
+ Provides an awaitable object that allows for awaits on that
+ preserve the culture.
+
+
+ The type of the result produced by the associated .
+
+ This type is intended for compiler use only.
+
+
+
+ Constructs a new instance of the class.
+
+ The task to be awaited on.
+
+
+ Gets an awaiter used to await this .
+ An awaiter instance.
+ This method is intended for compiler user rather than use directly in code.
+
+
+ Ends the await on the completed .
+ The result of the completed .
+ The awaiter was not properly initialized.
+ The task was canceled.
+ The task completed in a Faulted state.
+
+
+ This method is not implemented and should not be called.
+ The action to invoke when the await operation completes.
+
+
+
+ Schedules the continuation onto the associated with this
+ .
+
+ The action to invoke when the await operation completes.
+
+ The argument is null
+ (Nothing in Visual Basic).
+
+ The awaiter was not properly initialized.
+ This method is intended for compiler user rather than use directly in code.
+
+
+
+ Gets whether this Task has completed.
+
+
+ will return true when the Task is in one of the three
+ final states: RanToCompletion,
+ Faulted, or
+ Canceled.
+
+
+
+
+ Provides an awaitable object that allows for awaits on that
+ preserve the culture.
+
+ This type is intended for compiler use only.
+
+
+
+ Constructs a new instance of the class.
+
+ The task to be awaited on.
+
+
+ Gets an awaiter used to await this .
+ An awaiter instance.
+ This method is intended for compiler user rather than use directly in code.
+
+
+ Ends the await on the completed .
+ The awaiter was not properly initialized.
+ The task was canceled.
+ The task completed in a Faulted state.
+
+
+ This method is not implemented and should not be called.
+ The action to invoke when the await operation completes.
+
+
+
+ Schedules the continuation onto the associated with this
+ .
+
+ The action to invoke when the await operation completes.
+
+ The argument is null
+ (Nothing in Visual Basic).
+
+ The awaiter was not properly initialized.
+ This method is intended for compiler user rather than use directly in code.
+
+
+
+ Gets whether this Task has completed.
+
+
+ will return true when the Task is in one of the three
+ final states: RanToCompletion,
+ Faulted, or
+ Canceled.
+
+
+
+
+ This class is used by Code First Migrations to read and write migration history
+ from the database.
+ To customize the definition of the migrations history table you can derive from
+ this class and override OnModelCreating. Derived instances can either be registered
+ on a per migrations configuration basis using ,
+ or globally using .
+
+
+
+
+ The default name used for the migrations history table.
+
+
+
+
+ Initializes a new instance of the HistoryContext class.
+ If you are creating a derived history context you will generally expose a constructor
+ that accepts these same parameters and passes them to this base constructor.
+
+
+ An existing connection to use for the new context.
+
+
+ The default schema of the model being migrated.
+ This schema will be used for the migrations history table unless a different schema is configured in OnModelCreating.
+
+
+
+
+ Applies the default configuration for the migrations history table. If you override
+ this method it is recommended that you call this base implementation before applying your
+ custom configuration.
+
+ The builder that defines the model for the context being created.
+
+
+
+ Gets the key used to locate a model that was previously built for this context. This is used
+ to avoid processing OnModelCreating and calculating the model every time a new context instance is created.
+ By default this property returns the default schema.
+ In most cases you will not need to override this property. However, if your implementation of OnModelCreating
+ contains conditional logic that results in a different model being built for the same database provider and
+ default schema you should override this property and calculate an appropriate key.
+
+
+
+
+ Gets the default schema of the model being migrated.
+ This schema will be used for the migrations history table unless a different schema is configured in OnModelCreating.
+
+
+
+
+ Gets or sets a that can be used to read and write instances.
+
+
+
+
+ This class is used by Code First Migrations to read and write migration history
+ from the database.
+
+
+
+
+ Gets or sets the Id of the migration this row represents.
+
+
+
+
+ Gets or sets a key representing to which context the row applies.
+
+
+
+
+ Gets or sets the state of the model after this migration was applied.
+
+
+
+
+ Gets or sets the version of Entity Framework that created this entry.
+
+
+
+
+ Represents an error that occurs when an automatic migration would result in data loss.
+
+
+
+
+ Initializes a new instance of the AutomaticDataLossException class.
+
+
+
+
+ Initializes a new instance of the AutomaticDataLossException class.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of the MigrationsException class.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Represents an error that occurs when there are pending model changes after applying the last migration and automatic migration is disabled.
+
+
+
+
+ Initializes a new instance of the AutomaticMigrationsDisabledException class.
+
+
+
+
+ Initializes a new instance of the AutomaticMigrationsDisabledException class.
+
+ The message that describes the error.
+
+
+
+ Initializes a new instance of the MigrationsException class.
+
+ The message that describes the error.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Provides additional metadata about a code-based migration.
+
+
+
+
+ Gets the unique identifier for the migration.
+
+
+
+
+ Gets the state of the model before this migration is run.
+
+
+
+
+ Gets the state of the model after this migration is run.
+
+
+
+
+ Decorator to provide logging during migrations operations..
+
+
+
+
+ Initializes a new instance of the MigratorLoggingDecorator class.
+
+ The migrator that this decorator is wrapping.
+ The logger to write messages to.
+
+
+
+ Decorator to produce a SQL script instead of applying changes to the database.
+ Using this decorator to wrap will prevent
+ from applying any changes to the target database.
+
+
+
+
+ Initializes a new instance of the MigratorScriptingDecorator class.
+
+ The migrator that this decorator is wrapping.
+
+
+
+ Produces a script to update the database.
+
+
+ The migration to update from. If null is supplied, a script to update the
+ current database will be produced.
+
+
+ The migration to update to. If null is supplied,
+ a script to update to the latest migration will be produced.
+
+ The generated SQL script.
+
+
+
+ Represents a column being added to a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the AddColumnOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table the column should be added to.
+ Details of the column being added.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table the column should be added to.
+
+
+
+
+ Gets the details of the column being added.
+
+
+
+
+ Gets an operation that represents dropping the added column.
+
+
+
+
+
+
+
+ Represents a foreign key constraint being added to a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Base class for changes that affect foreign key constraints.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the ForeignKeyOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets or sets the name of the table that the foreign key constraint targets.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets or sets the name of the table that the foreign key columns exist in.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ The names of the foreign key column(s).
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets a value indicating if a specific name has been supplied for this foreign key constraint.
+
+
+
+
+ Gets or sets the name of this foreign key constraint.
+ If no name is supplied, a default name will be calculated.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the AddForeignKeyOperation class.
+ The PrincipalTable, PrincipalColumns, DependentTable and DependentColumns properties should also be populated.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets an operation to create an index on the foreign key column(s).
+
+ An operation to add the index.
+
+
+
+ The names of the column(s) that the foreign key constraint should target.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets or sets a value indicating if cascade delete should be configured on the foreign key constraint.
+
+
+
+
+ Gets an operation to drop the foreign key constraint.
+
+
+
+
+
+
+
+ Represents adding a primary key to a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Common base class to represent operations affecting primary keys.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Returns the default name for the primary key.
+
+ The target table name.
+ The default primary key name.
+
+
+
+ Initializes a new instance of the PrimaryKeyOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets or sets the name of the table that contains the primary key.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets the column(s) that make up the primary key.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets a value indicating if a specific name has been supplied for this primary key.
+
+
+
+
+ Gets or sets the name of this primary key.
+ If no name is supplied, a default name will be calculated.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+
+
+
+ Initializes a new instance of the AddPrimaryKeyOperation class.
+ The Table and Columns properties should also be populated.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets an operation to drop the primary key.
+
+
+
+
+ Gets or sets whether this is a clustered primary key.
+
+
+
+
+ Represents altering an existing column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the AlterColumnOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table that the column belongs to.
+ Details of what the column should be altered to.
+ Value indicating if this change will result in data loss.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the AlterColumnOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table that the column belongs to.
+ Details of what the column should be altered to.
+ Value indicating if this change will result in data loss.
+ An operation to revert this alteration of the column.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table that the column belongs to.
+
+
+
+
+ Gets the new definition for the column.
+
+
+
+
+ Gets an operation that represents reverting the alteration.
+ The inverse cannot be automatically calculated,
+ if it was not supplied to the constructor this property will return null.
+
+
+
+
+
+
+
+ Represents information about a column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the ColumnModel class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The data type for this column.
+
+
+
+ Initializes a new instance of the ColumnModel class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The data type for this column.
+ Additional details about the data type. This includes details such as maximum length, nullability etc.
+
+
+
+ Determines if this column is a narrower data type than another column.
+ Used to determine if altering the supplied column definition to this definition will result in data loss.
+
+ The column to compare to.
+ Details of the database provider being used.
+ True if this column is of a narrower data type.
+
+
+
+ Gets the CLR type corresponding to the database type of this column.
+
+
+
+
+ Gets the default value for the CLR type corresponding to the database type of this column.
+
+
+
+
+ Gets or sets a value indicating if this column can store null values.
+
+
+
+
+ Gets or sets a value indicating if values for this column will be generated by the database using the identity pattern.
+
+
+
+
+ Gets or sets a value indicating if this property model should be configured as a timestamp.
+
+
+
+
+ Gets or sets the custom annotations that have changed on the column.
+
+
+
+
+ Represents creating a database index.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Common base class for operations affecting indexes.
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Creates a default index name based on the supplied column names.
+
+ The column names used to create a default index name.
+ A default index name.
+
+
+
+ Initializes a new instance of the IndexOperation class.
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to
+ specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+
+ Gets or sets the table the index belongs to.
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets the columns that are indexed.
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets a value indicating if a specific name has been supplied for this index.
+
+
+
+
+ Gets or sets the name of this index.
+ If no name is supplied, a default name will be calculated.
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the CreateIndexOperation class.
+ The Table and Columns properties should also be populated.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets or sets a value indicating if this is a unique index.
+
+
+
+
+ Gets an operation to drop this index.
+
+
+
+
+
+
+
+ Gets or sets whether this is a clustered index.
+
+
+
+
+ Represents creating a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the CreateTableOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Name of the table to be created.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the CreateTableOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Name of the table to be created.
+ Custom annotations that exist on the table to be created. May be null or empty.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table to be created.
+
+
+
+
+ Gets the columns to be included in the new table.
+
+
+
+
+ Gets or sets the primary key for the new table.
+
+
+
+
+ Gets custom annotations that exist on the table to be created.
+
+
+
+
+ Gets an operation to drop the table.
+
+
+
+
+
+
+
+ Represents a column being dropped from a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the DropColumnOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table the column should be dropped from.
+ The name of the column to be dropped.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the DropColumnOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table the column should be dropped from.
+ The name of the column to be dropped.
+ Custom annotations that exist on the column that is being dropped. May be null or empty.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the DropColumnOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table the column should be dropped from.
+ The name of the column to be dropped.
+ The operation that represents reverting the drop operation.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the DropColumnOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table the column should be dropped from.
+ The name of the column to be dropped.
+ Custom annotations that exist on the column that is being dropped. May be null or empty.
+ The operation that represents reverting the drop operation.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table the column should be dropped from.
+
+
+
+
+ Gets the name of the column to be dropped.
+
+
+
+
+ Gets custom annotations that exist on the column that is being dropped.
+
+
+
+
+ Gets an operation that represents reverting dropping the column.
+ The inverse cannot be automatically calculated,
+ if it was not supplied to the constructor this property will return null.
+
+
+
+
+
+
+
+ Represents a foreign key constraint being dropped from a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the DropForeignKeyOperation class.
+ The PrincipalTable, DependentTable and DependentColumns properties should also be populated.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the DropForeignKeyOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc..
+
+ The operation that represents reverting dropping the foreign key constraint.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets an operation to drop the associated index on the foreign key column(s).
+
+ An operation to drop the index.
+
+
+
+ Gets an operation that represents reverting dropping the foreign key constraint.
+ The inverse cannot be automatically calculated,
+ if it was not supplied to the constructor this property will return null.
+
+
+
+
+
+
+
+ Represents dropping an existing index.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the DropIndexOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the DropIndexOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The operation that represents reverting dropping the index.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets an operation that represents reverting dropping the index.
+ The inverse cannot be automatically calculated,
+ if it was not supplied to the constructor this property will return null.
+
+
+
+
+
+
+
+ Represents dropping a primary key from a table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the DropPrimaryKeyOperation class.
+ The Table and Columns properties should also be populated.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets an operation to add the primary key.
+
+
+
+
+ Used when altering the migrations history table so that the table can be rebuilt rather than just dropping and adding the primary key.
+
+
+ The create table operation for the migrations history table.
+
+
+
+
+ Represents dropping an existing table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the DropTableOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table to be dropped.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the DropTableOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table to be dropped.
+ Custom annotations that exist on the table that is being dropped. May be null or empty.
+ Custom annotations that exist on columns of the table that is being dropped. May be null or empty.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the DropTableOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table to be dropped.
+ An operation that represents reverting dropping the table.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Initializes a new instance of the DropTableOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The name of the table to be dropped.
+ Custom annotations that exist on the table that is being dropped. May be null or empty.
+ Custom annotations that exist on columns of the table that is being dropped. May be null or empty.
+ An operation that represents reverting dropping the table.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table to be dropped.
+
+
+
+
+ Gets custom annotations that exist on the table that is being dropped.
+
+
+
+
+ Gets custom annotations that exist on columns of the table that is being dropped.
+
+
+
+
+ Gets an operation that represents reverting dropping the table.
+ The inverse cannot be automatically calculated,
+ if it was not supplied to the constructor this property will return null.
+
+
+
+
+
+
+
+ Operation representing DML changes to the migrations history table.
+ The migrations history table is used to store a log of the migrations that have been applied to the database.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the HistoryOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ A sequence of command trees representing the operations being applied to the history table.
+ Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ A sequence of commands representing the operations being applied to the history table.
+
+
+
+
+
+
+
+ Represents moving a table from one schema to another.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the MoveTableOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Name of the table to be moved.
+ Name of the schema to move the table to.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table to be moved.
+
+
+
+
+ Gets the name of the schema to move the table to.
+
+
+
+
+ Gets an operation that moves the table back to its original schema.
+
+
+
+
+
+
+
+ Used when altering the migrations history table so that data can be moved to the new table.
+
+
+ The context key for the model.
+
+
+
+
+ Gets a value that indicates whether this is a system table.
+
+
+ true if the table is a system table; otherwise, false.
+
+
+
+
+ Used when altering the migrations history table so that the table can be rebuilt rather than just dropping and adding the primary key.
+
+
+ The create table operation for the migrations history table.
+
+
+
+
+ Represents renaming an existing column.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the RenameColumnOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Name of the table the column belongs to.
+ Name of the column to be renamed.
+ New name for the column.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table the column belongs to.
+
+
+
+
+ Gets the name of the column to be renamed.
+
+
+
+
+ Gets the new name for the column.
+
+
+
+
+ Gets an operation that reverts the rename.
+
+
+
+
+
+
+
+ Represents renaming an existing table.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the RenameTableOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ Name of the table to be renamed.
+ New name for the table.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the name of the table to be renamed.
+
+
+
+
+ Gets the new name for the table.
+
+
+
+
+ Gets an operation that reverts the rename.
+
+
+
+
+
+
+
+ Represents a provider specific SQL statement to be executed directly against the target database.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Initializes a new instance of the SqlOperation class.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+ The SQL to be executed.
+ Additional arguments that may be processed by providers. Use anonymous type syntax to specify arguments e.g. 'new { SampleArgument = "MyValue" }'.
+
+
+
+ Gets the SQL to be executed.
+
+
+
+
+ Gets or sets a value indicating whether this statement should be performed outside of
+ the transaction scope that is used to make the migration process transactional.
+ If set to true, this operation will not be rolled back if the migration process fails.
+
+
+
+
+
+
+
+ Common base class for providers that convert provider agnostic migration
+ operations into database provider specific SQL commands.
+
+
+
+
+ Converts a set of migration operations into database provider specific SQL.
+
+ The operations to be converted.
+ Token representing the version of the database being targeted.
+ A list of SQL statements to be executed to perform the migration operations.
+
+
+
+ Generates the SQL body for a stored procedure.
+
+ The command trees representing the commands for an insert, update or delete operation.
+ The rows affected parameter name.
+ The provider manifest token.
+ The SQL body for the stored procedure.
+
+
+
+ Builds the store type usage for the specified using the facets from the specified .
+
+ Name of the store type.
+ The target property.
+ A store-specific TypeUsage
+
+
+
+ Gets or sets the provider manifest.
+
+
+ The provider manifest.
+
+
+
+
+ Represents a migration operation that has been translated into a SQL statement.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets or sets the SQL to be executed to perform this migration operation.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+
+
+ Gets or sets a value indicating whether this statement should be performed outside of
+ the transaction scope that is used to make the migration process transactional.
+ If set to true, this operation will not be rolled back if the migration process fails.
+
+
+
+
+ Gets or sets the batch terminator for the database provider.
+
+ Entity Framework Migrations APIs are not designed to accept input provided by untrusted sources
+ (such as the end user of an application). If input is accepted from such sources it should be validated
+ before being passed to these APIs to protect against SQL injection attacks etc.
+
+
+ The batch terminator for the database provider.
+
+
+
+
+ Extension methods for .
+
+
+
+
+ Returns an implementation that stays in sync with the given
+ .
+
+ The element type.
+ The collection that the binding list will stay in sync with.
+ The binding list.
+
+
+
+ Represents data in a geodetic (round earth) coordinate system.
+
+
+
+
+ Creates a new value based on the specified well known binary value.
+
+
+ A new DbGeography value as defined by the well known binary value with the default geography coordinate system identifier (SRID)(
+
+ ).
+
+ A byte array that contains a well known binary representation of the geography value.
+
+
+
+ Creates a new value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+
+ Creates a new line value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+
+ Creates a new point value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+
+ Creates a new polygon value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+ Returns the multiline value from a binary value.
+ The multiline value from a binary value.
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+ Returns the multipoint value from a well-known binary value.
+ The multipoint value from a well-known binary value.
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+ Returns the multi polygon value from a well-known binary value.
+ The multi polygon value from a well-known binary value.
+ The multi polygon well-known binary value.
+ The coordinate system identifier.
+
+
+
+ Creates a new collection value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+
+ Creates a new value based on the specified Geography Markup Language (GML) value.
+
+
+ A new DbGeography value as defined by the GML value with the default geography coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a Geography Markup Language (GML) representation of the geography value.
+
+
+
+ Creates a new value based on the specified Geography Markup Language (GML) value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the GML value with the specified coordinate system identifier.
+ A string that contains a Geography Markup Language (GML) representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+
+ Creates a new value based on the specified well known text value.
+
+
+ A new DbGeography value as defined by the well known text value with the default geography coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well known text representation of the geography value.
+
+
+
+ Creates a new value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+
+ Creates a new line value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+
+ Creates a new point value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+
+ Creates a new polygon value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+ Returns the multiline value from a well-known text value.
+ The multiline value from a well-known text value.
+ The well-known text.
+ The coordinate system identifier.
+
+
+ Returns the multipoint value from a well-known text value.
+ The multipoint value from a well-known text value.
+ The well-known text value.
+ The coordinate system identifier.
+
+
+ Returns the multi polygon value from a well-known text value.
+ The multi polygon value from a well-known text value.
+ The multi polygon well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new collection value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeography value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geography value.
+ The identifier of the coordinate system that the new DbGeography value should use.
+
+
+ Generates the well known text representation of this DbGeography value. Includes only Longitude and Latitude for points.
+ A string containing the well known text representation of this DbGeography value.
+
+
+ Generates the well known binary representation of this DbGeography value.
+ The well-known binary representation of this DbGeography value.
+
+
+ Generates the Geography Markup Language (GML) representation of this DbGeography value.
+ A string containing the GML representation of this DbGeography value.
+
+
+ Determines whether this DbGeography is spatially equal to the specified DbGeography argument.
+ true if other is spatially equal to this geography value; otherwise false.
+ The geography value that should be compared with this geography value for equality.
+
+
+ Determines whether this DbGeography is spatially disjoint from the specified DbGeography argument.
+ true if other is disjoint from this geography value; otherwise false.
+ The geography value that should be compared with this geography value for disjointness.
+
+
+ Determines whether this DbGeography value spatially intersects the specified DbGeography argument.
+ true if other intersects this geography value; otherwise false.
+ The geography value that should be compared with this geography value for intersection.
+
+
+ Returns a geography object that represents the union of all points whose distance from a geography instance is less than or equal to a specified value.
+ A geography object that represents the union of all points
+ The distance.
+
+
+ Computes the distance between the closest points in this DbGeography value and another DbGeography value.
+ A double value that specifies the distance between the two closest points in this geography value and other.
+ The geography value for which the distance from this value should be computed.
+
+
+ Computes the intersection of this DbGeography value and another DbGeography value.
+ A new DbGeography value representing the intersection between this geography value and other.
+ The geography value for which the intersection with this value should be computed.
+
+
+ Computes the union of this DbGeography value and another DbGeography value.
+ A new DbGeography value representing the union between this geography value and other.
+ The geography value for which the union with this value should be computed.
+
+
+ Computes the difference of this DbGeography value and another DbGeography value.
+ A new DbGeography value representing the difference between this geography value and other.
+ The geography value for which the difference with this value should be computed.
+
+
+ Computes the symmetric difference of this DbGeography value and another DbGeography value.
+ A new DbGeography value representing the symmetric difference between this geography value and other.
+ The geography value for which the symmetric difference with this value should be computed.
+
+
+ Returns an element of this DbGeography value from a specific position, if it represents a geography collection. <param name="index">The position within this geography value from which the element should be taken.</param><returns>The element in this geography value at the specified position, if it represents a collection of other geography values; otherwise null.</returns>
+ An element of this DbGeography value from a specific position
+ The index.
+
+
+ Returns an element of this DbGeography value from a specific position, if it represents a linestring or linear ring. <param name="index">The position within this geography value from which the element should be taken.</param><returns>The element in this geography value at the specified position, if it represents a linestring or linear ring; otherwise null.</returns>
+ An element of this DbGeography value from a specific position
+ The index.
+
+
+ Returns a string representation of the geography value.
+ A string representation of the geography value.
+
+
+ Gets the default coordinate system id (SRID) for geography values (WGS 84)
+ The default coordinate system id (SRID) for geography values (WGS 84)
+
+
+ Gets a representation of this DbGeography value that is specific to the underlying provider that constructed it.
+ A representation of this DbGeography value.
+
+
+
+ Gets the spatial provider that will be used for operations on this spatial type.
+
+
+
+ Gets or sets a data contract serializable well known representation of this DbGeography value.
+ A data contract serializable well known representation of this DbGeography value.
+
+
+ Gets the identifier associated with the coordinate system.
+ The identifier associated with the coordinate system.
+
+
+
+ Gets the dimension of the given value or, if the value is a collections, the largest element dimension.
+
+
+ The dimension of the given value.
+
+
+
+ Gets the spatial type name of the DBGeography.
+ The spatial type name of the DBGeography.
+
+
+ Gets a nullable Boolean value indicating whether this DbGeography value is empty.
+ True if this DbGeography value is empty; otherwise, false.
+
+
+ Gets the number of elements in this DbGeography value, if it represents a geography collection. <returns>The number of elements in this geography value, if it represents a collection of other geography values; otherwise null.</returns>
+ The number of elements in this DbGeography value.
+
+
+ Gets the Latitude coordinate of this DbGeography value, if it represents a point. <returns>The Latitude coordinate value of this geography value, if it represents a point; otherwise null.</returns>
+ The Latitude coordinate of this DbGeography value.
+
+
+ Gets the Longitude coordinate of this DbGeography value, if it represents a point. <returns>The Longitude coordinate value of this geography value, if it represents a point; otherwise null.</returns>
+ The Longitude coordinate of this DbGeography value.
+
+
+ Gets the elevation (Z coordinate) of this DbGeography value, if it represents a point. <returns>The elevation (Z coordinate) value of this geography value, if it represents a point; otherwise null.</returns>
+ The elevation (Z coordinate) of this DbGeography value.
+
+
+ Gets the M (Measure) coordinate of this DbGeography value, if it represents a point. <returns>The M (Measure) coordinate value of this geography value, if it represents a point; otherwise null.</returns>
+ The M (Measure) coordinate of this DbGeography value.
+
+
+ Gets a nullable double value that indicates the length of this DbGeography value, which may be null if this value does not represent a curve.
+ A nullable double value that indicates the length of this DbGeography value.
+
+
+ Gets a DbGeography value representing the start point of this value, which may be null if this DbGeography value does not represent a curve.
+ A DbGeography value representing the start point of this value.
+
+
+ Gets a DbGeography value representing the start point of this value, which may be null if this DbGeography value does not represent a curve.
+ A DbGeography value representing the start point of this value.
+
+
+ Gets a nullable Boolean value indicating whether this DbGeography value is closed, which may be null if this value does not represent a curve.
+ True if this DbGeography value is closed; otherwise, false.
+
+
+ Gets the number of points in this DbGeography value, if it represents a linestring or linear ring. <returns>The number of elements in this geography value, if it represents a linestring or linear ring; otherwise null.</returns>
+ The number of points in this DbGeography value.
+
+
+ Gets a nullable double value that indicates the area of this DbGeography value, which may be null if this value does not represent a surface.
+ A nullable double value that indicates the area of this DbGeography value.
+
+
+
+ A data contract serializable representation of a value.
+
+
+
+ Gets or sets the coordinate system identifier (SRID) of this value.
+
+
+ Gets or sets the well known text representation of this value.
+
+
+ Gets or sets the well known binary representation of this value.
+
+
+
+ Represents geometric shapes.
+
+
+
+
+ Creates a new value based on the specified well known binary value.
+
+
+ A new DbGeometry value as defined by the well known binary value with the default geometry coordinate system identifier (
+
+ ).
+
+ A byte array that contains a well known binary representation of the geometry value.
+ wellKnownBinary
+
+
+
+ Creates a new value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ wellKnownBinary
+ coordinateSystemId
+
+
+
+ Creates a new line value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ lineWellKnownBinary
+ coordinateSystemId
+
+
+
+ Creates a new point value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ pointWellKnownBinary
+ coordinateSystemId
+
+
+
+ Creates a new polygon value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ polygonWellKnownBinary
+ coordinateSystemId
+
+
+ Returns the multiline value from a binary value.
+ The multiline value from a binary value.
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+ Returns the multipoint value from a well-known binary value.
+ The multipoint value from a well-known binary value.
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+ Returns the multi polygon value from a well-known binary value.
+ The multipoint value from a well-known text value.
+ The multi polygon well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new collection value based on the specified well known binary value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known binary value with the specified coordinate system identifier.
+ A byte array that contains a well known binary representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ geometryCollectionWellKnownBinary
+ coordinateSystemId
+
+
+
+ Creates a new value based on the specified Geography Markup Language (GML) value.
+
+
+ A new DbGeometry value as defined by the GML value with the default geometry coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a Geography Markup Language (GML) representation of the geometry value.
+ geometryMarkup
+
+
+
+ Creates a new value based on the specified Geography Markup Language (GML) value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the GML value with the specified coordinate system identifier.
+ A string that contains a Geography Markup Language (GML) representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ geometryMarkup
+ coordinateSystemId
+
+
+
+ Creates a new value based on the specified well known text value.
+
+
+ A new DbGeometry value as defined by the well known text value with the default geometry coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well known text representation of the geometry value.
+ wellKnownText
+
+
+
+ Creates a new value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ wellKnownText
+ coordinateSystemId
+
+
+
+ Creates a new line value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ lineWellKnownText
+ coordinateSystemId
+
+
+
+ Creates a new point value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ pointWellKnownText
+ coordinateSystemId
+
+
+
+ Creates a new polygon value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ polygonWellKnownText
+ coordinateSystemId
+
+
+ Returns the multiline value from a well-known text value.
+ The multiline value from a well-known text value.
+ The well-known text.
+ The coordinate system identifier.
+
+
+ Returns the multipoint value from a well-known text value.
+ The multipoint value from a well-known text value.
+ The well-known text value.
+ The coordinate system identifier.
+
+
+ Returns the multi polygon value from a well-known binary value.
+ The multi polygon value from a well-known binary value.
+ The multi polygon well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new collection value based on the specified well known text value and coordinate system identifier (SRID).
+
+ A new DbGeometry value as defined by the well known text value with the specified coordinate system identifier.
+ A string that contains a well known text representation of the geometry value.
+ The identifier of the coordinate system that the new DbGeometry value should use.
+ geometryCollectionWellKnownText
+ coordinateSystemId
+
+
+ Generates the well known text representation of this DbGeometry value. Includes only X and Y coordinates for points.
+ A string containing the well known text representation of this DbGeometry value.
+
+
+ Generates the well known binary representation of this DbGeometry value.
+ The well-known binary representation of this DbGeometry value.
+
+
+ Generates the Geography Markup Language (GML) representation of this DbGeometry value.
+ A string containing the GML representation of this DbGeometry value.
+
+
+ Determines whether this DbGeometry is spatially equal to the specified DbGeometry argument.
+ true if other is spatially equal to this geometry value; otherwise false.
+ The geometry value that should be compared with this geometry value for equality.
+ other
+
+
+ Determines whether this DbGeometry is spatially disjoint from the specified DbGeometry argument.
+ true if other is disjoint from this geometry value; otherwise false.
+ The geometry value that should be compared with this geometry value for disjointness.
+ other
+
+
+ Determines whether this DbGeometry value spatially intersects the specified DbGeometry argument.
+ true if other intersects this geometry value; otherwise false.
+ The geometry value that should be compared with this geometry value for intersection.
+ other
+
+
+ Determines whether this DbGeometry value spatially touches the specified DbGeometry argument.
+ true if other touches this geometry value; otherwise false.
+ The geometry value that should be compared with this geometry value.
+ other
+
+
+ Determines whether this DbGeometry value spatially crosses the specified DbGeometry argument.
+ true if other crosses this geometry value; otherwise false.
+ The geometry value that should be compared with this geometry value.
+ other
+
+
+ Determines whether this DbGeometry value is spatially within the specified DbGeometry argument.
+ true if this geometry value is within other; otherwise false.
+ The geometry value that should be compared with this geometry value for containment.
+ other
+
+
+ Determines whether this DbGeometry value spatially contains the specified DbGeometry argument.
+ true if this geometry value contains other; otherwise false.
+ The geometry value that should be compared with this geometry value for containment.
+ other
+
+
+ Determines whether this DbGeometry value spatially overlaps the specified DbGeometry argument.
+ true if this geometry value overlaps other; otherwise false.
+ The geometry value that should be compared with this geometry value for overlap.
+ other
+
+
+ Determines whether this DbGeometry value spatially relates to the specified DbGeometry argument according to the given Dimensionally Extended Nine-Intersection Model (DE-9IM) intersection pattern.
+ true if this geometry value relates to other according to the specified intersection pattern matrix; otherwise false.
+ The geometry value that should be compared with this geometry value for relation.
+ A string that contains the text representation of the (DE-9IM) intersection pattern that defines the relation.
+ othermatrix
+
+
+ Returns a geometry object that represents the union of all points whose distance from a geometry instance is less than or equal to a specified value.
+ A geometry object that represents the union of all points.
+ The distance.
+
+
+ Computes the distance between the closest points in this DbGeometry value and another DbGeometry value.
+ A double value that specifies the distance between the two closest points in this geometry value and other.
+ The geometry value for which the distance from this value should be computed.
+ other
+
+
+ Computes the intersection of this DbGeometry value and another DbGeometry value.
+ A new DbGeometry value representing the intersection between this geometry value and other.
+ The geometry value for which the intersection with this value should be computed.
+ other
+
+
+ Computes the union of this DbGeometry value and another DbGeometry value.
+ A new DbGeometry value representing the union between this geometry value and other.
+ The geometry value for which the union with this value should be computed.
+ other
+
+
+ Computes the difference between this DbGeometry value and another DbGeometry value.
+ A new DbGeometry value representing the difference between this geometry value and other.
+ The geometry value for which the difference with this value should be computed.
+ other
+
+
+ Computes the symmetric difference between this DbGeometry value and another DbGeometry value.
+ A new DbGeometry value representing the symmetric difference between this geometry value and other.
+ The geometry value for which the symmetric difference with this value should be computed.
+ other
+
+
+ Returns an element of this DbGeometry value from a specific position, if it represents a geometry collection. <param name="index">The position within this geometry value from which the element should be taken.</param><returns>The element in this geometry value at the specified position, if it represents a collection of other geometry values; otherwise null.</returns>
+ An element of this DbGeometry value from a specific position.
+ The index.
+
+
+ Returns an element of this DbGeometry value from a specific position, if it represents a linestring or linear ring. <param name="index">The position within this geometry value from which the element should be taken.</param><returns>The element in this geometry value at the specified position, if it represents a linestring or linear ring; otherwise null.</returns>
+ An element of this DbGeometry value from a specific position.
+ The index.
+
+
+ Returns an interior ring from this DbGeometry value at a specific position, if it represents a polygon. <param name="index">The position within this geometry value from which the interior ring should be taken.</param><returns>The interior ring in this geometry value at the specified position, if it represents a polygon; otherwise null.</returns>
+ An interior ring from this DbGeometry value at a specific position.
+ The index.
+
+
+ Returns a string representation of the geometry value.
+ A string representation of the geometry value.
+
+
+ Gets the default coordinate system id (SRID) for geometry values.
+ The default coordinate system id (SRID) for geometry values.
+
+
+ Gets a representation of this DbGeometry value that is specific to the underlying provider that constructed it.
+ A representation of this DbGeometry value.
+
+
+
+ Gets the spatial provider that will be used for operations on this spatial type.
+
+
+
+ Gets or sets a data contract serializable well known representation of this DbGeometry value.
+ A data contract serializable well known representation of this DbGeometry value.
+
+
+ Gets the coordinate system identifier of the DbGeometry object.
+ The coordinate system identifier of the DbGeometry object.
+
+
+ Gets the boundary of the DbGeometry objects.
+ The boundary of the DbGeometry objects.
+
+
+
+ Gets the dimension of the given value or, if the value is a collection, the dimension of its largest element.
+
+
+ The dimension of the given value.
+
+
+
+ Gets the envelope (minimum bounding box) of this DbGeometry value, as a geometry value.
+ The envelope (minimum bounding box) of this DbGeometry value.
+
+
+ Gets a spatial type name representation of this DbGeometry value.
+ A spatial type name representation of this DbGeometry value.
+
+
+ Gets a nullable Boolean value indicating whether this DbGeometry value is empty, which may be null if this value does not represent a curve.
+ True if this DbGeometry value is empty; otherwise, false.
+
+
+ Gets a nullable Boolean value indicating whether this DbGeometry value is simple.
+ True if this DbGeometry value is simple; otherwise, false.
+
+
+ Gets a nullable Boolean value indicating whether this DbGeometry value is valid.
+ True if this DbGeometry value is valid; otherwise, false.
+
+
+ Gets the convex hull of this DbGeometry value as another DbGeometry value.
+ The convex hull of this DbGeometry value as another DbGeometry value.
+
+
+ Gets the number of elements in this DbGeometry value, if it represents a geometry collection. <returns>The number of elements in this geometry value, if it represents a collection of other geometry values; otherwise null.</returns>
+ The number of elements in this DbGeometry value.
+
+
+ Gets the X coordinate of this DbGeometry value, if it represents a point. <returns>The X coordinate value of this geometry value, if it represents a point; otherwise null.</returns>
+ The X coordinate of this DbGeometry value.
+
+
+ Gets the Y coordinate of this DbGeometry value, if it represents a point. <returns>The Y coordinate value of this geometry value, if it represents a point; otherwise null.</returns>
+ The Y coordinate of this DbGeometry value.
+
+
+ Gets the elevation (Z coordinate) of this DbGeometry value, if it represents a point. <returns>The elevation (Z coordinate) of this geometry value, if it represents a point; otherwise null.</returns>
+ The elevation (Z coordinate) of this DbGeometry value.
+
+
+ Gets the Measure (M coordinate) of this DbGeometry value, if it represents a point. <returns>The Measure (M coordinate) value of this geometry value, if it represents a point; otherwise null.</returns>
+ The Measure (M coordinate) of this DbGeometry value.
+
+
+ Gets a nullable double value that indicates the length of this DbGeometry value, which may be null if this value does not represent a curve.
+ The length of this DbGeometry value.
+
+
+ Gets a DbGeometry value representing the start point of this value, which may be null if this DbGeometry value does not represent a curve.
+ A DbGeometry value representing the start point of this value.
+
+
+ Gets a DbGeometry value representing the start point of this value, which may be null if this DbGeometry value does not represent a curve.
+ A DbGeometry value representing the start point of this value.
+
+
+ Gets a nullable Boolean value indicating whether this DbGeometry value is closed, which may be null if this value does not represent a curve.
+ True if this DbGeometry value is closed; otherwise, false.
+
+
+ Gets a nullable Boolean value indicating whether this DbGeometry value is a ring, which may be null if this value does not represent a curve.
+ True if this DbGeometry value is a ring; otherwise, false.
+
+
+ Gets the number of points in this DbGeometry value, if it represents a linestring or linear ring. <returns>The number of elements in this geometry value, if it represents a linestring or linear ring; otherwise null.</returns>
+ The number of points in this DbGeometry value.
+
+
+ Gets a nullable double value that indicates the area of this DbGeometry value, which may be null if this value does not represent a surface.
+ A nullable double value that indicates the area of this DbGeometry value.
+
+
+ Gets the DbGeometry value that represents the centroid of this DbGeometry value, which may be null if this value does not represent a surface.
+ The DbGeometry value that represents the centroid of this DbGeometry value.
+
+
+ Gets a point on the surface of this DbGeometry value, which may be null if this value does not represent a surface.
+ A point on the surface of this DbGeometry value.
+
+
+ Gets the DbGeometry value that represents the exterior ring of this DbGeometry value, which may be null if this value does not represent a polygon.
+ The DbGeometry value that represents the exterior ring of this DbGeometry value.
+
+
+ Gets the number of interior rings in this DbGeometry value, if it represents a polygon. <returns>The number of elements in this geometry value, if it represents a polygon; otherwise null.</returns>
+ The number of interior rings in this DbGeometry value.
+
+
+
+ A data contract serializable representation of a value.
+
+
+
+ Gets or sets the coordinate system identifier (SRID) of this value.
+
+
+ Gets or sets the well known text representation of this value.
+
+
+ Gets or sets the well known binary representation of this value.
+
+
+
+ A provider-independent service API for geospatial (Geometry/Geography) type support.
+
+
+
+
+ When implemented in derived types, reads an instance of from the column at the specified column ordinal.
+
+ The instance of DbGeography at the specified column value
+ The ordinal of the column that contains the geography value
+
+
+
+ Asynchronously reads an instance of from the column at the specified column ordinal.
+
+
+ Providers should override with an appropriate implementation.
+ The default implementation invokes the synchronous method and returns
+ a completed task, blocking the calling thread.
+
+ The ordinal of the column that contains the geography value.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the instance of at the specified column value.
+
+
+
+
+ When implemented in derived types, reads an instance of from the column at the specified column ordinal.
+
+ The instance of DbGeometry at the specified column value
+ The ordinal of the data record column that contains the provider-specific geometry data
+
+
+
+ Asynchronously reads an instance of from the column at the specified column ordinal.
+
+
+ Providers should override with an appropriate implementation.
+ The default implementation invokes the synchronous method and returns
+ a completed task, blocking the calling thread.
+
+ The ordinal of the data record column that contains the provider-specific geometry data.
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the instance of at the specified column value.
+
+
+
+
+ Returns whether the column at the specified column ordinal is of geography type
+
+ The column ordinal.
+
+ true if the column at the specified column ordinal is of geography type;
+ false otherwise.
+
+
+
+
+ Returns whether the column at the specified column ordinal is of geometry type
+
+ The column ordinal.
+
+ true if the column at the specified column ordinal is of geometry type;
+ false otherwise.
+
+
+
+
+ A provider-independent service API for geospatial (Geometry/Geography) type support.
+
+
+
+
+ This method is intended for use by derived implementations of
+
+ after suitable validation of the specified provider value to ensure it is suitable for use with the derived implementation.
+
+
+ A new instance that contains the specified providerValue and uses the specified spatialServices as its spatial implementation.
+
+
+ The spatial services instance that the returned value will depend on for its implementation of spatial functionality.
+
+ The provider value.
+
+
+
+ Creates a new value based on a provider-specific value that is compatible with this spatial services implementation.
+
+
+ A new value backed by this spatial services implementation and the specified provider value.
+
+ A provider-specific value that this spatial services implementation is capable of interpreting as a geography value.
+ A new DbGeography value backed by this spatial services implementation and the specified provider value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Creates a provider-specific value compatible with this spatial services implementation based on the specified well-known
+
+ representation.
+
+ A provider-specific value that encodes the information contained in wellKnownValue in a fashion compatible with this spatial services implementation.
+
+ An instance of that contains the well-known representation of a geography value.
+
+
+
+
+ Creates an instance of that represents the specified
+
+ value using one or both of the standard well-known spatial formats.
+
+
+ The well-known representation of geographyValue, as a new
+
+ .
+
+ The geography value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Creates a new value based on the specified well-known binary value.
+
+
+ A new value as defined by the well-known binary value with the default
+
+ coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geography value.
+
+
+
+ Creates a new value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new line value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new point value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new polygon value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new multiline value based on the specified well-known binary value and coordinate system identifier.
+
+
+ The new multiline value.
+
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+
+ Creates a new multipoint value based on the specified well-known binary value and coordinate system identifier.
+
+
+ A new multipoint value.
+
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+
+ Creates a new multi polygon value based on the specified well-known binary value and coordinate system identifier.
+
+
+ A new multi polygon value.
+
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+
+ Creates a new collection value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new value based on the specified well-known text value.
+
+
+ A new value as defined by the well-known text value with the default
+
+ coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geography value.
+
+
+
+ Creates a new value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new line value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new point value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new polygon value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new multiline value based on the specified well-known text value and coordinate system identifier.
+
+
+ A new multiline value.
+
+ The well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new multipoint value based on the specified well-known text value and coordinate system identifier.
+
+
+ A new multipoint value.
+
+ The well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new multi polygon value based on the specified well-known text value and coordinate system identifier.
+
+
+ A new multi polygon value.
+
+ The well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new collection value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new value based on the specified Geography Markup Language (GML) value.
+
+
+ A new value as defined by the GML value with the default
+
+ coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a Geometry Markup Language (GML) representation of the geography value.
+
+
+
+ Creates a new value based on the specified Geography Markup Language (GML) value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the GML value with the specified coordinate system identifier (SRID).
+
+ A string that contains a Geometry Markup Language (GML) representation of the geography value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Returns the coordinate system identifier of the given value.
+
+
+ The coordinate system identifier of the given value.
+
+ The geography value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Gets the dimension of the given value or, if the value is a collections, the largest element dimension.
+
+
+ The dimension of geographyValue, or the largest element dimension if
+
+ is a collection.
+
+ The geography value for which the dimension value should be retrieved.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that indicates the spatial type name of the given
+
+ value.
+
+
+ The spatial type name of the given value.
+
+ The geography value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable Boolean value that whether the given value is empty.
+
+
+ True if the given value is empty; otherwise, false.
+
+ The geography value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Gets the well-known text representation of the given value. This value should include only the Longitude and Latitude of points.
+
+ A string containing the well-known text representation of geographyValue.
+ The geography value for which the well-known text should be generated.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a text representation of with elevation and measure.
+
+
+ A text representation of .
+
+ The geography value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Gets the well-known binary representation of the given value.
+
+
+ The well-known binary representation of the given value.
+
+ The geography value for which the well-known binary should be generated.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Generates the Geography Markup Language (GML) representation of this
+
+ value.
+
+ A string containing the GML representation of this DbGeography value.
+ The geography value for which the GML should be generated.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values are spatially equal.
+
+ true if geographyValue is spatially equal to otherGeography; otherwise false.
+ The first geography value to compare for equality.
+ The second geography value to compare for equality.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values are spatially disjoint.
+
+ true if geographyValue is disjoint from otherGeography; otherwise false.
+ The first geography value to compare for disjointness.
+ The second geography value to compare for disjointness.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values spatially intersect.
+
+ true if geographyValue intersects otherGeography; otherwise false.
+ The first geography value to compare for intersection.
+ The second geography value to compare for intersection.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Creates a geography value representing all points less than or equal to distance from the given
+
+ value.
+
+ A new DbGeography value representing all points less than or equal to distance from geographyValue.
+ The geography value.
+ A double value specifying how far from geographyValue to buffer.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the distance between the closest points in two values.
+
+ A double value that specifies the distance between the two closest points in geographyValue and otherGeography.
+ The first geography value.
+ The second geography value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the intersection of two values.
+
+
+ A new value representing the intersection of geographyValue and otherGeography.
+
+ The first geography value.
+ The second geography value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the union of two values.
+
+
+ A new value representing the union of geographyValue and otherGeography.
+
+ The first geography value.
+ The second geography value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the difference of two values.
+
+ A new DbGeography value representing the difference of geographyValue and otherGeography.
+ The first geography value.
+ The second geography value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the symmetric difference of two values.
+
+
+ A new value representing the symmetric difference of geographyValue and otherGeography.
+
+ The first geography value.
+ The second geography value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the number of elements in the given value, if it represents a geography collection.
+
+ The number of elements in geographyValue, if it represents a collection of other geography values; otherwise null.
+ The geography value, which need not represent a geography collection.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns an element of the given value, if it represents a geography collection.
+
+ The element in geographyValue at position index, if it represents a collection of other geography values; otherwise null.
+ The geography value, which need not represent a geography collection.
+ The position within the geography value from which the element should be taken.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the Latitude coordinate of the given value, if it represents a point.
+
+
+ The Latitude coordinate of the given value.
+
+ The geography value, which need not represent a point.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the Longitude coordinate of the given value, if it represents a point.
+
+
+ The Longitude coordinate of the given value.
+
+ The geography value, which need not represent a point.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the elevation (Z coordinate) of the given value, if it represents a point.
+
+ The elevation (Z coordinate) of geographyValue, if it represents a point; otherwise null.
+ The geography value, which need not represent a point.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the M (Measure) coordinate of the given value, if it represents a point.
+
+
+ The M (Measure) coordinate of the given value.
+
+ The geography value, which need not represent a point.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable double value that indicates the length of the given
+
+ value, which may be null if the value does not represent a curve.
+
+
+ The length of the given value.
+
+ The geography value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that represents the start point of the given DbGeography value, which may be null if the value does not represent a curve.
+
+
+ The start point of the given value.
+
+ The geography value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that represents the end point of the given DbGeography value, which may be null if the value does not represent a curve.
+
+ The end point of geographyValue, if it represents a curve; otherwise null.
+ The geography value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable Boolean value that whether the given value is closed, which may be null if the value does not represent a curve.
+
+
+ True if the given value is closed; otherwise, false.
+
+ The geography value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the number of points in the given value, if it represents a linestring or linear ring.
+
+
+ The number of points in the given value.
+
+ The geography value, which need not represent a linestring or linear ring.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a point element of the given value, if it represents a linestring or linear ring.
+
+ The point in geographyValue at position index, if it represents a linestring or linear ring; otherwise null.
+ The geography value, which need not represent a linestring or linear ring.
+ The position within the geography value from which the element should be taken.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable double value that indicates the area of the given
+
+ value, which may be null if the value does not represent a surface.
+
+
+ A nullable double value that indicates the area of the given value.
+
+ The geography value, which need not represent a surface.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ This method is intended for use by derived implementations of
+
+ after suitable validation of the specified provider value to ensure it is suitable for use with the derived implementation.
+
+
+ A new instance that contains the specified providerValue and uses the specified spatialServices as its spatial implementation.
+
+
+ The spatial services instance that the returned value will depend on for its implementation of spatial functionality.
+
+ A provider value.
+
+
+
+ Creates a provider-specific value compatible with this spatial services implementation based on the specified well-known
+
+ representation.
+
+ A provider-specific value that encodes the information contained in wellKnownValue in a fashion compatible with this spatial services implementation.
+
+ An instance of that contains the well-known representation of a geometry value.
+
+
+
+
+ Creates an instance of that represents the specified
+
+ value using one or both of the standard well-known spatial formats.
+
+
+ The well-known representation of geometryValue, as a new
+
+ .
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Creates a new value based on a provider-specific value that is compatible with this spatial services implementation.
+
+
+ A new value backed by this spatial services implementation and the specified provider value.
+
+ A provider-specific value that this spatial services implementation is capable of interpreting as a geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Creates a new value based on the specified well-known binary value.
+
+
+ A new value as defined by the well-known binary value with the default
+
+ coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geometry value.
+
+
+
+ Creates a new value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new line value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new point value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new polygon value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new multiline value based on the specified well-known binary value and coordinate system identifier.
+
+
+ The new multiline value
+
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+
+ Creates a new multipoint value based on the specified well-known binary value and coordinate system identifier.
+
+
+ A new multipoint value.
+
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+
+ Creates a new multi polygon value based on the specified well-known binary value and coordinate system identifier.
+
+
+ A new multi polygon value.
+
+ The well-known binary value.
+ The coordinate system identifier.
+
+
+
+ Creates a new collection value based on the specified well-known binary value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known binary value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A byte array that contains a well-known binary representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new value based on the specified well-known text value.
+
+
+ A new value as defined by the well-known text value with the default
+
+ coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geometry value.
+
+
+
+ Creates a new value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new line value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new point value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new polygon value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new multiline value based on the specified well-known text value and coordinate system identifier.
+
+
+ A new multiline value
+
+ The well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new multipoint value based on the specified well-known text value and coordinate system identifier.
+
+
+ A new multipoint value.
+
+ The well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new multi polygon value based on the specified well-known text value and coordinate system identifier.
+
+
+ A new multi polygon value.
+
+ The well-known text value.
+ The coordinate system identifier.
+
+
+
+ Creates a new collection value based on the specified well-known text value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the well-known text value with the specified coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a well-known text representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Creates a new value based on the specified Geography Markup Language (GML) value.
+
+
+ A new value as defined by the GML value with the default
+
+ coordinate system identifier (SRID) (
+
+ ).
+
+ A string that contains a Geography Markup Language (GML) representation of the geometry value.
+
+
+
+ Creates a new value based on the specified Geography Markup Language (GML) value and coordinate system identifier (SRID).
+
+
+ A new value as defined by the GML value with the specified coordinate system identifier (SRID).
+
+ A string that contains a Geography Markup Language (GML) representation of the geometry value.
+
+ The identifier of the coordinate system that the new value should use.
+
+
+
+
+ Returns the coordinate system identifier of the given value.
+
+
+ The coordinate system identifier of the given value.
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable double value that indicates the boundary of the given
+
+ value.
+
+
+ The boundary of the given value.
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Gets the dimension of the given value or, if the value is a collections, the largest element dimension.
+
+
+ The dimension of geometryValue, or the largest element dimension if
+
+ is a collection.
+
+ The geometry value for which the dimension value should be retrieved.
+
+
+
+ Gets the envelope (minimum bounding box) of the given value, as a geometry value.
+
+
+ The envelope of geometryValue, as a value.
+
+ The geometry value for which the envelope value should be retrieved.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that indicates the spatial type name of the given
+
+ value.
+
+
+ The spatial type name of the given value.
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable Boolean value that whether the given value is empty.
+
+
+ True if the given value is empty; otherwise, false.
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable Boolean value that whether the given value is simple.
+
+
+ True if the given value is simple; otherwise, false.
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable Boolean value that whether the given value is valid.
+
+
+ True if the given value is valid; otherwise, false.
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Gets the well-known text representation of the given value, including only X and Y coordinates for points.
+
+ A string containing the well-known text representation of geometryValue.
+ The geometry value for which the well-known text should be generated.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a text representation of with elevation and measure.
+
+
+ A text representation of with elevation and measure.
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Gets the well-known binary representation of the given value.
+
+
+ The well-known binary representation of the given value.
+
+ The geometry value for which the well-known binary should be generated.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Generates the Geography Markup Language (GML) representation of this
+
+ value.
+
+ A string containing the GML representation of this DbGeometry value.
+ The geometry value for which the GML should be generated.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values are spatially equal.
+
+ true if geometryValue is spatially equal to otherGeometry; otherwise false.
+ The first geometry value to compare for equality.
+ The second geometry value to compare for equality.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values are spatially disjoint.
+
+ true if geometryValue is disjoint from otherGeometry; otherwise false.
+ The first geometry value to compare for disjointness.
+ The second geometry value to compare for disjointness.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values spatially intersect.
+
+ true if geometryValue intersects otherGeometry; otherwise false.
+ The first geometry value to compare for intersection.
+ The second geometry value to compare for intersection.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values spatially touch.
+
+ true if geometryValue touches otherGeometry; otherwise false.
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values spatially cross.
+
+ true if geometryValue crosses otherGeometry; otherwise false.
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether one value is spatially within the other.
+
+ true if geometryValue is within otherGeometry; otherwise false.
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether one value spatially contains the other.
+
+ true if geometryValue contains otherGeometry; otherwise false.
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values spatially overlap.
+
+ true if geometryValue overlaps otherGeometry; otherwise false.
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Determines whether the two given values are spatially related according to the given Dimensionally Extended Nine-Intersection Model (DE-9IM) intersection pattern.
+
+ true if this geometryValue value relates to otherGeometry according to the specified intersection pattern matrix; otherwise false.
+ The first geometry value.
+ The geometry value that should be compared with the first geometry value for relation.
+ A string that contains the text representation of the (DE-9IM) intersection pattern that defines the relation.
+
+
+ ,
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Creates a geometry value representing all points less than or equal to distance from the given
+
+ value.
+
+ A new DbGeometry value representing all points less than or equal to distance from geometryValue.
+ The geometry value.
+ A double value specifying how far from geometryValue to buffer.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the distance between the closest points in two values.
+
+ A double value that specifies the distance between the two closest points in geometryValue and otherGeometry.
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable double value that indicates the convex hull of the given
+
+ value.
+
+
+ The convex hull of the given value.
+
+ The geometry value.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the intersection of two values.
+
+
+ A new value representing the intersection of geometryValue and otherGeometry.
+
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the union of two values.
+
+
+ A new value representing the union of geometryValue and otherGeometry.
+
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the difference between two values.
+
+ A new DbGeometry value representing the difference between geometryValue and otherGeometry.
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Computes the symmetric difference between two values.
+
+
+ A new value representing the symmetric difference between geometryValue and otherGeometry.
+
+ The first geometry value.
+ The second geometry value.
+
+
+ or
+
+ is null.
+
+
+
+ or
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the number of elements in the given value, if it represents a geometry collection.
+
+ The number of elements in geometryValue, if it represents a collection of other geometry values; otherwise null.
+ The geometry value, which need not represent a geometry collection.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns an element of the given value, if it represents a geometry collection.
+
+ The element in geometryValue at position index, if it represents a collection of other geometry values; otherwise null.
+ The geometry value, which need not represent a geometry collection.
+ The position within the geometry value from which the element should be taken.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the X coordinate of the given value, if it represents a point.
+
+
+ The X coordinate of the given value.
+
+ The geometry value, which need not represent a point.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the Y coordinate of the given value, if it represents a point.
+
+
+ The Y coordinate of the given value.
+
+ The geometry value, which need not represent a point.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the elevation (Z) of the given value, if it represents a point.
+
+ The elevation (Z) of geometryValue, if it represents a point; otherwise null.
+ The geometry value, which need not represent a point.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the M (Measure) coordinate of the given value, if it represents a point.
+
+
+ The M (Measure) coordinate of the given value.
+
+ The geometry value, which need not represent a point.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable double value that indicates the length of the given
+
+ value, which may be null if the value does not represent a curve.
+
+
+ The length of the given value.
+
+ The geometry value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that represents the start point of the given DbGeometry value, which may be null if the value does not represent a curve.
+
+
+ The start point of the given value.
+
+ The geometry value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that represents the end point of the given DbGeometry value, which may be null if the value does not represent a curve.
+
+ The end point of geometryValue, if it represents a curve; otherwise null.
+ The geometry value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable Boolean value that whether the given value is closed, which may be null if the value does not represent a curve.
+
+
+ True if the given value is closed; otherwise, false.
+
+ The geometry value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable Boolean value that whether the given value is a ring, which may be null if the value does not represent a curve.
+
+
+ True if the given value is a ring; otherwise, false.
+
+ The geometry value, which need not represent a curve.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the number of points in the given value, if it represents a linestring or linear ring.
+
+
+ The number of points in the given value.
+
+ The geometry value, which need not represent a linestring or linear ring.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a point element of the given value, if it represents a linestring or linear ring.
+
+ The point in geometryValue at position index, if it represents a linestring or linear ring; otherwise null.
+ The geometry value, which need not represent a linestring or linear ring.
+ The position within the geometry value from which the element should be taken.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a nullable double value that indicates the area of the given
+
+ value, which may be null if the value does not represent a surface.
+
+
+ A nullable double value that indicates the area of the given value.
+
+ The geometry value, which need not represent a surface.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that represents the centroid of the given DbGeometry value, which may be null if the value does not represent a surface.
+
+ The centroid of geometryValue, if it represents a surface; otherwise null.
+ The geometry value, which need not represent a surface.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that represents a point on the surface of the given DbGeometry value, which may be null if the value does not represent a surface.
+
+
+ A value that represents a point on the surface of the given DbGeometry value.
+
+ The geometry value, which need not represent a surface.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns a value that represents the exterior ring of the given DbGeometry value, which may be null if the value does not represent a polygon.
+
+ A DbGeometry value representing the exterior ring on geometryValue, if it represents a polygon; otherwise null.
+ The geometry value, which need not represent a polygon.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns the number of interior rings in the given value, if it represents a polygon.
+
+ The number of elements in geometryValue, if it represents a polygon; otherwise null.
+ The geometry value, which need not represent a polygon.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Returns an interior ring from the given value, if it represents a polygon.
+
+ The interior ring in geometryValue at position index, if it represents a polygon; otherwise null.
+ The geometry value, which need not represent a polygon.
+ The position within the geometry value from which the element should be taken.
+
+
+ is null.
+
+
+
+ is not compatible with this spatial services implementation.
+
+
+
+
+ Gets the default services for the .
+
+ The default services.
+
+
+
+ Override this property to allow the spatial provider to fail fast when native types or other
+ resources needed for the spatial provider to function correctly are not available.
+ The default value is true
which means that EF will continue with the assumption
+ that the provider has the necessary types/resources rather than failing fast.
+
+
+
+
+ The same as but works in partial trust and adds explicit caching of
+ generated indentation string and also recognizes writing a string that contains just \r\n or \n as a write-line to ensure
+ we indent the next line properly.
+
+
+
+
+ Specifies the default tab string. This field is constant.
+
+
+
+
+ Specifies the culture what will be used by the underlying TextWriter. This static property is read-only.
+ Note that any writer passed to one of the constructors of must use this
+ same culture. The culture is .
+
+
+
+
+ Initializes a new instance of the IndentedTextWriter class using the specified text writer and default tab string.
+ Note that the writer passed to this constructor must use the specified by the
+ property.
+
+
+ The to use for output.
+
+
+
+
+ Initializes a new instance of the IndentedTextWriter class using the specified text writer and tab string.
+ Note that the writer passed to this constructor must use the specified by the
+ property.
+
+
+ The to use for output.
+
+ The tab string to use for indentation.
+
+
+
+ Closes the document being written to.
+
+
+
+
+ Flushes the stream.
+
+
+
+
+ Outputs the tab string once for each level of indentation according to the
+
+ property.
+
+
+
+
+ Builds a string representing the current indentation level for a new line.
+
+
+ Does NOT check if tabs are currently pending, just returns a string that would be
+ useful in replacing embedded newline characters.
+
+ An empty string, or a string that contains .Indent level's worth of specified tab-string.
+
+
+
+ Writes the specified string to the text stream.
+
+ The string to write.
+
+
+
+ Writes the text representation of a Boolean value to the text stream.
+
+ The Boolean value to write.
+
+
+
+ Writes a character to the text stream.
+
+ The character to write.
+
+
+
+ Writes a character array to the text stream.
+
+ The character array to write.
+
+
+
+ Writes a subarray of characters to the text stream.
+
+ The character array to write data from.
+ Starting index in the buffer.
+ The number of characters to write.
+
+
+
+ Writes the text representation of a Double to the text stream.
+
+ The double to write.
+
+
+
+ Writes the text representation of a Single to the text stream.
+
+ The single to write.
+
+
+
+ Writes the text representation of an integer to the text stream.
+
+ The integer to write.
+
+
+
+ Writes the text representation of an 8-byte integer to the text stream.
+
+ The 8-byte integer to write.
+
+
+
+ Writes the text representation of an object to the text stream.
+
+ The object to write.
+
+
+
+ Writes out a formatted string, using the same semantics as specified.
+
+ The formatting string.
+ The object to write into the formatted string.
+
+
+
+ Writes out a formatted string, using the same semantics as specified.
+
+ The formatting string to use.
+ The first object to write into the formatted string.
+ The second object to write into the formatted string.
+
+
+
+ Writes out a formatted string, using the same semantics as specified.
+
+ The formatting string to use.
+ The argument array to output.
+
+
+
+ Writes the specified string to a line without tabs.
+
+ The string to write.
+
+
+
+ Writes the specified string, followed by a line terminator, to the text stream.
+
+ The string to write.
+
+
+
+ Writes a line terminator.
+
+
+
+
+ Writes the text representation of a Boolean, followed by a line terminator, to the text stream.
+
+ The Boolean to write.
+
+
+
+ Writes a character, followed by a line terminator, to the text stream.
+
+ The character to write.
+
+
+
+ Writes a character array, followed by a line terminator, to the text stream.
+
+ The character array to write.
+
+
+
+ Writes a subarray of characters, followed by a line terminator, to the text stream.
+
+ The character array to write data from.
+ Starting index in the buffer.
+ The number of characters to write.
+
+
+
+ Writes the text representation of a Double, followed by a line terminator, to the text stream.
+
+ The double to write.
+
+
+
+ Writes the text representation of a Single, followed by a line terminator, to the text stream.
+
+ The single to write.
+
+
+
+ Writes the text representation of an integer, followed by a line terminator, to the text stream.
+
+ The integer to write.
+
+
+
+ Writes the text representation of an 8-byte integer, followed by a line terminator, to the text stream.
+
+ The 8-byte integer to write.
+
+
+
+ Writes the text representation of an object, followed by a line terminator, to the text stream.
+
+ The object to write.
+
+
+
+ Writes out a formatted string, followed by a line terminator, using the same semantics as specified.
+
+ The formatting string.
+ The object to write into the formatted string.
+
+
+
+ Writes out a formatted string, followed by a line terminator, using the same semantics as specified.
+
+ The formatting string to use.
+ The first object to write into the formatted string.
+ The second object to write into the formatted string.
+
+
+
+ Writes out a formatted string, followed by a line terminator, using the same semantics as specified.
+
+ The formatting string to use.
+ The argument array to output.
+
+
+
+ Writes the text representation of a UInt32, followed by a line terminator, to the text stream.
+
+ A UInt32 to output.
+
+
+
+ Gets the encoding for the text writer to use.
+
+
+ An that indicates the encoding for the text writer to use.
+
+
+
+
+ Gets or sets the new line character to use.
+
+ The new line character to use.
+
+
+
+ Gets or sets the number of spaces to indent.
+
+ The number of spaces to indent.
+
+
+
+ Gets the to use.
+
+
+ The to use.
+
+
+
+
+ Convention to apply column ordering specified via
+
+ or the API. This convention throws if a duplicate configured column order
+ is detected.
+
+
+
+
+ Convention to apply column ordering specified via
+
+ or the API.
+
+
+
+
+
+
+
+ Validates the ordering configuration supplied for columns.
+ This base implementation is a no-op.
+
+ The name of the table that the columns belong to.
+ The definition of the table.
+
+
+
+ Validates the ordering configuration supplied for columns to ensure
+ that the same ordinal was not supplied for two columns.
+
+ The name of the table that the columns belong to.
+ The definition of the table.
+
+
+
+ Represents a conceptual or store model. This class can be used to access information about the shape of the model
+ and the way the that it has been configured.
+
+
+
+
+ Adds an association type to the model.
+
+ The AssociationType instance to be added.
+
+
+
+ Adds a complex type to the model.
+
+ The ComplexType instance to be added.
+
+
+
+ Adds an entity type to the model.
+
+ The EntityType instance to be added.
+
+
+
+ Adds an enumeration type to the model.
+
+ The EnumType instance to be added.
+
+
+
+ Adds a function to the model.
+
+ The EdmFunction instance to be added.
+
+
+
+ Removes an association type from the model.
+
+ The AssociationType instance to be removed.
+
+
+
+ Removes a complex type from the model.
+
+ The ComplexType instance to be removed.
+
+
+
+ Removes an entity type from the model.
+
+ The EntityType instance to be removed.
+
+
+
+ Removes an enumeration type from the model.
+
+ The EnumType instance to be removed.
+
+
+
+ Removes a function from the model.
+
+ The EdmFunction instance to be removed.
+
+
+ Gets the built-in type kind for this type.
+
+ A object that represents the built-in type kind for this type.
+
+
+
+
+ Gets the data space associated with the model, which indicates whether
+ it is a conceptual model (DataSpace.CSpace) or a store model (DataSpace.SSpace).
+
+
+
+
+ Gets the association types in the model.
+
+
+
+
+ Gets the complex types in the model.
+
+
+
+
+ Gets the entity types in the model.
+
+
+
+
+ Gets the enum types in the model.
+
+
+
+
+ Gets the functions in the model.
+
+
+
+
+ Gets the container that stores entity and association sets, and function imports.
+
+
+
+ Gets the global items associated with the model.
+ The global items associated with the model.
+
+
+
+ An implementation of IDatabaseInitializer that will recreate and optionally re-seed the
+ database only if the database does not exist.
+ To seed the database, create a derived class and override the Seed method.
+
+ The type of the context.
+
+
+ Initializes a new instance of the class.
+
+
+
+ Executes the strategy to initialize the database for the given context.
+
+ The context.
+
+
+
+ A method that should be overridden to actually add data to the context for seeding.
+ The default implementation does nothing.
+
+ The context to seed.
+
+
+
+ An instance of this class is obtained from an object and can be used
+ to manage the actual database backing a DbContext or connection.
+ This includes creating, deleting, and checking for the existence of a database.
+ Note that deletion and checking for existence of a database can be performed using just a
+ connection (i.e. without a full context) by using the static methods of this class.
+
+
+
+
+ Enables the user to pass in a database transaction created outside of the object
+ if you want the Entity Framework to execute commands within that external transaction.
+ Alternatively, pass in null to clear the framework's knowledge of that transaction.
+
+ the external transaction
+ Thrown if the transaction is already completed
+
+ Thrown if the connection associated with the object is already enlisted in a
+
+ transaction
+
+
+ Thrown if the connection associated with the object is already participating in a transaction
+
+ Thrown if the connection associated with the transaction does not match the Entity Framework's connection
+
+
+
+ Begins a transaction on the underlying store connection
+
+
+ a object wrapping access to the underlying store's transaction object
+
+
+
+
+ Begins a transaction on the underlying store connection using the specified isolation level
+
+ The database isolation level with which the underlying store transaction will be created
+
+ a object wrapping access to the underlying store's transaction object
+
+
+
+
+ Sets the database initializer to use for the given context type. The database initializer is called when a
+ the given type is used to access a database for the first time.
+ The default strategy for Code First contexts is an instance of .
+
+ The type of the context.
+ The initializer to use, or null to disable initialization for the given context type.
+
+
+
+ Runs the the registered on this context.
+ If "force" is set to true, then the initializer is run regardless of whether or not it
+ has been run before. This can be useful if a database is deleted while an app is running
+ and needs to be reinitialized.
+ If "force" is set to false, then the initializer is only run if it has not already been
+ run for this context, model, and connection in this app domain. This method is typically
+ used when it is necessary to ensure that the database has been created and seeded
+ before starting some operation where doing so lazily will cause issues, such as when the
+ operation is part of a transaction.
+
+
+ If set to true the initializer is run even if it has already been run.
+
+
+
+
+ Checks whether or not the database is compatible with the the current Code First model.
+
+
+ Model compatibility currently uses the following rules.
+ If the context was created using either the Model First or Database First approach then the
+ model is assumed to be compatible with the database and this method returns true.
+ For Code First the model is considered compatible if the model is stored in the database
+ in the Migrations history table and that model has no differences from the current model as
+ determined by Migrations model differ.
+ If the model is not stored in the database but an EF 4.1/4.2 model hash is found instead,
+ then this is used to check for compatibility.
+
+
+ If set to true then an exception will be thrown if no model metadata is found in the database. If set to false then this method will return true if metadata is not found.
+
+ True if the model hash in the context and the database match; false otherwise.
+
+
+
+ Creates a new database on the database server for the model defined in the backing context.
+ Note that calling this method before the database initialization strategy has run will disable
+ executing that strategy.
+
+
+
+
+ Creates a new database on the database server for the model defined in the backing context, but only
+ if a database with the same name does not already exist on the server.
+
+ True if the database did not exist and was created; false otherwise.
+
+
+
+ Checks whether or not the database exists on the server.
+
+ True if the database exists; false otherwise.
+
+
+
+ Deletes the database on the database server if it exists, otherwise does nothing.
+ Calling this method from outside of an initializer will mark the database as having
+ not been initialized. This means that if an attempt is made to use the database again
+ after it has been deleted, then any initializer set will run again and, usually, will
+ try to create the database again automatically.
+
+ True if the database did exist and was deleted; false otherwise.
+
+
+
+ Checks whether or not the database exists on the server.
+ The connection to the database is created using the given database name or connection string
+ in the same way as is described in the documentation for the class.
+
+ The database name or a connection string to the database.
+ True if the database exists; false otherwise.
+
+
+
+ Deletes the database on the database server if it exists, otherwise does nothing.
+ The connection to the database is created using the given database name or connection string
+ in the same way as is described in the documentation for the class.
+
+ The database name or a connection string to the database.
+ True if the database did exist and was deleted; false otherwise.
+
+
+
+ Checks whether or not the database exists on the server.
+
+ An existing connection to the database.
+ True if the database exists; false otherwise.
+
+
+
+ Deletes the database on the database server if it exists, otherwise does nothing.
+
+ An existing connection to the database.
+ True if the database did exist and was deleted; false otherwise.
+
+
+
+ Creates a raw SQL query that will return elements of the given generic type.
+ The type can be any type that has properties that match the names of the columns returned
+ from the query, or can be a simple primitive type. The type does not have to be an
+ entity type. The results of this query are never tracked by the context even if the
+ type of object returned is an entity type. Use the
+ method to return entities that are tracked by the context.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Database.SqlQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Database.SqlQuery<Post>("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ The type of object returned by the query.
+ The SQL query string.
+
+ The parameters to apply to the SQL query string. If output parameters are used, their values will
+ not be available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A object that will execute the query when it is enumerated.
+
+
+
+
+ Creates a raw SQL query that will return elements of the given type.
+ The type can be any type that has properties that match the names of the columns returned
+ from the query, or can be a simple primitive type. The type does not have to be an
+ entity type. The results of this query are never tracked by the context even if the
+ type of object returned is an entity type. Use the
+ method to return entities that are tracked by the context.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Database.SqlQuery(typeof(Post), "SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Database.SqlQuery(typeof(Post), "SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ The type of object returned by the query.
+ The SQL query string.
+
+ The parameters to apply to the SQL query string. If output parameters are used, their values
+ will not be available until the results have been read completely. This is due to the underlying
+ behavior of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A object that will execute the query when it is enumerated.
+
+
+
+
+ Executes the given DDL/DML command against the database.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Database.ExecuteSqlCommand("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Database.ExecuteSqlCommand("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ If there isn't an existing local or ambient transaction a new transaction will be used
+ to execute the command.
+
+ The command string.
+ The parameters to apply to the command string.
+ The result returned by the database after executing the command.
+
+
+
+ Executes the given DDL/DML command against the database.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Database.ExecuteSqlCommand("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Database.ExecuteSqlCommand("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ Controls the creation of a transaction for this command.
+ The command string.
+ The parameters to apply to the command string.
+ The result returned by the database after executing the command.
+
+
+
+ Asynchronously executes the given DDL/DML command against the database.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Database.ExecuteSqlCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Database.ExecuteSqlCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ If there isn't an existing local transaction a new transaction will be used
+ to execute the command.
+
+ The command string.
+ The parameters to apply to the command string.
+
+ A task that represents the asynchronous operation.
+ The task result contains the result returned by the database after executing the command.
+
+
+
+
+ Asynchronously executes the given DDL/DML command against the database.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Database.ExecuteSqlCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Database.ExecuteSqlCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ Controls the creation of a transaction for this command.
+ The command string.
+ The parameters to apply to the command string.
+
+ A task that represents the asynchronous operation.
+ The task result contains the result returned by the database after executing the command.
+
+
+
+
+ Asynchronously executes the given DDL/DML command against the database.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Database.ExecuteSqlCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Database.ExecuteSqlCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ If there isn't an existing local transaction a new transaction will be used
+ to execute the command.
+
+ The command string.
+
+ A to observe while waiting for the task to complete.
+
+ The parameters to apply to the command string.
+
+ A task that represents the asynchronous operation.
+ The task result contains the result returned by the database after executing the command.
+
+
+
+
+ Asynchronously executes the given DDL/DML command against the database.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Database.ExecuteSqlCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Database.ExecuteSqlCommandAsync("UPDATE dbo.Posts SET Rating = 5 WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ Controls the creation of a transaction for this command.
+ The command string.
+
+ A to observe while waiting for the task to complete.
+
+ The parameters to apply to the command string.
+
+ A task that represents the asynchronous operation.
+ The task result contains the result returned by the database after executing the command.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets the transaction the underlying store connection is enlisted in. May be null.
+
+
+
+
+ Returns the connection being used by this context. This may cause the
+ connection to be created if it does not already exist.
+
+ Thrown if the context has been disposed.
+
+
+
+ The connection factory to use when creating a from just
+ a database name or a connection string.
+
+
+ This is used when just a database name or connection string is given to or when
+ the no database name or connection is given to DbContext in which case the name of
+ the context class is passed to this factory in order to generate a DbConnection.
+ By default, the instance to use is read from the application's .config
+ file from the "EntityFramework DefaultConnectionFactory" entry in appSettings. If no entry is found in
+ the config file then is used. Setting this property in code
+ always overrides whatever value is found in the config file.
+
+
+
+
+ Gets or sets the timeout value, in seconds, for all context operations.
+ The default value is null, where null indicates that the default value of the underlying
+ provider will be used.
+
+
+ The timeout, in seconds, or null to use the provider default.
+
+
+
+
+ Set this property to log the SQL generated by the to the given
+ delegate. For example, to log to the console, set this property to .
+
+
+ The format of the log text can be changed by creating a new formatter that derives from
+ and setting it with .
+ For more low-level control over logging/interception see and
+ .
+
+
+
+
+ DbModelBuilder is used to map CLR classes to a database schema.
+ This code centric approach to building an Entity Data Model (EDM) model is known as 'Code First'.
+
+
+ DbModelBuilder is typically used to configure a model by overriding
+ DbContext.OnModelCreating(DbModelBuilder)
+ .
+ You can also use DbModelBuilder independently of DbContext to build a model and then construct a
+ or .
+ The recommended approach, however, is to use OnModelCreating in as
+ the workflow is more intuitive and takes care of common tasks, such as caching the created model.
+ Types that form your model are registered with DbModelBuilder and optional configuration can be
+ performed by applying data annotations to your classes and/or using the fluent style DbModelBuilder
+ API.
+ When the Build method is called a set of conventions are run to discover the initial model.
+ These conventions will automatically discover aspects of the model, such as primary keys, and
+ will also process any data annotations that were specified on your classes. Finally
+ any configuration that was performed using the DbModelBuilder API is applied.
+ Configuration done via the DbModelBuilder API takes precedence over data annotations which
+ in turn take precedence over the default conventions.
+
+
+
+
+ Initializes a new instance of the class.
+ The process of discovering the initial model will use the set of conventions included
+ in the most recent version of the Entity Framework installed on your machine.
+
+
+ Upgrading to newer versions of the Entity Framework may cause breaking changes
+ in your application because new conventions may cause the initial model to be
+ configured differently. There is an alternate constructor that allows a specific
+ version of conventions to be specified.
+
+
+
+
+ Initializes a new instance of the class that will use
+ a specific set of conventions to discover the initial model.
+
+ The version of conventions to be used.
+
+
+
+ Excludes a type from the model. This is used to remove types from the model that were added
+ by convention during initial model discovery.
+
+ The type to be excluded.
+ The same DbModelBuilder instance so that multiple calls can be chained.
+
+
+
+ Configures the default database schema name. This default database schema name is used
+ for database objects that do not have an explicitly configured schema name.
+
+ The name of the default database schema.
+ The same DbModelBuilder instance so that multiple calls can be chained.
+
+
+
+ Excludes the specified type(s) from the model. This is used to remove types from the model that were added
+ by convention during initial model discovery.
+
+ The types to be excluded from the model.
+ The same DbModelBuilder instance so that multiple calls can be chained.
+
+
+
+ Registers an entity type as part of the model and returns an object that can be used to
+ configure the entity. This method can be called multiple times for the same entity to
+ perform multiple lines of configuration.
+
+ The type to be registered or configured.
+ The configuration object for the specified entity type.
+
+
+
+ Registers an entity type as part of the model.
+
+ The type to be registered.
+
+ This method is provided as a convenience to allow entity types to be registered dynamically
+ without the need to use MakeGenericMethod in order to call the normal generic Entity method.
+ This method does not allow further configuration of the entity type using the fluent APIs since
+ these APIs make extensive use of generic type parameters.
+
+
+
+
+ Registers a type as a complex type in the model and returns an object that can be used to
+ configure the complex type. This method can be called multiple times for the same type to
+ perform multiple lines of configuration.
+
+ The type to be registered or configured.
+ The configuration object for the specified complex type.
+
+
+
+ Begins configuration of a lightweight convention that applies to all entities and complex types in
+ the model.
+
+ A configuration object for the convention.
+
+
+
+ Begins configuration of a lightweight convention that applies to all entities and complex types
+ in the model that inherit from or implement the type specified by the generic argument.
+ This method does not register types as part of the model.
+
+ The type of the entities or complex types that this convention will apply to.
+ A configuration object for the convention.
+
+
+
+ Begins configuration of a lightweight convention that applies to all properties
+ in the model.
+
+ A configuration object for the convention.
+
+
+
+ Begins configuration of a lightweight convention that applies to all primitive
+ properties of the specified type in the model.
+
+ The type of the properties that the convention will apply to.
+ A configuration object for the convention.
+
+ The convention will apply to both nullable and non-nullable properties of the
+ specified type.
+
+
+
+
+ Creates a based on the configuration performed using this builder.
+ The connection is used to determine the database provider being used as this
+ affects the database layer of the generated model.
+
+ Connection to use to determine provider information.
+ The model that was built.
+
+
+
+ Creates a based on the configuration performed using this builder.
+ Provider information must be specified because this affects the database layer of the generated model.
+ For SqlClient the invariant name is 'System.Data.SqlClient' and the manifest token is the version year (i.e. '2005', '2008' etc.)
+
+ The database provider that the model will be used with.
+ The model that was built.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Provides access to the settings of this DbModelBuilder that deal with conventions.
+
+
+
+
+ Gets the for this DbModelBuilder.
+ The registrar allows derived entity and complex type configurations to be registered with this builder.
+
+
+
+
+ A value from this enumeration can be provided directly to the
+ class or can be used in the applied to
+ a class derived from . The value used defines which version of
+ the DbContext and DbModelBuilder conventions should be used when building a model from
+ code--also known as "Code First".
+
+
+ Using DbModelBuilderVersion.Latest ensures that all the latest functionality is available
+ when upgrading to a new release of the Entity Framework. However, it may result in an
+ application behaving differently with the new release than it did with a previous release.
+ This can be avoided by using a specific version of the conventions, but if a version
+ other than the latest is set then not all the latest functionality will be available.
+
+
+
+
+ Indicates that the latest version of the and
+ conventions should be used.
+
+
+
+
+ Indicates that the version of the and
+ conventions shipped with Entity Framework v4.1
+ should be used.
+
+
+
+
+ Indicates that the version of the and
+ conventions shipped with Entity Framework v5.0
+ when targeting .Net Framework 4 should be used.
+
+
+
+
+ Indicates that the version of the and
+ conventions shipped with Entity Framework v5.0
+ should be used.
+
+
+
+
+ Indicates that the version of the and
+ conventions shipped with Entity Framework v6.0
+ should be used.
+
+
+
+
+ This attribute can be applied to a class derived from to set which
+ version of the DbContext and conventions should be used when building
+ a model from code--also known as "Code First". See the
+ enumeration for details about DbModelBuilder versions.
+
+
+ If the attribute is missing from DbContextthen DbContext will always use the latest
+ version of the conventions. This is equivalent to using DbModelBuilderVersion.Latest.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The conventions version to use.
+
+
+
+
+ Gets the conventions version.
+
+
+ The conventions version.
+
+
+
+
+ A non-generic version of which can be used when the type of entity
+ is not known at build time.
+
+
+
+
+ Represents a non-generic LINQ to Entities query against a DbContext.
+
+
+
+
+ Throws an exception indicating that binding directly to a store query is not supported.
+ Instead populate a DbSet with data, for example by using the Load extension method, and
+ then bind to local data. For WPF bind to DbSet.Local. For Windows Forms bind to
+ DbSet.Local.ToBindingList().
+
+ Never returns; always throws.
+
+
+
+ Returns an which when enumerated will execute the query against the database.
+
+ The query results.
+
+
+
+ Returns an which when enumerated will execute the query against the database.
+
+ The query results.
+
+
+
+ Specifies the related objects to include in the query results.
+
+
+ Paths are all-inclusive. For example, if an include call indicates Include("Orders.OrderLines"), not only will
+ OrderLines be included, but also Orders. When you call the Include method, the query path is only valid on
+ the returned instance of the DbQuery<T>. Other instances of DbQuery<T> and the object context itself are not affected.
+ Because the Include method returns the query object, you can call this method multiple times on an DbQuery<T> to
+ specify multiple paths for the query.
+
+ The dot-separated list of related objects to return in the query results.
+
+ A new DbQuery<T> with the defined query path.
+
+
+
+
+ Returns a new query where the entities returned will not be cached in the .
+
+ A new query with NoTracking applied.
+
+
+
+ Returns a new query that will stream the results instead of buffering.
+
+ A new query with AsStreaming applied.
+
+
+
+ Returns the equivalent generic object.
+
+ The type of element for which the query was created.
+ The generic set object.
+
+
+
+ Returns a representation of the underlying query.
+
+ The query string.
+
+
+
+
+
+
+
+
+
+
+
+
+ Returns false.
+
+
+ false .
+
+
+
+
+ The IQueryable element type.
+
+
+
+
+ The IQueryable LINQ Expression.
+
+
+
+
+ The IQueryable provider.
+
+
+
+
+ Creates an instance of a when called from the constructor of a derived
+ type that will be used as a test double for DbSets. Methods and properties that will be used by the
+ test double must be implemented by the test double except AsNoTracking, AsStreaming, an Include where
+ the default implementation is a no-op.
+
+
+
+
+ Finds an entity with the given primary key values.
+ If an entity with the given primary key values exists in the context, then it is
+ returned immediately without making a request to the store. Otherwise, a request
+ is made to the store for an entity with the given primary key values and this entity,
+ if found, is attached to the context and returned. If no entity is found in the
+ context or the store, then null is returned.
+
+
+ The ordering of composite key values is as defined in the EDM, which is in turn as defined in
+ the designer, by the Code First fluent API, or by the DataMember attribute.
+
+ The values of the primary key for the entity to be found.
+ The entity found, or null.
+ Thrown if multiple entities exist in the context with the primary key values given.
+ Thrown if the type of entity is not part of the data model for this context.
+ Thrown if the types of the key values do not match the types of the key values for the entity type to be found.
+ Thrown if the context has been disposed.
+
+
+
+ Asynchronously finds an entity with the given primary key values.
+ If an entity with the given primary key values exists in the context, then it is
+ returned immediately without making a request to the store. Otherwise, a request
+ is made to the store for an entity with the given primary key values and this entity,
+ if found, is attached to the context and returned. If no entity is found in the
+ context or the store, then null is returned.
+
+
+ The ordering of composite key values is as defined in the EDM, which is in turn as defined in
+ the designer, by the Code First fluent API, or by the DataMember attribute.
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The values of the primary key for the entity to be found.
+ A task that represents the asynchronous find operation. The task result contains the entity found, or null.
+ Thrown if multiple entities exist in the context with the primary key values given.
+ Thrown if the type of entity is not part of the data model for this context.
+ Thrown if the types of the key values do not match the types of the key values for the entity type to be found.
+ Thrown if the context has been disposed.
+
+
+
+ Asynchronously finds an entity with the given primary key values.
+ If an entity with the given primary key values exists in the context, then it is
+ returned immediately without making a request to the store. Otherwise, a request
+ is made to the store for an entity with the given primary key values and this entity,
+ if found, is attached to the context and returned. If no entity is found in the
+ context or the store, then null is returned.
+
+
+ The ordering of composite key values is as defined in the EDM, which is in turn as defined in
+ the designer, by the Code First fluent API, or by the DataMember attribute.
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+ The values of the primary key for the entity to be found.
+ A task that represents the asynchronous find operation. The task result contains the entity found, or null.
+ Thrown if multiple entities exist in the context with the primary key values given.
+ Thrown if the type of entity is not part of the data model for this context.
+ Thrown if the types of the key values do not match the types of the key values for the entity type to be found.
+ Thrown if the context has been disposed.
+
+
+
+ Attaches the given entity to the context underlying the set. That is, the entity is placed
+ into the context in the Unchanged state, just as if it had been read from the database.
+
+ The entity to attach.
+ The entity.
+
+ Attach is used to repopulate a context with an entity that is known to already exist in the database.
+ SaveChanges will therefore not attempt to insert an attached entity into the database because
+ it is assumed to already be there.
+ Note that entities that are already in the context in some other state will have their state set
+ to Unchanged. Attach is a no-op if the entity is already in the context in the Unchanged state.
+
+
+
+
+ Adds the given entity to the context underlying the set in the Added state such that it will
+ be inserted into the database when SaveChanges is called.
+
+ The entity to add.
+ The entity.
+
+ Note that entities that are already in the context in some other state will have their state set
+ to Added. Add is a no-op if the entity is already in the context in the Added state.
+
+
+
+
+ Adds the given collection of entities into context underlying the set with each entity being put into
+ the Added state such that it will be inserted into the database when SaveChanges is called.
+
+ The collection of entities to add.
+
+ The collection of entities.
+
+
+ Note that if is set to true (which is
+ the default), then DetectChanges will be called once before adding any entities and will not be called
+ again. This means that in some situations AddRange may perform significantly better than calling
+ Add multiple times would do.
+ Note that entities that are already in the context in some other state will have their state set to
+ Added. AddRange is a no-op for entities that are already in the context in the Added state.
+
+
+
+
+ Marks the given entity as Deleted such that it will be deleted from the database when SaveChanges
+ is called. Note that the entity must exist in the context in some other state before this method
+ is called.
+
+ The entity to remove.
+ The entity.
+
+ Note that if the entity exists in the context in the Added state, then this method
+ will cause it to be detached from the context. This is because an Added entity is assumed not to
+ exist in the database such that trying to delete it does not make sense.
+
+
+
+
+ Removes the given collection of entities from the context underlying the set with each entity being put into
+ the Deleted state such that it will be deleted from the database when SaveChanges is called.
+
+ The collection of entities to delete.
+
+ The collection of entities.
+
+
+ Note that if is set to true (which is
+ the default), then DetectChanges will be called once before delete any entities and will not be called
+ again. This means that in some situations RemoveRange may perform significantly better than calling
+ Remove multiple times would do.
+ Note that if any entity exists in the context in the Added state, then this method
+ will cause it to be detached from the context. This is because an Added entity is assumed not to
+ exist in the database such that trying to delete it does not make sense.
+
+
+
+
+ Creates a new instance of an entity for the type of this set.
+ Note that this instance is NOT added or attached to the set.
+ The instance returned will be a proxy if the underlying context is configured to create
+ proxies and the entity type meets the requirements for creating a proxy.
+
+ The entity instance, which may be a proxy.
+
+
+
+ Creates a new instance of an entity for the type of this set or for a type derived
+ from the type of this set.
+ Note that this instance is NOT added or attached to the set.
+ The instance returned will be a proxy if the underlying context is configured to create
+ proxies and the entity type meets the requirements for creating a proxy.
+
+ The type of entity to create.
+ The entity instance, which may be a proxy.
+
+
+
+ Returns the equivalent generic object.
+
+ The type of entity for which the set was created.
+ The generic set object.
+
+
+
+ Creates a raw SQL query that will return entities in this set. By default, the
+ entities returned are tracked by the context; this can be changed by calling
+ AsNoTracking on the returned.
+ Note that the entities returned are always of the type for this set and never of
+ a derived type. If the table or tables queried may contain data for other entity
+ types, then the SQL query must be written appropriately to ensure that only entities of
+ the correct type are returned.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Set(typeof(Blog)).SqlQuery("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Set(typeof(Blog)).SqlQuery("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ The SQL query string.
+
+ The parameters to apply to the SQL query string. If output parameters are used, their values
+ will not be available until the results have been read completely. This is due to the underlying
+ behavior of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A object that will execute the query when it is enumerated.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets an that represents a local view of all Added, Unchanged,
+ and Modified entities in this set. This local view will stay in sync as entities are added or
+ removed from the context. Likewise, entities added to or removed from the local view will automatically
+ be added to or removed from the context.
+
+
+ This property can be used for data binding by populating the set with data, for example by using the Load
+ extension method, and then binding to the local data through this property. For WPF bind to this property
+ directly. For Windows Forms bind to the result of calling ToBindingList on this property
+
+ The local view.
+
+
+
+ A DbSet represents the collection of all entities in the context, or that can be queried from the
+ database, of a given type. DbSet objects are created from a DbContext using the DbContext.Set method.
+
+
+ Note that DbSet does not support MEST (Multiple Entity Sets per Type) meaning that there is always a
+ one-to-one correlation between a type and a set.
+
+ The type that defines the set.
+
+
+
+ Represents a LINQ to Entities query against a DbContext.
+
+ The type of entity to query for.
+
+
+
+ Specifies the related objects to include in the query results.
+
+
+ Paths are all-inclusive. For example, if an include call indicates Include("Orders.OrderLines"), not only will
+ OrderLines be included, but also Orders. When you call the Include method, the query path is only valid on
+ the returned instance of the DbQuery<T>. Other instances of DbQuery<T> and the object context itself are not affected.
+ Because the Include method returns the query object, you can call this method multiple times on an DbQuery<T> to
+ specify multiple paths for the query.
+
+ The dot-separated list of related objects to return in the query results.
+
+ A new with the defined query path.
+
+
+
+
+ Returns a new query where the entities returned will not be cached in the .
+
+ A new query with NoTracking applied.
+
+
+
+ Returns a new query that will stream the results instead of buffering.
+
+ A new query with AsStreaming applied.
+
+
+
+ Throws an exception indicating that binding directly to a store query is not supported.
+ Instead populate a DbSet with data, for example by using the Load extension method, and
+ then bind to local data. For WPF bind to DbSet.Local. For Windows Forms bind to
+ DbSet.Local.ToBindingList().
+
+ Never returns; always throws.
+
+
+
+ Returns an which when enumerated will execute the query against the database.
+
+ The query results.
+
+
+
+ Returns an which when enumerated will execute the query against the database.
+
+ The query results.
+
+
+
+ Returns an which when enumerated will execute the query against the database.
+
+ The query results.
+
+
+
+ Returns an which when enumerated will execute the query against the database.
+
+ The query results.
+
+
+
+ Returns a representation of the underlying query.
+
+ The query string.
+
+
+
+ Returns a new instance of the non-generic class for this query.
+
+ The query.
+ A non-generic version.
+
+
+
+
+
+
+
+
+
+
+
+
+ Returns false.
+
+
+ false .
+
+
+
+
+ The IQueryable element type.
+
+
+
+
+ The IQueryable LINQ Expression.
+
+
+
+
+ The IQueryable provider.
+
+
+
+
+ An represents the collection of all entities in the context, or that
+ can be queried from the database, of a given type. is a concrete
+ implementation of IDbSet.
+
+
+ was originally intended to allow creation of test doubles (mocks or
+ fakes) for . However, this approach has issues in that adding new members
+ to an interface breaks existing code that already implements the interface without the new members.
+ Therefore, starting with EF6, no new members will be added to this interface and it is recommended
+ that be used as the base class for test doubles.
+
+ The type that defines the set.
+
+
+
+ Finds an entity with the given primary key values.
+ If an entity with the given primary key values exists in the context, then it is
+ returned immediately without making a request to the store. Otherwise, a request
+ is made to the store for an entity with the given primary key values and this entity,
+ if found, is attached to the context and returned. If no entity is found in the
+ context or the store, then null is returned.
+
+
+ The ordering of composite key values is as defined in the EDM, which is in turn as defined in
+ the designer, by the Code First fluent API, or by the DataMember attribute.
+
+ The values of the primary key for the entity to be found.
+ The entity found, or null.
+
+
+
+ Adds the given entity to the context underlying the set in the Added state such that it will
+ be inserted into the database when SaveChanges is called.
+
+ The entity to add.
+ The entity.
+
+ Note that entities that are already in the context in some other state will have their state set
+ to Added. Add is a no-op if the entity is already in the context in the Added state.
+
+
+
+
+ Marks the given entity as Deleted such that it will be deleted from the database when SaveChanges
+ is called. Note that the entity must exist in the context in some other state before this method
+ is called.
+
+ The entity to remove.
+ The entity.
+
+ Note that if the entity exists in the context in the Added state, then this method
+ will cause it to be detached from the context. This is because an Added entity is assumed not to
+ exist in the database such that trying to delete it does not make sense.
+
+
+
+
+ Attaches the given entity to the context underlying the set. That is, the entity is placed
+ into the context in the Unchanged state, just as if it had been read from the database.
+
+ The entity to attach.
+ The entity.
+
+ Attach is used to repopulate a context with an entity that is known to already exist in the database.
+ SaveChanges will therefore not attempt to insert an attached entity into the database because
+ it is assumed to already be there.
+ Note that entities that are already in the context in some other state will have their state set
+ to Unchanged. Attach is a no-op if the entity is already in the context in the Unchanged state.
+
+
+
+
+ Creates a new instance of an entity for the type of this set.
+ Note that this instance is NOT added or attached to the set.
+ The instance returned will be a proxy if the underlying context is configured to create
+ proxies and the entity type meets the requirements for creating a proxy.
+
+ The entity instance, which may be a proxy.
+
+
+
+ Creates a new instance of an entity for the type of this set or for a type derived
+ from the type of this set.
+ Note that this instance is NOT added or attached to the set.
+ The instance returned will be a proxy if the underlying context is configured to create
+ proxies and the entity type meets the requirements for creating a proxy.
+
+ The type of entity to create.
+ The entity instance, which may be a proxy.
+
+
+
+ Gets an that represents a local view of all Added, Unchanged,
+ and Modified entities in this set. This local view will stay in sync as entities are added or
+ removed from the context. Likewise, entities added to or removed from the local view will automatically
+ be added to or removed from the context.
+
+
+ This property can be used for data binding by populating the set with data, for example by using the Load
+ extension method, and then binding to the local data through this property. For WPF bind to this property
+ directly. For Windows Forms bind to the result of calling ToBindingList on this property
+
+ The local view.
+
+
+
+ Creates an instance of a when called from the constructor of a derived
+ type that will be used as a test double for DbSets. Methods and properties that will be used by the
+ test double must be implemented by the test double except AsNoTracking, AsStreaming, an Include where
+ the default implementation is a no-op.
+
+
+
+
+ Finds an entity with the given primary key values.
+ If an entity with the given primary key values exists in the context, then it is
+ returned immediately without making a request to the store. Otherwise, a request
+ is made to the store for an entity with the given primary key values and this entity,
+ if found, is attached to the context and returned. If no entity is found in the
+ context or the store, then null is returned.
+
+
+ The ordering of composite key values is as defined in the EDM, which is in turn as defined in
+ the designer, by the Code First fluent API, or by the DataMember attribute.
+
+ The values of the primary key for the entity to be found.
+ The entity found, or null.
+ Thrown if multiple entities exist in the context with the primary key values given.
+ Thrown if the type of entity is not part of the data model for this context.
+ Thrown if the types of the key values do not match the types of the key values for the entity type to be found.
+ Thrown if the context has been disposed.
+
+
+
+ Asynchronously finds an entity with the given primary key values.
+ If an entity with the given primary key values exists in the context, then it is
+ returned immediately without making a request to the store. Otherwise, a request
+ is made to the store for an entity with the given primary key values and this entity,
+ if found, is attached to the context and returned. If no entity is found in the
+ context or the store, then null is returned.
+
+
+ The ordering of composite key values is as defined in the EDM, which is in turn as defined in
+ the designer, by the Code First fluent API, or by the DataMember attribute.
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+ The values of the primary key for the entity to be found.
+ A task that represents the asynchronous find operation. The task result contains the entity found, or null.
+ Thrown if multiple entities exist in the context with the primary key values given.
+ Thrown if the type of entity is not part of the data model for this context.
+ Thrown if the types of the key values do not match the types of the key values for the entity type to be found.
+ Thrown if the context has been disposed.
+
+
+
+ Asynchronously finds an entity with the given primary key values.
+ If an entity with the given primary key values exists in the context, then it is
+ returned immediately without making a request to the store. Otherwise, a request
+ is made to the store for an entity with the given primary key values and this entity,
+ if found, is attached to the context and returned. If no entity is found in the
+ context or the store, then null is returned.
+
+
+ The ordering of composite key values is as defined in the EDM, which is in turn as defined in
+ the designer, by the Code First fluent API, or by the DataMember attribute.
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+ The values of the primary key for the entity to be found.
+ A task that represents the asynchronous find operation. The task result contains the entity found, or null.
+
+
+
+
+
+
+
+
+
+ Adds the given collection of entities into context underlying the set with each entity being put into
+ the Added state such that it will be inserted into the database when SaveChanges is called.
+
+ The collection of entities to add.
+
+ The collection of entities.
+
+
+ Note that if is set to true (which is
+ the default), then DetectChanges will be called once before adding any entities and will not be called
+ again. This means that in some situations AddRange may perform significantly better than calling
+ Add multiple times would do.
+ Note that entities that are already in the context in some other state will have their state set to
+ Added. AddRange is a no-op for entities that are already in the context in the Added state.
+
+
+
+
+
+
+
+ Removes the given collection of entities from the context underlying the set with each entity being put into
+ the Deleted state such that it will be deleted from the database when SaveChanges is called.
+
+ The collection of entities to delete.
+
+ The collection of entities.
+
+
+ Note that if is set to true (which is
+ the default), then DetectChanges will be called once before delete any entities and will not be called
+ again. This means that in some situations RemoveRange may perform significantly better than calling
+ Remove multiple times would do.
+ Note that if any entity exists in the context in the Added state, then this method
+ will cause it to be detached from the context. This is because an Added entity is assumed not to
+ exist in the database such that trying to delete it does not make sense.
+
+
+
+
+
+
+
+
+
+
+ Returns the equivalent non-generic object.
+
+ The generic set object.
+ The non-generic set object.
+
+
+
+ Creates a raw SQL query that will return entities in this set. By default, the
+ entities returned are tracked by the context; this can be changed by calling
+ AsNoTracking on the returned.
+ Note that the entities returned are always of the type for this set and never of
+ a derived type. If the table or tables queried may contain data for other entity
+ types, then the SQL query must be written appropriately to ensure that only entities of
+ the correct type are returned.
+
+ As with any API that accepts SQL it is important to parameterize any user input to protect against a SQL injection attack. You can include parameter place holders in the SQL query string and then supply parameter values as additional arguments. Any parameter values you supply will automatically be converted to a DbParameter.
+ context.Blogs.SqlQuery("SELECT * FROM dbo.Posts WHERE Author = @p0", userSuppliedAuthor);
+ Alternatively, you can also construct a DbParameter and supply it to SqlQuery. This allows you to use named parameters in the SQL query string.
+ context.Blogs.SqlQuery("SELECT * FROM dbo.Posts WHERE Author = @author", new SqlParameter("@author", userSuppliedAuthor));
+
+ The SQL query string.
+
+ The parameters to apply to the SQL query string. If output parameters are used, their values will
+ not be available until the results have been read completely. This is due to the underlying behavior
+ of DbDataReader, see http://go.microsoft.com/fwlink/?LinkID=398589 for more details.
+
+
+ A object that will execute the query when it is enumerated.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ An implementation of IDatabaseInitializer that will always recreate and optionally re-seed the
+ database the first time that a context is used in the app domain.
+ To seed the database, create a derived class and override the Seed method.
+
+ The type of the context.
+
+
+ Initializes a new instance of the class.
+
+
+
+ Executes the strategy to initialize the database for the given context.
+
+ The context.
+
+
+ is
+ null
+ .
+
+
+
+
+ A method that should be overridden to actually add data to the context for seeding.
+ The default implementation does nothing.
+
+ The context to seed.
+
+
+
+ An implementation of IDatabaseInitializer that will DELETE, recreate, and optionally re-seed the
+ database only if the model has changed since the database was created.
+
+ The type of the context.
+
+ Whether or not the model has changed is determined by the
+ method.
+ To seed the database create a derived class and override the Seed method.
+
+
+
+ Initializes a new instance of the class.
+
+
+
+ Executes the strategy to initialize the database for the given context.
+
+ The context.
+
+
+ is
+ null
+ .
+
+
+
+
+ A method that should be overridden to actually add data to the context for seeding.
+ The default implementation does nothing.
+
+ The context to seed.
+
+
+
+ Returned by the ChangeTracker method of to provide access to features of
+ the context that are related to change tracking of entities.
+
+
+
+
+ Gets objects for all the entities tracked by this context.
+
+ The entries.
+
+
+
+ Gets objects for all the entities of the given type
+ tracked by this context.
+
+ The type of the entity.
+ The entries.
+
+
+
+ Checks if the is tracking any new, deleted, or changed entities or
+ relationships that will be sent to the database if is called.
+
+
+ Functionally, calling this method is equivalent to checking if there are any entities or
+ relationships in the Added, Updated, or Deleted state.
+ Note that this method calls unless
+ has been set to false.
+
+
+ True if underlying have changes, else false.
+
+
+
+
+ Detects changes made to the properties and relationships of POCO entities. Note that some types of
+ entity (such as change tracking proxies and entities that derive from
+ )
+ report changes automatically and a call to DetectChanges is not normally needed for these types of entities.
+ Also note that normally DetectChanges is called automatically by many of the methods of
+ and its related classes such that it is rare that this method will need to be called explicitly.
+ However, it may be desirable, usually for performance reasons, to turn off this automatic calling of
+ DetectChanges using the AutoDetectChangesEnabled flag from .
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ A non-generic version of the class.
+
+
+
+
+ This is an abstract base class use to represent a scalar or complex property, or a navigation property
+ of an entity. Scalar and complex properties use the derived class ,
+ reference navigation properties use the derived class , and collection
+ navigation properties use the derived class .
+
+
+
+
+ Validates this property.
+
+
+ Collection of objects. Never null. If the entity is valid the collection will be empty.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Returns the equivalent generic object.
+
+ The type of entity on which the member is declared.
+ The type of the property.
+ The equivalent generic object.
+
+
+
+ Gets the name of the property.
+
+ The property name.
+
+
+
+ Gets or sets the current value of this property.
+
+ The current value.
+
+
+
+ The to which this member belongs.
+
+ An entry for the entity that owns this member.
+
+
+
+ Loads the collection of entities from the database.
+ Note that entities that already exist in the context are not overwritten with values from the database.
+
+
+
+
+ Asynchronously loads the collection of entities from the database.
+ Note that entities that already exist in the context are not overwritten with values from the database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Asynchronously loads the collection of entities from the database.
+ Note that entities that already exist in the context are not overwritten with values from the database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Returns the query that would be used to load this collection from the database.
+ The returned query can be modified using LINQ to perform filtering or operations in the database, such
+ as counting the number of entities in the collection in the database without actually loading them.
+
+ A query for the collection.
+
+
+
+ Returns the equivalent generic object.
+
+ The type of entity on which the member is declared.
+ The type of the collection element.
+ The equivalent generic object.
+
+
+
+ Gets the property name.
+
+ The property name.
+
+
+
+ Gets or sets the current value of the navigation property. The current value is
+ the entity that the navigation property references.
+
+ The current value.
+
+
+
+ Gets or sets a value indicating whether all entities of this collection have been loaded from the database.
+
+
+ Loading the related entities from the database either using lazy-loading, as part of a query, or explicitly
+ with one of the Load methods will set the IsLoaded flag to true.
+ IsLoaded can be explicitly set to true to prevent the related entities of this collection from being lazy-loaded.
+ This can be useful if the application has caused a subset of related entities to be loaded into this collection
+ and wants to prevent any other entities from being loaded automatically.
+ Note that explict loading using one of the Load methods will load all related entities from the database
+ regardless of whether or not IsLoaded is true.
+ When any related entity in the collection is detached the IsLoaded flag is reset to false indicating that the
+ not all related entities are now loaded.
+
+
+ true if all the related entities are loaded or the IsLoaded has been explicitly set to true; otherwise, false.
+
+
+
+
+ The to which this navigation property belongs.
+
+ An entry for the entity that owns this navigation property.
+
+
+
+ Instances of this class are returned from the Collection method of
+ and allow operations such as loading to
+ be performed on the an entity's collection navigation properties.
+
+ The type of the entity to which this property belongs.
+ The type of the element in the collection of entities.
+
+
+
+ This is an abstract base class use to represent a scalar or complex property, or a navigation property
+ of an entity. Scalar and complex properties use the derived class ,
+ reference navigation properties use the derived class , and collection
+ navigation properties use the derived class .
+
+ The type of the entity to which this property belongs.
+ The type of the property.
+
+
+
+ Returns a new instance of the non-generic class for
+ the property represented by this object.
+
+ The object representing the property.
+ A non-generic version.
+
+
+
+ Validates this property.
+
+
+ Collection of objects. Never null. If the entity is valid the collection will be empty.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+ Gets the name of the property.
+ The name of the property.
+
+
+
+ Gets or sets the current value of this property.
+
+ The current value.
+
+
+
+ The to which this member belongs.
+
+ An entry for the entity that owns this member.
+
+
+
+ Loads the collection of entities from the database.
+ Note that entities that already exist in the context are not overwritten with values from the database.
+
+
+
+
+ Asynchronously loads the collection of entities from the database.
+ Note that entities that already exist in the context are not overwritten with values from the database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Asynchronously loads the collection of entities from the database.
+ Note that entities that already exist in the context are not overwritten with values from the database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Returns the query that would be used to load this collection from the database.
+ The returned query can be modified using LINQ to perform filtering or operations in the database, such
+ as counting the number of entities in the collection in the database without actually loading them.
+
+ A query for the collection.
+
+
+
+ Returns a new instance of the non-generic class for
+ the navigation property represented by this object.
+
+ The object representing the navigation property.
+ A non-generic version.
+
+
+
+ Gets the property name.
+
+ The property name.
+
+
+
+ Gets or sets the current value of the navigation property. The current value is
+ the entity that the navigation property references.
+
+ The current value.
+
+
+
+ Gets or sets a value indicating whether all entities of this collection have been loaded from the database.
+
+
+ Loading the related entities from the database either using lazy-loading, as part of a query, or explicitly
+ with one of the Load methods will set the IsLoaded flag to true.
+ IsLoaded can be explicitly set to true to prevent the related entities of this collection from being lazy-loaded.
+ This can be useful if the application has caused a subset of related entities to be loaded into this collection
+ and wants to prevent any other entities from being loaded automatically.
+ Note that explict loading using one of the Load methods will load all related entities from the database
+ regardless of whether or not IsLoaded is true.
+ When any related entity in the collection is detached the IsLoaded flag is reset to false indicating that the
+ not all related entities are now loaded.
+
+
+ true if all the related entities are loaded or the IsLoaded has been explicitly set to true; otherwise, false.
+
+
+
+
+ The to which this navigation property belongs.
+
+ An entry for the entity that owns this navigation property.
+
+
+
+ An immutable representation of an Entity Data Model (EDM) model that can be used to create an
+ or can be passed to the constructor of a .
+ For increased performance, instances of this type should be cached and re-used to construct contexts.
+
+
+
+
+ Creates an instance of ObjectContext or class derived from ObjectContext. Note that an instance
+ of DbContext can be created instead by using the appropriate DbContext constructor.
+ If a derived ObjectContext is used, then it must have a public constructor with a single
+ EntityConnection parameter.
+ The connection passed is used by the ObjectContext created, but is not owned by the context. The caller
+ must dispose of the connection once the context has been disposed.
+
+ The type of context to create.
+ An existing connection to a database for use by the context.
+ The context.
+
+
+
+ A non-generic version of the class.
+
+
+
+
+ A non-generic version of the class.
+
+
+
+
+ Returns the equivalent generic object.
+
+ The type of entity on which the member is declared.
+ The type of the property.
+ The equivalent generic object.
+
+
+
+ Gets the property name.
+
+ The property name.
+
+
+
+ Gets or sets the original value of this property.
+
+ The original value.
+
+
+
+ Gets or sets the current value of this property.
+
+ The current value.
+
+
+
+ Gets or sets a value indicating whether the value of this property has been modified since
+ it was loaded from the database.
+
+
+ Setting this value to false for a modified property will revert the change by setting the
+ current value to the original value. If the result is that no properties of the entity are
+ marked as modified, then the entity will be marked as Unchanged.
+ Setting this value to false for properties of Added, Unchanged, or Deleted entities
+ is a no-op.
+
+
+ true if this instance is modified; otherwise, false .
+
+
+
+
+ The to which this property belongs.
+
+ An entry for the entity that owns this property.
+
+
+
+ The of the property for which this is a nested property.
+ This method will only return a non-null entry for properties of complex objects; it will
+ return null for properties of the entity itself.
+
+ An entry for the parent complex property, or null if this is an entity property.
+
+
+
+ Gets an object that represents a nested property of this property.
+ This method can be used for both scalar or complex properties.
+
+ The name of the nested property.
+ An object representing the nested property.
+
+
+
+ Gets an object that represents a nested complex property of this property.
+
+ The name of the nested property.
+ An object representing the nested property.
+
+
+
+ Returns the equivalent generic object.
+
+ The type of entity on which the member is declared.
+ The type of the complex property.
+ The equivalent generic object.
+
+
+
+ Instances of this class are returned from the ComplexProperty method of
+ and allow access to the state of a complex property.
+
+ The type of the entity to which this property belongs.
+ The type of the property.
+
+
+
+ Instances of this class are returned from the Property method of
+ and allow access to the state of the scalar
+ or complex property.
+
+ The type of the entity to which this property belongs.
+ The type of the property.
+
+
+
+ Returns a new instance of the non-generic class for
+ the property represented by this object.
+
+ The object representing the property.
+ A non-generic version.
+
+
+
+ Gets the property name.
+
+ The property name.
+
+
+
+ Gets or sets the original value of this property.
+
+ The original value.
+
+
+
+ Gets or sets the current value of this property.
+
+ The current value.
+
+
+
+ Gets or sets a value indicating whether the value of this property has been modified since
+ it was loaded from the database.
+
+
+ true if this instance is modified; otherwise, false .
+
+
+
+
+ The to which this property belongs.
+
+ An entry for the entity that owns this property.
+
+
+
+ The of the property for which this is a nested property.
+ This method will only return a non-null entry for properties of complex objects; it will
+ return null for properties of the entity itself.
+
+ An entry for the parent complex property, or null if this is an entity property.
+
+
+
+ Returns a new instance of the non-generic class for
+ the property represented by this object.
+
+ The object representing the property.
+ A non-generic version.
+
+
+
+ Gets an object that represents a nested property of this property.
+ This method can be used for both scalar or complex properties.
+
+ The name of the nested property.
+ An object representing the nested property.
+
+
+
+ Gets an object that represents a nested property of this property.
+ This method can be used for both scalar or complex properties.
+
+ The type of the nested property.
+ The name of the nested property.
+ An object representing the nested property.
+
+
+
+ Gets an object that represents a nested property of this property.
+ This method can be used for both scalar or complex properties.
+
+ The type of the nested property.
+ An expression representing the nested property.
+ An object representing the nested property.
+
+
+
+ Gets an object that represents a nested complex property of this property.
+
+ The name of the nested property.
+ An object representing the nested property.
+
+
+
+ Gets an object that represents a nested complex property of this property.
+
+ The type of the nested property.
+ The name of the nested property.
+ An object representing the nested property.
+
+
+
+ Gets an object that represents a nested complex property of this property.
+
+ The type of the nested property.
+ An expression representing the nested property.
+ An object representing the nested property.
+
+
+
+ Describes the origin of the database connection string associated with a .
+
+
+
+
+ The connection string was created by convention.
+
+
+
+
+ The connection string was read from external configuration.
+
+
+
+
+ The connection string was explicitly specified at runtime.
+
+
+
+
+ The connection string was overriden by connection information supplied to DbContextInfo.
+
+
+
+
+ Returned by the Configuration method of to provide access to configuration
+ options for the context.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets or sets the value that determines whether SQL functions and commands should be always executed in a transaction.
+
+
+ This flag determines whether a new transaction will be started when methods such as
+ are executed outside of a transaction.
+ Note that this does not change the behavior of .
+
+
+ The default transactional behavior.
+
+
+
+
+ Gets or sets a value indicating whether lazy loading of relationships exposed as
+ navigation properties is enabled. Lazy loading is enabled by default.
+
+
+ true if lazy loading is enabled; otherwise, false .
+
+
+
+
+ Gets or sets a value indicating whether or not the framework will create instances of
+ dynamically generated proxy classes whenever it creates an instance of an entity type.
+ Note that even if proxy creation is enabled with this flag, proxy instances will only
+ be created for entity types that meet the requirements for being proxied.
+ Proxy creation is enabled by default.
+
+
+ true if proxy creation is enabled; otherwise, false .
+
+
+
+
+ Gets or sets a value indicating whether database null semantics are exhibited when comparing
+ two operands, both of which are potentially nullable. The default value is false.
+
+ For example (operand1 == operand2) will be translated as:
+
+ (operand1 = operand2)
+
+ if UseDatabaseNullSemantics is true, respectively
+
+ (((operand1 = operand2) AND (NOT (operand1 IS NULL OR operand2 IS NULL))) OR ((operand1 IS NULL) AND (operand2 IS NULL)))
+
+ if UseDatabaseNullSemantics is false.
+
+
+ true if database null comparison behavior is enabled, otherwise false .
+
+
+
+
+ Gets or sets a value indicating whether the
+ method is called automatically by methods of and related classes.
+ The default value is true.
+
+
+ true if should be called automatically; otherwise, false.
+
+
+
+
+ Gets or sets a value indicating whether tracked entities should be validated automatically when
+ is invoked.
+ The default value is true.
+
+
+
+
+ Provides runtime information about a given type.
+
+
+
+
+ Creates a new instance representing a given type.
+
+
+ The type deriving from .
+
+
+
+
+ Creates a new instance representing a given targeting a specific database.
+
+
+ The type deriving from .
+
+ Connection information for the database to be used.
+
+
+
+ Creates a new instance representing a given type. An external list of
+ connection strings can be supplied and will be used during connection string resolution in place
+ of any connection strings specified in external configuration files.
+
+
+ It is preferable to use the constructor that accepts the entire config document instead of using this
+ constructor. Providing the entire config document allows DefaultConnectionFactroy entries in the config
+ to be found in addition to explicitly specified connection strings.
+
+
+ The type deriving from .
+
+ A collection of connection strings.
+
+
+
+ Creates a new instance representing a given type. An external config
+ object (e.g. app.config or web.config) can be supplied and will be used during connection string
+ resolution. This includes looking for connection strings and DefaultConnectionFactory entries.
+
+
+ The type deriving from .
+
+ An object representing the config file.
+
+
+
+ Creates a new instance representing a given , targeting a specific database.
+ An external config object (e.g. app.config or web.config) can be supplied and will be used during connection string
+ resolution. This includes looking for connection strings and DefaultConnectionFactory entries.
+
+
+ The type deriving from .
+
+ An object representing the config file.
+ Connection information for the database to be used.
+
+
+
+ Creates a new instance representing a given type. A
+ can be supplied in order to override the default determined provider used when constructing
+ the underlying EDM model.
+
+
+ The type deriving from .
+
+
+ A specifying the underlying ADO.NET provider to target.
+
+
+
+
+ Creates a new instance representing a given type. An external config
+ object (e.g. app.config or web.config) can be supplied and will be used during connection string
+ resolution. This includes looking for connection strings and DefaultConnectionFactory entries.
+ A can be supplied in order to override the default determined
+ provider used when constructing the underlying EDM model. This can be useful to prevent EF from
+ connecting to discover a manifest token.
+
+
+ The type deriving from .
+
+ An object representing the config file.
+
+ A specifying the underlying ADO.NET provider to target.
+
+
+
+
+ If instances of the underlying type can be created, returns
+ a new instance; otherwise returns null.
+
+
+ A instance.
+
+
+
+
+ The concrete type.
+
+
+
+
+ Whether or not instances of the underlying type can be created.
+
+
+
+
+ The connection string used by the underlying type.
+
+
+
+
+ The connection string name used by the underlying type.
+
+
+
+
+ The ADO.NET provider name of the connection used by the underlying type.
+
+
+
+
+ The origin of the connection string used by the underlying type.
+
+
+
+
+ An action to be run on the DbModelBuilder after OnModelCreating has been run on the context.
+
+
+
+
+ A non-generic version of the class.
+
+
+
+
+ Queries the database for copies of the values of the tracked entity as they currently exist in the database.
+ Note that changing the values in the returned dictionary will not update the values in the database.
+ If the entity is not found in the database then null is returned.
+
+ The store values.
+
+
+
+ Asynchronously queries the database for copies of the values of the tracked entity as they currently exist in the database.
+ Note that changing the values in the returned dictionary will not update the values in the database.
+ If the entity is not found in the database then null is returned.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the store values.
+
+
+
+
+ Asynchronously queries the database for copies of the values of the tracked entity as they currently exist in the database.
+ Note that changing the values in the returned dictionary will not update the values in the database.
+ If the entity is not found in the database then null is returned.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the store values.
+
+
+
+
+ Reloads the entity from the database overwriting any property values with values from the database.
+ The entity will be in the Unchanged state after calling this method.
+
+
+
+
+ Asynchronously reloads the entity from the database overwriting any property values with values from the database.
+ The entity will be in the Unchanged state after calling this method.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Asynchronously reloads the entity from the database overwriting any property values with values from the database.
+ The entity will be in the Unchanged state after calling this method.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Gets an object that represents the reference (i.e. non-collection) navigation property from this
+ entity to another entity.
+
+ The name of the navigation property.
+ An object representing the navigation property.
+
+
+
+ Gets an object that represents the collection navigation property from this
+ entity to a collection of related entities.
+
+ The name of the navigation property.
+ An object representing the navigation property.
+
+
+
+ Gets an object that represents a scalar or complex property of this entity.
+
+ The name of the property.
+ An object representing the property.
+
+
+
+ Gets an object that represents a complex property of this entity.
+
+ The name of the complex property.
+ An object representing the complex property.
+
+
+
+ Gets an object that represents a member of the entity. The runtime type of the returned object will
+ vary depending on what kind of member is asked for. The currently supported member types and their return
+ types are:
+ Reference navigation property: .
+ Collection navigation property: .
+ Primitive/scalar property: .
+ Complex property: .
+
+ The name of the member.
+ An object representing the member.
+
+
+
+ Returns a new instance of the generic class for the given
+ generic type for the tracked entity represented by this object.
+ Note that the type of the tracked entity must be compatible with the generic type or
+ an exception will be thrown.
+
+ The type of the entity.
+ A generic version.
+
+
+
+ Validates this instance and returns validation result.
+
+
+ Entity validation result. Possibly null if
+ DbContext.ValidateEntity(DbEntityEntry, IDictionary{object,object})
+ method is overridden.
+
+
+
+
+ Determines whether the specified is equal to this instance.
+ Two instances are considered equal if they are both entries for
+ the same entity on the same .
+
+
+ The to compare with this instance.
+
+
+ true if the specified is equal to this instance; otherwise, false .
+
+
+
+
+ Determines whether the specified is equal to this instance.
+ Two instances are considered equal if they are both entries for
+ the same entity on the same .
+
+
+ The to compare with this instance.
+
+
+ true if the specified is equal to this instance; otherwise, false .
+
+
+
+
+ Returns a hash code for this instance.
+
+ A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table.
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets the entity.
+
+ The entity.
+
+
+
+ Gets or sets the state of the entity.
+
+ The state.
+
+
+
+ Gets the current property values for the tracked entity represented by this object.
+
+ The current values.
+
+
+
+ Gets the original property values for the tracked entity represented by this object.
+ The original values are usually the entity's property values as they were when last queried from
+ the database.
+
+ The original values.
+
+
+
+ Instances of this class provide access to information about and control of entities that
+ are being tracked by the . Use the Entity or Entities methods of
+ the context to obtain objects of this type.
+
+ The type of the entity.
+
+
+
+ Queries the database for copies of the values of the tracked entity as they currently exist in the database.
+ Note that changing the values in the returned dictionary will not update the values in the database.
+ If the entity is not found in the database then null is returned.
+
+ The store values.
+
+
+
+ Asynchronously queries the database for copies of the values of the tracked entity as they currently exist in the database.
+ Note that changing the values in the returned dictionary will not update the values in the database.
+ If the entity is not found in the database then null is returned.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the store values.
+
+
+
+
+ Asynchronously queries the database for copies of the values of the tracked entity as they currently exist in the database.
+ Note that changing the values in the returned dictionary will not update the values in the database.
+ If the entity is not found in the database then null is returned.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+ The task result contains the store values.
+
+
+
+
+ Reloads the entity from the database overwriting any property values with values from the database.
+ The entity will be in the Unchanged state after calling this method.
+
+
+
+
+ Asynchronously reloads the entity from the database overwriting any property values with values from the database.
+ The entity will be in the Unchanged state after calling this method.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Asynchronously reloads the entity from the database overwriting any property values with values from the database.
+ The entity will be in the Unchanged state after calling this method.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Gets an object that represents the reference (i.e. non-collection) navigation property from this
+ entity to another entity.
+
+ The name of the navigation property.
+ An object representing the navigation property.
+
+
+
+ Gets an object that represents the reference (i.e. non-collection) navigation property from this
+ entity to another entity.
+
+ The type of the property.
+ The name of the navigation property.
+ An object representing the navigation property.
+
+
+
+ Gets an object that represents the reference (i.e. non-collection) navigation property from this
+ entity to another entity.
+
+ The type of the property.
+ An expression representing the navigation property.
+ An object representing the navigation property.
+
+
+
+ Gets an object that represents the collection navigation property from this
+ entity to a collection of related entities.
+
+ The name of the navigation property.
+ An object representing the navigation property.
+
+
+
+ Gets an object that represents the collection navigation property from this
+ entity to a collection of related entities.
+
+ The type of elements in the collection.
+ The name of the navigation property.
+ An object representing the navigation property.
+
+
+
+ Gets an object that represents the collection navigation property from this
+ entity to a collection of related entities.
+
+ The type of elements in the collection.
+ An expression representing the navigation property.
+ An object representing the navigation property.
+
+
+
+ Gets an object that represents a scalar or complex property of this entity.
+
+ The name of the property.
+ An object representing the property.
+
+
+
+ Gets an object that represents a scalar or complex property of this entity.
+
+ The type of the property.
+ The name of the property.
+ An object representing the property.
+
+
+
+ Gets an object that represents a scalar or complex property of this entity.
+
+ The type of the property.
+ An expression representing the property.
+ An object representing the property.
+
+
+
+ Gets an object that represents a complex property of this entity.
+
+ The name of the complex property.
+ An object representing the complex property.
+
+
+
+ Gets an object that represents a complex property of this entity.
+
+ The type of the complex property.
+ The name of the complex property.
+ An object representing the complex property.
+
+
+
+ Gets an object that represents a complex property of this entity.
+
+ The type of the complex property.
+ An expression representing the complex property.
+ An object representing the complex property.
+
+
+
+ Gets an object that represents a member of the entity. The runtime type of the returned object will
+ vary depending on what kind of member is asked for. The currently supported member types and their return
+ types are:
+ Reference navigation property: .
+ Collection navigation property: .
+ Primitive/scalar property: .
+ Complex property: .
+
+ The name of the member.
+ An object representing the member.
+
+
+
+ Gets an object that represents a member of the entity. The runtime type of the returned object will
+ vary depending on what kind of member is asked for. The currently supported member types and their return
+ types are:
+ Reference navigation property: .
+ Collection navigation property: .
+ Primitive/scalar property: .
+ Complex property: .
+
+ The type of the member.
+ The name of the member.
+ An object representing the member.
+
+
+
+ Returns a new instance of the non-generic class for
+ the tracked entity represented by this object.
+
+ The object representing the tracked entity.
+ A non-generic version.
+
+
+
+ Validates this instance and returns validation result.
+
+
+ Entity validation result. Possibly null if
+ DbContext.ValidateEntity(DbEntityEntry, IDictionary{object, object})
+ method is overridden.
+
+
+
+
+ Determines whether the specified is equal to this instance.
+ Two instances are considered equal if they are both entries for
+ the same entity on the same .
+
+
+ The to compare with this instance.
+
+
+ true if the specified is equal to this instance; otherwise, false .
+
+
+
+
+ Determines whether the specified is equal to this instance.
+ Two instances are considered equal if they are both entries for
+ the same entity on the same .
+
+
+ The to compare with this instance.
+
+
+ true if the specified is equal to this instance; otherwise, false .
+
+
+
+
+ Returns a hash code for this instance.
+
+ A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table.
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets the entity.
+
+ The entity.
+
+
+
+ Gets or sets the state of the entity.
+
+ The state.
+
+
+
+ Gets the current property values for the tracked entity represented by this object.
+
+ The current values.
+
+
+
+ Gets the original property values for the tracked entity represented by this object.
+ The original values are usually the entity's property values as they were when last queried from
+ the database.
+
+ The original values.
+
+
+
+ Represents an Entity Data Model (EDM) created by the .
+ The Compile method can be used to go from this EDM representation to a
+ which is a compiled snapshot of the model suitable for caching and creation of
+ or instances.
+
+
+
+
+ Creates a for this mode which is a compiled snapshot
+ suitable for caching and creation of instances.
+
+ The compiled model.
+
+
+
+ Gets the provider information.
+
+
+
+
+ Gets the provider manifest.
+
+
+
+
+ Gets the conceptual model.
+
+
+
+
+ Gets the store model.
+
+
+
+
+ Gets the mapping model.
+
+
+
+
+ A collection of all the properties for an underlying entity or complex object.
+
+
+ An instance of this class can be converted to an instance of the generic class
+ using the Cast method.
+ Complex properties in the underlying entity or complex object are represented in
+ the property values as nested instances of this class.
+
+
+
+
+ Creates an object of the underlying type for this dictionary and hydrates it with property
+ values from this dictionary.
+
+ The properties of this dictionary copied into a new object.
+
+
+
+ Sets the values of this dictionary by reading values out of the given object.
+ The given object can be of any type. Any property on the object with a name that
+ matches a property name in the dictionary and can be read will be read. Other
+ properties will be ignored. This allows, for example, copying of properties from
+ simple Data Transfer Objects (DTOs).
+
+ The object to read values from.
+
+
+
+ Creates a new dictionary containing copies of all the properties in this dictionary.
+ Changes made to the new dictionary will not be reflected in this dictionary and vice versa.
+
+ A clone of this dictionary.
+
+
+
+ Sets the values of this dictionary by reading values from another dictionary.
+ The other dictionary must be based on the same type as this dictionary, or a type derived
+ from the type for this dictionary.
+
+ The dictionary to read values from.
+
+
+
+ Gets the value of the property just like using the indexed property getter but
+ typed to the type of the generic parameter. This is useful especially with
+ nested dictionaries to avoid writing expressions with lots of casts.
+
+ The type of the property.
+ Name of the property.
+ The value of the property.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Gets the set of names of all properties in this dictionary as a read-only set.
+
+ The property names.
+
+
+
+ Gets or sets the value of the property with the specified property name.
+ The value may be a nested instance of this class.
+
+ The property name.
+ The value of the property.
+
+
+
+ Groups a pair of strings that identify a provider and server version together into a single object.
+
+
+ Instances of this class act as the key for resolving a for a specific
+ provider from a . This is typically used when registering spatial services
+ in or when the spatial services specific to a provider is
+ resolved by an implementation of .
+
+
+
+
+ Creates a new object for a given provider invariant name and manifest token.
+
+
+ A string that identifies that provider. For example, the SQL Server
+ provider uses the string "System.Data.SqlCient".
+
+
+ A string that identifies that version of the database server being used. For example, the SQL Server
+ provider uses the string "2008" for SQL Server 2008. This cannot be null but may be empty.
+ The manifest token is sometimes referred to as a version hint.
+
+
+
+
+
+
+
+
+
+
+ A string that identifies that provider. For example, the SQL Server
+ provider uses the string "System.Data.SqlCient".
+
+
+
+
+ A string that identifies that version of the database server being used. For example, the SQL Server
+ provider uses the string "2008" for SQL Server 2008. This cannot be null but may be empty.
+
+
+
+
+ A non-generic version of the class.
+
+
+
+
+ Loads the entity from the database.
+ Note that if the entity already exists in the context, then it will not overwritten with values from the database.
+
+
+
+
+ Asynchronously loads the entity from the database.
+ Note that if the entity already exists in the context, then it will not overwritten with values from the database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Asynchronously loads the entity from the database.
+ Note that if the entity already exists in the context, then it will not overwritten with values from the database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Returns the query that would be used to load this entity from the database.
+ The returned query can be modified using LINQ to perform filtering or operations in the database.
+
+ A query for the entity.
+
+
+
+ Returns the equivalent generic object.
+
+ The type of entity on which the member is declared.
+ The type of the property.
+ The equivalent generic object.
+
+
+
+ Gets the property name.
+
+ The property name.
+
+
+
+ Gets or sets the current value of the navigation property. The current value is
+ the entity that the navigation property references.
+
+ The current value.
+
+
+
+ Gets or sets a value indicating whether the entity has been loaded from the database.
+
+
+ Loading the related entity from the database either using lazy-loading, as part of a query, or explicitly
+ with one of the Load methods will set the IsLoaded flag to true.
+ IsLoaded can be explicitly set to true to prevent the related entity from being lazy-loaded.
+ Note that explict loading using one of the Load methods will load the related entity from the database
+ regardless of whether or not IsLoaded is true.
+ When a related entity is detached the IsLoaded flag is reset to false indicating that the related entity is
+ no longer loaded.
+
+
+ true if the entity is loaded or the IsLoaded has been explicitly set to true; otherwise, false.
+
+
+
+
+ The to which this navigation property belongs.
+
+ An entry for the entity that owns this navigation property.
+
+
+
+ Instances of this class are returned from the Reference method of
+ and allow operations such as loading to
+ be performed on the an entity's reference navigation properties.
+
+ The type of the entity to which this property belongs.
+ The type of the property.
+
+
+
+ Loads the entity from the database.
+ Note that if the entity already exists in the context, then it will not overwritten with values from the database.
+
+
+
+
+ Asynchronously loads the entity from the database.
+ Note that if the entity already exists in the context, then it will not overwritten with values from the database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Asynchronously loads the entity from the database.
+ Note that if the entity already exists in the context, then it will not overwritten with values from the database.
+
+
+ Multiple active operations on the same context instance are not supported. Use 'await' to ensure
+ that any asynchronous operations have completed before calling another method on this context.
+
+
+ A to observe while waiting for the task to complete.
+
+
+ A task that represents the asynchronous operation.
+
+
+
+
+ Returns the query that would be used to load this entity from the database.
+ The returned query can be modified using LINQ to perform filtering or operations in the database.
+
+ A query for the entity.
+
+
+
+ Returns a new instance of the non-generic class for
+ the navigation property represented by this object.
+
+ The object representing the navigation property.
+ A non-generic version.
+
+
+
+ Gets the property name.
+
+ The property name.
+
+
+
+ Gets or sets the current value of the navigation property. The current value is
+ the entity that the navigation property references.
+
+ The current value.
+
+
+
+ Gets or sets a value indicating whether the entity has been loaded from the database.
+
+
+ Loading the related entity from the database either using lazy-loading, as part of a query, or explicitly
+ with one of the Load methods will set the IsLoaded flag to true.
+ IsLoaded can be explicitly set to true to prevent the related entity from being lazy-loaded.
+ Note that explict loading using one of the Load methods will load the related entity from the database
+ regardless of whether or not IsLoaded is true.
+ When a related entity is detached the IsLoaded flag is reset to false indicating that the related entity is
+ no longer loaded.
+
+
+ true if the entity is loaded or the IsLoaded has been explicitly set to true; otherwise, false.
+
+
+
+
+ The to which this navigation property belongs.
+
+ An entry for the entity that owns this navigation property.
+
+
+
+ Exception thrown by when it was expected that SaveChanges for an entity would
+ result in a database update but in fact no rows in the database were affected. This usually indicates
+ that the database has been concurrently updated such that a concurrency token that was expected to match
+ did not actually match.
+ Note that state entries referenced by this exception are not serialized due to security and accesses to
+ the state entries after serialization will return null.
+
+
+
+
+ Exception thrown by when the saving of changes to the database fails.
+ Note that state entries referenced by this exception are not serialized due to security and accesses to the
+ state entries after serialization will return null.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The message.
+
+
+
+ Initializes a new instance of the class.
+
+ The message.
+ The inner exception.
+
+
+
+ Gets objects that represents the entities that could not
+ be saved to the database.
+
+ The entries representing the entities that could not be saved.
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The message.
+
+
+
+ Initializes a new instance of the class.
+
+ The message.
+ The inner exception.
+
+
+
+ Represents an entity used to store metadata about an EDM in the database.
+
+
+
+
+ Attempts to get the model hash calculated by Code First for the given context.
+ This method will return null if the context is not being used in Code First mode.
+
+ The context.
+ The hash string.
+
+
+
+ Gets or sets the ID of the metadata entity, which is currently always 1.
+
+ The id.
+
+
+
+ Gets or sets the model hash which is used to check whether the model has
+ changed since the database was created from it.
+
+ The model hash.
+
+
+
+ Contains methods used to access the Entity Data Model created by Code First in the EDMX form.
+ These methods are typically used for debugging when there is a need to look at the model that
+ Code First creates internally.
+
+
+
+
+ Uses Code First with the given context and writes the resulting Entity Data Model to the given
+ writer in EDMX form. This method can only be used with context instances that use Code First
+ and create the model internally. The method cannot be used for contexts created using Database
+ First or Model First, for contexts created using a pre-existing , or
+ for contexts created using a pre-existing .
+
+ The context.
+ The writer.
+
+
+
+ Writes the Entity Data Model represented by the given to the
+ given writer in EDMX form.
+
+ An object representing the EDM.
+ The writer.
+
+
+
+ A factory for creating derived instances. Implement this
+ interface to enable design-time services for context types that do not have a
+ public default constructor.
+ At design-time, derived instances can be created in order to enable specific
+ design-time experiences such as model rendering, DDL generation etc. To enable design-time instantiation
+ for derived types that do not have a public, default constructor, implement
+ this interface. Design-time services will auto-discover implementations of this interface that are in the
+ same assembly as the derived type.
+
+ The type of the context.
+
+
+
+ Creates a new instance of a derived type.
+
+ An instance of TContext
+
+
+
+ This convention causes DbModelBuilder to include metadata about the model
+ when it builds the model. When creates a model by convention it will
+ add this convention to the list of those used by the DbModelBuilder. This will then result in
+ model metadata being written to the database if the DbContext is used to create the database.
+ This can then be used as a quick check to see if the model has changed since the last time it was
+ used against the database.
+ This convention can be removed from the conventions by overriding
+ the OnModelCreating method on a derived DbContext class.
+
+
+
+
+ This convention uses the name of the derived
+ class as the container for the conceptual model built by
+ Code First.
+
+
+
+
+ Applies the convention to the given model.
+
+ The container to apply the convention to.
+ The model.
+
+
+
+ This convention uses the namespace of the derived
+ class as the namespace of the conceptual model built by
+ Code First.
+
+
+
+
+ Instances of this class are used internally to create constant expressions for
+ that are inserted into the expression tree to replace references to
+ and .
+
+ The type of the element.
+
+
+
+ The public property expected in the LINQ expression tree.
+
+ The query.
+
+
+
+ Instances of this class are used to create DbConnection objects for
+ SQL Server Compact Edition based on a given database name or connection string.
+
+
+ It is necessary to provide the provider invariant name of the SQL Server Compact
+ Edition to use when creating an instance of this class. This is because different
+ versions of SQL Server Compact Editions use different invariant names.
+ An instance of this class can be set on the class to
+ cause all DbContexts created with no connection information or just a database
+ name or connection string to use SQL Server Compact Edition by default.
+ This class is immutable since multiple threads may access instances simultaneously
+ when creating connections.
+
+
+
+
+ Creates a new connection factory with empty (default) DatabaseDirectory and BaseConnectionString
+ properties.
+
+ The provider invariant name that specifies the version of SQL Server Compact Edition that should be used.
+
+
+
+ Creates a new connection factory with the given DatabaseDirectory and BaseConnectionString properties.
+
+ The provider invariant name that specifies the version of SQL Server Compact Edition that should be used.
+ The path to prepend to the database name that will form the file name used by SQL Server Compact Edition when it creates or reads the database file. An empty string means that SQL Server Compact Edition will use its default for the database file location.
+ The connection string to use for options to the database other than the 'Data Source'. The Data Source will be prepended to this string based on the database name when CreateConnection is called.
+
+
+
+ Creates a connection for SQL Server Compact Edition based on the given database name or connection string.
+ If the given string contains an '=' character then it is treated as a full connection string,
+ otherwise it is treated as a database name only.
+
+ The database name or connection string.
+ An initialized DbConnection.
+
+
+
+ The path to prepend to the database name that will form the file name used by
+ SQL Server Compact Edition when it creates or reads the database file.
+ The default value is "|DataDirectory|", which means the file will be placed
+ in the designated data directory.
+
+
+
+
+ The connection string to use for options to the database other than the 'Data Source'.
+ The Data Source will be prepended to this string based on the database name when
+ CreateConnection is called.
+ The default is the empty string, which means no other options will be used.
+
+
+
+
+ The provider invariant name that specifies the version of SQL Server Compact Edition
+ that should be used.
+
+
+
+
+ Instances of this class are used to create DbConnection objects for
+ SQL Server based on a given database name or connection string. By default, the connection is
+ made to '.\SQLEXPRESS'. This can be changed by changing the base connection
+ string when constructing a factory instance.
+
+
+ An instance of this class can be set on the class to
+ cause all DbContexts created with no connection information or just a database
+ name or connection string to use SQL Server by default.
+ This class is immutable since multiple threads may access instances simultaneously
+ when creating connections.
+
+
+
+
+ Creates a new connection factory with a default BaseConnectionString property of
+ 'Data Source=.\SQLEXPRESS; Integrated Security=True; MultipleActiveResultSets=True;'.
+
+
+
+
+ Creates a new connection factory with the given BaseConnectionString property.
+
+ The connection string to use for options to the database other than the 'Initial Catalog'. The 'Initial Catalog' will be prepended to this string based on the database name when CreateConnection is called.
+
+
+
+ Creates a connection for SQL Server based on the given database name or connection string.
+ If the given string contains an '=' character then it is treated as a full connection string,
+ otherwise it is treated as a database name only.
+
+ The database name or connection string.
+ An initialized DbConnection.
+
+
+
+ The connection string to use for options to the database other than the 'Initial Catalog'.
+ The 'Initial Catalog' will be prepended to this string based on the database name when
+ CreateConnection is called.
+ The default is 'Data Source=.\SQLEXPRESS; Integrated Security=True;'.
+
+
+
+
+ This attribute can be applied to either an entire derived class or to
+ individual or properties on that class. When applied
+ any discovered or properties will still be included
+ in the model but will not be automatically initialized.
+
+
+
+
+ Thrown when a context is generated from the templates in Database First or Model
+ First mode and is then used in Code First mode.
+
+
+ Code generated using the T4 templates provided for Database First and Model First use may not work
+ correctly if used in Code First mode. To use these classes with Code First please add any additional
+ configuration using attributes or the DbModelBuilder API and then remove the code that throws this
+ exception.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The object that holds the serialized object data.
+ The contextual information about the source or destination.
+
+
+
+ Initializes a new instance of the class.
+
+ The message.
+
+
+
+ Initializes a new instance of the class.
+
+ The message.
+ The inner exception.
+
+
+
+ Allows configuration to be performed for an complex type in a model.
+ A ComplexTypeConfiguration can be obtained via the ComplexType method on
+ or a custom type derived from ComplexTypeConfiguration
+ can be registered via the Configurations property on .
+
+ The complex type to be configured.
+
+
+
+ Allows configuration to be performed for a type in a model.
+
+ The type to be configured.
+
+
+
+ Configures a property that is defined on this type.
+
+ The type of the property being configured.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ The type of the property being configured.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is defined on this type.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Initializes a new instance of ComplexTypeConfiguration
+
+
+
+
+ Excludes a property from the model so that it will not be mapped to the database.
+
+ The type of the property to be ignored.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The same ComplexTypeConfiguration instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Allows derived configuration classes for entities and complex types to be registered with a
+ .
+
+
+ Derived configuration classes are created by deriving from
+ or and using a type to be included in the model as the generic
+ parameter.
+ Configuration can be performed without creating derived configuration classes via the Entity and ComplexType
+ methods on .
+
+
+
+
+ Discovers all types that inherit from or
+ in the given assembly and adds an instance
+ of each discovered type to this registrar.
+
+
+ Note that only types that are abstract or generic type definitions are skipped. Every
+ type that is discovered and added must provide a parameterless constructor.
+
+ The assembly containing model configurations to add.
+ The same ConfigurationRegistrar instance so that multiple calls can be chained.
+
+
+
+ Adds an to the .
+ Only one can be added for each type in a model.
+
+ The entity type being configured.
+ The entity type configuration to be added.
+ The same ConfigurationRegistrar instance so that multiple calls can be chained.
+
+
+
+ Adds an to the .
+ Only one can be added for each type in a model.
+
+ The complex type being configured.
+ The complex type configuration to be added
+ The same ConfigurationRegistrar instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Allows the conventions used by a instance to be customized.
+ The default conventions can be found in the System.Data.Entity.ModelConfiguration.Conventions namespace.
+
+
+
+
+ Discover all conventions in the given assembly and add them to the .
+
+
+ This method add all conventions ordered by type name. The order in which conventions are added
+ can have an impact on how they behave because it governs the order in which they are run.
+ All conventions found must have a parameterless public constructor.
+
+ The assembly containing conventions to be added.
+
+
+
+ Enables one or more conventions for the .
+
+ The conventions to be enabled.
+
+
+
+ Enables a convention for the .
+
+ The type of the convention to be enabled.
+
+
+
+ Enables a convention for the . This convention
+ will run after the one specified.
+
+ The type of the convention after which the enabled one will run.
+ The convention to enable.
+
+
+
+ Enables a configuration convention for the . This convention
+ will run before the one specified.
+
+ The type of the convention before which the enabled one will run.
+ The convention to enable.
+
+
+
+ Disables one or more conventions for the .
+
+ The conventions to be disabled.
+
+
+
+ Disables a convention for the .
+ The default conventions that are available for removal can be found in the
+ System.Data.Entity.ModelConfiguration.Conventions namespace.
+
+ The type of the convention to be disabled.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Configures the table and column mapping for an entity type or a sub-set of properties from an entity type.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+ The entity type to be mapped.
+
+
+ Initializes a new instance of the class.
+
+
+
+ Configures the properties that will be included in this mapping fragment.
+ If this method is not called then all properties that have not yet been
+ included in a mapping fragment will be configured.
+
+ An anonymous type including the properties to be mapped.
+ A lambda expression to an anonymous type that contains the properties to be mapped. C#: t => new { t.Id, t.Property1, t.Property2 } VB.Net: Function(t) New With { p.Id, t.Property1, t.Property2 }
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ The type of the property being configured.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ The type of the property being configured.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Configures a property that is included in this mapping fragment.
+
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to configure the property.
+
+
+
+ Re-maps all properties inherited from base types.
+ When configuring a derived type to be mapped to a separate table this will cause all properties to
+ be included in the table rather than just the non-inherited properties. This is known as
+ Table per Concrete Type (TPC) mapping.
+
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the table name to be mapped to.
+
+ Name of the table.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the table name and schema to be mapped to.
+
+ Name of the table.
+ Schema of the table.
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the table to which this entity is mapped. The annotation
+ value can later be used when processing the table such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the discriminator column used to differentiate between types in an inheritance hierarchy.
+
+ The name of the discriminator column.
+ A configuration object to further configure the discriminator column and values.
+
+
+
+ Configures the discriminator condition used to differentiate between types in an inheritance hierarchy.
+
+ The type of the property being used to discriminate between types.
+ A lambda expression representing the property being used to discriminate between types. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object to further configure the discriminator condition.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Used to configure a column with length facets for an entity type or complex type. This configuration functionality is exposed by the Code First Fluent API, see .
+
+
+
+
+ Configures a primitive column from an entity type.
+
+
+
+ Configures the primitive column to be optional.
+ The same instance so that multiple calls can be chained.
+
+
+ Configures the primitive column to be required.
+ The same instance so that multiple calls can be chained.
+
+
+ Configures the data type of the primitive column used to store the property.
+ The same instance so that multiple calls can be chained.
+ The name of the database provider specific data type.
+
+
+ Configures the order of the primitive column used to store the property. This method is also used to specify key ordering when an entity type has a composite key.
+ The same instance so that multiple calls can be chained.
+ The order that this column should appear in the database table.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+ Configures the column to allow the maximum length supported by the database provider.
+ The same instance so that multiple calls can be chained.
+
+
+ Configures the column to have the specified maximum length.
+ The same instance so that multiple calls can be chained.
+ The maximum length for the column. Setting the value to null will remove any maximum length restriction from the column and a default length will be used for the database column.
+
+
+ Configures the column to be fixed length.
+ The same instance so that multiple calls can be chained.
+
+
+ Configures the column to be variable length.
+ The same instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Configures a condition used to discriminate between types in an inheritance hierarchy based on the values assigned to a property.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the condition to require a value in the property.
+ Rows that do not have a value assigned to column that this property is stored in are
+ assumed to be of the base type of this entity type.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Configures a database column used to store a string values.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the column to allow the maximum length supported by the database provider.
+
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to have the specified maximum length.
+
+
+ The maximum length for the property. Setting 'null' will result in a default length being used for the column.
+
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the column to be fixed length.
+ Use HasMaxLength to set the length that the property is fixed to.
+
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the column to be variable length.
+ Columns are variable length by default.
+
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the column to be optional.
+
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the column to be required.
+
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the data type of the database column.
+
+ Name of the database provider specific data type.
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the order of the database column.
+
+ The order that this column should appear in the database table.
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the column to support Unicode string content.
+
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures whether or not the column supports Unicode string content.
+
+ Value indicating if the column supports Unicode string content or not. Specifying 'null' will remove the Unicode facet from the column. Specifying 'null' will cause the same runtime behavior as specifying 'false'.
+ The same StringColumnConfiguration instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Configures a discriminator column used to differentiate between types in an inheritance hierarchy.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the discriminator value used to identify the entity type being
+ configured from other types in the inheritance hierarchy.
+
+ Type of the discriminator value.
+ The value to be used to identify the entity type.
+ A configuration object to configure the column used to store discriminator values.
+
+
+
+ Configures the discriminator value used to identify the entity type being
+ configured from other types in the inheritance hierarchy.
+
+ Type of the discriminator value.
+ The value to be used to identify the entity type.
+ A configuration object to configure the column used to store discriminator values.
+
+
+
+ Configures the discriminator value used to identify the entity type being
+ configured from other types in the inheritance hierarchy.
+
+ The value to be used to identify the entity type.
+ A configuration object to configure the column used to store discriminator values.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Configures a many relationship from an entity type.
+
+ The entity type that the relationship originates from.
+ The entity type that the relationship targets.
+
+
+
+ Configures the relationship to be many:many with a navigation property on the other side of the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be many:many without a navigation property on the other side of the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be many:required with a navigation property on the other side of the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be many:required without a navigation property on the other side of the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be many:optional with a navigation property on the other side of the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be many:optional without a navigation property on the other side of the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Configures an optional relationship from an entity type.
+
+ The entity type that the relationship originates from.
+ The entity type that the relationship targets.
+
+
+
+ Configures the relationship to be optional:many with a navigation property on the other side of the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be optional:many without a navigation property on the other side of the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be optional:required with a navigation property on the other side of the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be optional:required without a navigation property on the other side of the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be optional:optional with a navigation property on the other side of the relationship.
+ The entity type being configured will be the dependent and contain a foreign key to the principal.
+ The entity type that the relationship targets will be the principal in the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be optional:optional without a navigation property on the other side of the relationship.
+ The entity type being configured will be the dependent and contain a foreign key to the principal.
+ The entity type that the relationship targets will be the principal in the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be optional:optional with a navigation property on the other side of the relationship.
+ The entity type being configured will be the principal in the relationship.
+ The entity type that the relationship targets will be the dependent and contain a foreign key to the principal.
+
+ A lambda expression representing the navigation property on the other end of the relationship.
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be optional:optional without a navigation property on the other side of the relationship.
+ The entity type being configured will be the principal in the relationship.
+ The entity type that the relationship targets will be the dependent and contain a foreign key to the principal.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Configures an required relationship from an entity type.
+
+ The entity type that the relationship originates from.
+ The entity type that the relationship targets.
+
+
+
+ Configures the relationship to be required:many with a navigation property on the other side of the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be required:many without a navigation property on the other side of the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be required:optional with a navigation property on the other side of the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be required:optional without a navigation property on the other side of the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be required:required with a navigation property on the other side of the relationship.
+ The entity type being configured will be the dependent and contain a foreign key to the principal.
+ The entity type that the relationship targets will be the principal in the relationship.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be required:required without a navigation property on the other side of the relationship.
+ The entity type being configured will be the dependent and contain a foreign key to the principal.
+ The entity type that the relationship targets will be the principal in the relationship.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be required:required with a navigation property on the other side of the relationship.
+ The entity type being configured will be the principal in the relationship.
+ The entity type that the relationship targets will be the dependent and contain a foreign key to the principal.
+
+ An lambda expression representing the navigation property on the other end of the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures the relationship to be required:required without a navigation property on the other side of the relationship.
+ The entity type being configured will be the principal in the relationship.
+ The entity type that the relationship targets will be the dependent and contain a foreign key to the principal.
+
+ A configuration object that can be used to further configure the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Base class for performing configuration of a relationship.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures a relationship that can support cascade on delete functionality.
+
+
+
+
+ Configures cascade delete to be on for the relationship.
+
+
+
+
+ Configures whether or not cascade delete is on for the relationship.
+
+ Value indicating if cascade delete is on or not.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Configures a relationship that can support foreign key properties that are exposed in the object model.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+ The dependent entity type.
+
+
+
+ Configures a relationship that can only support foreign key properties that are not exposed in the object model.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the relationship to use foreign key property(s) that are not exposed in the object model.
+ The column(s) and table can be customized by specifying a configuration action.
+ If an empty configuration action is specified then column name(s) will be generated by convention.
+ If foreign key properties are exposed in the object model then use the HasForeignKey method.
+ Not all relationships support exposing foreign key properties in the object model.
+
+ Action that configures the foreign key column(s) and table.
+ A configuration object that can be used to further configure the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Configures the relationship to use foreign key property(s) that are exposed in the object model.
+ If the foreign key property(s) are not exposed in the object model then use the Map method.
+
+ The type of the key.
+ A lambda expression representing the property to be used as the foreign key. If the foreign key is made up of multiple properties then specify an anonymous type including the properties. When using multiple foreign key properties, the properties must be specified in the same order that the the primary key properties were configured for the principal entity type.
+ A configuration object that can be used to further configure the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Configures the table and column mapping of a relationship that does not expose foreign key properties in the object model.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the name of the column(s) for the foreign key.
+
+ The foreign key column names. When using multiple foreign key properties, the properties must be specified in the same order that the the primary key properties were configured for the target entity type.
+ The same ForeignKeyAssociationMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for a database column that has been configured with .
+ The annotation value can later be used when processing the column such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The name of the column that was configured with the HasKey method.
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same ForeignKeyAssociationMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the table name that the foreign key column(s) reside in.
+ The table that is specified must already be mapped for the entity type.
+ If you want the foreign key(s) to reside in their own table then use the Map method
+ on to perform
+ entity splitting to create the table with just the primary key property. Foreign keys can
+ then be added to the table via this method.
+
+ Name of the table.
+ The same ForeignKeyAssociationMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the table name and schema that the foreign key column(s) reside in.
+ The table that is specified must already be mapped for the entity type.
+ If you want the foreign key(s) to reside in their own table then use the Map method
+ on to perform
+ entity splitting to create the table with just the primary key property. Foreign keys can
+ then be added to the table via this method.
+
+ Name of the table.
+ Schema of the table.
+ The same ForeignKeyAssociationMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Configures the table and column mapping of a many:many relationship.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the join table name for the relationship.
+
+ Name of the table.
+ The same ManyToManyAssociationMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the join table name and schema for the relationship.
+
+ Name of the table.
+ Schema of the table.
+ The same ManyToManyAssociationMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the join table. The annotation value can later be used when
+ processing the table such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the column(s) for the left foreign key.
+ The left foreign key points to the parent entity of the navigation property specified in the HasMany call.
+
+ The foreign key column names. When using multiple foreign key properties, the properties must be specified in the same order that the the primary key properties were configured for the target entity type.
+ The same ManyToManyAssociationMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the column(s) for the right foreign key.
+ The right foreign key points to the parent entity of the the navigation property specified in the WithMany call.
+
+ The foreign key column names. When using multiple foreign key properties, the properties must be specified in the same order that the the primary key properties were configured for the target entity type.
+ The same ManyToManyAssociationMappingConfiguration instance so that multiple calls can be chained.
+
+
+
+
+
+ Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare with the current object.
+
+
+
+
+
+
+
+
+
+
+
+
+ Configures a many:many relationship.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+ The type of the parent entity of the navigation property specified in the HasMany call.
+ The type of the parent entity of the navigation property specified in the WithMany call.
+
+
+
+ Configures the foreign key column(s) and table used to store the relationship.
+
+ Action that configures the foreign key column(s) and table.
+ The same instance so that multiple calls can be chained.
+
+
+
+ Configures stored procedures to be used for modifying this relationship.
+ The default conventions for procedure and parameter names will be used.
+
+ The same instance so that multiple calls can be chained.
+
+
+
+ Configures stored procedures to be used for modifying this relationship.
+
+
+ Configuration to override the default conventions for procedure and parameter names.
+
+ The same instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Used to configure a property of an entity type or complex type.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Used to configure a property with length facets for an entity type or complex type.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Used to configure a primitive property of an entity type or complex type.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the property to be optional.
+ The database column used to store this property will be nullable.
+
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be required.
+ The database column used to store this property will be non-nullable.
+
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures how values for the property are generated by the database.
+
+
+ The pattern used to generate values for the property in the database.
+ Setting 'null' will cause the default option to be used, which may be 'None', 'Identity', or 'Computed' depending
+ on the type of the property, its semantics in the model (e.g. primary keys are treated differently), and which
+ set of conventions are being used.
+
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be used as an optimistic concurrency token.
+
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures whether or not the property is to be used as an optimistic concurrency token.
+
+ Value indicating if the property is a concurrency token or not. Specifying 'null' will remove the concurrency token facet from the property. Specifying 'null' will cause the same runtime behavior as specifying 'false'.
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the data type of the database column used to store the property.
+
+ Name of the database provider specific data type.
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the database column used to store the property.
+
+ The name of the column.
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the database column used to store the property. The annotation
+ value can later be used when processing the column such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the parameter used in stored procedures for this property.
+
+ Name of the parameter.
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the order of the database column used to store the property.
+ This method is also used to specify key ordering when an entity type has a composite key.
+
+ The order that this column should appear in the database table.
+ The same PrimitivePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+
+
+
+
+
+
+
+
+
+ Gets the of the current instance.
+
+ The exact runtime type of the current instance.
+
+
+
+ Configures the property to allow the maximum length supported by the database provider.
+
+ The same LengthPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to have the specified maximum length.
+
+ The maximum length for the property. Setting 'null' will remove any maximum length restriction from the property and a default length will be used for the database column.
+ The same LengthPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be fixed length.
+ Use HasMaxLength to set the length that the property is fixed to.
+
+ The same LengthPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be variable length.
+ Properties are variable length by default.
+
+ The same LengthPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to allow the maximum length supported by the database provider.
+
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to have the specified maximum length.
+
+ The maximum length for the property. Setting 'null' will remove any maximum length restriction from the property.
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be fixed length.
+ Use HasMaxLength to set the length that the property is fixed to.
+
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be variable length.
+ properties are variable length by default.
+
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be optional.
+ The database column used to store this property will be nullable.
+ properties are optional by default.
+
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be required.
+ The database column used to store this property will be non-nullable.
+
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures how values for the property are generated by the database.
+
+
+ The pattern used to generate values for the property in the database.
+ Setting 'null' will cause the default option to be used, which may be 'None', 'Identity', or 'Computed' depending
+ on the type of the property, its semantics in the model (e.g. primary keys are treated differently), and which
+ set of conventions are being used.
+
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be used as an optimistic concurrency token.
+
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures whether or not the property is to be used as an optimistic concurrency token.
+
+ Value indicating if the property is a concurrency token or not. Specifying 'null' will remove the concurrency token facet from the property. Specifying 'null' will cause the same runtime behavior as specifying 'false'.
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the database column used to store the property.
+
+ The name of the column.
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the database column used to store the property. The annotation
+ value can later be used when processing the column such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the data type of the database column used to store the property.
+
+ Name of the database provider specific data type.
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the order of the database column used to store the property.
+ This method is also used to specify key ordering when an entity type has a composite key.
+
+ The order that this column should appear in the database table.
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be a row version in the database.
+ The actual data type will vary depending on the database provider being used.
+ Setting the property to be a row version will automatically configure it to be an
+ optimistic concurrency token.
+
+ The same BinaryPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Used to configure a property of an entity type or complex type.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the property to be optional.
+ The database column used to store this property will be nullable.
+
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be required.
+ The database column used to store this property will be non-nullable.
+ properties are required by default.
+
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures how values for the property are generated by the database.
+
+
+ The pattern used to generate values for the property in the database.
+ Setting 'null' will cause the default option to be used, which may be 'None', 'Identity', or 'Computed' depending
+ on the type of the property, its semantics in the model (e.g. primary keys are treated differently), and which
+ set of conventions are being used.
+
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be used as an optimistic concurrency token.
+
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures whether or not the property is to be used as an optimistic concurrency token.
+
+ Value indicating if the property is a concurrency token or not. Specifying 'null' will remove the concurrency token facet from the property. Specifying 'null' will cause the same runtime behavior as specifying 'false'.
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the database column used to store the property.
+
+ The name of the column.
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the database column used to store the property. The annotation
+ value can later be used when processing the column such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the data type of the database column used to store the property.
+
+ Name of the database provider specific data type.
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the order of the database column used to store the property.
+ This method is also used to specify key ordering when an entity type has a composite key.
+
+ The order that this column should appear in the database table.
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the precision of the property.
+ If the database provider does not support precision for the data type of the column then the value is ignored.
+
+ Precision of the property.
+ The same DateTimePropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Used to configure a property of an entity type or complex type.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the property to be optional.
+ The database column used to store this property will be nullable.
+
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be required.
+ The database column used to store this property will be non-nullable.
+ properties are required by default.
+
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures how values for the property are generated by the database.
+
+
+ The pattern used to generate values for the property in the database.
+ Setting 'null' will cause the default option to be used, which may be 'None', 'Identity', or 'Computed' depending
+ on the type of the property, its semantics in the model (e.g. primary keys are treated differently), and which
+ set of conventions are being used.
+
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be used as an optimistic concurrency token.
+
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures whether or not the property is to be used as an optimistic concurrency token.
+
+ Value indicating if the property is a concurrency token or not. Specifying 'null' will remove the concurrency token facet from the property. Specifying 'null' will cause the same runtime behavior as specifying 'false'.
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the database column used to store the property.
+
+ The name of the column.
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the database column used to store the property. The annotation
+ value can later be used when processing the column such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the data type of the database column used to store the property.
+
+ Name of the database provider specific data type.
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the order of the database column used to store the property.
+ This method is also used to specify key ordering when an entity type has a composite key.
+
+ The order that this column should appear in the database table.
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the precision and scale of the property.
+
+ The precision of the property.
+ The scale of the property.
+ The same DecimalPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Used to configure a property of an entity type or complex type.
+ This configuration functionality is available via the Code First Fluent API, see .
+
+
+
+
+ Configures the property to allow the maximum length supported by the database provider.
+
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to have the specified maximum length.
+
+ The maximum length for the property. Setting 'null' will remove any maximum length restriction from the property and a default length will be used for the database column..
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be fixed length.
+ Use HasMaxLength to set the length that the property is fixed to.
+
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be variable length.
+ properties are variable length by default.
+
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be optional.
+ The database column used to store this property will be nullable.
+ properties are optional by default.
+
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be required.
+ The database column used to store this property will be non-nullable.
+
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures how values for the property are generated by the database.
+
+
+ The pattern used to generate values for the property in the database.
+ Setting 'null' will cause the default option to be used, which may be 'None', 'Identity', or 'Computed' depending
+ on the type of the property, its semantics in the model (e.g. primary keys are treated differently), and which
+ set of conventions are being used.
+
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to be used as an optimistic concurrency token.
+
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures whether or not the property is to be used as an optimistic concurrency token.
+
+ Value indicating if the property is a concurrency token or not. Specifying 'null' will remove the concurrency token facet from the property. Specifying 'null' will cause the same runtime behavior as specifying 'false'.
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the name of the database column used to store the property.
+
+ The name of the column.
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the database column used to store the property. The annotation
+ value can later be used when processing the column such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the data type of the database column used to store the property.
+
+ Name of the database provider specific data type.
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the order of the database column used to store the property.
+ This method is also used to specify key ordering when an entity type has a composite key.
+
+ The order that this column should appear in the database table.
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the property to support Unicode string content.
+
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures whether or not the property supports Unicode string content.
+
+ Value indicating if the property supports Unicode string content or not. Specifying 'null' will remove the Unicode facet from the property. Specifying 'null' will cause the same runtime behavior as specifying 'false'.
+ The same StringPropertyConfiguration instance so that multiple calls can be chained.
+
+
+
+ Convention to process instances of found on properties in the model
+
+
+
+
+
+
+
+ Convention to process instances of found on properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on foreign key properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on properties in the model.
+
+
+
+
+ Convention to process instances of found on properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on navigation properties in the model.
+
+
+
+
+ Convention to process instances of found on primitive properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on properties in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on types in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on types in the model.
+
+
+
+
+
+
+
+ Convention to process instances of found on types in the model.
+
+
+
+
+
+
+
+ Convention to detect navigation properties to be inverses of each other when only one pair
+ of navigation properties exists between the related types.
+
+
+
+
+
+
+
+ Convention to configure a type as a complex type if it has no primary key, no mapped base type and no navigation properties.
+
+
+
+
+
+
+
+ Convention to add a cascade delete to the join table from both tables involved in a many to many relationship.
+
+
+
+
+ Convention to ensure an invalid/unsupported mapping is not created when mapping inherited properties
+
+
+
+
+ Convention to set the table name to be a pluralized version of the entity type name.
+
+
+
+
+
+
+
+ Convention to set precision to 18 and scale to 2 for decimal properties.
+
+
+
+
+ Initializes a new instance of with the default precision and scale.
+
+
+
+
+ Initializes a new instance of with the specified precision and scale.
+
+ Precision
+ Scale
+
+
+
+
+
+
+ Convention to move primary key properties to appear first.
+
+
+
+
+
+
+
+ Convention to distinguish between optional and required relationships based on CLR nullability of the foreign key property.
+
+
+
+
+
+
+
+ Base class for conventions that discover foreign key properties.
+
+
+
+
+ When overriden returns true if should be part of the foreign key.
+
+ The association type being configured.
+ The dependent end.
+ The candidate property on the dependent end.
+ The principal end entity type.
+ A key property on the principal end that is a candidate target for the foreign key.
+ true if dependentProperty should be a part of the foreign key; otherwise, false.
+
+
+
+
+
+
+ Returns true if the convention supports pairs of entity types that have multiple associations defined between them.
+
+
+
+
+ Convention to process instances of found on navigation properties in the model.
+
+
+
+
+
+
+
+ Convention to detect primary key properties.
+ Recognized naming patterns in order of precedence are:
+ 1. 'Id'
+ 2. [type name]Id
+ Primary key detection is case insensitive.
+
+
+
+
+ Base class for conventions that discover primary key properties.
+
+
+
+
+
+
+
+ When overriden returns the subset of properties that will be part of the primary key.
+
+ The entity type.
+ The primitive types of the entities
+ The properties that should be part of the primary key.
+
+
+
+
+
+
+ Convention to discover foreign key properties whose names are a combination
+ of the dependent navigation property name and the principal type primary key property name(s).
+
+
+
+
+
+
+
+
+
+
+ Convention to enable cascade delete for any required relationships.
+
+
+
+
+
+
+
+ Convention to configure the primary key(s) of the dependent entity type as foreign key(s) in a one:one relationship.
+
+
+
+
+
+
+
+ Convention to set the entity set name to be a pluralized version of the entity type name.
+
+
+
+
+
+
+
+ Convention to discover foreign key properties whose names match the principal type primary key property name(s).
+
+
+
+
+
+
+
+ Convention to set a maximum length for properties whose type supports length facets. The default value is 128.
+
+
+
+
+ Initializes a new instance of with the default length.
+
+
+
+
+ Initializes a new instance of with the specified length.
+
+ The maximum lenght of properties.
+
+
+
+
+
+
+
+
+
+
+
+
+ Convention to set a default maximum length of 4000 for properties whose type supports length facets when SqlCe is the provider.
+
+
+
+
+ Initializes a new instance of with the default length.
+
+
+
+
+ Initializes a new instance of with the specified length.
+
+ The default maximum length for properties.
+
+
+
+
+
+
+
+
+
+ Convention to configure integer primary keys to be identity.
+
+
+
+
+
+
+
+ Convention to discover foreign key properties whose names are a combination
+ of the principal type name and the principal type primary key property name(s).
+
+
+
+
+
+
+
+ Allows configuration to be performed for an entity type in a model.
+ An EntityTypeConfiguration can be obtained via the Entity method on
+ or a custom type derived from EntityTypeConfiguration
+ can be registered via the Configurations property on .
+
+ The entity type being configured.
+
+
+
+ Initializes a new instance of EntityTypeConfiguration
+
+
+
+
+ Configures the primary key property(s) for this entity type.
+
+ The type of the key.
+ A lambda expression representing the property to be used as the primary key. C#: t => t.Id VB.Net: Function(t) t.Id If the primary key is made up of multiple properties then specify an anonymous type including the properties. C#: t => new { t.Id1, t.Id2 } VB.Net: Function(t) New With { t.Id1, t.Id2 }
+ The same EntityTypeConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the entity set name to be used for this entity type.
+ The entity set name can only be configured for the base type in each set.
+
+ The name of the entity set.
+ The same EntityTypeConfiguration instance so that multiple calls can be chained.
+
+
+
+ Excludes a property from the model so that it will not be mapped to the database.
+
+ The type of the property to be ignored.
+ A lambda expression representing the property to be configured. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ The same EntityTypeConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the table name that this entity type is mapped to.
+
+ The name of the table.
+ The same EntityTypeConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures the table name that this entity type is mapped to.
+
+ The name of the table.
+ The database schema of the table.
+ The same EntityTypeConfiguration instance so that multiple calls can be chained.
+
+
+
+ Sets an annotation in the model for the table to which this entity is mapped. The annotation
+ value can later be used when processing the table such as when creating migrations.
+
+
+ It will likely be necessary to register a if the type of
+ the annotation value is anything other than a string. Passing a null value clears any annotation with
+ the given name on the column that had been previously set.
+
+ The annotation name, which must be a valid C#/EDM identifier.
+ The annotation value, which may be a string or some other type that
+ can be serialized with an .
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures this type to use stored procedures for insert, update and delete.
+ The default conventions for procedure and parameter names will be used.
+
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Configures this type to use stored procedures for insert, update and delete.
+
+
+ Configuration to override the default conventions for procedure and parameter names.
+
+ The same configuration instance so that multiple calls can be chained.
+
+
+
+ Allows advanced configuration related to how this entity type is mapped to the database schema.
+ By default, any configuration will also apply to any type derived from this entity type.
+ Derived types can be configured via the overload of Map that configures a derived type or
+ by using an EntityTypeConfiguration for the derived type.
+ The properties of an entity can be split between multiple tables using multiple Map calls.
+ Calls to Map are additive, subsequent calls will not override configuration already preformed via Map.
+
+
+ An action that performs configuration against an
+
+ .
+
+ The same EntityTypeConfiguration instance so that multiple calls can be chained.
+
+
+
+ Allows advanced configuration related to how a derived entity type is mapped to the database schema.
+ Calls to Map are additive, subsequent calls will not override configuration already preformed via Map.
+
+ The derived entity type to be configured.
+
+ An action that performs configuration against an
+
+ .
+
+ The same EntityTypeConfiguration instance so that multiple calls can be chained.
+
+
+
+ Configures an optional relationship from this entity type.
+ Instances of the entity type will be able to be saved to the database without this relationship being specified.
+ The foreign key in the database will be nullable.
+
+ The type of the entity at the other end of the relationship.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures a required relationship from this entity type.
+ Instances of the entity type will not be able to be saved to the database unless this relationship is specified.
+ The foreign key in the database will be non-nullable.
+
+ The type of the entity at the other end of the relationship.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+ Configures a many relationship from this entity type.
+
+ The type of the entity at the other end of the relationship.
+ A lambda expression representing the navigation property for the relationship. C#: t => t.MyProperty VB.Net: Function(t) t.MyProperty
+ A configuration object that can be used to further configure the relationship.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Exception thrown by during model creation when an invalid model is generated.
+
+
+
+
+ Initializes a new instance of ModelValidationException
+
+
+
+
+ Initializes a new instance of ModelValidationException
+
+ The exception message.
+
+
+
+ Initializes a new instance of ModelValidationException
+
+ The exception message.
+ The inner exception.
+
+
+ Initializes a new instance of class serialization info and streaming context.
+ The serialization info.
+ The streaming context.
+
+
+
+ Exception thrown from when validating entities fails.
+
+
+
+
+ Initializes a new instance of DbEntityValidationException.
+
+
+
+
+ Initializes a new instance of DbEntityValidationException.
+
+ The exception message.
+
+
+
+ Initializes a new instance of DbEntityValidationException.
+
+ The exception message.
+ Validation results.
+
+
+
+ Initializes a new instance of DbEntityValidationException.
+
+ The exception message.
+ The inner exception.
+
+
+
+ Initializes a new instance of DbEntityValidationException.
+
+ The exception message.
+ Validation results.
+ The inner exception.
+
+
+
+ Validation results.
+
+
+
+
+ Represents validation results for single entity.
+
+
+
+
+ Creates an instance of class.
+
+ Entity entry the results applies to. Never null.
+
+ List of instances. Never null. Can be empty meaning the entity is valid.
+
+
+
+
+ Gets an instance of the results applies to.
+
+
+
+
+ Gets validation errors. Never null.
+
+
+
+
+ Gets an indicator if the entity is valid.
+
+
+
+
+ Exception thrown from when an exception is thrown from the validation
+ code.
+
+
+
+
+ Initializes a new instance of DbUnexpectedValidationException.
+
+
+
+
+ Initializes a new instance of DbUnexpectedValidationException.
+
+ The exception message.
+
+
+
+ Initializes a new instance of DbUnexpectedValidationException.
+
+ The exception message.
+ The inner exception.
+
+
+
+ Initializes a new instance of DbUnexpectedValidationException with the specified serialization info and
+ context.
+
+ The serialization info.
+ The streaming context.
+
+
+
+ Validation error. Can be either entity or property level validation error.
+
+
+
+
+ Creates an instance of .
+
+ Name of the invalid property. Can be null.
+ Validation error message. Can be null.
+
+
+
+ Gets name of the invalid property.
+
+
+
+
+ Gets validation error message.
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Core.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Core.dll
new file mode 100644
index 000000000..47ffda535
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Core.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Core.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Core.xml
new file mode 100644
index 000000000..f27dd0f38
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Core.xml
@@ -0,0 +1,2740 @@
+
+
+
+ Microsoft.AspNet.Identity.Core
+
+
+
+
+ Sync method to send the IdentityMessage
+
+
+
+
+
+
+ Expose a way to send messages (i.e. email/sms)
+
+
+
+
+ This method should send the message
+
+
+
+
+
+
+ Represents a message
+
+
+
+
+ Destination, i.e. To email, or SMS phone number
+
+
+
+
+ Subject
+
+
+
+
+ Message contents
+
+
+
+
+ Interface to generate user tokens
+
+
+
+
+ Generate a token for a user with a specific purpose
+
+
+
+
+
+
+
+
+ Validate a token for a user with a specific purpose
+
+
+
+
+
+
+
+
+
+ Notifies the user that a token has been generated, for example an email or sms could be sent, or
+ this can be a no-op
+
+
+
+
+
+
+
+
+ Returns true if provider can be used for this user, i.e. could require a user to have an email
+
+
+
+
+
+
+
+ Stores a user's phone number
+
+
+
+
+
+ Stores a user's phone number
+
+
+
+
+
+
+ Interface that exposes basic user management apis
+
+
+
+
+
+
+ Insert a new user
+
+
+
+
+
+
+ Update a user
+
+
+
+
+
+
+ Delete a user
+
+
+
+
+
+
+ Finds a user
+
+
+
+
+
+
+ Find a user by name
+
+
+
+
+
+
+ Set the user's phone number
+
+
+
+
+
+
+
+ Get the user phone number
+
+
+
+
+
+
+ Returns true if the user phone number is confirmed
+
+
+
+
+
+
+ Sets whether the user phone number is confirmed
+
+
+
+
+
+
+
+ Stores information which can be used to implement account lockout, including access failures and lockout status
+
+
+
+
+
+
+ Returns the DateTimeOffset that represents the end of a user's lockout, any time in the past should be considered
+ not locked out.
+
+
+
+
+
+
+ Locks a user out until the specified end date (set to a past date, to unlock a user)
+
+
+
+
+
+
+
+ Used to record when an attempt to access the user has failed
+
+
+
+
+
+
+ Used to reset the access failed count, typically after the account is successfully accessed
+
+
+
+
+
+
+ Returns the current number of failed access attempts. This number usually will be reset whenever the password is
+ verified or the account is locked out.
+
+
+
+
+
+
+ Returns whether the user can be locked out.
+
+
+
+
+
+
+ Sets whether the user can be locked out.
+
+
+
+
+
+
+
+ Stores whether two factor authentication is enabled for a user
+
+
+
+
+
+
+ Sets whether two factor authentication is enabled for the user
+
+
+
+
+
+
+
+ Returns whether two factor authentication is enabled for the user
+
+
+
+
+
+
+ Stores a user's email
+
+
+
+
+
+ Stores a user's email
+
+
+
+
+
+
+ Set the user email
+
+
+
+
+
+
+
+ Get the user email
+
+
+
+
+
+
+ Returns true if the user email is confirmed
+
+
+
+
+
+
+ Sets whether the user email is confirmed
+
+
+
+
+
+
+
+ Returns the user associated with this email
+
+
+
+
+
+
+ Interface that exposes an IQueryable roles
+
+
+
+
+
+ Interface that exposes an IQueryable roles
+
+
+
+
+
+
+ Interface that exposes basic role management
+
+
+
+
+
+
+ Create a new role
+
+
+
+
+
+
+ Update a role
+
+
+
+
+
+
+ Delete a role
+
+
+
+
+
+
+ Find a role by id
+
+
+
+
+
+
+ Find a role by name
+
+
+
+
+
+
+ IQueryable Roles
+
+
+
+
+ Interface that exposes an IQueryable users
+
+
+
+
+
+ Interface that exposes an IQueryable users
+
+
+
+
+
+
+ IQueryable users
+
+
+
+
+ Stores a user's security stamp
+
+
+
+
+
+ Stores a user's security stamp
+
+
+
+
+
+
+ Set the security stamp for the user
+
+
+
+
+
+
+
+ Get the user security stamp
+
+
+
+
+
+
+ Interface for creating a ClaimsIdentity from an IUser
+
+
+
+
+
+
+ Create a ClaimsIdentity from an user using a UserManager
+
+
+
+
+
+
+
+
+ Interface for creating a ClaimsIdentity from a user
+
+
+
+
+
+ Create a ClaimsIdentity from an user using a UserManager
+
+
+
+
+
+
+
+
+ Extension methods for RoleManager
+
+
+
+
+ Find a role by id
+
+
+
+
+
+
+
+ Find a role by name
+
+
+
+
+
+
+
+ Create a role
+
+
+
+
+
+
+
+ Update an existing role
+
+
+
+
+
+
+
+ Delete a role
+
+
+
+
+
+
+
+ Returns true if the role exists
+
+
+
+
+
+
+
+ Stores a user's password hash
+
+
+
+
+
+ Stores a user's password hash
+
+
+
+
+
+
+ Set the user password hash
+
+
+
+
+
+
+
+ Get the user password hash
+
+
+
+
+
+
+ Returns true if a user has a password set
+
+
+
+
+
+
+ Used to validate some basic password policy like length and number of non alphanumerics
+
+
+
+
+ Used to validate an item
+
+
+
+
+
+ Validate the item
+
+
+
+
+
+
+ Ensures that the string is of the required length and meets the configured requirements
+
+
+
+
+
+
+ Returns true if the character is a digit between '0' and '9'
+
+
+
+
+
+
+ Returns true if the character is between 'a' and 'z'
+
+
+
+
+
+
+ Returns true if the character is between 'A' and 'Z'
+
+
+
+
+
+
+ Returns true if the character is upper, lower, or a digit
+
+
+
+
+
+
+ Minimum required length
+
+
+
+
+ Require a non letter or digit character
+
+
+
+
+ Require a lower case letter ('a' - 'z')
+
+
+
+
+ Require an upper case letter ('A' - 'Z')
+
+
+
+
+ Require a digit ('0' - '9')
+
+
+
+
+ Return result for IPasswordHasher
+
+
+
+
+ Password verification failed
+
+
+
+
+ Success
+
+
+
+
+ Success but should update and rehash the password
+
+
+
+
+ TokenProvider that generates tokens from the user's security stamp and notifies a user via their email
+
+
+
+
+
+ TokenProvider that generates tokens from the user's security stamp and notifies a user via their email
+
+
+
+
+
+
+ TokenProvider that generates time based codes using the user's security stamp
+
+
+
+
+
+
+ This token provider does not notify the user by default
+
+
+
+
+
+
+
+
+ Returns true if the provider can generate tokens for the user, by default this is equal to
+ manager.SupportsUserSecurityStamp
+
+
+
+
+
+
+
+ Generate a token for the user using their security stamp
+
+
+
+
+
+
+
+
+ Validate the token for the user
+
+
+
+
+
+
+
+
+
+ Used for entropy in the token, uses the user.Id by default
+
+
+
+
+
+
+
+
+ True if the user has an email set
+
+
+
+
+
+
+
+ Returns the email of the user for entropy in the token
+
+
+
+
+
+
+
+
+ Notifies the user with a token via email using the Subject and BodyFormat
+
+
+
+
+
+
+
+
+ Email subject used when a token notification is received
+
+
+
+
+ Email body which should contain a formatted string which the token will be the only argument
+
+
+
+
+ TokenProvider that generates tokens from the user's security stamp and notifies a user via their phone number
+
+
+
+
+
+ TokenProvider that generates tokens from the user's security stamp and notifies a user via their phone number
+
+
+
+
+
+
+ Returns true if the user has a phone number set
+
+
+
+
+
+
+
+ Returns the phone number of the user for entropy in the token
+
+
+
+
+
+
+
+
+ Notifies the user with a token via sms using the MessageFormat
+
+
+
+
+
+
+
+
+ Message contents which should contain a format string which the token will be the only argument
+
+
+
+
+ Validates roles before they are saved
+
+
+
+
+
+ Validates roles before they are saved
+
+
+
+
+
+
+ Constructor
+
+
+
+
+
+ Validates a role before saving
+
+
+
+
+
+
+ Constructor
+
+
+
+
+
+ Interface that exposes basic role management
+
+
+
+
+
+ Exposes role related api which will automatically save changes to the RoleStore
+
+
+
+
+
+ Exposes role related api which will automatically save changes to the RoleStore
+
+
+
+
+
+
+ Constructor
+
+ The IRoleStore is responsible for commiting changes via the UpdateAsync/CreateAsync methods
+
+
+
+ Dispose this object
+
+
+
+
+ Create a role
+
+
+
+
+
+
+ Update an existing role
+
+
+
+
+
+
+ Delete a role
+
+
+
+
+
+
+ Returns true if the role exists
+
+
+
+
+
+
+ Find a role by id
+
+
+
+
+
+
+ Find a role by name
+
+
+
+
+
+
+ When disposing, actually dipose the store
+
+
+
+
+
+ Persistence abstraction that the Manager operates against
+
+
+
+
+ Used to validate roles before persisting changes
+
+
+
+
+ Returns an IQueryable of roles if the store is an IQueryableRoleStore
+
+
+
+
+ Constructor
+
+
+
+
+
+ Interface that maps users to their roles
+
+
+
+
+
+ Interface that maps users to their roles
+
+
+
+
+
+
+ Adds a user to a role
+
+
+
+
+
+
+
+ Removes the role for the user
+
+
+
+
+
+
+
+ Returns the roles for this user
+
+
+
+
+
+
+ Returns true if a user is in the role
+
+
+
+
+
+
+
+ Default authentication types values
+
+
+
+
+ Default value for the main application cookie used by UseSignInCookies
+
+
+
+
+ Default value used for the ExternalSignInAuthenticationType configured by UseSignInCookies
+
+
+
+
+ Default value used by the UseOAuthBearerTokens method
+
+
+
+
+ Default value for authentication type used for two factor partial sign in
+
+
+
+
+ Default value for authentication type used for two factor remember browser
+
+
+
+
+ Extensions making it easier to get the user name/user id claims off of an identity
+
+
+
+
+ Return the user name using the UserNameClaimType
+
+
+
+
+
+
+ Return the user id using the UserIdClaimType
+
+
+
+
+
+
+
+ Return the user id using the UserIdClaimType
+
+
+
+
+
+
+ Return the claim value for the first claim with the specified type if it exists, null otherwise
+
+
+
+
+
+
+
+ Extension methods for UserManager
+
+
+
+
+ Creates a ClaimsIdentity representing the user
+
+
+
+
+
+
+
+
+ Find a user by id
+
+
+
+
+
+
+
+ Return a user with the specified username and password or null if there is no match.
+
+
+
+
+
+
+
+
+ Find a user by name
+
+
+
+
+
+
+
+ Find a user by email
+
+
+
+
+
+
+
+ Create a user with no password
+
+
+
+
+
+
+
+ Create a user and associates it with the given password (if one is provided)
+
+
+
+
+
+
+
+
+ Update an user
+
+
+
+
+
+
+
+ Delete an user
+
+
+
+
+
+
+
+ Returns true if a user has a password set
+
+
+
+
+
+
+
+ Add a user password only if one does not already exist
+
+
+
+
+
+
+
+
+ Change a user password
+
+
+
+
+
+
+
+
+
+ Reset a user's password using a reset password token
+
+
+
+ This should be the user's security stamp by default
+
+
+
+
+
+ Get the password reset token for the user
+
+
+
+
+
+
+
+ Get the current security stamp for a user
+
+
+
+
+
+
+
+ Get the confirmation token for the user
+
+
+
+
+
+
+
+ Confirm the user with confirmation token
+
+
+
+
+
+
+
+
+ Returns true if the user's email has been confirmed
+
+
+
+
+
+
+
+ Generate a new security stamp for a user, used for SignOutEverywhere functionality
+
+
+
+
+
+
+
+ Returns true if the password combination is valid for the user
+
+
+
+
+
+
+
+
+ Associate a login with a user
+
+
+
+
+
+
+
+ Sync extension
+
+
+
+
+
+
+
+
+ Remove a user login
+
+
+
+
+
+
+
+
+ Gets the logins for a user.
+
+
+
+
+
+
+
+ Sync extension
+
+
+
+
+
+
+
+ Add a user claim
+
+
+
+
+
+
+
+
+ Remove a user claim
+
+
+
+
+
+
+
+
+ Get a users's claims
+
+
+
+
+
+
+
+ Add a user to a role
+
+
+
+
+
+
+
+
+ Add a user to several roles
+
+
+
+
+
+
+
+
+ Remove a user from a role.
+
+
+
+
+
+
+
+
+ Remove a user from the specified roles.
+
+
+
+
+
+
+
+
+ Get a users's roles
+
+
+
+
+
+
+
+ Returns true if the user is in the specified role
+
+
+
+
+
+
+
+
+ Get an user's email
+
+
+
+
+
+
+
+ Set an user's email
+
+
+
+
+
+
+
+
+ Get an user's phoneNumber
+
+
+
+
+
+
+
+ Set an user's phoneNumber
+
+
+
+
+
+
+
+
+ Change a phone number using the verification token
+
+
+
+
+
+
+
+
+
+
+
+ Generate a token for using to change to a specific phone number for the user
+
+
+
+
+
+
+
+
+
+
+ Verify that a token is valid for changing the user's phone number
+
+
+
+
+
+
+
+
+
+
+
+ Returns true if the user's phone number has been confirmed
+
+
+
+
+
+
+
+ Get a user token for a factor provider
+
+
+
+
+
+
+
+
+
+
+ Verify a user factor token with the specified provider
+
+
+
+
+
+
+
+
+
+
+
+ Returns a list of valid two factor providers for a user
+
+
+
+
+
+
+
+
+
+ Get a user token for a specific purpose
+
+
+
+
+
+
+
+
+ Validate a user token
+
+
+
+
+
+
+
+
+
+
+
+ Notify a user with a token from a specific user factor provider
+
+
+
+
+
+
+
+
+
+ Returns true if two factor is enabled for the user
+
+
+
+
+
+
+
+ Set whether a user's two factor is enabled
+
+
+
+
+
+
+
+
+
+
+ Send email with supplied subject and body
+
+
+
+
+
+
+
+
+
+
+ Send text message using the given message
+
+
+
+
+
+
+
+
+
+ Returns true if the user is locked out
+
+
+
+
+
+
+
+ Sets whether the user allows lockout
+
+
+
+
+
+
+
+
+ Returns whether the user allows lockout
+
+
+
+
+
+
+
+ Returns the user lockout end date
+
+
+
+
+
+
+
+ Sets the user lockout end date
+
+
+
+
+
+
+
+
+ Increments the access failed count for the user
+
+
+
+
+
+
+
+ Resets the access failed count for the user to 0
+
+
+
+
+
+
+
+ Returns the number of failed access attempts for the user
+
+
+
+
+
+
+
+ Constants class
+
+
+
+
+ ClaimType used for the security stamp by default
+
+
+
+
+ Creates a ClaimsIdentity from a User
+
+
+
+
+
+ Creates a ClaimsIdentity from a User
+
+
+
+
+
+
+ Constructor
+
+
+
+
+ Create a ClaimsIdentity from a user
+
+
+
+
+
+
+
+
+ Convert the key to a string, by default just calls .ToString()
+
+
+
+
+
+
+ Claim type used for role claims
+
+
+
+
+ Claim type used for the user name
+
+
+
+
+ Claim type used for the user id
+
+
+
+
+ Claim type used for the user security stamp
+
+
+
+
+ Stores user specific claims
+
+
+
+
+
+ Stores user specific claims
+
+
+
+
+
+
+ Returns the claims for the user with the issuer set
+
+
+
+
+
+
+ Add a new user claim
+
+
+
+
+
+
+
+ Remove a user claim
+
+
+
+
+
+
+
+ Interface that maps users to login providers, i.e. Google, Facebook, Twitter, Microsoft
+
+
+
+
+
+ Interface that maps users to login providers, i.e. Google, Facebook, Twitter, Microsoft
+
+
+
+
+
+
+ Adds a user login with the specified provider and key
+
+
+
+
+
+
+
+ Removes the user login with the specified combination if it exists
+
+
+
+
+
+
+
+ Returns the linked accounts for this user
+
+
+
+
+
+
+ Returns the user associated with this login
+
+
+
+
+
+ Abstraction for password hashing methods
+
+
+
+
+ Hash a password
+
+
+
+
+
+
+ Verify that a password matches the hashed password
+
+
+
+
+
+
+
+ Interface that exposes basic user management apis
+
+
+
+
+
+ Implements password hashing methods
+
+
+
+
+ Hash a password
+
+
+
+
+
+
+ Verify that a password matches the hashedPassword
+
+
+
+
+
+
+
+ Used to validate that passwords are a minimum length
+
+
+
+
+ Constructor
+
+
+
+
+
+ Ensures that the password is of the required length
+
+
+
+
+
+
+ Minimum required length for the password
+
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to An unknown failure has occured..
+
+
+
+
+ Looks up a localized string similar to Email '{0}' is already taken..
+
+
+
+
+ Looks up a localized string similar to Name {0} is already taken..
+
+
+
+
+ Looks up a localized string similar to A user with that external login already exists..
+
+
+
+
+ Looks up a localized string similar to Email '{0}' is invalid..
+
+
+
+
+ Looks up a localized string similar to Invalid token..
+
+
+
+
+ Looks up a localized string similar to User name {0} is invalid, can only contain letters or digits..
+
+
+
+
+ Looks up a localized string similar to Lockout is not enabled for this user..
+
+
+
+
+ Looks up a localized string similar to No IUserTokenProvider is registered..
+
+
+
+
+ Looks up a localized string similar to No IUserTwoFactorProvider for '{0}' is registered..
+
+
+
+
+ Looks up a localized string similar to Incorrect password..
+
+
+
+
+ Looks up a localized string similar to Passwords must have at least one digit ('0'-'9')..
+
+
+
+
+ Looks up a localized string similar to Passwords must have at least one lowercase ('a'-'z')..
+
+
+
+
+ Looks up a localized string similar to Passwords must have at least one non letter or digit character..
+
+
+
+
+ Looks up a localized string similar to Passwords must have at least one uppercase ('A'-'Z')..
+
+
+
+
+ Looks up a localized string similar to Passwords must be at least {0} characters..
+
+
+
+
+ Looks up a localized string similar to {0} cannot be null or empty..
+
+
+
+
+ Looks up a localized string similar to Role {0} does not exist..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IQueryableRoleStore<TRole>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IQueryableUserStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserClaimStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserConfirmationStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserEmailStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserLockoutStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserLoginStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserPasswordStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserPhoneNumberStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserRoleStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserSecurityStampStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to Store does not implement IUserTwoFactorStore<TUser>..
+
+
+
+
+ Looks up a localized string similar to User already has a password set..
+
+
+
+
+ Looks up a localized string similar to User already in role..
+
+
+
+
+ Looks up a localized string similar to UserId not found..
+
+
+
+
+ Looks up a localized string similar to User {0} does not exist..
+
+
+
+
+ Looks up a localized string similar to User is not in role..
+
+
+
+
+ Represents the result of an identity operation
+
+
+
+
+ Failure constructor that takes error messages
+
+
+
+
+
+ Failure constructor that takes error messages
+
+
+
+
+
+ Constructor that takes whether the result is successful
+
+
+
+
+
+ Failed helper method
+
+
+
+
+
+
+ True if the operation was successful
+
+
+
+
+ List of errors
+
+
+
+
+ Static success result
+
+
+
+
+
+ Mimimal set of data needed to persist role information
+
+
+
+
+ Mimimal set of data needed to persist role information
+
+
+
+
+
+ Id of the role
+
+
+
+
+ Name of the role
+
+
+
+
+ Represents a linked login for a user (i.e. a facebook/google account)
+
+
+
+
+ Constructor
+
+
+
+
+
+
+ Provider for the linked login, i.e. Facebook, Google, etc.
+
+
+
+
+ User specific key for the login provider
+
+
+
+
+ Minimal interface for a user with id and username
+
+
+
+
+ Minimal interface for a user with id and username
+
+
+
+
+
+ Unique key for the user
+
+
+
+
+ Unique username
+
+
+
+
+ UserManager for users where the primary key for the User is of type string
+
+
+
+
+
+ Exposes user related api which will automatically save changes to the UserStore
+
+
+
+
+
+
+ Constructor
+
+ The IUserStore is responsible for commiting changes via the UpdateAsync/CreateAsync methods
+
+
+
+ Dispose this object
+
+
+
+
+ Creates a ClaimsIdentity representing the user
+
+
+
+
+
+
+
+ Create a user with no password
+
+
+
+
+
+
+ Update a user
+
+
+
+
+
+
+ Delete a user
+
+
+
+
+
+
+ Find a user by id
+
+
+
+
+
+
+ Find a user by user name
+
+
+
+
+
+
+ Create a user with the given password
+
+
+
+
+
+
+
+ Return a user with the specified username and password or null if there is no match.
+
+
+
+
+
+
+
+ Returns true if the password is valid for the user
+
+
+
+
+
+
+
+ Returns true if the user has a password
+
+
+
+
+
+
+ Add a user password only if one does not already exist
+
+
+
+
+
+
+
+ Change a user password
+
+
+
+
+
+
+
+
+ Remove a user's password
+
+
+
+
+
+
+ By default, retrieves the hashed password from the user store and calls PasswordHasher.VerifyHashPassword
+
+
+
+
+
+
+
+
+ Returns the current security stamp for a user
+
+
+
+
+
+
+ Generate a new security stamp for a user, used for SignOutEverywhere functionality
+
+
+
+
+
+
+ Generate a password reset token for the user using the UserTokenProvider
+
+
+
+
+
+
+ Reset a user's password using a reset password token
+
+
+
+
+
+
+
+
+ Returns the user associated with this login
+
+
+
+
+
+ Remove a user login
+
+
+
+
+
+
+
+ Associate a login with a user
+
+
+
+
+
+
+
+ Gets the logins for a user.
+
+
+
+
+
+
+ Add a user claim
+
+
+
+
+
+
+
+ Remove a user claim
+
+
+
+
+
+
+
+ Get a users's claims
+
+
+
+
+
+
+ Add a user to a role
+
+
+
+
+
+
+
+ Method to add user to multiple roles
+
+ user id
+ list of role names
+
+
+
+
+ Remove user from multiple roles
+
+ user id
+ list of role names
+
+
+
+
+ Remove a user from a role.
+
+
+
+
+
+
+
+ Returns the roles for the user
+
+
+
+
+
+
+ Returns true if the user is in the specified role
+
+
+
+
+
+
+
+ Get a user's email
+
+
+
+
+
+
+ Set a user's email
+
+
+
+
+
+
+
+ Find a user by his email
+
+
+
+
+
+
+ Get the email confirmation token for the user
+
+
+
+
+
+
+ Confirm the user's email with confirmation token
+
+
+
+
+
+
+
+ Returns true if the user's email has been confirmed
+
+
+
+
+
+
+ Get a user's phoneNumber
+
+
+
+
+
+
+ Set a user's phoneNumber
+
+
+
+
+
+
+
+ Set a user's phoneNumber with the verification token
+
+
+
+
+
+
+
+
+ Returns true if the user's phone number has been confirmed
+
+
+
+
+
+
+ Generate a code that the user can use to change their phone number to a specific number
+
+
+
+
+
+
+
+ Verify the code is valid for a specific user and for a specific phone number
+
+
+
+
+
+
+
+
+ Verify a user token with the specified purpose
+
+
+
+
+
+
+
+
+ Get a user token for a specific purpose
+
+
+
+
+
+
+
+ Register a two factor authentication provider with the TwoFactorProviders mapping
+
+
+
+
+
+
+ Returns a list of valid two factor providers for a user
+
+
+
+
+
+
+ Verify a two factor token with the specified provider
+
+
+
+
+
+
+
+
+ Get a token for a specific two factor provider
+
+
+
+
+
+
+
+ Notify a user with a token using a specific two-factor authentication provider's Notify method
+
+
+
+
+
+
+
+
+ Get whether two factor authentication is enabled for a user
+
+
+
+
+
+
+ Set whether a user has two factor authentication enabled
+
+
+
+
+
+
+
+ Send an email to the user
+
+
+
+
+
+
+
+
+ Send a user a sms message
+
+
+
+
+
+
+
+ Returns true if the user is locked out
+
+
+
+
+
+
+ Sets whether lockout is enabled for this user
+
+
+
+
+
+
+
+ Returns whether lockout is enabled for the user
+
+
+
+
+
+
+ Returns when the user is no longer locked out, dates in the past are considered as not being locked out
+
+
+
+
+
+
+ Sets the when a user lockout ends
+
+
+
+
+
+
+
+ Increments the access failed count for the user and if the failed access account is greater than or equal
+ to the MaxFailedAccessAttempsBeforeLockout, the user will be locked out for the next DefaultAccountLockoutTimeSpan
+ and the AccessFailedCount will be reset to 0. This is used for locking out the user account.
+
+
+
+
+
+
+ Resets the access failed count for the user to 0
+
+
+
+
+
+
+ Returns the number of failed access attempts for the user
+
+
+
+
+
+
+ When disposing, actually dipose the store
+
+
+
+
+
+ Persistence abstraction that the UserManager operates against
+
+
+
+
+ Used to hash/verify passwords
+
+
+
+
+ Used to validate users before changes are saved
+
+
+
+
+ Used to validate passwords before persisting changes
+
+
+
+
+ Used to create claims identities from users
+
+
+
+
+ Used to send email
+
+
+
+
+ Used to send a sms message
+
+
+
+
+ Used for generating reset password and confirmation tokens
+
+
+
+
+ If true, will enable user lockout when users are created
+
+
+
+
+ Number of access attempts allowed before a user is locked out (if lockout is enabled)
+
+
+
+
+ Default amount of time that a user is locked out for after MaxFailedAccessAttemptsBeforeLockout is reached
+
+
+
+
+ Returns true if the store is an IUserTwoFactorStore
+
+
+
+
+ Returns true if the store is an IUserPasswordStore
+
+
+
+
+ Returns true if the store is an IUserSecurityStore
+
+
+
+
+ Returns true if the store is an IUserRoleStore
+
+
+
+
+ Returns true if the store is an IUserLoginStore
+
+
+
+
+ Returns true if the store is an IUserEmailStore
+
+
+
+
+ Returns true if the store is an IUserPhoneNumberStore
+
+
+
+
+ Returns true if the store is an IUserClaimStore
+
+
+
+
+ Returns true if the store is an IUserLockoutStore
+
+
+
+
+ Returns true if the store is an IQueryableUserStore
+
+
+
+
+ Returns an IQueryable of users if the store is an IQueryableUserStore
+
+
+
+
+ Maps the registered two-factor authentication providers for users by their id
+
+
+
+
+ Constructor
+
+
+
+
+
+ Validates users before they are saved
+
+
+
+
+
+ Validates users before they are saved
+
+
+
+
+
+
+ Constructor
+
+
+
+
+
+ Validates a user before saving
+
+
+
+
+
+
+ Only allow [A-Za-z0-9@_] in UserNames
+
+
+
+
+ If set, enforces that emails are non empty, valid, and unique
+
+
+
+
+ Constructor
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.EntityFramework.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.EntityFramework.dll
new file mode 100644
index 000000000..f84a693ad
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.EntityFramework.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.EntityFramework.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.EntityFramework.xml
new file mode 100644
index 000000000..bce091d7e
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.EntityFramework.xml
@@ -0,0 +1,1064 @@
+
+
+
+ Microsoft.AspNet.Identity.EntityFramework
+
+
+
+
+ EntityFramework based implementation
+
+
+
+
+
+ EntityFramework based implementation
+
+
+
+
+
+
+
+ Constructor which takes a db context and wires up the stores with default instances using the context
+
+
+
+
+
+ Find a role by id
+
+
+
+
+
+
+ Find a role by name
+
+
+
+
+
+
+ Insert an entity
+
+
+
+
+
+ Mark an entity for deletion
+
+
+
+
+
+ Update an entity
+
+
+
+
+
+ Dispose the store
+
+
+
+
+ If disposing, calls dispose on the Context. Always nulls out the Context
+
+
+
+
+
+ Context for the store
+
+
+
+
+ If true will call dispose on the DbContext during Dipose
+
+
+
+
+ Returns an IQueryable of users
+
+
+
+
+ Constructor
+
+
+
+
+ Constructor
+
+
+
+
+
+ EntityFramework based user store implementation that supports IUserStore, IUserLoginStore, IUserClaimStore and
+ IUserRoleStore
+
+
+
+
+
+ EntityFramework based user store implementation that supports IUserStore, IUserLoginStore, IUserClaimStore and
+ IUserRoleStore
+
+
+
+
+
+
+
+
+
+
+ Constructor which takes a db context and wires up the stores with default instances using the context
+
+
+
+
+
+ Return the claims for a user
+
+
+
+
+
+
+ Add a claim to a user
+
+
+
+
+
+
+
+ Remove a claim from a user
+
+
+
+
+
+
+
+ Returns whether the user email is confirmed
+
+
+
+
+
+
+ Set IsConfirmed on the user
+
+
+
+
+
+
+
+ Set the user email
+
+
+
+
+
+
+
+ Get the user's email
+
+
+
+
+
+
+ Find a user by email
+
+
+
+
+
+
+ Returns the DateTimeOffset that represents the end of a user's lockout, any time in the past should be considered
+ not locked out.
+
+
+
+
+
+
+ Locks a user out until the specified end date (set to a past date, to unlock a user)
+
+
+
+
+
+
+
+ Used to record when an attempt to access the user has failed
+
+
+
+
+
+
+ Used to reset the account access count, typically after the account is successfully accessed
+
+
+
+
+
+
+ Returns the current number of failed access attempts. This number usually will be reset whenever the password is
+ verified or the account is locked out.
+
+
+
+
+
+
+ Returns whether the user can be locked out.
+
+
+
+
+
+
+ Sets whether the user can be locked out.
+
+
+
+
+
+
+
+ Find a user by id
+
+
+
+
+
+
+ Find a user by name
+
+
+
+
+
+
+ Insert an entity
+
+
+
+
+
+ Mark an entity for deletion
+
+
+
+
+
+ Update an entity
+
+
+
+
+
+ Dispose the store
+
+
+
+
+ Returns the user associated with this login
+
+
+
+
+
+ Add a login to the user
+
+
+
+
+
+
+
+ Remove a login from a user
+
+
+
+
+
+
+
+ Get the logins for a user
+
+
+
+
+
+
+ Set the password hash for a user
+
+
+
+
+
+
+
+ Get the password hash for a user
+
+
+
+
+
+
+ Returns true if the user has a password set
+
+
+
+
+
+
+ Set the user's phone number
+
+
+
+
+
+
+
+ Get a user's phone number
+
+
+
+
+
+
+ Returns whether the user phoneNumber is confirmed
+
+
+
+
+
+
+ Set PhoneNumberConfirmed on the user
+
+
+
+
+
+
+
+ Add a user to a role
+
+
+
+
+
+
+
+ Remove a user from a role
+
+
+
+
+
+
+
+ Get the names of the roles a user is a member of
+
+
+
+
+
+
+ Returns true if the user is in the named role
+
+
+
+
+
+
+
+ Set the security stamp for the user
+
+
+
+
+
+
+
+ Get the security stamp for a user
+
+
+
+
+
+
+ Set whether two factor authentication is enabled for the user
+
+
+
+
+
+
+
+ Gets whether two factor authentication is enabled for the user
+
+
+
+
+
+
+ Used to attach child entities to the User aggregate, i.e. Roles, Logins, and Claims
+
+
+
+
+
+
+ If disposing, calls dispose on the Context. Always nulls out the Context
+
+
+
+
+
+ Context for the store
+
+
+
+
+ If true will call dispose on the DbContext during Dispose
+
+
+
+
+ If true will call SaveChanges after Create/Update/Delete
+
+
+
+
+ Returns an IQueryable of users
+
+
+
+
+ Default constuctor which uses a new instance of a default EntityyDbContext
+
+
+
+
+ Constructor
+
+
+
+
+
+ EntityType that represents a user belonging to a role
+
+
+
+
+ EntityType that represents a user belonging to a role
+
+
+
+
+
+ UserId for the user that is in the role
+
+
+
+
+ RoleId for the role
+
+
+
+
+ EntityFramework based IIdentityEntityStore that allows query/manipulation of a TEntity set
+
+ Concrete entity type, i.e .User
+
+
+
+ Constructor that takes a Context
+
+
+
+
+
+ FindAsync an entity by ID
+
+
+
+
+
+
+ Insert an entity
+
+
+
+
+
+ Mark an entity for deletion
+
+
+
+
+
+ Update an entity
+
+
+
+
+
+ Context for the store
+
+
+
+
+ Used to query the entities
+
+
+
+
+ EntitySet for this store
+
+
+
+
+ Default IdentityDbContext that uses the default entity types for ASP.NET Identity Users, Roles, Claims, Logins.
+ Use this overload to add your own entity types.
+
+
+
+
+ Generic IdentityDbContext base that can be customized with entity types that extend from the base IdentityUserXXX types.
+
+
+
+
+
+
+
+
+
+
+ Default constructor which uses the "DefaultConnection" connectionString
+
+
+
+
+ Constructor which takes the connection string to use
+
+
+
+
+
+ Constructs a new context instance using the existing connection to connect to a database, and initializes it from
+ the given model. The connection will not be disposed when the context is disposed if contextOwnsConnection is
+ false.
+
+ An existing connection to use for the new context.
+ The model that will back this context.
+
+ Constructs a new context instance using the existing connection to connect to a
+ database, and initializes it from the given model. The connection will not be disposed when the context is
+ disposed if contextOwnsConnection is false.
+
+
+
+
+ Constructs a new context instance using conventions to create the name of
+ the database to which a connection will be made, and initializes it from
+ the given model. The by-convention name is the full name (namespace + class
+ name) of the derived context class. See the class remarks for how this is
+ used to create a connection.
+
+ The model that will back this context.
+
+
+
+ Constructs a new context instance using the existing connection to connect
+ to a database. The connection will not be disposed when the context is disposed
+ if contextOwnsConnection is false.
+
+ An existing connection to use for the new context.
+ If set to true the connection is disposed when the context is disposed, otherwise
+ the caller must dispose the connection.
+
+
+
+
+ Constructs a new context instance using the given string as the name or connection
+ string for the database to which a connection will be made, and initializes
+ it from the given model. See the class remarks for how this is used to create
+ a connection.
+
+ Either the database name or a connection string.
+ The model that will back this context.
+
+
+
+ Maps table names, and sets up relationships between the various user entities
+
+
+
+
+
+ Validates that UserNames are unique and case insenstive
+
+
+
+
+
+
+
+ IDbSet of Users
+
+
+
+
+ IDbSet of Roles
+
+
+
+
+ If true validates that emails are unique
+
+
+
+
+ Default constructor which uses the DefaultConnection
+
+
+
+
+ Constructor which takes the connection string to use
+
+
+
+
+
+ Constructs a new context instance using the existing connection to connect to a database, and initializes it from
+ the given model. The connection will not be disposed when the context is disposed if contextOwnsConnection is
+ false.
+
+ An existing connection to use for the new context.
+ The model that will back this context.
+
+ Constructs a new context instance using the existing connection to connect to a
+ database, and initializes it from the given model. The connection will not be disposed when the context is
+ disposed if contextOwnsConnection is false.
+
+
+
+
+ Constructs a new context instance using conventions to create the name of
+ the database to which a connection will be made, and initializes it from
+ the given model. The by-convention name is the full name (namespace + class
+ name) of the derived context class. See the class remarks for how this is
+ used to create a connection.
+
+ The model that will back this context.
+
+
+
+ Constructs a new context instance using the existing connection to connect
+ to a database. The connection will not be disposed when the context is disposed
+ if contextOwnsConnection is false.
+
+ An existing connection to use for the new context.
+ If set to true the connection is disposed when the context is disposed, otherwise
+ the caller must dispose the connection.
+
+
+
+
+ Constructs a new context instance using the given string as the name or connection
+ string for the database to which a connection will be made, and initializes
+ it from the given model. See the class remarks for how this is used to create
+ a connection.
+
+ Either the database name or a connection string.
+ The model that will back this context.
+
+
+
+ DbContext which uses a custom user entity with a string primary key
+
+
+
+
+
+ Default constructor which uses the DefaultConnection
+
+
+
+
+ Constructor which takes the connection string to use
+
+
+
+
+
+ Constructor which takes the connection string to use
+
+
+ Will throw an exception if the schema matches that of Identity 1.0.0
+
+
+
+ Constructs a new context instance using the existing connection to connect to a database, and initializes it from
+ the given model. The connection will not be disposed when the context is disposed if contextOwnsConnection is
+ false.
+
+ An existing connection to use for the new context.
+ The model that will back this context.
+
+ Constructs a new context instance using the existing connection to connect to a
+ database, and initializes it from the given model. The connection will not be disposed when the context is
+ disposed if contextOwnsConnection is false.
+
+
+
+
+ Constructs a new context instance using conventions to create the name of
+ the database to which a connection will be made, and initializes it from
+ the given model. The by-convention name is the full name (namespace + class
+ name) of the derived context class. See the class remarks for how this is
+ used to create a connection.
+
+ The model that will back this context.
+
+
+
+ Constructs a new context instance using the existing connection to connect
+ to a database. The connection will not be disposed when the context is disposed
+ if contextOwnsConnection is false.
+
+ An existing connection to use for the new context.
+ If set to true the connection is disposed when the context is disposed, otherwise
+ the caller must dispose the connection.
+
+
+
+
+ Constructs a new context instance using the given string as the name or connection
+ string for the database to which a connection will be made, and initializes
+ it from the given model. See the class remarks for how this is used to create
+ a connection.
+
+ Either the database name or a connection string.
+ The model that will back this context.
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to Database Validation failed..
+
+
+
+
+ Looks up a localized string similar to Email {0} is already taken..
+
+
+
+
+ Looks up a localized string similar to User name {0} is already taken..
+
+
+
+
+ Looks up a localized string similar to Entity Type {0} failed validation..
+
+
+
+
+ Looks up a localized string similar to A user with that external login already exists..
+
+
+
+
+ Looks up a localized string similar to The model backing the 'ApplicationDbContext' context has changed since the database was created. This could have happened because the model used by ASP.NET Identity Framework has changed or the model being used in your application has changed. To resolve this issue, you need to update your database. Consider using Code First Migrations to update the database (http://go.microsoft.com/fwlink/?LinkId=301867). Before you update your database using Code First Migrations, please disable the schema consistency ch [rest of string was truncated]";.
+
+
+
+
+ Looks up a localized string similar to Incorrect type, expected type of {0}..
+
+
+
+
+ Looks up a localized string similar to {0} cannot be null or empty..
+
+
+
+
+ Looks up a localized string similar to Role {0} already exists..
+
+
+
+
+ Looks up a localized string similar to Role is not empty..
+
+
+
+
+ Looks up a localized string similar to Role {0} does not exist..
+
+
+
+
+ Looks up a localized string similar to User already in role..
+
+
+
+
+ Looks up a localized string similar to The UserId cannot be found..
+
+
+
+
+ Looks up a localized string similar to UserLogin already exists for loginProvider: {0} with providerKey: {1}.
+
+
+
+
+ Looks up a localized string similar to User {0} does not exist..
+
+
+
+
+ Looks up a localized string similar to User is not in role..
+
+
+
+
+ Looks up a localized string similar to Value cannot be null or empty..
+
+
+
+
+ Represents a Role entity
+
+
+
+
+ Represents a Role entity
+
+
+
+
+
+
+ Constructor
+
+
+
+
+ Navigation property for users in the role
+
+
+
+
+ Role id
+
+
+
+
+ Role name
+
+
+
+
+ Constructor
+
+
+
+
+ Constructor
+
+
+
+
+
+ Default EntityFramework IUser implementation
+
+
+
+
+ Default EntityFramework IUser implementation
+
+
+
+
+
+
+
+
+ Constructor
+
+
+
+
+ Email
+
+
+
+
+ True if the email is confirmed, default is false
+
+
+
+
+ The salted/hashed form of the user password
+
+
+
+
+ A random value that should change whenever a users credentials have changed (password changed, login removed)
+
+
+
+
+ PhoneNumber for the user
+
+
+
+
+ True if the phone number is confirmed, default is false
+
+
+
+
+ Is two factor enabled for the user
+
+
+
+
+ DateTime in UTC when lockout ends, any time in the past is considered not locked out.
+
+
+
+
+ Is lockout enabled for this user
+
+
+
+
+ Used to record failures for the purposes of lockout
+
+
+
+
+ Navigation property for user roles
+
+
+
+
+ Navigation property for user claims
+
+
+
+
+ Navigation property for user logins
+
+
+
+
+ User ID (Primary Key)
+
+
+
+
+ User name
+
+
+
+
+ Constructor which creates a new Guid for the Id
+
+
+
+
+ Constructor that takes a userName
+
+
+
+
+
+ EntityType that represents one specific user claim
+
+
+
+
+ EntityType that represents one specific user claim
+
+
+
+
+
+ Primary key
+
+
+
+
+ User Id for the user who owns this login
+
+
+
+
+ Claim type
+
+
+
+
+ Claim value
+
+
+
+
+ Entity type for a user's login (i.e. facebook, google)
+
+
+
+
+ Entity type for a user's login (i.e. facebook, google)
+
+
+
+
+
+ The login provider for the login (i.e. facebook, google)
+
+
+
+
+ Key representing the login for the provider
+
+
+
+
+ User Id for the user who owns this login
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Owin.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Owin.dll
new file mode 100644
index 000000000..37d4be9bc
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Owin.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Owin.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Owin.xml
new file mode 100644
index 000000000..e2a9ec7a6
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.AspNet.Identity.Owin.xml
@@ -0,0 +1,642 @@
+
+
+
+ Microsoft.AspNet.Identity.Owin
+
+
+
+
+ Extension methods for SignInManager/>
+
+
+
+
+ Called to generate the ClaimsIdentity for the user, override to add additional claims before SignIn
+
+
+
+
+
+
+
+ Creates a user identity and then signs the identity using the AuthenticationManager
+
+
+
+
+
+
+
+
+
+ Send a two factor code to a user
+
+
+
+
+
+
+
+ Get the user id that has been verified already or null.
+
+
+
+
+
+
+ Has the user been verified (ie either via password or external login)
+
+
+
+
+
+
+ Two factor verification step
+
+
+
+
+
+
+
+
+
+
+ Sign the user in using an associated external login
+
+
+
+
+
+
+
+
+ Sign in the user in using the user name and password
+
+
+
+
+
+
+
+
+
+
+ OwinMiddleware that initializes an object for use in the OwinContext via the Get/Set generic extensions method
+
+
+
+
+
+
+ Constructor
+
+ The next middleware in the OWIN pipeline to invoke
+ Configuration options for the middleware
+
+
+
+ Create an object using the Options.Provider, storing it in the OwinContext and then disposes the object when finished
+
+
+
+
+
+
+ Configuration options
+
+
+
+
+ Configuration options for a IdentityFactoryMiddleware
+
+
+
+
+
+ Used to configure the data protection provider
+
+
+
+
+ Provider used to Create and Dispose objects
+
+
+
+
+ Interface used to create objects per request
+
+
+
+
+
+ Called once per request to create an object
+
+
+
+
+
+
+
+ Called at the end of the request to dispose the object created
+
+
+
+
+
+
+ Used to configure how the IdentityFactoryMiddleware will create an instance of the specified type for each OwinContext
+
+
+
+
+
+ Constructor
+
+
+
+
+ Calls the OnCreate Delegate
+
+
+
+
+
+
+
+ Calls the OnDispose delegate
+
+
+
+
+
+
+ A delegate assigned to this property will be invoked when the related method is called
+
+
+
+
+ A delegate assigned to this property will be invoked when the related method is called
+
+
+
+
+ Token provider that uses an IDataProtector to generate encrypted tokens based off of the security stamp
+
+
+
+
+ Token provider that uses an IDataProtector to generate encrypted tokens based off of the security stamp
+
+
+
+
+ Constructor
+
+
+
+
+
+ Generate a protected string for a user
+
+
+
+
+
+
+
+
+ Return false if the token is not valid
+
+
+
+
+
+
+
+
+
+ Returns true if the provider can be used to generate tokens for this user
+
+
+
+
+
+
+
+ This provider no-ops by default when asked to notify a user
+
+
+
+
+
+
+
+
+ IDataProtector for the token
+
+
+
+
+ Lifespan after which the token is considered expired
+
+
+
+
+ Constructor
+
+
+
+
+
+ Extensions off of IAppBuilder to make it easier to configure the SignInCookies
+
+
+
+
+ Registers a callback that will be invoked to create an instance of type T that will be stored in the OwinContext
+ which can fetched via context.Get
+
+
+ The passed to the configuration method
+ Invoked to create an instance of T
+ The updated
+
+
+
+ Registers a callback that will be invoked to create an instance of type T that will be stored in the OwinContext
+ which can fetched via context.Get
+
+
+
+
+
+
+
+
+ Registers a callback that will be invoked to create an instance of type T that will be stored in the OwinContext
+ which can fetched via context.Get
+
+
+
+
+
+
+
+
+
+ Configure the app to use owin middleware based cookie authentication for external identities
+
+
+
+
+
+ Configure the app to use owin middleware based cookie authentication for external identities
+
+
+
+
+
+
+ Configures a cookie intended to be used to store the partial credentials for two factor authentication
+
+
+
+
+
+
+
+ Configures a cookie intended to be used to store whether two factor authentication has been done already
+
+
+
+
+
+
+ Configure the app to use owin middleware based oauth bearer tokens
+
+
+
+
+
+
+ Extensions methods on IAuthenticationManager that add methods for using the default Application and External
+ authentication type constants
+
+
+
+
+ Return the authentication types which are considered external because they have captions
+
+
+
+
+
+
+ Return the identity associated with the default external authentication type
+
+
+
+
+
+ Return the identity associated with the default external authentication type
+
+
+
+
+
+
+
+ Extracts login info out of an external identity
+
+
+
+
+
+
+ Extracts login info out of an external identity
+
+
+
+
+
+
+ Extracts login info out of an external identity
+
+
+ key that will be used to find the userId to verify
+
+ the value expected to be found using the xsrfKey in the AuthenticationResult.Properties
+ dictionary
+
+
+
+
+
+ Extracts login info out of an external identity
+
+
+ key that will be used to find the userId to verify
+
+ the value expected to be found using the xsrfKey in the AuthenticationResult.Properties
+ dictionary
+
+
+
+
+
+ Returns true if there is a TwoFactorRememberBrowser cookie for a user
+
+
+
+
+
+
+
+ Returns true if there is a TwoFactorRememberBrowser cookie for a user
+
+
+
+
+
+
+
+ Creates a TwoFactorRememberBrowser cookie for a user
+
+
+
+
+
+
+
+ Extension methods for OwinContext/>
+
+
+
+
+ Stores an object in the OwinContext using a key based on the AssemblyQualified type name
+
+
+
+
+
+
+
+
+ Retrieves an object from the OwinContext using a key based on the AssemblyQualified type name
+
+
+
+
+
+
+
+ Get the user manager from the context
+
+
+
+
+
+
+
+ Used to return information needed to associate an external login
+
+
+
+
+ Associated login data
+
+
+
+
+ Suggested user name for a user
+
+
+
+
+ Email claim from the external identity
+
+
+
+
+ The external identity
+
+
+
+
+ Static helper class used to configure a CookieAuthenticationProvider to validate a cookie against a user's security
+ stamp
+
+
+
+
+ Can be used as the ValidateIdentity method for a CookieAuthenticationProvider which will check a user's security
+ stamp after validateInterval
+ Rejects the identity if the stamp changes, and otherwise will call regenerateIdentity to sign in a new
+ ClaimsIdentity
+
+
+
+
+
+
+
+
+
+ Can be used as the ValidateIdentity method for a CookieAuthenticationProvider which will check a user's security
+ stamp after validateInterval
+ Rejects the identity if the stamp changes, and otherwise will call regenerateIdentity to sign in a new
+ ClaimsIdentity
+
+
+
+
+
+
+
+
+
+
+
+ Manages Sign In operations for users
+
+
+
+
+
+
+ Constructor
+
+
+
+
+
+
+ Called to generate the ClaimsIdentity for the user, override to add additional claims before SignIn
+
+
+
+
+
+
+ Convert a TKey userId to a string, by default this just calls ToString()
+
+
+
+
+
+
+ Convert a string id to the proper TKey using Convert.ChangeType
+
+
+
+
+
+
+ Creates a user identity and then signs the identity using the AuthenticationManager
+
+
+
+
+
+
+
+
+ Send a two factor code to a user
+
+
+
+
+
+
+ Get the user id that has been verified already or null.
+
+
+
+
+
+ Has the user been verified (ie either via password or external login)
+
+
+
+
+
+ Two factor verification step
+
+
+
+
+
+
+
+
+
+ Sign the user in using an associated external login
+
+
+
+
+
+
+
+ Sign in the user in using the user name and password
+
+
+
+
+
+
+
+
+
+ Dispose
+
+
+
+
+ If disposing, calls dispose on the Context. Always nulls out the Context
+
+
+
+
+
+ AuthenticationType that will be used by sign in, defaults to DefaultAuthenticationTypes.ApplicationCookie
+
+
+
+
+ Used to operate on users
+
+
+
+
+ Used to sign in identities
+
+
+
+
+ Possible results from a sign in attempt
+
+
+
+
+ Sign in was successful
+
+
+
+
+ User is locked out
+
+
+
+
+ Sign in requires addition verification (i.e. two factor)
+
+
+
+
+ Sign in failed
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.CodeDom.Providers.DotNetCompilerPlatform.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.CodeDom.Providers.DotNetCompilerPlatform.dll
new file mode 100644
index 000000000..4d638b3df
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.CodeDom.Providers.DotNetCompilerPlatform.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.CodeDom.Providers.DotNetCompilerPlatform.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.CodeDom.Providers.DotNetCompilerPlatform.xml
new file mode 100644
index 000000000..1a4935118
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.CodeDom.Providers.DotNetCompilerPlatform.xml
@@ -0,0 +1,40 @@
+
+
+
+ Microsoft.CodeDom.Providers.DotNetCompilerPlatform
+
+
+
+
+ Provides access to instances of the .NET Compiler Platform C# code generator and code compiler.
+
+
+
+
+ Default Constructor
+
+
+
+
+ Gets an instance of the .NET Compiler Platform C# code compiler.
+
+ An instance of the .NET Compiler Platform C# code compiler
+
+
+
+ Provides access to instances of the .NET Compiler Platform VB code generator and code compiler.
+
+
+
+
+ Default Constructor
+
+
+
+
+ Gets an instance of the .NET Compiler Platform VB code compiler.
+
+ An instance of the .NET Compiler Platform VB code compiler
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Host.SystemWeb.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Host.SystemWeb.dll
new file mode 100644
index 000000000..00bc4485e
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Host.SystemWeb.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Host.SystemWeb.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Host.SystemWeb.xml
new file mode 100644
index 000000000..c164a1675
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Host.SystemWeb.xml
@@ -0,0 +1,526 @@
+
+
+
+ Microsoft.Owin.Host.SystemWeb
+
+
+
+
+ Locates the startup class based on the following convention:
+ AssemblyName.Startup, with a method named Configuration
+
+
+
+
+
+
+
+
+
+ Allows for a fallback loader to be specified.
+
+
+
+
+
+ Allows for a fallback loader and a Dependency Injection activator to be specified.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Executes the loader, searching for the entry point by name.
+
+ The name of the assembly and type entry point
+
+
+
+
+
+
+
+
+
+
+
+
+ A default fallback loader that does nothing.
+
+
+
+
+ A placeholder method that always returns null.
+
+
+
+ null.
+
+
+
+ A singleton instance of the NullLoader type.
+
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to For the app startup parameter value '{0}', the assembly '{1}' was not found..
+
+
+
+
+ Looks up a localized string similar to For the app startup parameter value '{0}', the class '{1}' was not found in assembly '{2}'..
+
+
+
+
+ Looks up a localized string similar to The OwinStartup attribute discovered in assembly '{0}' referencing startup type '{1}' conflicts with the attribute in assembly '{2}' referencing startup type '{3}' because they have the same FriendlyName '{4}'. Remove or rename one of the attributes, or reference the desired type directly..
+
+
+
+
+ Looks up a localized string similar to The discovered startup type '{0}' conflicts with the type '{1}'. Remove or rename one of the types, or reference the desired type directly..
+
+
+
+
+ Looks up a localized string similar to The OwinStartupAttribute.FriendlyName value '{0}' does not match the given value '{1}' in Assembly '{2}'..
+
+
+
+
+ Looks up a localized string similar to No '{0}' method was found in class '{1}'..
+
+
+
+
+ Looks up a localized string similar to No assembly found containing a Startup or [AssemblyName].Startup class..
+
+
+
+
+ Looks up a localized string similar to No assembly found containing an OwinStartupAttribute..
+
+
+
+
+ Looks up a localized string similar to The OwinStartupAttribute.StartupType value is empty in Assembly '{0}'..
+
+
+
+
+ Looks up a localized string similar to The type '{0}' referenced from assembly '{1}' does not define a property 'StartupType' of type 'Type'..
+
+
+
+
+ Looks up a localized string similar to The given type or method '{0}' was not found. Try specifying the Assembly..
+
+
+
+
+ Looks up a localized string similar to The '{0}' method on class '{1}' does not have the expected signature 'void {0}(IAppBuilder)'..
+
+
+
+
+ Used to provide the data protection services that are derived from the MachineKey API. It is the best choice of
+ data protection when you application is hosted by ASP.NET and all servers in the farm are running with the same Machine Key values.
+
+
+
+
+ Returns a new instance of IDataProtection for the provider.
+
+ Additional entropy used to ensure protected data may only be unprotected for the correct purposes.
+ An instance of a data protection service
+
+
+
+ Provides extension methods for .
+
+
+
+
+ Gets the for the current request.
+
+
+
+
+
+
+ Gets the for the current request.
+
+
+
+
+
+
+ Provides extension methods for .
+
+
+
+
+ Gets the for the current request.
+
+
+
+
+
+
+ Gets the for the current request.
+
+
+
+
+
+
+ Processes requests from System.Web as OWIN requests.
+
+
+
+
+ Processes requests using the default OWIN application.
+
+
+
+
+ Initiates an asynchronous call to the HTTP handler.
+
+
+ An System.Web.HttpContextBase object that provides references to intrinsic server
+ objects (for example, Request, Response, Session, and Server) used to service
+ HTTP requests.
+
+
+ The System.AsyncCallback to call when the asynchronous method call is complete.
+ If callback is null, the delegate is not called.
+
+
+ Any extra data needed to process the request.
+
+
+ An System.IAsyncResult that contains information about the status of the process.
+
+
+
+
+ Provides an asynchronous process End method when the process ends.
+
+
+ An System.IAsyncResult that contains information about the status of the process.
+
+
+
+
+ Gets a value indicating whether another request can use the System.Web.IHttpHandler instance.
+
+
+ true.
+
+
+
+
+ Processes a route through an OWIN pipeline.
+
+
+
+
+ Initialize an OwinRouteHandler
+
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
+ Provides the object that processes the request.
+
+
+ An object that processes the request.
+
+ An object that encapsulates information about the request.
+
+
+
+ Registers the OWIN request processing module at application startup.
+
+
+
+
+ Registers the OWIN request processing module.
+
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to The following errors occurred while attempting to load the app..
+
+
+
+
+ Looks up a localized string similar to Cannot register for 'OnSendingHeaders' event after response headers have been sent..
+
+
+
+
+ Looks up a localized string similar to The key '{0}' is already present in the dictionary..
+
+
+
+
+ Looks up a localized string similar to To disable OWIN startup discovery, add the appSetting owin:AutomaticAppStartup with a value of "false" in your web.config..
+
+
+
+
+ Looks up a localized string similar to To specify the OWIN startup Assembly, Class, or Method, add the appSetting owin:AppStartup with the fully qualified startup class or configuration method name in your web.config..
+
+
+
+
+ Looks up a localized string similar to The given stage '{0}' is not supported..
+
+
+
+
+ Looks up a localized string similar to No owin.Environment item was found in the context..
+
+
+
+
+ Looks up a localized string similar to An exception was thrown while trying to load the client certificate:.
+
+
+
+
+ Looks up a localized string similar to The OWIN entry point threw an exception:.
+
+
+
+
+ Looks up a localized string similar to The IAsyncResult callback for OwinCallHandler threw an exception:.
+
+
+
+
+ Looks up a localized string similar to Failed to register the OWIN module:.
+
+
+
+
+ Looks up a localized string similar to The application threw one or more exceptions when notified of a client disconnect:.
+
+
+
+
+ Looks up a localized string similar to Shutdown detection setup failed:.
+
+
+
+
+ Looks up a localized string similar to One or more exceptions were thrown during app pool shutdown:.
+
+
+
+
+ Looks up a localized string similar to An exception was thrown from a timer callback:.
+
+
+
+
+ Looks up a localized string similar to An exception was thrown while processing the WebSocket:.
+
+
+
+
+ Looks up a localized string similar to Support for WebSockets has been detected..
+
+
+
+
+ Looks up a localized string similar to No support for WebSockets has been detected..
+
+
+
+
+ Provides extension methods for registering OWIN applications as System.Web routes.
+
+
+
+
+ Registers a route for the default OWIN application.
+
+ The route collection.
+ The route path to map to the default OWIN application.
+ The created route.
+
+
+
+ Registers a route for a specific OWIN application entry point.
+
+ The OWIN application entry point type.
+ The route collection.
+ The route path to map to the given OWIN application.
+ The OWIN application entry point.
+ The created route.
+
+
+
+ Invokes the System.Action startup delegate to build the OWIN application
+ and then registers a route for it on the given path.
+
+ The route collection.
+ The route path to map to the given OWIN application.
+ A System.Action delegate invoked to build the OWIN application.
+ The created route.
+
+
+
+ Registers a route for the default OWIN application.
+
+ The route collection.
+ The given name of the route.
+ The route path to map to the default OWIN application.
+ The created route.
+
+
+
+ Registers a route for a specific OWIN application entry point.
+
+ The OWIN application entry point type.
+ The route collection.
+ The given name of the route.
+ The route path to map to the given OWIN application.
+ The OWIN application entry point.
+ The created route.
+
+
+
+ Invokes the System.Action startup delegate to build the OWIN application
+ and then registers a route for it on the given path.
+
+ The route collection.
+ The given name of the route.
+ The route path to map to the given OWIN application.
+ A System.Action delegate invoked to build the OWIN application.
+ The created route.
+
+
+
+ Provides a way to define routes for an OWIN pipeline.
+
+ The route collection.
+ The URL pattern for the route.
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
+ Provides a way to define routes for an OWIN pipeline.
+
+ The route collection.
+ The URL pattern for the route.
+ The values to use if the URL does not contain all the parameters.
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
+ Provides a way to define routes for an OWIN pipeline.
+
+ The route collection.
+ The URL pattern for the route.
+ The values to use if the URL does not contain all the parameters.
+ A regular expression that specifies valid values for a URL parameter.
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
+ Provides a way to define routes for an OWIN pipeline.
+
+ The route collection.
+ The URL pattern for the route.
+ The values to use if the URL does not contain all the parameters.
+ A regular expression that specifies valid values for a URL parameter.
+ Custom values that are passed to the route handler, but which are not used to determine whether the route matches a specific URL pattern. These values are passed to the route handler, where they can be used for processing the request.
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
+ Provides a way to define routes for an OWIN pipeline.
+
+ The route collection.
+ The name of the route.
+ The URL pattern for the route.
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
+ Provides a way to define routes for an OWIN pipeline.
+
+ The route collection.
+ The name of the route.
+ The URL pattern for the route.
+ The values to use if the URL does not contain all the parameters.
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
+ Provides a way to define routes for an OWIN pipeline.
+
+ The route collection.
+ The name of the route.
+ The URL pattern for the route.
+ The values to use if the URL does not contain all the parameters.
+ A regular expression that specifies valid values for a URL parameter.
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
+ Provides a way to define routes for an OWIN pipeline.
+
+ The route collection.
+ The name of the route.
+ The URL pattern for the route.
+ The values to use if the URL does not contain all the parameters.
+ A regular expression that specifies valid values for a URL parameter.
+ Custom values that are passed to the route handler, but which are not used to determine whether the route matches a specific URL pattern. These values are passed to the route handler, where they can be used for processing the request.
+ The method to initialize the pipeline that processes requests for the route.
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.ActiveDirectory.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.ActiveDirectory.dll
new file mode 100644
index 000000000..06d77364c
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.ActiveDirectory.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.ActiveDirectory.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.ActiveDirectory.xml
new file mode 100644
index 000000000..b6dba1544
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.ActiveDirectory.xml
@@ -0,0 +1,266 @@
+
+
+
+ Microsoft.Owin.Security.ActiveDirectory
+
+
+
+
+ Extension methods provided by the ADFS JWT bearer token middleware.
+
+
+
+
+ Adds Active Directory Federation Services (ADFS) issued JWT bearer token middleware to your web application pipeline.
+
+ The IAppBuilder passed to your configuration method.
+ An options class that controls the middleware behavior.
+ The original app parameter.
+
+
+
+ Options to configure the Active Directory Federation Services JWT middleware.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Gets or sets the WSFed Metadata Endpoint for the Security Token Service JWTs will be issued from.
+
+
+ The WSFed Metadata Endpoint for the Security Token Service JWTs will be issued from.
+
+
+
+
+ Gets or sets the expected audience for any received JWT token.
+
+
+ The expected audience for any received JWT token.
+
+
+
+
+ Gets or sets the authentication realm.
+
+
+ The authentication realm.
+
+
+
+
+ Gets or sets the authentication provider.
+
+
+ The provider.
+
+
+
+
+ Gets or sets the a certificate validator to use to validate the metadata endpoint.
+
+
+ The certificate validator.
+
+ If this property is null then the default certificate checks are performed,
+ validating the subject name and if the signing chain is a trusted party.
+
+
+
+ Gets or sets timeout value in for back channel communications with the metadata endpoint.
+
+
+ The back channel timeout.
+
+
+
+
+ The HttpMessageHandler used to communicate with the metadata endpoint.
+ This cannot be set at the same time as BackchannelCertificateValidator unless the value
+ can be downcast to a WebRequestHandler.
+
+
+
+
+ Gets or sets the used to determine if a token is valid.
+
+
+
+
+ A System.IdentityModel.Tokens.SecurityTokenHandler designed for creating and validating Json Web Tokens.
+
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to No SecurityTokenServiceType descriptor in metadata..
+
+
+
+
+ Looks up a localized string similar to The '{0}' option must be provided..
+
+
+
+
+ Looks up a localized string similar to An ICertificateValidator cannot be specified at the same time as an HttpMessageHandler unless it is a WebRequestHandler..
+
+
+
+
+ A security token provider which retrieves the issuer and signing tokens from a WSFed metadata endpoint.
+
+
+
+
+ Gets the issuer the credentials are for.
+
+
+ The issuer the credentials are for.
+
+
+
+
+ Gets all known security tokens.
+
+
+ All known security tokens.
+
+
+
+
+ Signing metadata parsed from a WSFed endpoint.
+
+
+
+
+ The token issuer.
+
+
+
+
+ Signing tokens.
+
+
+
+
+ Helper for parsing WSFed metadata.
+
+
+
+
+ Extension methods provided by the Windows Azure Active Directory JWT bearer token middleware.
+
+
+
+
+ Adds Windows Azure Active Directory (WAAD) issued JWT bearer token middleware to your web application pipeline.
+
+ The IAppBuilder passed to your configuration method.
+ An options class that controls the middleware behavior.
+ The original app parameter.
+
+
+
+ Options to configure the Windows Azure Active Directory JWT middleware.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Gets or sets the expected audience for any received JWT token.
+
+
+ The expected audience for any received JWT token.
+
+
+
+
+ Gets or sets the authentication realm.
+
+
+ The authentication realm.
+
+
+
+
+ Gets or sets the Azure Active Directory tenant the tokens are issued from.
+
+
+ The Azure Active Directory tenant the tokens are issued from.
+
+
+
+
+ Gets or sets the address to retrieve the configuration metadata
+ This can be generated from the Tenant if present.
+
+
+
+
+ Gets or sets the authentication provider.
+
+
+ The provider.
+
+
+
+
+ Gets or sets the a certificate validator to use to validate the metadata endpoint.
+
+
+ The certificate validator.
+
+ If this property is null then the default certificate checks are performed,
+ validating the subject name and if the signing chain is a trusted party.
+
+
+
+ Gets or sets timeout value in for back channel communications with the metadata endpoint.
+
+
+ The back channel timeout.
+
+
+
+
+ The HttpMessageHandler used to communicate with the metadata endpoint.
+ This cannot be set at the same time as BackchannelCertificateValidator unless the value
+ can be downcast to a WebRequestHandler.
+
+
+
+
+ Gets or sets the used to determine if a token is valid.
+
+
+
+
+ A System.IdentityModel.Tokens.SecurityTokenHandler designed for creating and validating Json Web Tokens.
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Cookies.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Cookies.dll
new file mode 100644
index 000000000..431cee6d1
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Cookies.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Cookies.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Cookies.xml
new file mode 100644
index 000000000..50815b07f
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Cookies.xml
@@ -0,0 +1,545 @@
+
+
+
+ Microsoft.Owin.Security.Cookies
+
+
+
+
+ Default values related to cookie-based authentication middleware
+
+
+
+
+ The default value used for CookieAuthenticationOptions.AuthenticationType
+
+
+
+
+ The prefix used to provide a default CookieAuthenticationOptions.CookieName
+
+
+
+
+ The default value of the CookieAuthenticationOptions.ReturnUrlParameter
+
+
+
+
+ The default value used by UseApplicationSignInCookie for the
+ CookieAuthenticationOptions.LoginPath
+
+
+
+
+ The default value used by UseApplicationSignInCookie for the
+ CookieAuthenticationOptions.LogoutPath
+
+
+
+
+ Determines how the identity cookie's security property is set.
+
+
+
+
+ If the URI that provides the cookie is HTTPS, then the cookie will only be returned to the server on
+ subsequent HTTPS requests. Otherwise if the URI that provides the cookie is HTTP, then the cookie will
+ be returned to the server on all HTTP and HTTPS requests. This is the default value because it ensures
+ HTTPS for all authenticated requests on deployed servers, and also supports HTTP for localhost development
+ and for servers that do not have HTTPS support.
+
+
+
+
+ CookieOptions.Secure is never marked true. Use this value when your login page is HTTPS, but other pages
+ on the site which are HTTP also require authentication information. This setting is not recommended because
+ the authentication information provided with an HTTP request may be observed and used by other computers
+ on your local network or wireless connection.
+
+
+
+
+ CookieOptions.Secure is always marked true. Use this value when your login page and all subsequent pages
+ requiring the authenticated identity are HTTPS. Local development will also need to be done with HTTPS urls.
+
+
+
+
+ Extension methods provided by the cookies authentication middleware
+
+
+
+
+ Adds a cookie-based authentication middleware to your web application pipeline.
+
+ The IAppBuilder passed to your configuration method
+ An options class that controls the middleware behavior
+ The original app parameter
+
+
+
+ Adds a cookie-based authentication middleware to your web application pipeline.
+
+ The IAppBuilder passed to your configuration method
+ An options class that controls the middleware behavior
+
+ The original app parameter
+
+
+
+ Cookie based authentication middleware
+
+
+
+
+ Initializes a
+
+ The next middleware in the OWIN pipeline to invoke
+ The OWIN application
+ Configuration options for the middleware
+
+
+
+ Provides the object for processing authentication-related requests.
+
+ An configured with the supplied to the constructor.
+
+
+
+ Contains the options used by the CookiesAuthenticationMiddleware
+
+
+
+
+ Create an instance of the options initialized with the default values
+
+
+
+
+ Determines the cookie name used to persist the identity. The default value is ".AspNet.Cookies".
+ This value should be changed if you change the name of the AuthenticationType, especially if your
+ system uses the cookie authentication middleware multiple times.
+
+
+
+
+ Determines the domain used to create the cookie. Is not provided by default.
+
+
+
+
+ Determines the path used to create the cookie. The default value is "/" for highest browser compatability.
+
+
+
+
+ Determines if the browser should allow the cookie to be accessed by client-side javascript. The
+ default is true, which means the cookie will only be passed to http requests and is not made available
+ to script on the page.
+
+
+
+
+ Determines if the cookie should only be transmitted on HTTPS request. The default is to limit the cookie
+ to HTTPS requests if the page which is doing the SignIn is also HTTPS. If you have an HTTPS sign in page
+ and portions of your site are HTTP you may need to change this value.
+
+
+
+
+ Controls how much time the cookie will remain valid from the point it is created. The expiration
+ information is in the protected cookie ticket. Because of that an expired cookie will be ignored
+ even if it is passed to the server after the browser should have purged it
+
+
+
+
+ The SlidingExpiration is set to true to instruct the middleware to re-issue a new cookie with a new
+ expiration time any time it processes a request which is more than halfway through the expiration window.
+
+
+
+
+ The LoginPath property informs the middleware that it should change an outgoing 401 Unauthorized status
+ code into a 302 redirection onto the given login path. The current url which generated the 401 is added
+ to the LoginPath as a query string parameter named by the ReturnUrlParameter. Once a request to the
+ LoginPath grants a new SignIn identity, the ReturnUrlParameter value is used to redirect the browser back
+ to the url which caused the original unauthorized status code.
+
+ If the LoginPath is null or empty, the middleware will not look for 401 Unauthorized status codes, and it will
+ not redirect automatically when a login occurs.
+
+
+
+
+ If the LogoutPath is provided the middleware then a request to that path will redirect based on the ReturnUrlParameter.
+
+
+
+
+ The ReturnUrlParameter determines the name of the query string parameter which is appended by the middleware
+ when a 401 Unauthorized status code is changed to a 302 redirect onto the login path. This is also the query
+ string parameter looked for when a request arrives on the login path or logout path, in order to return to the
+ original url after the action is performed.
+
+
+
+
+ The Provider may be assigned to an instance of an object created by the application at startup time. The middleware
+ calls methods on the provider which give the application control at certain points where processing is occuring.
+ If it is not provided a default instance is supplied which does nothing when the methods are called.
+
+
+
+
+ The TicketDataFormat is used to protect and unprotect the identity and other properties which are stored in the
+ cookie value. If it is not provided a default data handler is created using the data protection service contained
+ in the IAppBuilder.Properties. The default data protection service is based on machine key when running on ASP.NET,
+ and on DPAPI when running in a different process.
+
+
+
+
+ The SystemClock provides access to the system's current time coordinates. If it is not provided a default instance is
+ used which calls DateTimeOffset.UtcNow. This is typically not replaced except for unit testing.
+
+
+
+
+ The component used to get cookies from the request or set them on the response.
+
+ ChunkingCookieManager will be used by default.
+
+
+
+
+ An optional container in which to store the identity across requests. When used, only a session identifier is sent
+ to the client. This can be used to mitigate potential problems with very large identities.
+
+
+
+
+ Context passed when a Challenge, SignIn, or SignOut causes a redirect in the cookie middleware
+
+
+
+
+ Creates a new context object.
+
+ The OWIN request context
+ The cookie middleware options
+ The initial redirect URI
+
+
+
+ Gets or Sets the URI used for the redirect operation.
+
+
+
+
+ This default implementation of the ICookieAuthenticationProvider may be used if the
+ application only needs to override a few of the interface methods. This may be used as a base class
+ or may be instantiated directly.
+
+
+
+
+ Specifies callback methods which the invokes to enable developer control over the authentication process. />
+
+
+
+
+ Called each time a request identity has been validated by the middleware. By implementing this method the
+ application may alter or reject the identity which has arrived with the request.
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Called when an endpoint has provided sign in information before it is converted into a cookie. By
+ implementing this method the claims and extra information that go into the ticket may be altered.
+
+ Contains information about the login session as well as the user .
+
+
+
+ Called when an endpoint has provided sign in information after it is converted into a cookie.
+
+ Contains information about the login session as well as the user .
+
+
+
+ Called when a Challenge, SignIn, or SignOut causes a redirect in the cookie middleware
+
+ Contains information about the event
+
+
+
+ Called during the sign-out flow to augment the cookie cleanup process.
+
+ Contains information about the login session as well as information about the authentication cookie.
+
+
+
+ Called when an exception occurs during request or response processing.
+
+ Contains information about the exception that occurred
+
+
+
+ Create a new instance of the default provider.
+
+
+
+
+ Implements the interface method by invoking the related delegate method
+
+
+
+
+
+
+ Implements the interface method by invoking the related delegate method
+
+
+
+
+
+ Implements the interface method by invoking the related delegate method
+
+
+
+
+
+ Implements the interface method by invoking the related delegate method
+
+
+
+
+
+ Implements the interface method by invoking the related delegate method
+
+ Contains information about the event
+
+
+
+ Implements the interface method by invoking the related delegate method
+
+ Contains information about the event
+
+
+
+ A delegate assigned to this property will be invoked when the related method is called
+
+
+
+
+ A delegate assigned to this property will be invoked when the related method is called
+
+
+
+
+ A delegate assigned to this property will be invoked when the related method is called
+
+
+
+
+ A delegate assigned to this property will be invoked when the related method is called
+
+
+
+
+ A delegate assigned to this property will be invoked when the related method is called
+
+
+
+
+ A delegate assigned to this property will be invoked when the related method is called
+
+
+
+
+ Context object passed to the ICookieAuthenticationProvider method Exception.
+
+
+
+
+ Creates a new instance of the context object.
+
+ The OWIN request context
+ The middleware options
+ The location of the exception
+ The exception thrown.
+ The current ticket, if any.
+
+
+
+ The code path the exception occurred in.
+
+
+
+
+ The exception thrown.
+
+
+
+
+ True if the exception should be re-thrown (default), false if it should be suppressed.
+
+
+
+
+ The current authentication ticket, if any.
+ In the AuthenticateAsync code path, if the given exception is not re-thrown then this ticket
+ will be returned to the application. The ticket may be replaced if needed.
+
+
+
+
+ The code paths where exceptions may be reported.
+
+
+
+
+ The exception was reported in the AuthenticateAsync code path.
+
+
+
+
+ The exception was reported in the ApplyResponseGrant code path, during sign-in, sign-out, or refresh.
+
+
+
+
+ The exception was reported in the ApplyResponseChallenge code path, during redirect generation.
+
+
+
+
+ Context object passed to the ICookieAuthenticationProvider method ResponseSignedIn.
+
+
+
+
+ Creates a new instance of the context object.
+
+ The OWIN request context
+ The middleware options
+ Initializes AuthenticationType property
+ Initializes Identity property
+ Initializes Properties property
+
+
+
+ The name of the AuthenticationType creating a cookie
+
+
+
+
+ Contains the claims that were converted into the outgoing cookie.
+
+
+
+
+ Contains the extra data that was contained in the outgoing cookie.
+
+
+
+
+ Context object passed to the ICookieAuthenticationProvider method ResponseSignIn.
+
+
+
+
+ Creates a new instance of the context object.
+
+ The OWIN request context
+ The middleware options
+ Initializes AuthenticationType property
+ Initializes Identity property
+ Initializes Extra property
+ Initializes options for the authentication cookie.
+
+
+
+ The name of the AuthenticationType creating a cookie
+
+
+
+
+ Contains the claims about to be converted into the outgoing cookie.
+ May be replaced or altered during the ResponseSignIn call.
+
+
+
+
+ Contains the extra data about to be contained in the outgoing cookie.
+ May be replaced or altered during the ResponseSignIn call.
+
+
+
+
+ The options for creating the outgoing cookie.
+ May be replace or altered during the ResponseSignIn call.
+
+
+
+
+ Context object passed to the ICookieAuthenticationProvider method ResponseSignOut
+
+
+
+
+
+
+
+
+
+
+
+
+ The options for creating the outgoing cookie.
+ May be replace or altered during the ResponseSignOut call.
+
+
+
+
+ Context object passed to the ICookieAuthenticationProvider method ValidateIdentity.
+
+
+
+
+ Creates a new instance of the context object.
+
+
+ Contains the initial values for identity and extra data
+
+
+
+
+ Called to replace the claims identity. The supplied identity will replace the value of the
+ Identity property, which determines the identity of the authenticated request.
+
+ The identity used as the replacement
+
+
+
+ Called to reject the incoming identity. This may be done if the application has determined the
+ account is no longer active, and the request should be treated as if it was anonymous.
+
+
+
+
+ Contains the claims identity arriving with the request. May be altered to change the
+ details of the authenticated user.
+
+
+
+
+ Contains the extra meta-data arriving with the request ticket. May be altered.
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Facebook.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Facebook.dll
new file mode 100644
index 000000000..ce200d331
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Facebook.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Facebook.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Facebook.xml
new file mode 100644
index 000000000..e0bb20e77
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Facebook.xml
@@ -0,0 +1,342 @@
+
+
+
+ Microsoft.Owin.Security.Facebook
+
+
+
+
+ Extension methods for using
+
+
+
+
+ Authenticate users using Facebook
+
+ The passed to the configuration method
+ Middleware configuration options
+ The updated
+
+
+
+ Authenticate users using Facebook
+
+ The passed to the configuration method
+ The appId assigned by Facebook
+ The appSecret assigned by Facebook
+ The updated
+
+
+
+ OWIN middleware for authenticating users using Facebook
+
+
+
+
+ Initializes a
+
+ The next middleware in the OWIN pipeline to invoke
+ The OWIN application
+ Configuration options for the middleware
+
+
+
+ Provides the object for processing authentication-related requests.
+
+ An configured with the supplied to the constructor.
+
+
+
+ Configuration options for
+
+
+
+
+ Initializes a new
+
+
+
+
+ Gets or sets the Facebook-assigned appId
+
+
+
+
+ Gets or sets the Facebook-assigned app secret
+
+
+
+
+ Gets or sets the URI where the client will be redirected to authenticate.
+ The default value is 'https://www.facebook.com/dialog/oauth'.
+
+
+
+
+ Gets or sets the URI the middleware will access to exchange the OAuth token.
+ The default value is 'https://graph.facebook.com/oauth/access_token'.
+
+
+
+
+ Gets or sets the URI the middleware will access to obtain the user information.
+ The default value is 'https://graph.facebook.com/me'.
+
+
+
+
+ Gets or sets the a pinned certificate validator to use to validate the endpoints used
+ in back channel communications belong to Facebook.
+
+
+ The pinned certificate validator.
+
+ If this property is null then the default certificate checks are performed,
+ validating the subject name and if the signing chain is a trusted party.
+
+
+
+ Gets or sets timeout value in milliseconds for back channel communications with Facebook.
+
+
+ The back channel timeout in milliseconds.
+
+
+
+
+ The HttpMessageHandler used to communicate with Facebook.
+ This cannot be set at the same time as BackchannelCertificateValidator unless the value
+ can be downcast to a WebRequestHandler.
+
+
+
+
+ Get or sets the text that the user can display on a sign in user interface.
+
+
+
+
+ The request path within the application's base path where the user-agent will be returned.
+ The middleware will process this request when it arrives.
+ Default value is "/signin-facebook".
+
+
+
+
+ Gets or sets the name of another authentication middleware which will be responsible for actually issuing a user .
+
+
+
+
+ Gets or sets the used to handle authentication events.
+
+
+
+
+ Gets or sets the type used to secure data handled by the middleware.
+
+
+
+
+ A list of permissions to request.
+
+
+
+
+ Gets or sets if the appsecret_proof should be generated and sent with Facebook API calls.
+ This is enabled by default.
+
+
+
+
+ Context passed when a Challenge causes a redirect to authorize endpoint in the Facebook middleware
+
+
+
+
+ Creates a new context object.
+
+ The OWIN request context
+ The Facebook middleware options
+ The authenticaiton properties of the challenge
+ The initial redirect URI
+
+
+
+ Gets the URI used for the redirect operation.
+
+
+
+
+ Gets the authentication properties of the challenge
+
+
+
+
+ Contains information about the login session as well as the user .
+
+
+
+
+ Initializes a
+
+ The OWIN environment
+ The JSON-serialized user
+ Facebook Access token
+ Seconds until expiration
+
+
+
+ Gets the JSON-serialized user
+
+
+
+
+ Gets the Facebook access token
+
+
+
+
+ Gets the Facebook access token expiration time
+
+
+
+
+ Gets the Facebook user ID
+
+
+
+
+ Gets the user's name
+
+
+
+
+ Gets the Facebook username
+
+
+
+
+ Gets the Facebook email
+
+
+
+
+ Gets the representing the user
+
+
+
+
+ Gets or sets a property bag for common authentication properties
+
+
+
+
+ Default implementation.
+
+
+
+
+ Specifies callback methods which the invokes to enable developer control over the authentication process. />
+
+
+
+
+ Invoked whenever Facebook succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Facebook middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Initializes a
+
+
+
+
+ Invoked whenever Facebook succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Facebook middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Gets or sets the function that is invoked when the Authenticated method is invoked.
+
+
+
+
+ Gets or sets the function that is invoked when the ReturnEndpoint method is invoked.
+
+
+
+
+ Gets or sets the delegate that is invoked when the ApplyRedirect method is invoked.
+
+
+
+
+ Provides context information to middleware providers.
+
+
+
+
+
+
+ OWIN environment
+ The authentication ticket
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to The '{0}' option must be provided..
+
+
+
+
+ Looks up a localized string similar to An ICertificateValidator cannot be specified at the same time as an HttpMessageHandler unless it is a WebRequestHandler..
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Google.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Google.dll
new file mode 100644
index 000000000..e2541db3d
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Google.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Google.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Google.xml
new file mode 100644
index 000000000..e4dee94aa
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Google.xml
@@ -0,0 +1,606 @@
+
+
+
+ Microsoft.Owin.Security.Google
+
+
+
+
+ Extension methods for using
+
+
+
+
+ Authenticate users using Google OpenId
+
+ The passed to the configuration method
+ Middleware configuration options
+ The updated
+
+
+
+ Authenticate users using Google OpenId
+
+ The passed to the configuration method
+ The updated
+
+
+
+ Authenticate users using Google OAuth 2.0
+
+ The passed to the configuration method
+ Middleware configuration options
+ The updated
+
+
+
+ Authenticate users using Google OAuth 2.0
+
+ The passed to the configuration method
+ The google assigned client id
+ The google assigned client secret
+ The updated
+
+
+
+ OWIN middleware for authenticating users using Google OAuth 2.0
+
+
+
+
+ Initializes a
+
+ The next middleware in the OWIN pipeline to invoke
+ The OWIN application
+ Configuration options for the middleware
+
+
+
+ Provides the object for processing authentication-related requests.
+
+ An configured with the supplied to the constructor.
+
+
+
+ OWIN middleware for authenticating users using Google OpenID
+
+
+
+
+ Initializes a
+
+ The next middleware in the OWIN pipeline to invoke
+ The OWIN application
+ Configuration options for the middleware
+
+
+
+ Provides the object for processing authentication-related requests.
+
+ An configured with the supplied to the constructor.
+
+
+
+ Configuration options for
+
+
+
+
+ Initializes a new
+
+
+
+
+ Gets or sets the a pinned certificate validator to use to validate the endpoints used
+ in back channel communications belong to Google.
+
+
+ The pinned certificate validator.
+
+ If this property is null then the default certificate checks are performed,
+ validating the subject name and if the signing chain is a trusted party.
+
+
+
+ Gets or sets timeout value in milliseconds for back channel communications with Google.
+
+
+ The back channel timeout.
+
+
+
+
+ The HttpMessageHandler used to communicate with Google.
+ This cannot be set at the same time as BackchannelCertificateValidator unless the value
+ can be downcast to a WebRequestHandler.
+
+
+
+
+ Get or sets the text that the user can display on a sign in user interface.
+
+
+
+
+ The request path within the application's base path where the user-agent will be returned.
+ The middleware will process this request when it arrives.
+ Default value is "/signin-google".
+
+
+
+
+ Gets or sets the name of another authentication middleware which will be responsible for actually issuing a user .
+
+
+
+
+ Gets or sets the used to handle authentication events.
+
+
+
+
+ Gets or sets the type used to secure data handled by the middleware.
+
+
+
+
+ Configuration options for
+
+
+
+
+ Initializes a new
+
+
+
+
+ Gets or sets the Google-assigned client id
+
+
+
+
+ Gets or sets the Google-assigned client secret
+
+
+
+
+ Gets or sets the a pinned certificate validator to use to validate the endpoints used
+ in back channel communications belong to Google.
+
+
+ The pinned certificate validator.
+
+ If this property is null then the default certificate checks are performed,
+ validating the subject name and if the signing chain is a trusted party.
+
+
+
+ Gets or sets timeout value in milliseconds for back channel communications with Google.
+
+
+ The back channel timeout in milliseconds.
+
+
+
+
+ The HttpMessageHandler used to communicate with Google.
+ This cannot be set at the same time as BackchannelCertificateValidator unless the value
+ can be downcast to a WebRequestHandler.
+
+
+
+
+ Get or sets the text that the user can display on a sign in user interface.
+
+
+
+
+ The request path within the application's base path where the user-agent will be returned.
+ The middleware will process this request when it arrives.
+ Default value is "/signin-google".
+
+
+
+
+ Gets or sets the name of another authentication middleware which will be responsible for actually issuing a user .
+
+
+
+
+ Gets or sets the used to handle authentication events.
+
+
+
+
+ Gets or sets the type used to secure data handled by the middleware.
+
+
+
+
+ A list of permissions to request.
+
+
+
+
+ access_type. Set to 'offline' to request a refresh token.
+
+
+
+
+ Adds the openid parameters from querystring or form body into Namespaces and Properties collections.
+ This normalizes the parameter name, by replacing the variable namespace alias with the
+ actual namespace in the collection's key, and will optionally skip any parameters that are
+ not signed if the strict argument is true.
+
+ The keys and values of the incoming querystring or form body
+ True if keys that are not signed should be ignored
+
+
+
+ Contains information about the login session as well as the user .
+
+
+
+
+ Initializes a
+
+ The OWIN environment
+ The representing the user
+ A property bag for common authentication properties
+
+
+
+
+
+ Gets or sets the representing the user
+
+
+
+
+ Gets or sets a property bag for common authentication properties
+
+
+
+
+ Gets or sets parsed response message from openid query string
+
+
+
+
+ Gets the key-value dictinary of message properties
+
+
+
+
+ Default implementation.
+
+
+
+
+ Specifies callback methods which the invokes to enable developer control over the authentication process. />
+
+
+
+
+ Invoked whenever Google succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Google OpenID middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Initializes a
+
+
+
+
+ Invoked whenever Google successfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Google OpenID middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Gets or sets the function that is invoked when the Authenticated method is invoked.
+
+
+
+
+ Gets or sets the function that is invoked when the ReturnEndpoint method is invoked.
+
+
+
+
+ Gets or sets the delegate that is invoked when the ApplyRedirect method is invoked.
+
+
+
+
+ Context passed when a Challenge causes a redirect to authorize endpoint in the Google OpenID middleware
+
+
+
+
+ Creates a new context object.
+
+ The OWIN request context
+ The Google OpenID middleware options
+ The authentication properties of the challenge
+ The initial redirect URI
+
+
+
+ Gets the URI used for the redirect operation.
+
+
+
+
+ Gets the authentication properties of the challenge
+
+
+
+
+ Context passed when a Challenge causes a redirect to authorize endpoint in the Google OAuth 2.0 middleware
+
+
+
+
+ Creates a new context object.
+
+ The OWIN request context
+ The Google OAuth 2.0 middleware options
+ The authenticaiton properties of the challenge
+ The initial redirect URI
+
+
+
+ Gets the URI used for the redirect operation.
+
+
+
+
+ Gets the authenticaiton properties of the challenge
+
+
+
+
+ Contains information about the login session as well as the user .
+
+
+
+
+ Initializes a
+
+ The OWIN environment
+ The JSON-serialized Google user info
+ Google OAuth 2.0 access token
+ Goolge OAuth 2.0 refresh token
+ Seconds until expiration
+
+
+
+ Initializes a
+
+ The OWIN environment
+ The JSON-serialized Google user info
+ The JSON-serialized token response Google
+
+
+
+ Gets the JSON-serialized user
+
+
+ Contains the Google user obtained from the endpoint https://www.googleapis.com/oauth2/v3/userinfo
+
+
+
+
+ Gets the Google access token
+
+
+
+
+ Gets the Google refresh token
+
+
+ This value is not null only when access_type authorize parameter is offline.
+
+
+
+
+ Gets the Google access token expiration time
+
+
+
+
+ Gets the Google user ID
+
+
+
+
+ Gets the user's name
+
+
+
+
+ Gets the user's given name
+
+
+
+
+ Gets the user's family name
+
+
+
+
+ Gets the user's profile link
+
+
+
+
+ Gets the user's email
+
+
+
+
+ Gets the representing the user
+
+
+
+
+ Token response from Google
+
+
+
+
+ Gets or sets a property bag for common authentication properties
+
+
+
+
+ Default implementation.
+
+
+
+
+ Specifies callback methods which the invokes to enable developer control over the authentication process. />
+
+
+
+
+ Invoked whenever Google succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+ Contains context information and authentication ticket of the return endpoint.
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Google OAuth 2.0 middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Initializes a
+
+
+
+
+ Invoked whenever Google succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+ Contains context information and authentication ticket of the return endpoint.
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Google OAuth 2.0 middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Gets or sets the function that is invoked when the Authenticated method is invoked.
+
+
+
+
+ Gets or sets the function that is invoked when the ReturnEndpoint method is invoked.
+
+
+
+
+ Gets or sets the delegate that is invoked when the ApplyRedirect method is invoked.
+
+
+
+
+ Provides context information to middleware providers.
+
+
+
+
+ Initialize a
+
+ OWIN environment
+ The authentication ticket
+
+
+
+ Provides context information to middleware providers.
+
+
+
+
+
+
+ OWIN environment
+ The authentication ticket
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to The '{0}' option must be provided..
+
+
+
+
+ Looks up a localized string similar to An ICertificateValidator cannot be specified at the same time as an HttpMessageHandler unless it is a WebRequestHandler..
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Jwt.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Jwt.dll
new file mode 100644
index 000000000..7e43f9c44
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Jwt.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Jwt.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Jwt.xml
new file mode 100644
index 000000000..661ddcf2d
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Jwt.xml
@@ -0,0 +1,290 @@
+
+
+
+ Microsoft.Owin.Security.Jwt
+
+
+
+
+ Provides security token information to the implementing class.
+
+
+
+
+ Gets the issuer the credentials are for.
+
+
+ The issuer the credentials are for.
+
+
+
+
+ Gets all known security tokens.
+
+
+ All known security tokens.
+
+
+
+
+ Extension methods provided by the JWT bearer token middleware.
+
+
+
+
+ Adds JWT bearer token middleware to your web application pipeline.
+
+ The IAppBuilder passed to your configuration method.
+ An options class that controls the middleware behavior.
+ The original app parameter.
+
+
+
+ Options for JWT Bearer Token handler configuration.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Gets or sets the allowed audiences an inbound JWT will be checked against.
+
+
+ The allowed audiences.
+
+
+
+
+ Gets or sets the issuer security token providers which provide the signing keys
+ a JWT signature is checked against.
+
+
+ The issuer security token providers.
+
+
+
+
+ Gets or sets the authentication provider.
+
+
+ The provider.
+
+
+
+
+ Gets or sets the authentication realm.
+
+
+ The authentication realm.
+
+
+
+
+ Gets or sets the used to determine if a token is valid.
+
+
+
+
+ A System.IdentityModel.Tokens.SecurityTokenHandler designed for creating and validating Json Web Tokens.
+
+
+
+
+ Signs and validates JSON Web Tokens.
+
+
+
+
+ Creates a new JwtFormat with TokenHandler and UseTokenLifetime enabled by default.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The allowed audience for JWTs.
+ The issuer credential provider.
+ Thrown if the is null.
+
+
+
+ Initializes a new instance of the class.
+
+ The allowed audience for JWTs.
+ The issuer credential provider.
+ Thrown if the is null.
+
+
+
+ Initializes a new instance of the class.
+
+ used to determine if a token is valid.
+ Thrown if the is null.
+
+
+
+ Transforms the specified authentication ticket into a JWT.
+
+ The authentication ticket to transform into a JWT.
+
+
+
+
+ Validates the specified JWT and builds an AuthenticationTicket from it.
+
+ The JWT to validate.
+ An AuthenticationTicket built from the
+ Thrown if the is null.
+ Thrown if the is not a JWT.
+
+
+
+ Gets or sets a value indicating whether JWT issuers should be validated.
+
+
+ true if the issuer should be validate; otherwise, false.
+
+
+
+
+ A System.IdentityModel.Tokens.SecurityTokenHandler designed for creating and validating Json Web Tokens.
+
+
+
+
+ Indicates that the authentication session lifetime (e.g. cookies) should match that of the authentication token.
+ If the token does not provide lifetime information then normal session lifetimes will be used.
+ This is enabled by default.
+
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to One or more audiences must be specified..
+
+
+
+
+ Looks up a localized string similar to JWT does not contain an issuer and ValidateIssuer=true..
+
+
+
+
+ Looks up a localized string similar to Invalid JWT..
+
+
+
+
+ Looks up a localized string similar to One or more issuer credential providers must be specified..
+
+
+
+
+ Looks up a localized string similar to Issuer not known..
+
+
+
+
+ Implements an for symmetric key signed JWTs.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The issuer of a JWT token.
+ The symmetric key a JWT is signed with.
+ Thrown when the issuer is null.
+
+
+
+ Initializes a new instance of the class.
+
+ The issuer of a JWT token.
+ Symmetric keys a JWT could be signed with.
+ Thrown when the issuer is null.
+
+
+
+ Initializes a new instance of the class.
+
+ The issuer of a JWT token.
+ The base64 encoded symmetric key a JWT is signed with.
+ Thrown when the issuer is null.
+
+
+
+ Initializes a new instance of the class.
+
+ The issuer of a JWT token.
+ The base64 encoded symmetric keys a JWT could be signed with.
+
+
+
+ Gets the issuer the signing keys are for.
+
+
+ The issuer the signing keys are for.
+
+
+
+
+ Gets all known security tokens.
+
+
+ All known security tokens.
+
+
+
+
+ Implements an for X509 JWTs.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The issuer.
+ The certificate.
+
+ issuer
+ or
+ certificate
+
+
+
+
+ Gets the issuer the credentials are for.
+
+
+ The issuer the credentials are for.
+
+
+
+
+ Gets all known security tokens.
+
+
+ All known security tokens.
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.MicrosoftAccount.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.MicrosoftAccount.dll
new file mode 100644
index 000000000..c7b1e0530
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.MicrosoftAccount.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.MicrosoftAccount.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.MicrosoftAccount.xml
new file mode 100644
index 000000000..e319a2fc0
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.MicrosoftAccount.xml
@@ -0,0 +1,341 @@
+
+
+
+ Microsoft.Owin.Security.MicrosoftAccount
+
+
+
+
+ Extension methods for using
+
+
+
+
+ Authenticate users using Microsoft Account
+
+ The passed to the configuration method
+ Middleware configuration options
+ The updated
+
+
+
+ Authenticate users using Microsoft Account
+
+ The passed to the configuration method
+ The application client ID assigned by the Microsoft authentication service
+ The application client secret assigned by the Microsoft authentication service
+
+
+
+
+ OWIN middleware for authenticating users using the Microsoft Account service
+
+
+
+
+ Initializes a
+
+ The next middleware in the OWIN pipeline to invoke
+ The OWIN application
+ Configuration options for the middleware
+
+
+
+ Provides the object for processing authentication-related requests.
+
+ An configured with the supplied to the constructor.
+
+
+
+ Configuration options for
+
+
+
+
+ Initializes a new .
+
+
+
+
+ Gets or sets the a pinned certificate validator to use to validate the endpoints used
+ in back channel communications belong to Microsoft Account.
+
+
+ The pinned certificate validator.
+
+ If this property is null then the default certificate checks are performed,
+ validating the subject name and if the signing chain is a trusted party.
+
+
+
+ Get or sets the text that the user can display on a sign in user interface.
+
+
+ The default value is 'Microsoft'
+
+
+
+
+ The application client ID assigned by the Microsoft authentication service.
+
+
+
+
+ The application client secret assigned by the Microsoft authentication service.
+
+
+
+
+ Gets or sets timeout value in milliseconds for back channel communications with Microsoft.
+
+
+ The back channel timeout.
+
+
+
+
+ The HttpMessageHandler used to communicate with Microsoft.
+ This cannot be set at the same time as BackchannelCertificateValidator unless the value
+ can be downcast to a WebRequestHandler.
+
+
+
+
+ A list of permissions to request.
+
+
+
+
+ The request path within the application's base path where the user-agent will be returned.
+ The middleware will process this request when it arrives.
+ Default value is "/signin-microsoft".
+
+
+
+
+ Gets or sets the name of another authentication middleware which will be responsible for actually issuing a user .
+
+
+
+
+ Gets or sets the used to handle authentication events.
+
+
+
+
+ Gets or sets the type used to secure data handled by the middleware.
+
+
+
+
+ Specifies callback methods which the invokes to enable developer control over the authentication process. />
+
+
+
+
+ Invoked whenever Microsoft succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Microsoft middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Contains information about the login session as well as the user .
+
+
+
+
+ Initializes a
+
+ The OWIN environment
+ The JSON-serialized user
+ The access token provided by the Microsoft authentication service
+ The refresh token provided by Microsoft authentication service
+ Seconds until expiration
+
+
+
+ Gets the JSON-serialized user
+
+
+
+
+ Gets the access token provided by the Microsoft authenication service
+
+
+
+
+ Gets the refresh token provided by Microsoft authentication service
+
+
+ Refresh token is only available when wl.offline_access is request.
+ Otherwise, it is null.
+
+
+
+
+ Gets the Microsoft access token expiration time
+
+
+
+
+ Gets the Microsoft Account user ID
+
+
+
+
+ Gets the user name
+
+
+
+
+ Gets the user first name
+
+
+
+
+ Gets the user last name
+
+
+
+
+ Gets the user email address
+
+
+
+
+ Gets the representing the user
+
+
+
+
+ Gets or sets a property bag for common authentication properties
+
+
+
+
+ Default implementation.
+
+
+
+
+ Initializes a new
+
+
+
+
+ Invoked whenever Microsoft succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+ Contains information about the login session as well as the user
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Microsoft account middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Gets or sets the function that is invoked when the Authenticated method is invoked.
+
+
+
+
+ Gets or sets the function that is invoked when the ReturnEndpoint method is invoked.
+
+
+
+
+ Gets or sets the delegate that is invoked when the ApplyRedirect method is invoked.
+
+
+
+
+ Provides context information to middleware providers.
+
+
+
+
+ Initializes a new .
+
+ OWIN environment
+ The authentication ticket
+
+
+
+ Context passed when a Challenge causes a redirect to authorize endpoint in the Microsoft account middleware
+
+
+
+
+ Creates a new context object.
+
+ The OWIN request context
+ The Microsoft account middleware options
+ The authenticaiton properties of the challenge
+ The initial redirect URI
+
+
+
+ Gets the URI used for the redirect operation.
+
+
+
+
+ Gets the authenticaiton properties of the challenge
+
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to The user does not have an id..
+
+
+
+
+ Looks up a localized string similar to The '{0}' option must be provided..
+
+
+
+
+ Looks up a localized string similar to An ICertificateValidator cannot be specified at the same time as an HttpMessageHandler unless it is a WebRequestHandler..
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.OAuth.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.OAuth.dll
new file mode 100644
index 000000000..8f95e3053
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.OAuth.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.OAuth.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.OAuth.xml
new file mode 100644
index 000000000..c480bc855
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.OAuth.xml
@@ -0,0 +1,1637 @@
+
+
+
+ Microsoft.Owin.Security.OAuth
+
+
+
+
+ Data object used by TokenEndpointRequest which contains parameter information when the "grant_type" is unrecognized.
+
+
+
+
+ The parameter information when the "grant_type" is unrecognized.
+
+
+
+
+ Data object used by TokenEndpointRequest when the "grant_type" parameter is "refresh_token".
+
+
+
+
+ The value passed to the Token endpoint in the "refresh_token" parameter
+
+
+
+
+ The value passed to the Token endpoint in the "scope" parameter
+
+
+
+
+ Data object used by TokenEndpointRequest when the "grant_type" is "authorization_code".
+
+
+
+
+ The value passed to the Token endpoint in the "code" parameter
+
+
+
+
+ The value passed to the Token endpoint in the "redirect_uri" parameter. This MUST be provided by the caller
+ if the original visit to the Authorize endpoint contained a "redirect_uri" parameter.
+
+
+
+
+ Data object representing the information contained in the query string of an Authorize endpoint request.
+
+
+
+
+ Creates a new instance populated with values from the query string parameters.
+
+ Query string parameters from a request.
+
+
+
+ True if the "response_type" query string contains the passed responseType.
+ See also, http://openid.net/specs/oauth-v2-multiple-response-types-1_0.html
+
+ The responseType that is expected within the "response_type" query string
+ True if the "response_type" query string contains the passed responseType.
+
+
+
+ The "response_type" query string parameter of the Authorize request. Known values are "code" and "token".
+
+
+
+
+ The "response_mode" query string parameter of the Authorize request. Known values are "query", "fragment" and "form_post"
+ See also, http://openid.net/specs/oauth-v2-form-post-response-mode-1_0.html
+
+
+
+
+ The "client_id" query string parameter of the Authorize request.
+
+
+
+
+ The "redirect_uri" query string parameter of the Authorize request. May be absent if the server should use the
+ redirect uri known to be registered to the client id.
+
+
+
+
+ The "scope" query string parameter of the Authorize request. May be absent if the server should use default scopes.
+
+
+
+
+ The "scope" query string parameter of the Authorize request. May be absent if the client does not require state to be
+ included when returning to the RedirectUri.
+
+
+
+
+ True if the "response_type" query string parameter is "code".
+ See also, http://tools.ietf.org/html/rfc6749#section-4.1.1
+
+
+
+
+ True if the "response_type" query string parameter is "token".
+ See also, http://tools.ietf.org/html/rfc6749#section-4.2.1
+
+
+
+
+ Data object representing the information contained in form encoded body of a Token endpoint request.
+
+
+
+
+ Creates a new instance populated with values from the form encoded body parameters.
+
+ Form encoded body parameters from a request.
+
+
+
+ The form encoded body parameters of the Token endpoint request
+
+
+
+
+ The "grant_type" parameter of the Token endpoint request. This parameter is required.
+
+
+
+
+ The "client_id" parameter of the Token endpoint request. This parameter is optional. It might not
+ be present if the request is authenticated in a different way, for example, by using basic authentication
+ credentials.
+
+
+
+
+ Data object available when the "grant_type" is "authorization_code".
+ See also http://tools.ietf.org/html/rfc6749#section-4.1.3
+
+
+
+
+ Data object available when the "grant_type" is "client_credentials".
+ See also http://tools.ietf.org/html/rfc6749#section-4.4.2
+
+
+
+
+ Data object available when the "grant_type" is "refresh_token".
+ See also http://tools.ietf.org/html/rfc6749#section-6
+
+
+
+
+ Data object available when the "grant_type" is "password".
+ See also http://tools.ietf.org/html/rfc6749#section-4.3.2
+
+
+
+
+ Data object available when the "grant_type" is unrecognized.
+ See also http://tools.ietf.org/html/rfc6749#section-4.5
+
+
+
+
+ True when the "grant_type" is "authorization_code".
+ See also http://tools.ietf.org/html/rfc6749#section-4.1.3
+
+
+
+
+ True when the "grant_type" is "client_credentials".
+ See also http://tools.ietf.org/html/rfc6749#section-4.4.2
+
+
+
+
+ True when the "grant_type" is "refresh_token".
+ See also http://tools.ietf.org/html/rfc6749#section-6
+
+
+
+
+ True when the "grant_type" is "password".
+ See also http://tools.ietf.org/html/rfc6749#section-4.3.2
+
+
+
+
+ True when the "grant_type" is unrecognized.
+ See also http://tools.ietf.org/html/rfc6749#section-4.5
+
+
+
+
+ Data object used by TokenEndpointRequest when the "grant_type" is "client_credentials".
+
+
+
+
+ The value passed to the Token endpoint in the "scope" parameter
+
+
+
+
+ Data object used by TokenEndpointRequest when the "grant_type" is "password".
+
+
+
+
+ The value passed to the Token endpoint in the "username" parameter
+
+
+
+
+ The value passed to the Token endpoint in the "password" parameter
+
+
+
+
+ The value passed to the Token endpoint in the "scope" parameter
+
+
+
+
+ Extension methods to add Authorization Server capabilities to an OWIN pipeline
+
+
+
+
+ Adds OAuth2 Authorization Server capabilities to an OWIN web application. This middleware
+ performs the request processing for the Authorize and Token endpoints defined by the OAuth2 specification.
+ See also http://tools.ietf.org/html/rfc6749
+
+ The web application builder
+ Options which control the behavior of the Authorization Server.
+ The application builder
+
+
+
+ Options class provides information needed to control Authorization Server middleware behavior
+
+
+
+
+ Creates an instance of authorization server options with default values.
+
+
+
+
+ The request path where client applications will redirect the user-agent in order to
+ obtain user consent to issue a token. Must begin with a leading slash, like "/Authorize".
+
+
+
+
+ The request path client applications communicate with directly as part of the OAuth protocol.
+ Must begin with a leading slash, like "/Token". If the client is issued a client_secret, it must
+ be provided to this endpoint.
+
+
+
+
+ The object provided by the application to process events raised by the Authorization Server middleware.
+ The application may implement the interface fully, or it may create an instance of OAuthAuthorizationServerProvider
+ and assign delegates only to the events it wants to process.
+
+
+
+
+ The data format used to protect and unprotect the information contained in the authorization code.
+ If not provided by the application the default data protection provider depends on the host server.
+ The SystemWeb host on IIS will use ASP.NET machine key data protection, and HttpListener and other self-hosted
+ servers will use DPAPI data protection.
+
+
+
+
+ The data format used to protect the information contained in the access token.
+ If not provided by the application the default data protection provider depends on the host server.
+ The SystemWeb host on IIS will use ASP.NET machine key data protection, and HttpListener and other self-hosted
+ servers will use DPAPI data protection. If a different access token
+ provider or format is assigned, a compatible instance must be assigned to the OAuthBearerAuthenticationOptions.AccessTokenProvider
+ or OAuthBearerAuthenticationOptions.AccessTokenFormat property of the resource server.
+
+
+
+
+ The data format used to protect and unprotect the information contained in the refresh token.
+ If not provided by the application the default data protection provider depends on the host server.
+ The SystemWeb host on IIS will use ASP.NET machine key data protection, and HttpListener and other self-hosted
+ servers will use DPAPI data protection.
+
+
+
+
+ The period of time the authorization code remains valid after being issued. The default is five minutes.
+ This time span must also take into account clock synchronization between servers in a web farm, so a very
+ brief value could result in unexpectedly expired tokens.
+
+
+
+
+ The period of time the access token remains valid after being issued. The default is twenty minutes.
+ The client application is expected to refresh or acquire a new access token after the token has expired.
+
+
+
+
+ Produces a single-use authorization code to return to the client application. For the OAuth server to be secure the
+ application MUST provide an instance for AuthorizationCodeProvider where the token produced by the OnCreate or OnCreateAsync event
+ is considered valid for only one call to OnReceive or OnReceiveAsync.
+
+
+
+
+ Produces a bearer token the client application will typically be providing to resource server as the authorization bearer
+ http request header. If not provided the token produced on the server's default data protection. If a different access token
+ provider or format is assigned, a compatible instance must be assigned to the OAuthBearerAuthenticationOptions.AccessTokenProvider
+ or OAuthBearerAuthenticationOptions.AccessTokenFormat property of the resource server.
+
+
+
+
+ Produces a refresh token which may be used to produce a new access token when needed. If not provided the authorization server will
+ not return refresh tokens from the /Token endpoint.
+
+
+
+
+ Set to true if the web application is able to render error messages on the /Authorize endpoint. This is only needed for cases where
+ the browser is not redirected back to the client application, for example, when the client_id or redirect_uri are incorrect. The
+ /Authorize endpoint should expect to see "oauth.Error", "oauth.ErrorDescription", "oauth.ErrorUri" properties added to the owin environment.
+
+
+
+
+ Used to know what the current clock time is when calculating or validating token expiration. When not assigned default is based on
+ DateTimeOffset.UtcNow. This is typically needed only for unit testing.
+
+
+
+
+ True to allow authorize and token requests to arrive on http URI addresses, and to allow incoming
+ redirect_uri authorize request parameter to have http URI addresses.
+
+
+
+
+ Endpoint responsible for Form Post Response Mode
+ See also, http://openid.net/specs/oauth-v2-form-post-response-mode-1_0.html
+
+
+
+
+ Authorization Server middleware component which is added to an OWIN pipeline. This class is not
+ created by application code directly, instead it is added by calling the the IAppBuilder UseOAuthAuthorizationServer
+ extension method.
+
+
+
+
+ Authorization Server middleware component which is added to an OWIN pipeline. This constructor is not
+ called by application code directly, instead it is added by calling the the IAppBuilder UseOAuthAuthorizationServer
+ extension method.
+
+
+
+
+ Called by the AuthenticationMiddleware base class to create a per-request handler.
+
+ A new instance of the request handler
+
+
+
+ Extension methods to add OAuth Bearer authentication capabilities to an OWIN application pipeline
+
+
+
+
+ Adds Bearer token processing to an OWIN application pipeline. This middleware understands appropriately
+ formatted and secured tokens which appear in the request header. If the Options.AuthenticationMode is Active, the
+ claims within the bearer token are added to the current request's IPrincipal User. If the Options.AuthenticationMode
+ is Passive, then the current request is not modified, but IAuthenticationManager AuthenticateAsync may be used at
+ any time to obtain the claims from the request's bearer token.
+ See also http://tools.ietf.org/html/rfc6749
+
+ The web application builder
+ Options which control the processing of the bearer header.
+ The application builder
+
+
+
+ Bearer authentication middleware component which is added to an OWIN pipeline. This class is not
+ created by application code directly, instead it is added by calling the the IAppBuilder UseOAuthBearerAuthentication
+ extension method.
+
+
+
+
+ Bearer authentication component which is added to an OWIN pipeline. This constructor is not
+ called by application code directly, instead it is added by calling the the IAppBuilder UseOAuthBearerAuthentication
+ extension method.
+
+
+
+
+ Called by the AuthenticationMiddleware base class to create a per-request handler.
+
+ A new instance of the request handler
+
+
+
+ Options class provides information needed to control Bearer Authentication middleware behavior
+
+
+
+
+ Creates an instance of bearer authentication options with default values.
+
+
+
+
+ Determines what realm value is included when the bearer middleware adds a response header to an unauthorized request.
+ If not assigned, the response header does not have a realm.
+
+
+
+
+ Specifies the full challenge to send to the client, and should start with "Bearer". If a challenge is provided then the
+ Realm property is ignored. If no challenge is specified then one is created using "Bearer" and the value of the Realm
+ property.
+
+
+
+
+ The object provided by the application to process events raised by the bearer authentication middleware.
+ The application may implement the interface fully, or it may create an instance of OAuthBearerAuthenticationProvider
+ and assign delegates only to the events it wants to process.
+
+
+
+
+ The data format used to un-protect the information contained in the access token.
+ If not provided by the application the default data protection provider depends on the host server.
+ The SystemWeb host on IIS will use ASP.NET machine key data protection, and HttpListener and other self-hosted
+ servers will use DPAPI data protection. If a different access token
+ provider or format is assigned, a compatible instance must be assigned to the OAuthAuthorizationServerOptions.AccessTokenProvider
+ and OAuthAuthorizationServerOptions.AccessTokenFormat of the authorization server.
+
+
+
+
+ Receives the bearer token the client application will be providing to web application. If not provided the token
+ produced on the server's default data protection by using the AccessTokenFormat. If a different access token
+ provider or format is assigned, a compatible instance must be assigned to the OAuthAuthorizationServerOptions.AccessTokenProvider
+ and OAuthAuthorizationServerOptions.AccessTokenFormat of the authorization server.
+
+
+
+
+ Used to know what the current clock time is when calculating or validating token expiration. When not assigned default is based on
+ DateTimeOffset.UtcNow. This is typically needed only for unit testing.
+
+
+
+
+ Default values used by authorization server and bearer authentication.
+
+
+
+
+ Default value for AuthenticationType property in the OAuthBearerAuthenticationOptions and
+ OAuthAuthorizationServerOptions.
+
+
+
+
+ Provides context information used at the end of a token-endpoint-request.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+ Issues the token.
+
+
+
+
+
+
+ Gets the identity of the resource owner.
+
+
+
+
+ Dictionary containing the state of the authentication session.
+
+
+
+
+ The issued Access-Token
+
+
+
+
+ Gets information about the token endpoint request.
+
+
+
+
+ Gets whether or not the token should be issued.
+
+
+
+
+ Enables additional values to be appended to the token response.
+
+
+
+
+ Base class used for certain event contexts
+
+
+
+
+ Base class used for certain event contexts
+
+
+
+
+ Initializes base class used for certain event contexts
+
+
+
+
+ Marks this context as validated by the application. IsValidated becomes true and HasError becomes false as a result of calling.
+
+ True if the validation has taken effect.
+
+
+
+ Marks this context as not validated by the application. IsValidated and HasError become false as a result of calling.
+
+
+
+
+ Marks this context as not validated by the application and assigns various error information properties.
+ HasError becomes true and IsValidated becomes false as a result of calling.
+
+ Assigned to the Error property
+
+
+
+ Marks this context as not validated by the application and assigns various error information properties.
+ HasError becomes true and IsValidated becomes false as a result of calling.
+
+ Assigned to the Error property
+ Assigned to the ErrorDescription property
+
+
+
+ Marks this context as not validated by the application and assigns various error information properties.
+ HasError becomes true and IsValidated becomes false as a result of calling.
+
+ Assigned to the Error property
+ Assigned to the ErrorDescription property
+ Assigned to the ErrorUri property
+
+
+
+ True if application code has called any of the Validate methods on this context.
+
+
+
+
+ True if application code has called any of the SetError methods on this context.
+
+
+
+
+ The error argument provided when SetError was called on this context. This is eventually
+ returned to the client app as the OAuth "error" parameter.
+
+
+
+
+ The optional errorDescription argument provided when SetError was called on this context. This is eventually
+ returned to the client app as the OAuth "error_description" parameter.
+
+
+
+
+ The optional errorUri argument provided when SetError was called on this context. This is eventually
+ returned to the client app as the OAuth "error_uri" parameter.
+
+
+
+
+ Initializes base class used for certain event contexts
+
+
+
+
+ The "client_id" parameter for the current request. The Authorization Server application is responsible for
+ validating this value identifies a registered client.
+
+
+
+
+ Base class used for certain event contexts
+
+
+
+
+ Initializes base class used for certain event contexts
+
+
+
+
+ Replaces the ticket information on this context and marks it as as validated by the application.
+ IsValidated becomes true and HasError becomes false as a result of calling.
+
+ Assigned to the Ticket property
+ True if the validation has taken effect.
+
+
+
+ Alters the ticket information on this context and marks it as as validated by the application.
+ IsValidated becomes true and HasError becomes false as a result of calling.
+
+ Assigned to the Ticket.Identity property
+ True if the validation has taken effect.
+
+
+
+ Contains the identity and properties for the application to authenticate. If the Validated method
+ is invoked with an AuthenticationTicket or ClaimsIdentity argument, that new value is assigned to
+ this property in addition to changing IsValidated to true.
+
+
+
+
+ Provides context information when processing an Authorization Response
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+ Gets the identity of the resource owner.
+
+
+
+
+ Dictionary containing the state of the authentication session.
+
+
+
+
+ Gets information about the authorize endpoint request.
+
+
+
+
+ Enables additional values to be appended to the token response.
+
+
+
+
+ The serialized Access-Token. Depending on the flow, it can be null.
+
+
+
+
+ The created Authorization-Code. Depending on the flow, it can be null.
+
+
+
+
+ An event raised after the Authorization Server has processed the request, but before it is passed on to the web application.
+ Calling RequestCompleted will prevent the request from passing on to the web application.
+
+
+
+
+ Creates an instance of this context
+
+
+
+
+ Gets OAuth authorization request data.
+
+
+
+
+ Interface for OAuthAuthorizationServerOptions.Provider property used by Authorization
+ Server to communicate with the web application while processing requests.
+
+
+
+
+ Called to determine if an incoming request is treated as an Authorize or Token
+ endpoint. If Options.AuthorizeEndpointPath or Options.TokenEndpointPath
+ are assigned values, then handling this event is optional and context.IsAuthorizeEndpoint and context.IsTokenEndpoint
+ will already be true if the request path matches.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called to validate that the context.ClientId is a registered "client_id", and that the context.RedirectUri a "redirect_uri"
+ registered for that client. This only occurs when processing the Authorize endpoint. The application MUST implement this
+ call, and it MUST validate both of those factors before calling context.Validated. If the context.Validated method is called
+ with a given redirectUri parameter, then IsValidated will only become true if the incoming redirect URI matches the given redirect URI.
+ If context.Validated is not called the request will not proceed further.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called to validate that the origin of the request is a registered "client_id", and that the correct credentials for that client are
+ present on the request. If the web application accepts Basic authentication credentials,
+ context.TryGetBasicCredentials(out clientId, out clientSecret) may be called to acquire those values if present in the request header. If the web
+ application accepts "client_id" and "client_secret" as form encoded POST parameters,
+ context.TryGetFormCredentials(out clientId, out clientSecret) may be called to acquire those values if present in the request body.
+ If context.Validated is not called the request will not proceed further.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called for each request to the Authorize endpoint to determine if the request is valid and should continue.
+ The default behavior when using the OAuthAuthorizationServerProvider is to assume well-formed requests, with
+ validated client redirect URI, should continue processing. An application may add any additional constraints.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called for each request to the Token endpoint to determine if the request is valid and should continue.
+ The default behavior when using the OAuthAuthorizationServerProvider is to assume well-formed requests, with
+ validated client credentials, should continue processing. An application may add any additional constraints.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "authorization_code". This occurs after the Authorize
+ endpoint as redirected the user-agent back to the client with a "code" parameter, and the client is exchanging that for an "access_token".
+ The claims and properties
+ associated with the authorization code are present in the context.Ticket. The application must call context.Validated to instruct the Authorization
+ Server middleware to issue an access token based on those claims and properties. The call to context.Validated may be given a different
+ AuthenticationTicket or ClaimsIdentity in order to control which information flows from authorization code to access token.
+ The default behavior when using the OAuthAuthorizationServerProvider is to flow information from the authorization code to
+ the access token unmodified.
+ See also http://tools.ietf.org/html/rfc6749#section-4.1.3
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "refresh_token". This occurs if your application has issued a "refresh_token"
+ along with the "access_token", and the client is attempting to use the "refresh_token" to acquire a new "access_token", and possibly a new "refresh_token".
+ To issue a refresh token the an Options.RefreshTokenProvider must be assigned to create the value which is returned. The claims and properties
+ associated with the refresh token are present in the context.Ticket. The application must call context.Validated to instruct the
+ Authorization Server middleware to issue an access token based on those claims and properties. The call to context.Validated may
+ be given a different AuthenticationTicket or ClaimsIdentity in order to control which information flows from the refresh token to
+ the access token. The default behavior when using the OAuthAuthorizationServerProvider is to flow information from the refresh token to
+ the access token unmodified.
+ See also http://tools.ietf.org/html/rfc6749#section-6
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "password". This occurs when the user has provided name and password
+ credentials directly into the client application's user interface, and the client application is using those to acquire an "access_token" and
+ optional "refresh_token". If the web application supports the
+ resource owner credentials grant type it must validate the context.Username and context.Password as appropriate. To issue an
+ access token the context.Validated must be called with a new ticket containing the claims about the resource owner which should be associated
+ with the access token. The application should take appropriate measures to ensure that the endpoint isn’t abused by malicious callers. .
+ The default behavior is to reject this grant type.
+ See also http://tools.ietf.org/html/rfc6749#section-4.3.2
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "client_credentials". This occurs when a registered client
+ application wishes to acquire an "access_token" to interact with protected resources on it's own behalf, rather than on behalf of an authenticated user.
+ If the web application supports the client credentials it may assume the context.ClientId has been validated by the ValidateClientAuthentication call.
+ To issue an access token the context.Validated must be called with a new ticket containing the claims about the client application which should be associated
+ with the access token. The application should take appropriate measures to ensure that the endpoint isn’t abused by malicious callers.
+ The default behavior is to reject this grant type.
+ See also http://tools.ietf.org/html/rfc6749#section-4.4.2
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token andpoint arrives with a "grant_type" of any other value. If the application supports custom grant types
+ it is entirely responsible for determining if the request should result in an access_token. If context.Validated is called with ticket
+ information the response body is produced in the same way as the other standard grant types. If additional response parameters must be
+ included they may be added in the final TokenEndpoint call.
+ See also http://tools.ietf.org/html/rfc6749#section-4.5
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called at the final stage of an incoming Authorize endpoint request before the execution continues on to the web application component
+ responsible for producing the html response. Anything present in the OWIN pipeline following the Authorization Server may produce the
+ response for the Authorize page. If running on IIS any ASP.NET technology running on the server may produce the response for the
+ Authorize page. If the web application wishes to produce the response directly in the AuthorizeEndpoint call it may write to the
+ context.Response directly and should call context.RequestCompleted to stop other handlers from executing. If the web application wishes
+ to grant the authorization directly in the AuthorizeEndpoint call it cay call context.OwinContext.Authentication.SignIn with the
+ appropriate ClaimsIdentity and should call context.RequestCompleted to stop other handlers from executing.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called at the final stage of a successful Token endpoint request. An application may implement this call in order to do any final
+ modification of the claims being used to issue access or refresh tokens. This call may also be used in order to add additional
+ response parameters to the Token endpoint's json response body.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called before the AuthorizationEndpoint redirects its response to the caller. The response could be the
+ token, when using implicit flow or the AuthorizationEndpoint when using authorization code flow.
+ An application may implement this call in order to do any final modification of the claims being used
+ to issue access or refresh tokens. This call may also be used in order to add additional
+ response parameters to the authorization endpoint's response.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called before the TokenEndpoint redirects its response to the caller.
+
+
+
+
+
+
+ Default implementation of IOAuthAuthorizationServerProvider used by Authorization
+ Server to communicate with the web application while processing requests. OAuthAuthorizationServerProvider provides some default behavior,
+ may be used as a virtual base class, and offers delegate properties which may be used to
+ handle individual calls without declaring a new class type.
+
+
+
+
+ Creates new instance of default provider behavior
+
+
+
+
+ Called to determine if an incoming request is treated as an Authorize or Token
+ endpoint. If Options.AuthorizeEndpointPath or Options.TokenEndpointPath
+ are assigned values, then handling this event is optional and context.IsAuthorizeEndpoint and context.IsTokenEndpoint
+ will already be true if the request path matches.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called to validate that the context.ClientId is a registered "client_id", and that the context.RedirectUri a "redirect_uri"
+ registered for that client. This only occurs when processing the Authorize endpoint. The application MUST implement this
+ call, and it MUST validate both of those factors before calling context.Validated. If the context.Validated method is called
+ with a given redirectUri parameter, then IsValidated will only become true if the incoming redirect URI matches the given redirect URI.
+ If context.Validated is not called the request will not proceed further.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called to validate that the origin of the request is a registered "client_id", and that the correct credentials for that client are
+ present on the request. If the web application accepts Basic authentication credentials,
+ context.TryGetBasicCredentials(out clientId, out clientSecret) may be called to acquire those values if present in the request header. If the web
+ application accepts "client_id" and "client_secret" as form encoded POST parameters,
+ context.TryGetFormCredentials(out clientId, out clientSecret) may be called to acquire those values if present in the request body.
+ If context.Validated is not called the request will not proceed further.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called for each request to the Authorize endpoint to determine if the request is valid and should continue.
+ The default behavior when using the OAuthAuthorizationServerProvider is to assume well-formed requests, with
+ validated client redirect URI, should continue processing. An application may add any additional constraints.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called for each request to the Token endpoint to determine if the request is valid and should continue.
+ The default behavior when using the OAuthAuthorizationServerProvider is to assume well-formed requests, with
+ validated client credentials, should continue processing. An application may add any additional constraints.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "authorization_code". This occurs after the Authorize
+ endpoint as redirected the user-agent back to the client with a "code" parameter, and the client is exchanging that for an "access_token".
+ The claims and properties
+ associated with the authorization code are present in the context.Ticket. The application must call context.Validated to instruct the Authorization
+ Server middleware to issue an access token based on those claims and properties. The call to context.Validated may be given a different
+ AuthenticationTicket or ClaimsIdentity in order to control which information flows from authorization code to access token.
+ The default behavior when using the OAuthAuthorizationServerProvider is to flow information from the authorization code to
+ the access token unmodified.
+ See also http://tools.ietf.org/html/rfc6749#section-4.1.3
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "refresh_token". This occurs if your application has issued a "refresh_token"
+ along with the "access_token", and the client is attempting to use the "refresh_token" to acquire a new "access_token", and possibly a new "refresh_token".
+ To issue a refresh token the an Options.RefreshTokenProvider must be assigned to create the value which is returned. The claims and properties
+ associated with the refresh token are present in the context.Ticket. The application must call context.Validated to instruct the
+ Authorization Server middleware to issue an access token based on those claims and properties. The call to context.Validated may
+ be given a different AuthenticationTicket or ClaimsIdentity in order to control which information flows from the refresh token to
+ the access token. The default behavior when using the OAuthAuthorizationServerProvider is to flow information from the refresh token to
+ the access token unmodified.
+ See also http://tools.ietf.org/html/rfc6749#section-6
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "password". This occurs when the user has provided name and password
+ credentials directly into the client application's user interface, and the client application is using those to acquire an "access_token" and
+ optional "refresh_token". If the web application supports the
+ resource owner credentials grant type it must validate the context.Username and context.Password as appropriate. To issue an
+ access token the context.Validated must be called with a new ticket containing the claims about the resource owner which should be associated
+ with the access token. The application should take appropriate measures to ensure that the endpoint isn’t abused by malicious callers.
+ The default behavior is to reject this grant type.
+ See also http://tools.ietf.org/html/rfc6749#section-4.3.2
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "client_credentials". This occurs when a registered client
+ application wishes to acquire an "access_token" to interact with protected resources on it's own behalf, rather than on behalf of an authenticated user.
+ If the web application supports the client credentials it may assume the context.ClientId has been validated by the ValidateClientAuthentication call.
+ To issue an access token the context.Validated must be called with a new ticket containing the claims about the client application which should be associated
+ with the access token. The application should take appropriate measures to ensure that the endpoint isn’t abused by malicious callers.
+ The default behavior is to reject this grant type.
+ See also http://tools.ietf.org/html/rfc6749#section-4.4.2
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of any other value. If the application supports custom grant types
+ it is entirely responsible for determining if the request should result in an access_token. If context.Validated is called with ticket
+ information the response body is produced in the same way as the other standard grant types. If additional response parameters must be
+ included they may be added in the final TokenEndpoint call.
+ See also http://tools.ietf.org/html/rfc6749#section-4.5
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called at the final stage of an incoming Authorize endpoint request before the execution continues on to the web application component
+ responsible for producing the html response. Anything present in the OWIN pipeline following the Authorization Server may produce the
+ response for the Authorize page. If running on IIS any ASP.NET technology running on the server may produce the response for the
+ Authorize page. If the web application wishes to produce the response directly in the AuthorizeEndpoint call it may write to the
+ context.Response directly and should call context.RequestCompleted to stop other handlers from executing. If the web application wishes
+ to grant the authorization directly in the AuthorizeEndpoint call it cay call context.OwinContext.Authentication.SignIn with the
+ appropriate ClaimsIdentity and should call context.RequestCompleted to stop other handlers from executing.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called at the final stage of a successful Token endpoint request. An application may implement this call in order to do any final
+ modification of the claims being used to issue access or refresh tokens. This call may also be used in order to add additional
+ response parameters to the Token endpoint's json response body.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called before the AuthorizationEndpoint redirects its response to the caller. The response could be the
+ token, when using implicit flow or the AuthorizationEndpoint when using authorization code flow.
+ An application may implement this call in order to do any final modification of the claims being used
+ to issue access or refresh tokens. This call may also be used in order to add additional
+ response parameters to the authorization endpoint's response.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called before the TokenEndpoint redirects its response to the caller.
+
+
+
+
+
+
+ Called to determine if an incoming request is treated as an Authorize or Token
+ endpoint. If Options.AuthorizeEndpointPath or Options.TokenEndpointPath
+ are assigned values, then handling this event is optional and context.IsAuthorizeEndpoint and context.IsTokenEndpoint
+ will already be true if the request path matches.
+
+
+
+
+ Called to validate that the context.ClientId is a registered "client_id", and that the context.RedirectUri a "redirect_uri"
+ registered for that client. This only occurs when processing the Authorize endpoint. The application MUST implement this
+ call, and it MUST validate both of those factors before calling context.Validated. If the context.Validated method is called
+ with a given redirectUri parameter, then IsValidated will only become true if the incoming redirect URI matches the given redirect URI.
+ If context.Validated is not called the request will not proceed further.
+
+
+
+
+ Called to validate that the origin of the request is a registered "client_id", and that the correct credentials for that client are
+ present on the request. If the web application accepts Basic authentication credentials,
+ context.TryGetBasicCredentials(out clientId, out clientSecret) may be called to acquire those values if present in the request header. If the web
+ application accepts "client_id" and "client_secret" as form encoded POST parameters,
+ context.TryGetFormCredentials(out clientId, out clientSecret) may be called to acquire those values if present in the request body.
+ If context.Validated is not called the request will not proceed further.
+
+
+
+
+ Called for each request to the Authorize endpoint to determine if the request is valid and should continue.
+ The default behavior when using the OAuthAuthorizationServerProvider is to assume well-formed requests, with
+ validated client redirect URI, should continue processing. An application may add any additional constraints.
+
+
+
+
+ Called for each request to the Token endpoint to determine if the request is valid and should continue.
+ The default behavior when using the OAuthAuthorizationServerProvider is to assume well-formed requests, with
+ validated client credentials, should continue processing. An application may add any additional constraints.
+
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "authorization_code". This occurs after the Authorize
+ endpoint as redirected the user-agent back to the client with a "code" parameter, and the client is exchanging that for an "access_token".
+ The claims and properties
+ associated with the authorization code are present in the context.Ticket. The application must call context.Validated to instruct the Authorization
+ Server middleware to issue an access token based on those claims and properties. The call to context.Validated may be given a different
+ AuthenticationTicket or ClaimsIdentity in order to control which information flows from authorization code to access token.
+ The default behavior when using the OAuthAuthorizationServerProvider is to flow information from the authorization code to
+ the access token unmodified.
+ See also http://tools.ietf.org/html/rfc6749#section-4.1.3
+
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "password". This occurs when the user has provided name and password
+ credentials directly into the client application's user interface, and the client application is using those to acquire an "access_token" and
+ optional "refresh_token". If the web application supports the
+ resource owner credentials grant type it must validate the context.Username and context.Password as appropriate. To issue an
+ access token the context.Validated must be called with a new ticket containing the claims about the resource owner which should be associated
+ with the access token. The application should take appropriate measures to ensure that the endpoint isn’t abused by malicious callers.
+ The default behavior is to reject this grant type.
+ See also http://tools.ietf.org/html/rfc6749#section-4.3.2
+
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "client_credentials". This occurs when a registered client
+ application wishes to acquire an "access_token" to interact with protected resources on it's own behalf, rather than on behalf of an authenticated user.
+ If the web application supports the client credentials it may assume the context.ClientId has been validated by the ValidateClientAuthentication call.
+ To issue an access token the context.Validated must be called with a new ticket containing the claims about the client application which should be associated
+ with the access token. The application should take appropriate measures to ensure that the endpoint isn’t abused by malicious callers.
+ The default behavior is to reject this grant type.
+ See also http://tools.ietf.org/html/rfc6749#section-4.4.2
+
+
+
+
+ Called when a request to the Token endpoint arrives with a "grant_type" of "refresh_token". This occurs if your application has issued a "refresh_token"
+ along with the "access_token", and the client is attempting to use the "refresh_token" to acquire a new "access_token", and possibly a new "refresh_token".
+ To issue a refresh token the an Options.RefreshTokenProvider must be assigned to create the value which is returned. The claims and properties
+ associated with the refresh token are present in the context.Ticket. The application must call context.Validated to instruct the
+ Authorization Server middleware to issue an access token based on those claims and properties. The call to context.Validated may
+ be given a different AuthenticationTicket or ClaimsIdentity in order to control which information flows from the refresh token to
+ the access token. The default behavior when using the OAuthAuthorizationServerProvider is to flow information from the refresh token to
+ the access token unmodified.
+ See also http://tools.ietf.org/html/rfc6749#section-6
+
+
+
+
+ Called when a request to the Token andpoint arrives with a "grant_type" of any other value. If the application supports custom grant types
+ it is entirely responsible for determining if the request should result in an access_token. If context.Validated is called with ticket
+ information the response body is produced in the same way as the other standard grant types. If additional response parameters must be
+ included they may be added in the final TokenEndpoint call.
+ See also http://tools.ietf.org/html/rfc6749#section-4.5
+
+
+
+
+ Called at the final stage of an incoming Authorize endpoint request before the execution continues on to the web application component
+ responsible for producing the html response. Anything present in the OWIN pipeline following the Authorization Server may produce the
+ response for the Authorize page. If running on IIS any ASP.NET technology running on the server may produce the response for the
+ Authorize page. If the web application wishes to produce the response directly in the AuthorizeEndpoint call it may write to the
+ context.Response directly and should call context.RequestCompleted to stop other handlers from executing. If the web application wishes
+ to grant the authorization directly in the AuthorizeEndpoint call it cay call context.OwinContext.Authentication.SignIn with the
+ appropriate ClaimsIdentity and should call context.RequestCompleted to stop other handlers from executing.
+
+
+
+
+ Called at the final stage of a successful Token endpoint request. An application may implement this call in order to do any final
+ modification of the claims being used to issue access or refresh tokens. This call may also be used in order to add additional
+ response parameters to the Token endpoint's json response body.
+
+
+
+
+ Called before the AuthorizationEndpoint redirects its response to the caller. The response could be the
+ token, when using implicit flow or the AuthorizationEndpoint when using authorization code flow.
+ An application may implement this call in order to do any final modification of the claims being used
+ to issue access or refresh tokens. This call may also be used in order to add additional
+ response parameters to the authorization endpoint's response.
+
+ The context of the event carries information in and results out.
+ Task to enable asynchronous execution
+
+
+
+ Called before the TokenEndpoint redirects its response to the caller.
+
+
+
+
+
+
+ OAuth bearer token middleware provider
+
+
+
+
+ Specifies callback methods which the invokes to enable developer control over the authentication process. />
+
+
+
+
+ Invoked before the is created. Gives the application an
+ opportunity to find the identity from a different location, adjust, or reject the token.
+
+ Contains the token string.
+ A representing the completed operation.
+
+
+
+ Called each time a request identity has been validated by the middleware. By implementing this method the
+ application may alter or reject the identity which has arrived with the request.
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Called each time a challenge is being sent to the client. By implementing this method the application
+ may modify the challenge as needed.
+
+ Contains the default challenge.
+ A representing the completed operation.
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+ Handles processing OAuth bearer token.
+
+
+
+
+
+
+ Handles validating the identity produced from an OAuth bearer token.
+
+
+
+
+
+
+ Handles applying the authentication challenge to the response message.
+
+
+
+
+
+
+ Handles processing OAuth bearer token.
+
+
+
+
+ Handles validating the identity produced from an OAuth bearer token.
+
+
+
+
+ Handles applying the authentication challenge to the response message.
+
+
+
+
+ Specifies the HTTP response header for the bearer authentication scheme.
+
+
+
+
+ Initializes a new
+
+ OWIN environment
+ The www-authenticate header value.
+
+
+
+ The www-authenticate header value.
+
+
+
+
+ Provides context information when handling an OAuth authorization code grant.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+ Provides context information used when granting an OAuth refresh token.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+ The OAuth client id.
+
+
+
+
+ Specifies the HTTP request header for the bearer authentication scheme.
+
+
+
+
+ Initializes a new
+
+ OWIN environment
+ The authorization header value.
+
+
+
+ The authorization header value
+
+
+
+
+ Contains information about the client credentials.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+ Sets the client id and marks the context as validated by the application.
+
+
+
+
+
+
+ Extracts HTTP basic authentication credentials from the HTTP authenticate header.
+
+
+
+
+
+
+
+ Extracts forms authentication credentials from the HTTP request body.
+
+
+
+
+
+
+
+ Gets the set of form parameters from the request.
+
+
+
+
+ Provides context information used when determining the OAuth flow type based on the request.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+ Sets the endpoint type to authorize endpoint.
+
+
+
+
+ Sets the endpoint type to token endpoint.
+
+
+
+
+ Sets the endpoint type to neither authorize nor token.
+
+
+
+
+ Gets whether or not the endpoint is an OAuth authorize endpoint.
+
+
+
+
+ Gets whether or not the endpoint is an OAuth token endpoint.
+
+
+
+
+ Provides context information used when processing an OAuth token request.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+ Issues the token.
+
+
+
+
+
+
+ Gets the identity of the resource owner.
+
+
+
+
+ Dictionary containing the state of the authentication session.
+
+
+
+
+ Gets information about the token endpoint request.
+
+
+
+
+ Gets whether or not the token should be issued.
+
+
+
+
+ Enables additional values to be appended to the token response.
+
+
+
+
+ Provides context information used in handling an OAuth client credentials grant.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+ OAuth client id.
+
+
+
+
+ List of scopes allowed by the resource owner.
+
+
+
+
+ Provides context information used when handling OAuth extension grant types.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+
+ Gets the OAuth client id.
+
+
+
+
+ Gets the name of the OAuth extension grant type.
+
+
+
+
+ Gets a list of additional parameters from the token request.
+
+
+
+
+ Provides context information used in validating an OAuth authorization request.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+ Gets OAuth authorization request data.
+
+
+
+
+ Gets data about the OAuth client.
+
+
+
+
+ Contains data about the OAuth client redirect URI
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+ Marks this context as validated by the application. IsValidated becomes true and HasError becomes false as a result of calling.
+
+
+
+
+
+ Checks the redirect URI to determine whether it equals .
+
+
+
+
+
+
+ Gets the client redirect URI
+
+
+
+
+ Contains the authentication ticket data from an OAuth bearer token.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+ Provides context information used in handling an OAuth resource owner grant.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+
+
+ OAuth client id.
+
+
+
+
+ Resource owner username.
+
+
+
+
+ Resource owner password.
+
+
+
+
+ List of scopes allowed by the resource owner.
+
+
+
+
+ Provides context information used in validating an OAuth token request.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+
+
+ Gets the token request data.
+
+
+
+
+ Gets information about the client.
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Twitter.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Twitter.dll
new file mode 100644
index 000000000..c74ff7a22
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Twitter.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Twitter.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Twitter.xml
new file mode 100644
index 000000000..b32f29d8e
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.Twitter.xml
@@ -0,0 +1,379 @@
+
+
+
+ Microsoft.Owin.Security.Twitter
+
+
+
+
+ Twitter access token
+
+
+
+
+ Twitter request token
+
+
+
+
+ Gets or sets the Twitter token
+
+
+
+
+ Gets or sets the Twitter token secret
+
+
+
+
+ Gets or sets a property bag for common authentication properties
+
+
+
+
+ Gets or sets the Twitter User ID
+
+
+
+
+ Gets or sets the Twitter screen name
+
+
+
+
+ Serializes and deserializes Twitter request and access tokens so that they can be used by other application components.
+
+
+
+
+ Serialize a request token
+
+ The token to serialize
+ A byte array containing the serialized token
+
+
+
+ Deserializes a request token
+
+ A byte array containing the serialized token
+ The Twitter request token
+
+
+
+ Writes a Twitter request token as a series of bytes. Used by the method.
+
+ The writer to use in writing the token
+ The token to write
+
+
+
+ Reads a Twitter request token from a series of bytes. Used by the method.
+
+ The reader to use in reading the token bytes
+ The token
+
+
+
+ Provides access to a request token serializer
+
+
+
+
+ Gets or sets a statically-avaliable serializer object. The value for this property will be by default.
+
+
+
+
+ Specifies callback methods which the invokes to enable developer control over the authentication process. />
+
+
+
+
+ Invoked whenever Twitter succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Twitter middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Context passed when a Challenge causes a redirect to authorize endpoint in the Twitter middleware
+
+
+
+
+ Creates a new context object.
+
+ The OWIN request context
+ The Facebook middleware options
+ The authenticaiton properties of the challenge
+ The initial redirect URI
+
+
+
+ Gets the URI used for the redirect operation.
+
+
+
+
+ Gets the authenticaiton properties of the challenge
+
+
+
+
+ Contains information about the login session as well as the user .
+
+
+
+
+ Initializes a
+
+ The OWIN environment
+ Twitter user ID
+ Twitter screen name
+ Twitter access token
+ Twitter access token secret
+
+
+
+ Gets the Twitter user ID
+
+
+
+
+ Gets the Twitter screen name
+
+
+
+
+ Gets the Twitter access token
+
+
+
+
+ Gets the Twitter access token secret
+
+
+
+
+ Gets the representing the user
+
+
+
+
+ Gets or sets a property bag for common authentication properties
+
+
+
+
+ Default implementation.
+
+
+
+
+ Initializes a
+
+
+
+
+ Invoked whenever Twitter succesfully authenticates a user
+
+ Contains information about the login session as well as the user .
+ A representing the completed operation.
+
+
+
+ Invoked prior to the being saved in a local cookie and the browser being redirected to the originally requested URL.
+
+
+ A representing the completed operation.
+
+
+
+ Called when a Challenge causes a redirect to authorize endpoint in the Twitter middleware
+
+ Contains redirect URI and of the challenge
+
+
+
+ Gets or sets the function that is invoked when the Authenticated method is invoked.
+
+
+
+
+ Gets or sets the function that is invoked when the ReturnEndpoint method is invoked.
+
+
+
+
+ Gets or sets the delegate that is invoked when the ApplyRedirect method is invoked.
+
+
+
+
+ Provides context information to middleware providers.
+
+
+
+
+ Initializes a new .
+
+ OWIN environment
+ The authentication ticket
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to The '{0}' option must be provided..
+
+
+
+
+ Looks up a localized string similar to An ICertificateValidator cannot be specified at the same time as an HttpMessageHandler unless it is a WebRequestHandler..
+
+
+
+
+ Extension methods for using
+
+
+
+
+ Authenticate users using Twitter
+
+ The passed to the configuration method
+ Middleware configuration options
+ The updated
+
+
+
+ Authenticate users using Twitter
+
+ The passed to the configuration method
+ The Twitter-issued consumer key
+ The Twitter-issued consumer secret
+ The updated
+
+
+
+ OWIN middleware for authenticating users using Twitter
+
+
+
+
+ Initializes a
+
+ The next middleware in the OWIN pipeline to invoke
+ The OWIN application
+ Configuration options for the middleware
+
+
+
+ Provides the object for processing authentication-related requests.
+
+ An configured with the supplied to the constructor.
+
+
+
+ Options for the Twitter authentication middleware.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Gets or sets the consumer key used to communicate with Twitter.
+
+ The consumer key used to communicate with Twitter.
+
+
+
+ Gets or sets the consumer secret used to sign requests to Twitter.
+
+ The consumer secret used to sign requests to Twitter.
+
+
+
+ Gets or sets timeout value in milliseconds for back channel communications with Twitter.
+
+
+ The back channel timeout.
+
+
+
+
+ Gets or sets the a pinned certificate validator to use to validate the endpoints used
+ in back channel communications belong to Twitter.
+
+
+ The pinned certificate validator.
+
+ If this property is null then the default certificate checks are performed,
+ validating the subject name and if the signing chain is a trusted party.
+
+
+
+ The HttpMessageHandler used to communicate with Twitter.
+ This cannot be set at the same time as BackchannelCertificateValidator unless the value
+ can be downcast to a WebRequestHandler.
+
+
+
+
+ Get or sets the text that the user can display on a sign in user interface.
+
+
+
+
+ The request path within the application's base path where the user-agent will be returned.
+ The middleware will process this request when it arrives.
+ Default value is "/signin-twitter".
+
+
+
+
+ Gets or sets the name of another authentication middleware which will be responsible for actually issuing a user .
+
+
+
+
+ Gets or sets the type used to secure data handled by the middleware.
+
+
+
+
+ Gets or sets the used to handle authentication events.
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.dll
new file mode 100644
index 000000000..54901f282
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.xml
new file mode 100644
index 000000000..fb50684f2
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.Security.xml
@@ -0,0 +1,494 @@
+
+
+
+ Microsoft.Owin.Security
+
+
+
+
+ Provides extensions methods for app.Property values that are only needed by implementations of authentication middleware.
+
+
+
+
+ Returns the previously set AuthenticationType that external sign in middleware should use when the
+ browser navigates back to their return url.
+
+ App builder passed to the application startup code
+
+
+
+
+ Called by middleware to change the name of the AuthenticationType that external middleware should use
+ when the browser navigates back to their return url.
+
+ App builder passed to the application startup code
+ AuthenticationType that external middleware should sign in as.
+
+
+
+ Controls the behavior of authentication middleware
+
+
+
+
+ In Active mode the authentication middleware will alter the user identity as the request arrives, and
+ will also alter a plain 401 as the response leaves.
+
+
+
+
+ In Passive mode the authentication middleware will only provide user identity when asked, and will only
+ alter 401 responses where the authentication type named in the extra challenge data.
+
+
+
+
+ Base Options for all authentication middleware
+
+
+
+
+ Initialize properties of AuthenticationOptions base class
+
+ Assigned to the AuthenticationType property
+
+
+
+ The AuthenticationType in the options corresponds to the IIdentity AuthenticationType property. A different
+ value may be assigned in order to use the same authentication middleware type more than once in a pipeline.
+
+
+
+
+ If Active the authentication middleware alter the request user coming in and
+ alter 401 Unauthorized responses going out. If Passive the authentication middleware will only provide
+ identity and alter responses when explicitly indicated by the AuthenticationType.
+
+
+
+
+ Additional information about the authentication type which is made available to the application.
+
+
+
+
+ String constants used only by the Security assembly
+
+
+
+
+ Used by middleware extension methods to coordinate the default value Options property SignInAsAuthenticationType
+
+
+
+
+ Factory used to create IDataProtection instances
+
+
+
+
+ Returns a new instance of IDataProtection for the provider.
+
+ Additional entropy used to ensure protected data may only be unprotected for the correct purposes.
+ An instance of a data protection service
+
+
+
+ Service used to protect and unprotect data
+
+
+
+
+ Called to protect user data.
+
+ The original data that must be protected
+ A different byte array that may be unprotected or altered only by software that has access to
+ the an identical IDataProtection service.
+
+
+
+ Called to unprotect user data
+
+ The byte array returned by a call to Protect on an identical IDataProtection service.
+ The byte array identical to the original userData passed to Protect.
+
+
+
+ Base class for the per-request work performed by most authentication middleware.
+
+ Specifies which type for of AuthenticationOptions property
+
+
+
+ Base class for the per-request work performed by most authentication middleware.
+
+
+
+
+ Called once per request after Initialize and Invoke.
+
+ async completion
+
+
+
+ Called once by common code after initialization. If an authentication middleware responds directly to
+ specifically known paths it must override this virtual, compare the request path to it's known paths,
+ provide any response information as appropriate, and true to stop further processing.
+
+ Returning false will cause the common code to call the next middleware in line. Returning true will
+ cause the common code to begin the async completion journey without calling the rest of the middleware
+ pipeline.
+
+
+
+ Causes the authentication logic in AuthenticateCore to be performed for the current request
+ at most once and returns the results. Calling Authenticate more than once will always return
+ the original value.
+
+ This method should always be called instead of calling AuthenticateCore directly.
+
+ The ticket data provided by the authentication logic
+
+
+
+ The core authentication logic which must be provided by the handler. Will be invoked at most
+ once per request. Do not call directly, call the wrapping Authenticate method instead.
+
+ The ticket data provided by the authentication logic
+
+
+
+ Causes the ApplyResponseCore to be invoked at most once per request. This method will be
+ invoked either earlier, when the response headers are sent as a result of a response write or flush,
+ or later, as the last step when the original async call to the middleware is returning.
+
+
+
+
+
+ Core method that may be overridden by handler. The default behavior is to call two common response
+ activities, one that deals with sign-in/sign-out concerns, and a second to deal with 401 challenges.
+
+
+
+
+
+ Override this method to dela with sign-in/sign-out concerns, if an authentication scheme in question
+ deals with grant/revoke as part of it's request flow. (like setting/deleting cookies)
+
+
+
+
+
+ Override this method to deal with 401 challenge concerns, if an authentication scheme in question
+ deals an authentication interaction as part of it's request flow. (like adding a response header, or
+ changing the 401 result to 302 of a login page or external sign-in location.)
+
+
+
+
+
+ Initialize is called once per request to contextualize this instance with appropriate state.
+
+ The original options passed by the application control behavior
+ The utility object to observe the current request and response
+ async completion
+
+
+
+ Contains user identity information as well as additional authentication state.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+ Gets the authenticated user identity.
+
+
+
+
+ Additional state values for the authentication session.
+
+
+
+
+ Interface for providing pinned certificate validation, which checks HTTPS
+ communication against a known good list of certificates to protect against
+ compromised or rogue CAs issuing certificates for hosts without the
+ knowledge of the host owner.
+
+
+
+
+ Verifies the remote Secure Sockets Layer (SSL) certificate used for authentication.
+
+ An object that contains state information for this validation.
+ The certificate used to authenticate the remote party.
+ The chain of certificate authorities associated with the remote certificate.
+ One or more errors associated with the remote certificate.
+ A Boolean value that determines whether the specified certificate is accepted for authentication.
+
+
+
+ Provides pinned certificate validation based on the certificate thumbprint.
+
+
+
+
+ Initializes a new instance of the class.
+
+ A set of thumbprints which are valid for an HTTPS request.
+
+
+
+ Validates that the certificate thumbprints in the signing chain match at least one whitelisted thumbprint.
+
+ An object that contains state information for this validation.
+ The certificate used to authenticate the remote party.
+ The chain of certificate authorities associated with the remote certificate.
+ One or more errors associated with the remote certificate.
+ A Boolean value that determines whether the specified certificate is accepted for authentication.
+
+
+
+ Base class used for certain event contexts
+
+
+
+
+ Discontinue all processing for this request and return to the client.
+ The caller is responsible for generating the full response.
+
+
+
+
+ Discontinue processing the request in the current middleware and pass control to the next one.
+
+
+
+
+ Continue with normal processing.
+
+
+
+
+ Discontinue processing the request in the current middleware and pass control to the next one.
+
+
+
+
+ Discontinue all processing for this request.
+
+
+
+
+ Discontinue all processing for this request and return to the client.
+ The caller is responsible for generating the full response.
+
+
+
+
+ Gets or set the
+
+
+
+
+ Gets or sets the Protocol message
+
+
+
+
+ Used to provide the data protection services that are derived from the Data Protection API. It is the best choice of
+ data protection when you application is not hosted by ASP.NET and all processes are running as the same domain identity.
+
+
+
+
+ Initializes a new DpapiDataProtectionProvider with a random application
+ name. This is only useful to protect data for the duration of the
+ current application execution.
+
+
+
+
+ Initializes a new DpapiDataProtectionProvider which uses the given
+ appName as part of the protection algorithm
+
+ A user provided value needed to round-trip secured
+ data. The default value comes from the IAppBuilder.Properties["owin.AppName"]
+ when self-hosted.
+
+
+
+ Returns a new instance of IDataProtection for the provider.
+
+ Additional entropy used to ensure protected data may only be unprotected for the correct purposes.
+ An instance of a data protection service
+
+
+
+ Helper code used when implementing authentication middleware
+
+
+
+
+ Helper code used when implementing authentication middleware
+
+
+
+
+
+ Add an additional ClaimsIdentity to the ClaimsPrincipal in the "server.User" environment key
+
+
+
+
+
+ Find response challenge details for a specific authentication middleware
+
+ The authentication type to look for
+ The authentication mode the middleware is running under
+ The information instructing the middleware how it should behave
+
+
+
+ Find response sign-in details for a specific authentication middleware
+
+ The authentication type to look for
+ The information instructing the middleware how it should behave
+
+
+
+ Find response sign-out details for a specific authentication middleware
+
+ The authentication type to look for
+ The authentication mode the middleware is running under
+ The information instructing the middleware how it should behave
+
+
+
+ Base class used for certain event contexts
+
+
+
+
+ Creates an instance of this context
+
+
+
+
+ Prevents the request from being processed further by other components.
+ IsRequestCompleted becomes true after calling.
+
+
+
+
+ True if the request should not be processed further by other components.
+
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to The AuthenticationTokenProvider's required synchronous events have not been registered..
+
+
+
+
+ Looks up a localized string similar to The default data protection provider may only be used when the IAppBuilder.Properties contains an appropriate 'host.AppName' key..
+
+
+
+
+ Looks up a localized string similar to A default value for SignInAsAuthenticationType was not found in IAppBuilder Properties. This can happen if your authentication middleware are added in the wrong order, or if one is missing..
+
+
+
+
+ Looks up a localized string similar to The state passed to UnhookAuthentication may only be the return value from HookAuthentication..
+
+
+
+
+ Provides pinned certificate validation based on the subject key identifier of the certificate.
+
+
+
+
+ Initializes a new instance of the class.
+
+ A set of subject key identifiers which are valid for an HTTPS request.
+
+
+
+ Verifies the remote Secure Sockets Layer (SSL) certificate used for authentication.
+
+ An object that contains state information for this validation.
+ The certificate used to authenticate the remote party.
+ The chain of certificate authorities associated with the remote certificate.
+ One or more errors associated with the remote certificate.
+ A Boolean value that determines whether the specified certificate is accepted for authentication.
+
+
+
+ The algorithm used to generate the subject public key information blob hashes.
+
+
+
+
+ Implements a cert pinning validator passed on
+ http://datatracker.ietf.org/doc/draft-ietf-websec-key-pinning/?include_text=1
+
+
+
+
+ Initializes a new instance of the class.
+
+ A collection of valid base64 encoded hashes of the certificate public key information blob.
+ The algorithm used to generate the hashes.
+
+
+
+ Validates at least one SPKI hash is known.
+
+ An object that contains state information for this validation.
+ The certificate used to authenticate the remote party.
+ The chain of certificate authorities associated with the remote certificate.
+ One or more errors associated with the remote certificate.
+ A Boolean value that determines whether the specified certificate is accepted for authentication.
+
+
+
+ Encodes a structure of the type indicated by the value of the lpszStructType parameter.
+
+ Type of encoding used.
+ The high-order word is zero, the low-order word specifies the integer identifier for the type of the specified structure so
+ we can use the constants in http://msdn.microsoft.com/en-us/library/windows/desktop/aa378145%28v=vs.85%29.aspx
+ A pointer to the structure to be encoded.
+ A pointer to a buffer to receive the encoded structure. This parameter can be NULL to retrieve the size of this information for memory allocation purposes.
+ A pointer to a DWORD variable that contains the size, in bytes, of the buffer pointed to by the pbEncoded parameter.
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.dll
new file mode 100644
index 000000000..37dc69b0e
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.xml
new file mode 100644
index 000000000..c76bbd4ad
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Owin.xml
@@ -0,0 +1,3224 @@
+
+
+
+ Microsoft.Owin
+
+
+
+
+ Extension methods for .
+
+
+
+
+ Inserts a middleware into the OWIN pipeline.
+
+ The middleware type
+
+ Any additional arguments for the middleware constructor
+
+
+
+
+ Inserts into the OWIN pipeline a middleware which does not have a next middleware reference.
+
+
+ An app that handles all requests
+
+
+
+ Inserts a middleware into the OWIN pipeline.
+
+
+ An app that handles the request or calls the given next Func
+
+
+
+
+ Represents a middleware for executing in-line function middleware.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The pointer to next middleware.
+ A function that handles all requests.
+
+
+
+ Initializes a new instance of the class.
+
+ The pointer to next middleware.
+ A function that handles the request or calls the given next function.
+
+
+
+ Invokes the handler for processing the request.
+
+ The OWIN context.
+ The object that represents the request operation.
+
+
+
+ Contains the parsed form values.
+
+
+
+
+ Accessors for query, forms, etc.
+
+
+
+
+ Accessors for headers, query, forms, etc.
+
+
+
+
+ Get the associated value from the collection. Multiple values will be merged.
+ Returns null if the key is not present.
+
+
+
+
+
+
+ Get the associated values from the collection in their original format.
+ Returns null if the key is not present.
+
+
+
+
+
+
+ Get the associated value from the collection. Multiple values will be merged.
+ Returns null if the key is not present.
+
+
+
+
+
+
+ Create a new wrapper
+
+
+
+
+
+ Get the associated value from the collection. Multiple values will be merged.
+ Returns null if the key is not present.
+
+
+
+
+
+
+ Get the associated values from the collection in their original format.
+ Returns null if the key is not present.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Get the associated value from the collection. Multiple values will be merged.
+ Returns null if the key is not present.
+
+
+
+
+
+
+ Contains the parsed form values.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The store for the form.
+
+
+
+ Represents a wrapper for owin.RequestHeaders and owin.ResponseHeaders.
+
+
+
+
+ Represents a wrapper for owin.RequestHeaders and owin.ResponseHeaders.
+
+
+
+
+ Get the associated values from the collection separated into individual values.
+ Quoted values will not be split, and the quotes will be removed.
+
+ The header name.
+ the associated values from the collection separated into individual values, or null if the key is not present.
+
+
+
+ Add a new value. Appends to the header if already present
+
+ The header name.
+ The header value.
+
+
+
+ Add new values. Each item remains a separate array entry.
+
+ The header name.
+ The header values.
+
+
+
+ Quotes any values containing comas, and then coma joins all of the values with any existing values.
+
+ The header name.
+ The header values.
+
+
+
+ Sets a specific header value.
+
+ The header name.
+ The header value.
+
+
+
+ Sets the specified header values without modification.
+
+ The header name.
+ The header values.
+
+
+
+ Quotes any values containing comas, and then coma joins all of the values.
+
+ The header name.
+ The header values.
+
+
+
+ Get or sets the associated value from the collection as a single string.
+
+ The header name.
+ the associated value from the collection as a single string or null if the key is not present.
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying data store.
+
+
+
+ Returns an enumerator that iterates through a collection.
+
+ An object that can be used to iterate through the collection.
+
+
+
+ Returns an enumerator that iterates through a collection.
+
+ An object that can be used to iterate through the collection.
+
+
+
+ Get the associated value from the collection as a single string.
+
+ The header name.
+ the associated value from the collection as a single string or null if the key is not present.
+
+
+
+ Get the associated values from the collection without modification.
+
+ The header name.
+ the associated value from the collection without modification, or null if the key is not present.
+
+
+
+ Get the associated values from the collection separated into individual values.
+ Quoted values will not be split, and the quotes will be removed.
+
+ The header name.
+ the associated values from the collection separated into individual values, or null if the key is not present.
+
+
+
+ Add a new value. Appends to the header if already present
+
+ The header name.
+ The header value.
+
+
+
+ Add new values. Each item remains a separate array entry.
+
+ The header name.
+ The header values.
+
+
+
+ Quotes any values containing comas, and then coma joins all of the values with any existing values.
+
+ The header name.
+ The header values.
+
+
+
+ Sets a specific header value.
+
+ The header name.
+ The header value.
+
+
+
+ Sets the specified header values without modification.
+
+ The header name.
+ The header values.
+
+
+
+ Quotes any values containing comas, and then coma joins all of the values.
+
+ The header name.
+ The header values.
+
+
+
+ Adds the given header and values to the collection.
+
+ The header name.
+ The header values.
+
+
+
+ Determines whether the contains a specific key.
+
+ The key.
+ true if the contains a specific key; otherwise, false.
+
+
+
+ Removes the given header from the collection.
+
+ The header name.
+ true if the specified object was removed from the collection; otherwise, false.
+
+
+
+ Retrieves a value from the dictionary.
+
+ The header name.
+ The value.
+ true if the contains the key; otherwise, false.
+
+
+
+ Adds a new list of items to the collection.
+
+ The item to add.
+
+
+
+ Clears the entire list of objects.
+
+
+
+
+ Returns a value indicating whether the specified object occurs within this collection.
+
+ The item.
+ true if the specified object occurs within this collection; otherwise, false.
+
+
+
+ Copies the elements to a one-dimensional Array instance at the specified index.
+
+ The one-dimensional Array that is the destination of the specified objects copied from the .
+ The zero-based index in at which copying begins.
+
+
+
+ Removes the given item from the the collection.
+
+ The item.
+ true if the specified object was removed from the collection; otherwise, false.
+
+
+
+ Gets an that contains the keys in the ;.
+
+ An that contains the keys in the .
+
+
+
+
+
+
+
+
+ Gets the number of elements contained in the ;.
+
+ The number of elements contained in the .
+
+
+
+ Gets a value that indicates whether the is in read-only mode.
+
+ true if the is in read-only mode; otherwise, false.
+
+
+
+ Get or sets the associated value from the collection as a single string.
+
+ The header name.
+ the associated value from the collection as a single string or null if the key is not present.
+
+
+
+ Throws KeyNotFoundException if the key is not present.
+
+ The header name.
+
+
+
+
+ Represents the host portion of a Uri can be used to construct Uri's properly formatted and encoded for use in
+ HTTP headers.
+
+
+
+
+ Creates a new HostString without modification. The value should be Unicode rather than punycode, and may have a port.
+ IPv4 and IPv6 addresses are also allowed, and also may have ports.
+
+
+
+
+
+ Returns the value as normalized by ToUriComponent().
+
+
+
+
+
+ Returns the value properly formatted and encoded for use in a URI in a HTTP header.
+ Any Unicode is converted to punycode. IPv6 addresses will have brackets added if they are missing.
+
+
+
+
+
+ Creates a new HostString from the given uri component.
+ Any punycode will be converted to Unicode.
+
+
+
+
+
+
+ Creates a new HostString from the host and port of the give Uri instance.
+ Punycode will be converted to Unicode.
+
+
+
+
+
+
+ Compares the equality of the Value property, ignoring case.
+
+
+
+
+
+
+ Compares against the given object only if it is a HostString.
+
+
+
+
+
+
+ Gets a hash code for the value.
+
+
+
+
+
+ Compares the two instances for equality.
+
+
+
+
+
+
+
+ Compares the two instances for inequality.
+
+
+
+
+
+
+
+ Returns the original value from the constructor.
+
+
+
+
+ This handles cookies that are limited by per cookie length. It breaks down long cookies for responses, and reassembles them
+ from requests.
+
+
+
+
+ Get the reassembled cookie. Non chunked cookies are returned normally.
+ Cookies with missing chunks just have their "chunks:XX" header returned.
+
+
+
+ The reassembled cookie, if any, or null.
+
+
+
+ Appends a new response cookie to the Set-Cookie header. If the cookie is larger than the given size limit
+ then it will be broken down into multiple cookies as follows:
+ Set-Cookie: CookieName=chunks:3; path=/
+ Set-Cookie: CookieNameC1=Segment1; path=/
+ Set-Cookie: CookieNameC2=Segment2; path=/
+ Set-Cookie: CookieNameC3=Segment3; path=/
+
+
+
+
+
+
+
+
+ Deletes the cookie with the given key by setting an expired state. If a matching chunked cookie exists on
+ the request, delete each chunk.
+
+
+
+
+
+
+
+ The maximum size of cookie to send back to the client. If a cookie exceeds this size it will be broken down into multiple
+ cookies. Set this value to null to disable this behavior. The default is 4090 characters, which is supported by all
+ common browsers.
+
+ Note that browsers may also have limits on the total size of all cookies per domain, and on the number of cookies per domain.
+
+
+
+
+ Throw if not all chunks of a cookie are available on a request for re-assembly.
+
+
+
+
+ This wraps OWIN environment dictionary and provides strongly typed accessors.
+
+
+
+
+ Gets a value from the OWIN environment, or returns default(T) if not present.
+
+ The type of the value.
+ The key of the value to get.
+ The value with the specified key or the default(T) if not present.
+
+
+
+ Sets the given key and value in the OWIN environment.
+
+ The type of the value.
+ The key of the value to set.
+ The value to set.
+ This instance.
+
+
+
+ Gets a wrapper exposing request specific properties.
+
+ A wrapper exposing request specific properties.
+
+
+
+ Gets a wrapper exposing response specific properties.
+
+ A wrapper exposing response specific properties.
+
+
+
+ Gets the Authentication middleware functionality available on the current request.
+
+ The authentication middleware functionality available on the current request.
+
+
+
+ Gets the OWIN environment.
+
+ The OWIN environment.
+
+
+
+ Gets or sets the host.TraceOutput environment value.
+
+ The host.TraceOutput TextWriter.
+
+
+
+ This wraps OWIN environment dictionary and provides strongly typed accessors.
+
+
+
+
+ Asynchronously reads and parses the request body as a form.
+
+ The parsed form data.
+
+
+
+ Gets a value from the OWIN environment, or returns default(T) if not present.
+
+ The type of the value.
+ The key of the value to get.
+ The value with the specified key or the default(T) if not present.
+
+
+
+ Sets the given key and value in the OWIN environment.
+
+ The type of the value.
+ The key of the value to set.
+ The value to set.
+ This instance.
+
+
+
+ Gets the OWIN environment.
+
+ The OWIN environment.
+
+
+
+ Gets the request context.
+
+ The request context.
+
+
+
+ Gets or set the HTTP method.
+
+ The HTTP method.
+
+
+
+ Gets or set the HTTP request scheme from owin.RequestScheme.
+
+ The HTTP request scheme from owin.RequestScheme.
+
+
+
+ Returns true if the owin.RequestScheme is https.
+
+ true if this request is using https; otherwise, false.
+
+
+
+ Gets or set the Host header. May include the port.
+
+ The Host header.
+
+
+
+ Gets or set the owin.RequestPathBase.
+
+ The owin.RequestPathBase.
+
+
+
+ Gets or set the request path from owin.RequestPath.
+
+ The request path from owin.RequestPath.
+
+
+
+ Gets or set the query string from owin.RequestQueryString.
+
+ The query string from owin.RequestQueryString.
+
+
+
+ Gets the query value collection parsed from owin.RequestQueryString.
+
+ The query value collection parsed from owin.RequestQueryString.
+
+
+
+ Gets the uniform resource identifier (URI) associated with the request.
+
+ The uniform resource identifier (URI) associated with the request.
+
+
+
+ Gets or set the owin.RequestProtocol.
+
+ The owin.RequestProtocol.
+
+
+
+ Gets the request headers.
+
+ The request headers.
+
+
+
+ Gets the collection of Cookies for this request.
+
+ The collection of Cookies for this request.
+
+
+
+ Gets or sets the Content-Type header.
+
+ The Content-Type header.
+
+
+
+ Gets or sets the Cache-Control header.
+
+ The Cache-Control header.
+
+
+
+ Gets or sets the Media-Type header.
+
+ The Media-Type header.
+
+
+
+ Gets or set the Accept header.
+
+ The Accept header.
+
+
+
+ Gets or set the owin.RequestBody Stream.
+
+ The owin.RequestBody Stream.
+
+
+
+ Gets or sets the cancellation token for the request.
+
+ The cancellation token for the request.
+
+
+
+ Gets or set the server.LocalIpAddress.
+
+ The server.LocalIpAddress.
+
+
+
+ Gets or set the server.LocalPort.
+
+ The server.LocalPort.
+
+
+
+ Gets or set the server.RemoteIpAddress.
+
+ The server.RemoteIpAddress.
+
+
+
+ Gets or set the server.RemotePort.
+
+ The server.RemotePort.
+
+
+
+ Gets or set the server.User.
+
+ The server.User.
+
+
+
+ This wraps OWIN environment dictionary and provides strongly typed accessors.
+
+
+
+
+ Registers for an event that fires when the response headers are sent.
+
+ The callback method.
+ The callback state.
+
+
+
+ Sets a 302 response status code and the Location header.
+
+ The location where to redirect the client.
+
+
+
+ Writes the given text to the response body stream using UTF-8.
+
+ The response data.
+
+
+
+ Writes the given bytes to the response body stream.
+
+ The response data.
+
+
+
+ Writes the given bytes to the response body stream.
+
+ The response data.
+ The zero-based byte offset in the parameter at which to begin copying bytes.
+ The number of bytes to write.
+
+
+
+ Asynchronously writes the given text to the response body stream using UTF-8.
+
+ The response data.
+ A Task tracking the state of the write operation.
+
+
+
+ Asynchronously writes the given text to the response body stream using UTF-8.
+
+ The response data.
+ A token used to indicate cancellation.
+ A Task tracking the state of the write operation.
+
+
+
+ Asynchronously writes the given bytes to the response body stream.
+
+ The response data.
+ A Task tracking the state of the write operation.
+
+
+
+ Asynchronously writes the given bytes to the response body stream.
+
+ The response data.
+ A token used to indicate cancellation.
+ A Task tracking the state of the write operation.
+
+
+
+ Asynchronously writes the given bytes to the response body stream.
+
+ The response data.
+ The zero-based byte offset in the parameter at which to begin copying bytes.
+ The number of bytes to write.
+ A token used to indicate cancellation.
+ A Task tracking the state of the write operation.
+
+
+
+ Gets a value from the OWIN environment, or returns default(T) if not present.
+
+ The type of the value.
+ The key of the value to get.
+ The value with the specified key or the default(T) if not present.
+
+
+
+ Sets the given key and value in the OWIN environment.
+
+ The type of the value.
+ The key of the value to set.
+ The value to set.
+ This instance.
+
+
+
+ Gets the OWIN environment.
+
+ The OWIN environment.
+
+
+
+ Gets the request context.
+
+ The request context.
+
+
+
+ Gets or sets the optional owin.ResponseStatusCode.
+
+ The optional owin.ResponseStatusCode, or 200 if not set.
+
+
+
+ Gets or sets the the optional owin.ResponseReasonPhrase.
+
+ The the optional owin.ResponseReasonPhrase.
+
+
+
+ Gets or sets the owin.ResponseProtocol.
+
+ The owin.ResponseProtocol.
+
+
+
+ Gets the response header collection.
+
+ The response header collection.
+
+
+
+ Gets a collection used to manipulate the Set-Cookie header.
+
+ A collection used to manipulate the Set-Cookie header.
+
+
+
+ Gets or sets the Content-Length header.
+
+ The Content-Length header.
+
+
+
+ Gets or sets the Content-Type header.
+
+ The Content-Type header.
+
+
+
+ Gets or sets the Expires header.
+
+ The Expires header.
+
+
+
+ Gets or sets the E-Tag header.
+
+ The E-Tag header.
+
+
+
+ Gets or sets the owin.ResponseBody Stream.
+
+ The owin.ResponseBody Stream.
+
+
+
+ Used to mark which class in an assembly should be used for automatic startup.
+
+
+
+
+ Initializes a new instance of the class
+
+ The startup class
+
+
+
+ Initializes a new instance of the class
+
+ A non-default configuration, e.g. staging.
+ The startup class
+
+
+
+ Initializes a new instance of the class
+
+ The startup class
+ Specifies which method to call
+
+
+
+ Initializes a new instance of the class
+
+ A non-default configuration, e.g. staging.
+ The startup class
+ Specifies which method to call
+
+
+
+ A non-default configuration if any. e.g. Staging.
+
+
+
+
+ The startup class
+
+
+
+
+ The name of the configuration method
+
+
+
+
+ An ordered list of known Asp.Net integrated pipeline stages. More details on the ASP.NET integrated pipeline can be found at http://msdn.microsoft.com/en-us/library/system.web.httpapplication.aspx
+
+
+
+
+ Corresponds to the AuthenticateRequest stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the PostAuthenticateRequest stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the AuthorizeRequest stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the PostAuthorizeRequest stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the ResolveRequestCache stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the PostResolveRequestCache stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the MapRequestHandler stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the PostMapRequestHandler stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the AcquireRequestState stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the PostAcquireRequestState stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Corresponds to the PreRequestHandlerExecute stage of the ASP.NET integrated pipeline.
+
+
+
+
+ Extension methods for the MapMiddleware
+
+
+
+
+ If the request path starts with the given pathMatch, execute the app configured via configuration parameter instead of
+ continuing to the next component in the pipeline.
+
+
+ The path to match
+ The branch to take for positive path matches
+
+
+
+
+ If the request path starts with the given pathMatch, execute the app configured via configuration parameter instead of
+ continuing to the next component in the pipeline.
+
+
+ The path to match
+ The branch to take for positive path matches
+
+
+
+
+ Used to create path based branches in your application pipeline.
+ The owin.RequestPathBase is not included in the evaluation, only owin.RequestPath.
+ Matching paths have the matching piece removed from owin.RequestPath and added to the owin.RequestPathBase.
+
+
+
+
+ Initializes a new instance of the class
+
+ The normal pipeline taken for a negative match
+
+
+
+
+ Process an individual request.
+
+
+
+
+
+
+ Options for the Map middleware
+
+
+
+
+ The path to match
+
+
+
+
+ The branch taken for a positive match
+
+
+
+
+ Extension methods for the MapWhenMiddleware
+
+
+
+
+ Branches the request pipeline based on the result of the given predicate.
+
+
+ Invoked with the request environment to determine if the branch should be taken
+ Configures a branch to take
+
+
+
+
+ Branches the request pipeline based on the async result of the given predicate.
+
+
+ Invoked asynchronously with the request environment to determine if the branch should be taken
+ Configures a branch to take
+
+
+
+
+ Determines if the request should take a specific branch of the pipeline by passing the environment
+ to a user defined callback.
+
+
+
+
+ Initializes a new instance of the class
+
+ The normal application pipeline
+
+
+
+
+ Process an individual request.
+
+
+
+
+
+
+ Options for the MapWhen middleware
+
+
+
+
+ The user callback that determines if the branch should be taken
+
+
+
+
+ The async user callback that determines if the branch should be taken
+
+
+
+
+ The branch taken for a positive match
+
+
+
+
+ This wraps OWIN environment dictionary and provides strongly typed accessors.
+
+
+
+
+ Create a new context with only request and response header collections.
+
+
+
+
+ Create a new wrapper.
+
+ OWIN environment dictionary which stores state information about the request, response and relevant server state.
+
+
+
+ Gets a value from the OWIN environment, or returns default(T) if not present.
+
+ The type of the value.
+ The key of the value to get.
+ The value with the specified key or the default(T) if not present.
+
+
+
+ Sets the given key and value in the OWIN environment.
+
+ The type of the value.
+ The key of the value to set.
+ The value to set.
+ This instance.
+
+
+
+ Gets a wrapper exposing request specific properties.
+
+ A wrapper exposing request specific properties.
+
+
+
+ Gets a wrapper exposing response specific properties.
+
+ A wrapper exposing response specific properties.
+
+
+
+ Gets the Authentication middleware functionality available on the current request.
+
+ The authentication middleware functionality available on the current request.
+
+
+
+ Gets the OWIN environment.
+
+ The OWIN environment.
+
+
+
+ Gets or sets the host.TraceOutput environment value.
+
+ The host.TraceOutput TextWriter.
+
+
+
+ Provides correct escaping for Path and PathBase values when needed to reconstruct a request or redirect URI string
+
+
+
+
+ Represents the empty path. This field is read-only.
+
+
+
+
+ Initialize the path string with a given value. This value must be in un-escaped format. Use
+ PathString.FromUriComponent(value) if you have a path value which is in an escaped format.
+
+ The unescaped path to be assigned to the Value property.
+
+
+
+ Provides the path string escaped in a way which is correct for combining into the URI representation.
+
+ The escaped path value
+
+
+
+ Provides the path string escaped in a way which is correct for combining into the URI representation.
+
+ The escaped path value
+
+
+
+ Returns an PathString given the path as it is escaped in the URI format. The string MUST NOT contain any
+ value that is not a path.
+
+ The escaped path as it appears in the URI format.
+ The resulting PathString
+
+
+
+ Returns an PathString given the path as from a Uri object. Relative Uri objects are not supported.
+
+ The Uri object
+ The resulting PathString
+
+
+
+ Checks if this instance starts with or exactly matches the other instance. Only full segments are matched.
+
+
+
+
+
+
+ Checks if this instance starts with or exactly matches the other instance. Only full segments are matched.
+
+
+ Any remaining segments from this instance not included in the other instance.
+
+
+
+
+ Adds two PathString instances into a combined PathString value.
+
+ The combined PathString value
+
+
+
+ Combines a PathString and QueryString into the joined URI formatted string value.
+
+ The joined URI formatted string value
+
+
+
+ Compares this PathString value to another value. The default comparison is StringComparison.OrdinalIgnoreCase.
+
+ The second PathString for comparison.
+ True if both PathString values are equal
+
+
+
+ Compares this PathString value to another value using a specific StringComparison type
+
+ The second PathString for comparison
+ The StringComparison type to use
+ True if both PathString values are equal
+
+
+
+ Compares this PathString value to another value. The default comparison is StringComparison.OrdinalIgnoreCase.
+
+ The second PathString for comparison.
+ True if both PathString values are equal
+
+
+
+ Returns the hash code for the PathString value. The hash code is provided by the OrdinalIgnoreCase implementation.
+
+ The hash code
+
+
+
+ Operator call through to Equals
+
+ The left parameter
+ The right parameter
+ True if both PathString values are equal
+
+
+
+ Operator call through to Equals
+
+ The left parameter
+ The right parameter
+ True if both PathString values are not equal
+
+
+
+ Operator call through to Add
+
+ The left parameter
+ The right parameter
+ The PathString combination of both values
+
+
+
+ Operator call through to Add
+
+ The left parameter
+ The right parameter
+ The PathString combination of both values
+
+
+
+ The unescaped path value
+
+
+
+
+ True if the path is not empty
+
+
+
+
+ Provides correct handling for QueryString value when needed to reconstruct a request or redirect URI string
+
+
+
+
+ Represents the empty query string. This field is read-only.
+
+
+
+
+ Initialize the query string with a given value. This value must be in escaped and delimited format without
+ a leading '?' character.
+
+ The query string to be assigned to the Value property.
+
+
+
+ Initialize a query string with a single given parameter name and value. The value is
+
+ The unencoded parameter name
+ The unencoded parameter value
+
+
+
+ Provides the query string escaped in a way which is correct for combining into the URI representation.
+ A leading '?' character will be prepended unless the Value is null or empty. Characters which are potentially
+ dangerous are escaped.
+
+ The query string value
+
+
+
+ Provides the query string escaped in a way which is correct for combining into the URI representation.
+ A leading '?' character will be prepended unless the Value is null or empty. Characters which are potentially
+ dangerous are escaped.
+
+ The query string value
+
+
+
+ Returns an QueryString given the query as it is escaped in the URI format. The string MUST NOT contain any
+ value that is not a query.
+
+ The escaped query as it appears in the URI format.
+ The resulting QueryString
+
+
+
+ Returns an QueryString given the query as from a Uri object. Relative Uri objects are not supported.
+
+ The Uri object
+ The resulting QueryString
+
+
+
+ Indicates whether the current instance is equal to the other instance.
+
+
+
+
+
+
+ Indicates whether the current instance is equal to the other instance.
+
+
+
+
+
+
+ Returns the hash code for this instance.
+
+
+
+
+
+ Compares the two instances for equality.
+
+
+
+
+
+
+
+ Compares the two instances for inequality.
+
+
+
+
+
+
+
+ The escaped query string without the leading '?' character
+
+
+
+
+ True if the query string is not empty
+
+
+
+
+ A wrapper for the request Cookie header
+
+
+
+
+ Create a new wrapper
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Returns null rather than throwing KeyNotFoundException
+
+
+
+
+
+
+ A strongly-typed resource class, for looking up localized strings, etc.
+
+
+
+
+ Returns the cached ResourceManager instance used by this class.
+
+
+
+
+ Overrides the current thread's CurrentUICulture property for all
+ resource lookups using this strongly typed resource class.
+
+
+
+
+ Looks up a localized string similar to Conversion delegate must take one parameter..
+
+
+
+
+ Looks up a localized string similar to The cookie key and options are larger than ChunksSize, leaving no room for data..
+
+
+
+
+ Looks up a localized string similar to The chunked cookie is incomplete. Only {0} of the expected {1} chunks were found, totaling {2} characters. A client size limit may have been exceeded..
+
+
+
+
+ Looks up a localized string similar to The type '{0}' does not match any known middleware pattern..
+
+
+
+
+ Looks up a localized string similar to The OWIN key 'server.OnSendingHeaders' is not available for this request..
+
+
+
+
+ Looks up a localized string similar to The class '{0}' does not have a constructor taking {1} arguments..
+
+
+
+
+ Looks up a localized string similar to No conversion available between {0} and {1}..
+
+
+
+
+ Looks up a localized string similar to The path must not end with a '/'.
+
+
+
+
+ Looks up a localized string similar to The path must start with a '/' followed by one or more characters..
+
+
+
+
+ Looks up a localized string similar to The path is required.
+
+
+
+
+ Looks up a localized string similar to The query string must start with a '?' unless null or empty..
+
+
+
+
+ A standard implementation of IAppBuilder
+
+
+
+
+ Initializes a new instance of the the type.
+
+
+
+
+
+
+
+
+
+
+
+ Adds a middleware node to the OWIN function pipeline. The middleware are
+ invoked in the order they are added: the first middleware passed to Use will
+ be the outermost function, and the last middleware passed to Use will be the
+ innermost.
+
+
+ The middleware parameter determines which behavior is being chained into the
+ pipeline.
+
+ If the middleware given to Use is a Delegate, then it will be invoked with the "next app" in
+ the chain as the first parameter. If the delegate takes more than the single argument,
+ then the additional values must be provided to Use in the args array.
+
+ If the middleware given to Use is a Type, then the public constructor will be
+ invoked with the "next app" in the chain as the first parameter. The resulting object
+ must have a public Invoke method. If the object has constructors which take more than
+ the single "next app" argument, then additional values may be provided in the args array.
+
+
+ Any additional args passed to Use will be passed as additional values, following the "next app"
+ parameter, when the OWIN call pipeline is build.
+
+ They are passed as additional parameters if the middleware parameter is a Delegate, or as additional
+ constructor arguments if the middle parameter is a Type.
+
+
+ The IAppBuilder itself is returned. This enables you to chain your use statements together.
+
+
+
+
+ The New method creates a new instance of an IAppBuilder. This is needed to create
+ a tree structure in your processing, rather than a linear pipeline. The new instance share the
+ same Properties, but will be created with a new, empty middleware list.
+
+ To create a tangent pipeline you would first call New, followed by several calls to Use on
+ the new builder, ending with a call to Build on the new builder. The return value from Build
+ will be the entry-point to your tangent pipeline. This entry-point may now be added to the
+ main pipeline as an argument to a switching middleware, which will either call the tangent
+ pipeline or the "next app", based on something in the request.
+
+ That said - all of that work is typically hidden by a middleware like Map, which will do that
+ for you.
+
+ The new instance of the IAppBuilder implementation
+
+
+
+ The Build is called at the point when all of the middleware should be chained
+ together. This is typically done by the hosting component which created the app builder,
+ and does not need to be called by the startup method if the IAppBuilder is passed in.
+
+
+ The Type argument indicates which calling convention should be returned, and
+ is typically typeof() for the OWIN
+ calling convention.
+
+
+ Returns an instance of the pipeline's entry point. This object may be safely cast to the
+ type which was provided
+
+
+
+
+ Contains arbitrary properties which may added, examined, and modified by
+ components during the startup sequence.
+
+ Returns .
+
+
+
+ Simple object used by AppBuilder as seed OWIN callable if the
+ builder.Properties["builder.DefaultApp"] is not set
+
+
+
+
+ Abstracts the system clock to facilitate testing.
+
+
+
+
+ Retrieves the current system time in UTC.
+
+
+
+
+ Provides access to the normal system clock.
+
+
+
+
+ Retrieves the current system time in UTC.
+
+
+
+
+ Response generation utilities.
+
+
+
+
+ Append the given query to the uri.
+
+ The base uri.
+ The query string to append, if any.
+ The combine result.
+
+
+
+ Append the given query key and value to the uri.
+
+ The base uri.
+ The name of the query key.
+ The query value.
+ The combine result.
+
+
+
+ Append the given query keys and values to the uri.
+
+ The base uri.
+ A collection of name value query pairs to append.
+ The combine result.
+
+
+
+ A wrapper for the response Set-Cookie header
+
+
+
+
+ Create a new wrapper
+
+
+
+
+
+ Add a new cookie and value
+
+
+
+
+
+
+ Add a new cookie
+
+
+
+
+
+
+
+ Sets an expired cookie
+
+
+
+
+
+ Sets an expired cookie
+
+
+
+
+
+
+ Acts as the return value from calls to the IAuthenticationManager's AuthenticeAsync methods.
+
+
+
+
+ Create an instance of the result object
+
+ Assigned to Identity. May be null.
+ Assigned to Properties. Contains extra information carried along with the identity.
+ Assigned to Description. Contains information describing the authentication provider.
+
+
+
+ Contains the claims that were authenticated by the given AuthenticationType. If the authentication
+ type was not successful the Identity property will be null.
+
+
+
+
+ Contains extra values that were provided with the original SignIn call.
+
+
+
+
+ Contains description properties for the middleware authentication type in general. Does not
+ vary per request.
+
+
+
+
+ Contains information describing an authentication provider.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+ Contains metadata about the authentication provider.
+
+
+
+
+ Gets or sets the name used to reference the authentication middleware instance.
+
+
+
+
+ Gets or sets the display name for the authentication provider.
+
+
+
+
+ Extension methods used to indicate at which stage in the integrated pipeline prior middleware should run.
+
+
+
+
+ Call after other middleware to specify when they should run in the integrated pipeline.
+
+ The IAppBuilder.
+ The name of the integrated pipeline in which to run.
+ The original IAppBuilder for chaining.
+
+
+
+ Call after other middleware to specify when they should run in the integrated pipeline.
+
+ The IAppBuilder.
+ The stage of the integrated pipeline in which to run.
+ The original IAppBuilder for chaining.
+
+
+
+ Logging extension methods for IAppBuilder.
+
+
+
+
+ Sets the server.LoggerFactory in the Properties collection.
+
+
+
+
+
+
+ Retrieves the server.LoggerFactory from the Properties collection.
+
+
+
+
+
+
+ Creates a new ILogger instance from the server.LoggerFactory in the Properties collection.
+
+
+
+
+
+
+
+ Creates a new ILogger instance from the server.LoggerFactory in the Properties collection.
+
+
+
+
+
+
+
+ Creates a new ILogger instance from the server.LoggerFactory in the Properties collection.
+
+
+
+
+
+
+
+ Used to create logger instances of the given name.
+
+
+
+
+ Creates a new ILogger instance of the given name.
+
+
+
+
+
+
+ A generic interface for logging.
+
+
+
+
+ Aggregates most logging patterns to a single method. This must be compatible with the Func representation in the OWIN environment.
+
+ To check IsEnabled call WriteCore with only TraceEventType and check the return value, no event will be written.
+
+
+
+
+
+
+
+
+
+
+ Contains the parts of an address.
+
+
+
+
+ Initializes a new instance.
+
+
+
+
+
+ Initializes a new with the given parts.
+
+ The scheme.
+ The host.
+ The port.
+ The path.
+
+
+
+ Creates a new
+
+ A new
+
+
+
+ Determines whether the specified object is equal to the current object.
+
+ The other object.
+ true if the specified object is equal to the current object; otherwise, false.
+
+
+
+ Determines whether the specified object is equal to the current object.
+
+ The other object.
+ true if the specified object is equal to the current object; otherwise, false.
+
+
+
+ Returns the hash code for this instance.
+
+ The hash code for this instance.
+
+
+
+ Determines whether two specified instances of are equal.
+
+ The first object to compare.
+ The second object to compare.
+ true if left and right represent the same address; otherwise, false.
+
+
+
+ Determines whether two specified instances of are not equal.
+
+ The first object to compare.
+ The second object to compare.
+ true if left and right do not represent the same address; otherwise, false.
+
+
+
+ Gets a specified key and value from the underlying dictionary.
+
+
+ The key.
+
+
+
+
+ Sets a specified key and value in the underlying dictionary.
+
+ The key.
+ The value.
+
+
+
+
+ Gets the internal dictionary for this collection.
+
+ The internal dictionary for this collection.
+
+
+
+ The uri scheme.
+
+
+
+
+ The uri host.
+
+
+
+
+ The uri port.
+
+
+
+
+ The uri path.
+
+
+
+
+ Wraps the host.Addresses list.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The address list to set to the collection.
+
+
+
+ Adds the specified address to the collection.
+
+ The address to add to the collection.
+
+
+
+ Gets the enumerator that iterates through the collection.
+
+ The enumerator that can be used to iterate through the collection.
+
+
+
+ Gets the enumerator that iterates through the collection.
+
+ The enumerator that can be used to iterate through the collection.
+
+
+
+ Creates a new empty instance of .
+
+ A new empty instance of .
+
+
+
+ Determines whether the current collection is equal to the specified collection.
+
+ The other collection to compare to the current collection.
+ true if current collection is equal to the specified collection; otherwise, false.
+
+
+
+ Determines whether the current collection is equal to the specified object.
+
+ The object to compare to the current collection.
+ true if current collection is equal to the specified object; otherwise, false.
+
+
+
+ Gets the hash code for this instance.
+
+ The hash code for this instance.
+
+
+
+ Determines whether the first collection is equal to the second collection.
+
+ The first collection to compare.
+ The second collection to compare.
+ true if both collections are equal; otherwise, false.
+
+
+
+ Determines whether the first collection is not equal to the second collection.
+
+ The first collection to compare.
+ The second collection to compare.
+ true if both collections are not equal; otherwise, false.
+
+
+
+ Gets the underlying address list.
+
+ The underlying address list.
+
+
+
+ Gets the number of elements in the collection.
+
+ The number of elements in the collection.
+
+
+
+ Gets the item with the specified index from the collection.
+
+ The index.
+ The item with the specified index.
+
+
+
+ A wrapper for the IDictionary.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+
+ Determines whether the current AppProperties is equal to the specified AppProperties.
+
+ The other AppProperties to compare with the current instance.
+ true if the current AppProperties is equal to the specified AppProperties; otherwise, false.
+
+
+
+ Determines whether the current AppProperties is equal to the specified object.
+
+ The object to compare with the current instance.
+ true if the current AppProperties is equal to the specified object; otherwise, false.
+
+
+
+ Returns the hash code for this instance.
+
+ The hash code for this instance.
+
+
+
+ Determines whether the first AppPProperties is equal to the second AppProperties.
+
+ The first AppPropeties to compare.
+ The second AppPropeties to compare.
+ true if both AppProperties are equal; otherwise, false.
+
+
+
+ Determines whether the first AppPProperties is not equal to the second AppProperties.
+
+ The first AppPropeties to compare.
+ The second AppPropeties to compare.
+ true if both AppProperties are not equal; otherwise, false.
+
+
+
+ Gets the value from the dictionary with the specified key.
+
+ The type of the value.
+ The key of the value to get.
+ The value with the specified key.
+
+
+
+ Sets the value with the specified key.
+
+ The key of the value to set.
+ The value to set.
+ This instance.
+
+
+
+ Gets or sets the string value for “owin.Version”.
+
+ The string value for “owin.Version”.
+
+
+
+ Gets or sets the function delegate for “builder.DefaultApp”.
+
+ The function delegate for “builder.DefaultApp”.
+
+
+
+ Gets or sets the action delegate for “builder.AddSignatureConversion”.
+
+ The action delegate for “builder.AddSignatureConversion”.
+
+
+
+ Gets or sets the string value for “host.AppName”.
+
+ The string value for “host.AppName”.
+
+
+
+ Gets or sets the text writer for “host.TraceOutput”.
+
+ The text writer for “host.TraceOutput”.
+
+
+
+ Gets or sets the cancellation token for “host.OnAppDisposing”.
+
+ The cancellation token for “host.OnAppDisposing”.
+
+
+
+ Gets or sets the address collection for “host.Addresses”.
+
+ The address collection for “host.Addresses”.
+
+
+
+ Gets or sets the list of “server.Capabilities”.
+
+ The list of “server.Capabilities”.
+
+
+
+ Gets the underlying dictionary for this instance.
+
+ The underlying dictionary for this instance.
+
+
+
+ Represents the capabilities for the builder properties.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+
+ Initializes a new instance of the class.
+
+ A new instance of the class.
+
+
+
+ Determines whether the current Capabilities instance is equal to the specified Capabilities.
+
+ The other Capabilities to compare with the current instance.
+ true if the specified object is equal to the current object; otherwise, false.
+
+
+
+ Determines whether the current Capabilities is equal to the specified object.
+
+ The object to compare with the current instance.
+ true if the current Capabilities is equal to the specified object; otherwise, false.
+
+
+
+ Returns the hash code for this instance.
+
+ The hash code for this instance.
+
+
+
+ Determines whether two specified instances of are equal.
+
+ The first object to compare.
+ The second object to compare.
+ true if the two specified instances of are equal; otherwise, false.
+
+
+
+ Determines whether two specified instances of are not equal.
+
+ The first object to compare.
+ The second object to compare.
+ true if the two specified instances of are not equal; otherwise, false.
+
+
+
+ Gets the value from the dictionary with the specified key.
+
+ The type of the value.
+ The key of the value to get.
+ The value with the specified key.
+
+
+
+ Sets the given key and value in the underlying dictionary.
+
+ The key of the value to set.
+ The value to set.
+ This instance.
+
+
+
+ The underling IDictionary
+
+
+
+
+ Gets or sets the string value for "sendfile.Version"
+
+ the string value for "sendfile.Version"
+
+
+
+ Gets or sets the websocket version.
+
+ The websocket version.
+
+
+
+ Options used to create a new cookie.
+
+
+
+
+ Creates a default cookie with a path of '/'.
+
+
+
+
+ Gets or sets the domain to associate the cookie with.
+
+ The domain to associate the cookie with.
+
+
+
+ Gets or sets the cookie path.
+
+ The cookie path.
+
+
+
+ Gets or sets the expiration date and time for the cookie.
+
+ The expiration date and time for the cookie.
+
+
+
+ Gets or sets a value that indicates whether to transmit the cookie using Secure Sockets Layer (SSL)—that is, over HTTPS only.
+
+ true to transmit the cookie only over an SSL connection (HTTPS); otherwise, false.
+
+
+
+ Gets or sets a value that indicates whether a cookie is accessible by client-side script.
+
+ true if a cookie is accessible by client-side script; otherwise, false.
+
+
+
+ Provides a default ILoggerFactory.
+
+
+
+
+ Provides a default ILoggerFactory based on System.Diagnostics.TraceSorce.
+
+
+
+
+ Extension methods for IAppBuilder.
+
+
+
+
+ The Build is called at the point when all of the middleware should be chained
+ together. May be called to build pipeline branches.
+
+
+ The request processing entry point for this section of the pipeline.
+
+
+
+ The Build is called at the point when all of the middleware should be chained
+ together. May be called to build pipeline branches.
+
+ The application signature.
+
+ The request processing entry point for this section of the pipeline.
+
+
+
+ Adds converters for adapting between disparate application signatures.
+
+
+
+
+
+
+ Adds converters for adapting between disparate application signatures.
+
+
+
+
+
+
+
+
+ Provides helper methods for processing requests.
+
+
+
+
+ Parses an HTTP form body.
+
+ The HTTP form body to parse.
+ The object containing the parsed HTTP form body.
+
+
+
+ Converts between an OwinMiddlware and an .
+
+
+
+
+ An abstract base class for a standard middleware pattern.
+
+
+
+
+ Instantiates the middleware with an optional pointer to the next component.
+
+
+
+
+
+ Process an individual request.
+
+
+
+
+
+
+ The optional next component.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Transitions between and OwinMiddleware.
+
+
+
+
+
+
+
+
+
+
+
+
+ OWIN environment dictionary which stores state information about the request, response and relevant server state.
+
+
+
+
+ Adds adapters between and OwinMiddleware.
+
+
+
+
+ Adds adapters between and OwinMiddleware.
+
+
+
+
+
+ This wraps OWIN environment dictionary and provides strongly typed accessors.
+
+
+
+
+ Create a new context with only request and response header collections.
+
+
+
+
+ Create a new environment wrapper exposing request properties.
+
+ OWIN environment dictionary which stores state information about the request, response and relevant server state.
+
+
+
+ Asynchronously reads and parses the request body as a form.
+
+ The parsed form data.
+
+
+
+ Gets a value from the OWIN environment, or returns default(T) if not present.
+
+ The type of the value.
+ The key of the value to get.
+ The value with the specified key or the default(T) if not present.
+
+
+
+ Sets the given key and value in the OWIN environment.
+
+ The type of the value.
+ The key of the value to set.
+ The value to set.
+ This instance.
+
+
+
+ Gets the OWIN environment.
+
+ The OWIN environment.
+
+
+
+ Gets the request context.
+
+ The request context.
+
+
+
+ Gets or set the HTTP method.
+
+ The HTTP method.
+
+
+
+ Gets or set the HTTP request scheme from owin.RequestScheme.
+
+ The HTTP request scheme from owin.RequestScheme.
+
+
+
+ Returns true if the owin.RequestScheme is https.
+
+ true if this request is using https; otherwise, false.
+
+
+
+ Gets or set the Host header. May include the port.
+
+ The Host header.
+
+
+
+ Gets or set the owin.RequestPathBase.
+
+ The owin.RequestPathBase.
+
+
+
+ Gets or set the request path from owin.RequestPath.
+
+ The request path from owin.RequestPath.
+
+
+
+ Gets or set the query string from owin.RequestQueryString.
+
+ The query string from owin.RequestQueryString.
+
+
+
+ Gets the query value collection parsed from owin.RequestQueryString.
+
+ The query value collection parsed from owin.RequestQueryString.
+
+
+
+ Gets the uniform resource identifier (URI) associated with the request.
+
+ The uniform resource identifier (URI) associated with the request.
+
+
+
+ Gets or set the owin.RequestProtocol.
+
+ The owin.RequestProtocol.
+
+
+
+ Gets the request headers.
+
+ The request headers.
+
+
+
+ Gets the collection of Cookies for this request.
+
+ The collection of Cookies for this request.
+
+
+
+ Gets or sets the Content-Type header.
+
+ The Content-Type header.
+
+
+
+ Gets or sets the Cache-Control header.
+
+ The Cache-Control header.
+
+
+
+ Gets or sets the Media-Type header.
+
+ The Media-Type header.
+
+
+
+ Gets or set the Accept header.
+
+ The Accept header.
+
+
+
+ Gets or set the owin.RequestBody Stream.
+
+ The owin.RequestBody Stream.
+
+
+
+ Gets or sets the cancellation token for the request.
+
+ The cancellation token for the request.
+
+
+
+ Gets or set the server.LocalIpAddress.
+
+ The server.LocalIpAddress.
+
+
+
+ Gets or set the server.LocalPort.
+
+ The server.LocalPort.
+
+
+
+ Gets or set the server.RemoteIpAddress.
+
+ The server.RemoteIpAddress.
+
+
+
+ Gets or set the server.RemotePort.
+
+ The server.RemotePort.
+
+
+
+ Gets or set the server.User.
+
+ The server.User.
+
+
+
+ This wraps OWIN environment dictionary and provides strongly typed accessors.
+
+
+
+
+ Create a new context with only request and response header collections.
+
+
+
+
+ Creates a new environment wrapper exposing response properties.
+
+ OWIN environment dictionary which stores state information about the request, response and relevant server state.
+
+
+
+ Registers for an event that fires when the response headers are sent.
+
+ The callback method.
+ The callback state.
+
+
+
+ Sets a 302 response status code and the Location header.
+
+ The location where to redirect the client.
+
+
+
+ Writes the given text to the response body stream using UTF-8.
+
+ The response data.
+
+
+
+ Writes the given bytes to the response body stream.
+
+ The response data.
+
+
+
+ Writes the given bytes to the response body stream.
+
+ The response data.
+ The zero-based byte offset in the parameter at which to begin copying bytes.
+ The number of bytes to write.
+
+
+
+ Asynchronously writes the given text to the response body stream using UTF-8.
+
+ The response data.
+ A Task tracking the state of the write operation.
+
+
+
+ Asynchronously writes the given text to the response body stream using UTF-8.
+
+ The response data.
+ A token used to indicate cancellation.
+ A Task tracking the state of the write operation.
+
+
+
+ Asynchronously writes the given bytes to the response body stream.
+
+ The response data.
+ A Task tracking the state of the write operation.
+
+
+
+ Asynchronously writes the given bytes to the response body stream.
+
+ The response data.
+ A token used to indicate cancellation.
+ A Task tracking the state of the write operation.
+
+
+
+ Asynchronously writes the given bytes to the response body stream.
+
+ The response data.
+ The zero-based byte offset in the parameter at which to begin copying bytes.
+ The number of bytes to write.
+ A token used to indicate cancellation.
+ A Task tracking the state of the write operation.
+
+
+
+ Gets a value from the OWIN environment, or returns default(T) if not present.
+
+ The type of the value.
+ The key of the value to get.
+ The value with the specified key or the default(T) if not present.
+
+
+
+ Sets the given key and value in the OWIN environment.
+
+ The type of the value.
+ The key of the value to set.
+ The value to set.
+ This instance.
+
+
+
+ Gets the OWIN environment.
+
+ The OWIN environment.
+
+
+
+ Gets the request context.
+
+ The request context.
+
+
+
+ Gets or sets the optional owin.ResponseStatusCode.
+
+ The optional owin.ResponseStatusCode, or 200 if not set.
+
+
+
+ Gets or sets the the optional owin.ResponseReasonPhrase.
+
+ The the optional owin.ResponseReasonPhrase.
+
+
+
+ Gets or sets the owin.ResponseProtocol.
+
+ The owin.ResponseProtocol.
+
+
+
+ Gets the response header collection.
+
+ The response header collection.
+
+
+
+ Gets a collection used to manipulate the Set-Cookie header.
+
+ A collection used to manipulate the Set-Cookie header.
+
+
+
+ Gets or sets the Content-Length header.
+
+ The Content-Length header.
+
+
+
+ Gets or sets the Content-Type header.
+
+ The Content-Type header.
+
+
+
+ Gets or sets the Expires header.
+
+ The Expires header.
+
+
+
+ Gets or sets the E-Tag header.
+
+ The E-Tag header.
+
+
+
+ Gets or sets the owin.ResponseBody Stream.
+
+ The owin.ResponseBody Stream.
+
+
+
+ Used to interact with authentication middleware that have been chained in the pipeline
+
+
+
+
+ Lists all of the description data provided by authentication middleware that have been chained
+
+ The authentication descriptions
+
+
+
+ Lists the description data of all of the authentication middleware which are true for a given predicate
+
+ A function provided by the caller which returns true for descriptions that should be in the returned list
+ The authentication descriptions
+
+
+
+ Call back through the middleware to ask for a specific form of authentication to be performed
+ on the current request
+
+ Identifies which middleware should respond to the request
+ for authentication. This value is compared to the middleware's Options.AuthenticationType property.
+ Returns an object with the results of the authentication. The AuthenticationResult.Identity
+ may be null if authentication failed. Even if the Identity property is null, there may still be
+ AuthenticationResult.properties and AuthenticationResult.Description information returned.
+
+
+
+ Called to perform any number of authentication mechanisms on the current request.
+
+ Identifies one or more middleware which should attempt to respond
+ Returns the AuthenticationResult information from the middleware which responded. The
+ order is determined by the order the middleware are in the pipeline. Latest added is first in the list.
+
+
+
+ Add information into the response environment that will cause the authentication middleware to challenge
+ the caller to authenticate. This also changes the status code of the response to 401. The nature of that
+ challenge varies greatly, and ranges from adding a response header or changing the 401 status code to
+ a 302 redirect.
+
+ Additional arbitrary values which may be used by particular authentication types.
+ Identify which middleware should perform their alterations on the
+ response. If the authenticationTypes is null or empty, that means the
+ AuthenticationMode.Active middleware should perform their alterations on the response.
+
+
+
+ Add information into the response environment that will cause the authentication middleware to challenge
+ the caller to authenticate. This also changes the status code of the response to 401. The nature of that
+ challenge varies greatly, and ranges from adding a response header or changing the 401 status code to
+ a 302 redirect.
+
+ Identify which middleware should perform their alterations on the
+ response. If the authenticationTypes is null or empty, that means the
+ AuthenticationMode.Active middleware should perform their alterations on the response.
+
+
+
+ Add information to the response environment that will cause the appropriate authentication middleware
+ to grant a claims-based identity to the recipient of the response. The exact mechanism of this may vary.
+ Examples include setting a cookie, to adding a fragment on the redirect url, or producing an OAuth2
+ access code or token response.
+
+ Contains additional properties the middleware are expected to persist along with
+ the claims. These values will be returned as the AuthenticateResult.properties collection when AuthenticateAsync
+ is called on subsequent requests.
+ Determines which claims are granted to the signed in user. The
+ ClaimsIdentity.AuthenticationType property is compared to the middleware's Options.AuthenticationType
+ value to determine which claims are granted by which middleware. The recommended use is to have a single
+ ClaimsIdentity which has the AuthenticationType matching a specific middleware.
+
+
+
+ Add information to the response environment that will cause the appropriate authentication middleware
+ to grant a claims-based identity to the recipient of the response. The exact mechanism of this may vary.
+ Examples include setting a cookie, to adding a fragment on the redirect url, or producing an OAuth2
+ access code or token response.
+
+ Determines which claims are granted to the signed in user. The
+ ClaimsIdentity.AuthenticationType property is compared to the middleware's Options.AuthenticationType
+ value to determine which claims are granted by which middleware. The recommended use is to have a single
+ ClaimsIdentity which has the AuthenticationType matching a specific middleware.
+
+
+
+ Add information to the response environment that will cause the appropriate authentication middleware
+ to revoke any claims identity associated the the caller. The exact method varies.
+
+ Additional arbitrary values which may be used by particular authentication types.
+ Identifies which middleware should perform the work to sign out.
+ Multiple authentication types may be provided to clear out more than one cookie at a time, or to clear
+ cookies and redirect to an external single-sign out url.
+
+
+
+ Add information to the response environment that will cause the appropriate authentication middleware
+ to revoke any claims identity associated the the caller. The exact method varies.
+
+ Identifies which middleware should perform the work to sign out.
+ Multiple authentication types may be provided to clear out more than one cookie at a time, or to clear
+ cookies and redirect to an external single-sign out url.
+
+
+
+ Returns the current user for the request
+
+
+
+
+ Exposes the security.Challenge environment value as a strong type.
+
+
+
+
+ Exposes the security.SignIn environment value as a strong type.
+
+
+
+
+ Exposes the security.SignOut environment value as a strong type.
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Exposes the security.Challenge environment value as a strong type.
+
+
+
+
+ Exposes the security.SignIn environment value as a strong type.
+
+
+
+
+ Exposes the security.SignOut environment value as a strong type.
+
+
+
+
+ Dictionary used to store state values about the authentication session.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+ State values about the authentication session.
+
+
+
+
+ Gets or sets whether the authentication session is persisted across multiple requests.
+
+
+
+
+ Gets or sets the full path or absolute URI to be used as an http redirect response value.
+
+
+
+
+ Gets or sets the time at which the authentication ticket was issued.
+
+
+
+
+ Gets or sets the time at which the authentication ticket expires.
+
+
+
+
+ Gets or sets if refreshing the authentication session should be allowed.
+
+
+
+
+ Exposes the security.Challenge environment value as a strong type.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+ List of the authentication types that should send a challenge in the response.
+
+
+
+
+ Dictionary used to store state values about the authentication session.
+
+
+
+
+ Exposes the security.SignIn environment value as a strong type.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+
+
+ The identity associated with the user sign in.
+
+
+
+
+ The security principal associated with the user sign in.
+
+
+
+
+ Dictionary used to store state values about the authentication session.
+
+
+
+
+ Exposes the security.SignOut and security.SignOutProperties environment values as a strong type.
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+ Initializes a new instance of the class
+
+
+
+
+
+
+ List of the authentication types that should be revoked on sign out.
+
+
+
+
+ Dictionary used to store state values about the authentication session.
+
+
+
+
+ Provides an ILoggerFactory based on System.Diagnostics.TraceSource.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a factory named "Microsoft.Owin".
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+
+
+ Creates a new DiagnosticsLogger for the given component name.
+
+
+
+
+
+
+ ILogger extension methods for common scenarios.
+
+
+
+
+ Checks if the given TraceEventType is enabled.
+
+
+
+
+
+
+
+ Writes a verbose log message.
+
+
+
+
+
+
+ Writes an informational log message.
+
+
+
+
+
+
+ Writes a warning log message.
+
+
+
+
+
+
+
+ Writes a warning log message.
+
+
+
+
+
+
+
+ Writes an error log message.
+
+
+
+
+
+
+ Writes an error log message.
+
+
+
+
+
+
+
+ Writes a critical log message.
+
+
+
+
+
+
+ Writes a critical log message.
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Web.Infrastructure.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Web.Infrastructure.dll
new file mode 100644
index 000000000..85f1138c5
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Microsoft.Web.Infrastructure.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Newtonsoft.Json.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Newtonsoft.Json.dll
new file mode 100644
index 000000000..597a1cef9
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Newtonsoft.Json.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Newtonsoft.Json.xml b/samples/angular-aad-webapi/api/api.securecall/bin/Newtonsoft.Json.xml
new file mode 100644
index 000000000..8e08389c0
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/Newtonsoft.Json.xml
@@ -0,0 +1,8558 @@
+
+
+
+ Newtonsoft.Json
+
+
+
+
+ Represents a BSON Oid (object id).
+
+
+
+
+ Initializes a new instance of the class.
+
+ The Oid value.
+
+
+
+ Gets or sets the value of the Oid.
+
+ The value of the Oid.
+
+
+
+ Represents a reader that provides fast, non-cached, forward-only access to serialized Json data.
+
+
+
+
+ Represents a reader that provides fast, non-cached, forward-only access to serialized Json data.
+
+
+
+
+ Initializes a new instance of the class with the specified .
+
+
+
+
+ Reads the next JSON token from the stream.
+
+ true if the next token was read successfully; false if there are no more tokens to read.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A or a null reference if the next JSON token is null. This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Skips the children of the current token.
+
+
+
+
+ Sets the current token.
+
+ The new token.
+
+
+
+ Sets the current token and value.
+
+ The new token.
+ The value.
+
+
+
+ Sets the state based on current token type.
+
+
+
+
+ Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
+
+
+
+
+ Releases unmanaged and - optionally - managed resources
+
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+
+ Changes the to Closed.
+
+
+
+
+ Gets the current reader state.
+
+ The current reader state.
+
+
+
+ Gets or sets a value indicating whether the underlying stream or
+ should be closed when the reader is closed.
+
+
+ true to close the underlying stream or when
+ the reader is closed; otherwise false. The default is true.
+
+
+
+
+ Gets or sets a value indicating whether multiple pieces of JSON content can
+ be read from a continuous stream without erroring.
+
+
+ true to support reading multiple pieces of JSON content; otherwise false. The default is false.
+
+
+
+
+ Gets the quotation mark character used to enclose the value of a string.
+
+
+
+
+ Get or set how time zones are handling when reading JSON.
+
+
+
+
+ Get or set how date formatted strings, e.g. "\/Date(1198908717056)\/" and "2012-03-21T05:40Z", are parsed when reading JSON.
+
+
+
+
+ Get or set how floating point numbers, e.g. 1.0 and 9.9, are parsed when reading JSON text.
+
+
+
+
+ Get or set how custom date formatted strings are parsed when reading JSON.
+
+
+
+
+ Gets or sets the maximum depth allowed when reading JSON. Reading past this depth will throw a .
+
+
+
+
+ Gets the type of the current JSON token.
+
+
+
+
+ Gets the text value of the current JSON token.
+
+
+
+
+ Gets The Common Language Runtime (CLR) type for the current JSON token.
+
+
+
+
+ Gets the depth of the current token in the JSON document.
+
+ The depth of the current token in the JSON document.
+
+
+
+ Gets the path of the current JSON token.
+
+
+
+
+ Gets or sets the culture used when reading JSON. Defaults to .
+
+
+
+
+ Specifies the state of the reader.
+
+
+
+
+ The Read method has not been called.
+
+
+
+
+ The end of the file has been reached successfully.
+
+
+
+
+ Reader is at a property.
+
+
+
+
+ Reader is at the start of an object.
+
+
+
+
+ Reader is in an object.
+
+
+
+
+ Reader is at the start of an array.
+
+
+
+
+ Reader is in an array.
+
+
+
+
+ The Close method has been called.
+
+
+
+
+ Reader has just read a value.
+
+
+
+
+ Reader is at the start of a constructor.
+
+
+
+
+ Reader in a constructor.
+
+
+
+
+ An error occurred that prevents the read operation from continuing.
+
+
+
+
+ The end of the file has been reached successfully.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The stream.
+
+
+
+ Initializes a new instance of the class.
+
+ The reader.
+
+
+
+ Initializes a new instance of the class.
+
+ The stream.
+ if set to true the root object will be read as a JSON array.
+ The used when reading values from BSON.
+
+
+
+ Initializes a new instance of the class.
+
+ The reader.
+ if set to true the root object will be read as a JSON array.
+ The used when reading values from BSON.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+
+ A or a null reference if the next JSON token is null. This method will return null at the end of an array.
+
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+
+ A . This method will return null at the end of an array.
+
+
+
+
+ Reads the next JSON token from the stream.
+
+
+ true if the next token was read successfully; false if there are no more tokens to read.
+
+
+
+
+ Changes the to Closed.
+
+
+
+
+ Gets or sets a value indicating whether binary data reading should compatible with incorrect Json.NET 3.5 written binary.
+
+
+ true if binary data reading will be compatible with incorrect Json.NET 3.5 written binary; otherwise, false.
+
+
+
+
+ Gets or sets a value indicating whether the root object will be read as a JSON array.
+
+
+ true if the root object will be read as a JSON array; otherwise, false.
+
+
+
+
+ Gets or sets the used when reading values from BSON.
+
+ The used when reading values from BSON.
+
+
+
+ Represents a writer that provides a fast, non-cached, forward-only way of generating JSON data.
+
+
+
+
+ Represents a writer that provides a fast, non-cached, forward-only way of generating Json data.
+
+
+
+
+ Creates an instance of the JsonWriter class.
+
+
+
+
+ Flushes whatever is in the buffer to the underlying streams and also flushes the underlying stream.
+
+
+
+
+ Closes this stream and the underlying stream.
+
+
+
+
+ Writes the beginning of a Json object.
+
+
+
+
+ Writes the end of a Json object.
+
+
+
+
+ Writes the beginning of a Json array.
+
+
+
+
+ Writes the end of an array.
+
+
+
+
+ Writes the start of a constructor with the given name.
+
+ The name of the constructor.
+
+
+
+ Writes the end constructor.
+
+
+
+
+ Writes the property name of a name/value pair on a JSON object.
+
+ The name of the property.
+
+
+
+ Writes the property name of a name/value pair on a JSON object.
+
+ The name of the property.
+ A flag to indicate whether the text should be escaped when it is written as a JSON property name.
+
+
+
+ Writes the end of the current Json object or array.
+
+
+
+
+ Writes the current token and its children.
+
+ The to read the token from.
+
+
+
+ Writes the current token.
+
+ The to read the token from.
+ A flag indicating whether the current token's children should be written.
+
+
+
+ Writes the specified end token.
+
+ The end token to write.
+
+
+
+ Writes indent characters.
+
+
+
+
+ Writes the JSON value delimiter.
+
+
+
+
+ Writes an indent space.
+
+
+
+
+ Writes a null value.
+
+
+
+
+ Writes an undefined value.
+
+
+
+
+ Writes raw JSON without changing the writer's state.
+
+ The raw JSON to write.
+
+
+
+ Writes raw JSON where a value is expected and updates the writer's state.
+
+ The raw JSON to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+ An error will raised if the value cannot be written as a single JSON token.
+
+ The value to write.
+
+
+
+ Writes out a comment /*...*/
containing the specified text.
+
+ Text to place inside the comment.
+
+
+
+ Writes out the given white space.
+
+ The string of white space characters.
+
+
+
+ Sets the state of the JsonWriter,
+
+ The JsonToken being written.
+ The value being written.
+
+
+
+ Gets or sets a value indicating whether the underlying stream or
+ should be closed when the writer is closed.
+
+
+ true to close the underlying stream or when
+ the writer is closed; otherwise false. The default is true.
+
+
+
+
+ Gets the top.
+
+ The top.
+
+
+
+ Gets the state of the writer.
+
+
+
+
+ Gets the path of the writer.
+
+
+
+
+ Indicates how JSON text output is formatted.
+
+
+
+
+ Get or set how dates are written to JSON text.
+
+
+
+
+ Get or set how time zones are handling when writing JSON text.
+
+
+
+
+ Get or set how strings are escaped when writing JSON text.
+
+
+
+
+ Get or set how special floating point numbers, e.g. ,
+ and ,
+ are written to JSON text.
+
+
+
+
+ Get or set how and values are formatting when writing JSON text.
+
+
+
+
+ Gets or sets the culture used when writing JSON. Defaults to .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The stream.
+
+
+
+ Initializes a new instance of the class.
+
+ The writer.
+
+
+
+ Flushes whatever is in the buffer to the underlying streams and also flushes the underlying stream.
+
+
+
+
+ Writes the end.
+
+ The token.
+
+
+
+ Writes out a comment /*...*/
containing the specified text.
+
+ Text to place inside the comment.
+
+
+
+ Writes the start of a constructor with the given name.
+
+ The name of the constructor.
+
+
+
+ Writes raw JSON.
+
+ The raw JSON to write.
+
+
+
+ Writes raw JSON where a value is expected and updates the writer's state.
+
+ The raw JSON to write.
+
+
+
+ Writes the beginning of a Json array.
+
+
+
+
+ Writes the beginning of a Json object.
+
+
+
+
+ Writes the property name of a name/value pair on a Json object.
+
+ The name of the property.
+
+
+
+ Closes this stream and the underlying stream.
+
+
+
+
+ Writes a value.
+ An error will raised if the value cannot be written as a single JSON token.
+
+ The value to write.
+
+
+
+ Writes a null value.
+
+
+
+
+ Writes an undefined value.
+
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value that represents a BSON object id.
+
+ The Object ID value to write.
+
+
+
+ Writes a BSON regex.
+
+ The regex pattern.
+ The regex options.
+
+
+
+ Gets or sets the used when writing values to BSON.
+ When set to no conversion will occur.
+
+ The used when writing values to BSON.
+
+
+
+ Specifies how constructors are used when initializing objects during deserialization by the .
+
+
+
+
+ First attempt to use the public default constructor, then fall back to single paramatized constructor, then the non-public default constructor.
+
+
+
+
+ Json.NET will use a non-public default constructor before falling back to a paramatized constructor.
+
+
+
+
+ Converts a binary value to and from a base 64 string value.
+
+
+
+
+ Converts an object to and from JSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Gets the of the JSON produced by the JsonConverter.
+
+ The of the JSON produced by the JsonConverter.
+
+
+
+ Gets a value indicating whether this can read JSON.
+
+ true if this can read JSON; otherwise, false.
+
+
+
+ Gets a value indicating whether this can write JSON.
+
+ true if this can write JSON; otherwise, false.
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Converts a to and from JSON and BSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Create a custom object
+
+ The object type to convert.
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Creates an object which will then be populated by the serializer.
+
+ Type of the object.
+ The created object.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Gets a value indicating whether this can write JSON.
+
+
+ true if this can write JSON; otherwise, false.
+
+
+
+
+ Converts a to and from JSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified value type.
+
+ Type of the value.
+
+ true if this instance can convert the specified value type; otherwise, false.
+
+
+
+
+ Converts a to and from JSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified value type.
+
+ Type of the value.
+
+ true if this instance can convert the specified value type; otherwise, false.
+
+
+
+
+ Provides a base class for converting a to and from JSON.
+
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Converts a F# discriminated union type to and from JSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Converts an Entity Framework EntityKey to and from JSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Converts an ExpandoObject to and from JSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Gets a value indicating whether this can write JSON.
+
+
+ true if this can write JSON; otherwise, false.
+
+
+
+
+ Converts a to and from the ISO 8601 date format (e.g. 2008-04-12T12:53Z).
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Gets or sets the date time styles used when converting a date to and from JSON.
+
+ The date time styles used when converting a date to and from JSON.
+
+
+
+ Gets or sets the date time format used when converting a date to and from JSON.
+
+ The date time format used when converting a date to and from JSON.
+
+
+
+ Gets or sets the culture used when converting a date to and from JSON.
+
+ The culture used when converting a date to and from JSON.
+
+
+
+ Converts a to and from a JavaScript date constructor (e.g. new Date(52231943)).
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing property value of the JSON that is being converted.
+ The calling serializer.
+ The object value.
+
+
+
+ Converts a to and from JSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Converts a to and from JSON and BSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Converts an to and from its name string value.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Gets or sets a value indicating whether the written enum text should be camel case.
+
+ true if the written enum text will be camel case; otherwise, false.
+
+
+
+ Gets or sets a value indicating whether integer values are allowed.
+
+ true if integers are allowed; otherwise, false.
+
+
+
+ Converts a to and from a string (e.g. "1.2.3.4").
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The value.
+ The calling serializer.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing property value of the JSON that is being converted.
+ The calling serializer.
+ The object value.
+
+
+
+ Determines whether this instance can convert the specified object type.
+
+ Type of the object.
+
+ true if this instance can convert the specified object type; otherwise, false.
+
+
+
+
+ Converts XML to and from JSON.
+
+
+
+
+ Writes the JSON representation of the object.
+
+ The to write to.
+ The calling serializer.
+ The value.
+
+
+
+ Reads the JSON representation of the object.
+
+ The to read from.
+ Type of the object.
+ The existing value of object being read.
+ The calling serializer.
+ The object value.
+
+
+
+ Checks if the attributeName is a namespace attribute.
+
+ Attribute name to test.
+ The attribute name prefix if it has one, otherwise an empty string.
+ True if attribute name is for a namespace attribute, otherwise false.
+
+
+
+ Determines whether this instance can convert the specified value type.
+
+ Type of the value.
+
+ true if this instance can convert the specified value type; otherwise, false.
+
+
+
+
+ Gets or sets the name of the root element to insert when deserializing to XML if the JSON structure has produces multiple root elements.
+
+ The name of the deserialize root element.
+
+
+
+ Gets or sets a flag to indicate whether to write the Json.NET array attribute.
+ This attribute helps preserve arrays when converting the written XML back to JSON.
+
+ true if the array attibute is written to the XML; otherwise, false.
+
+
+
+ Gets or sets a value indicating whether to write the root JSON object.
+
+ true if the JSON root object is omitted; otherwise, false.
+
+
+
+ Specifies how floating point numbers, e.g. 1.0 and 9.9, are parsed when reading JSON text.
+
+
+
+
+ Floating point numbers are parsed to .
+
+
+
+
+ Floating point numbers are parsed to .
+
+
+
+
+ Specifies how dates are formatted when writing JSON text.
+
+
+
+
+ Dates are written in the ISO 8601 format, e.g. "2012-03-21T05:40Z".
+
+
+
+
+ Dates are written in the Microsoft JSON format, e.g. "\/Date(1198908717056)\/".
+
+
+
+
+ Specifies how date formatted strings, e.g. "\/Date(1198908717056)\/" and "2012-03-21T05:40Z", are parsed when reading JSON text.
+
+
+
+
+ Date formatted strings are not parsed to a date type and are read as strings.
+
+
+
+
+ Date formatted strings, e.g. "\/Date(1198908717056)\/" and "2012-03-21T05:40Z", are parsed to .
+
+
+
+
+ Date formatted strings, e.g. "\/Date(1198908717056)\/" and "2012-03-21T05:40Z", are parsed to .
+
+
+
+
+ Specifies how to treat the time value when converting between string and .
+
+
+
+
+ Treat as local time. If the object represents a Coordinated Universal Time (UTC), it is converted to the local time.
+
+
+
+
+ Treat as a UTC. If the object represents a local time, it is converted to a UTC.
+
+
+
+
+ Treat as a local time if a is being converted to a string.
+ If a string is being converted to , convert to a local time if a time zone is specified.
+
+
+
+
+ Time zone information should be preserved when converting.
+
+
+
+
+ Specifies default value handling options for the .
+
+
+
+
+
+
+
+
+ Include members where the member value is the same as the member's default value when serializing objects.
+ Included members are written to JSON. Has no effect when deserializing.
+
+
+
+
+ Ignore members where the member value is the same as the member's default value when serializing objects
+ so that is is not written to JSON.
+ This option will ignore all default values (e.g. null for objects and nullable types; 0 for integers,
+ decimals and floating point numbers; and false for booleans). The default value ignored can be changed by
+ placing the on the property.
+
+
+
+
+ Members with a default value but no JSON will be set to their default value when deserializing.
+
+
+
+
+ Ignore members where the member value is the same as the member's default value when serializing objects
+ and sets members to their default value when deserializing.
+
+
+
+
+ Specifies float format handling options when writing special floating point numbers, e.g. ,
+ and with .
+
+
+
+
+ Write special floating point values as strings in JSON, e.g. "NaN", "Infinity", "-Infinity".
+
+
+
+
+ Write special floating point values as symbols in JSON, e.g. NaN, Infinity, -Infinity.
+ Note that this will produce non-valid JSON.
+
+
+
+
+ Write special floating point values as the property's default value in JSON, e.g. 0.0 for a property, null for a property.
+
+
+
+
+ Specifies formatting options for the .
+
+
+
+
+ No special formatting is applied. This is the default.
+
+
+
+
+ Causes child objects to be indented according to the and settings.
+
+
+
+
+ Provides an interface to enable a class to return line and position information.
+
+
+
+
+ Gets a value indicating whether the class can return line information.
+
+
+ true if LineNumber and LinePosition can be provided; otherwise, false.
+
+
+
+
+ Gets the current line number.
+
+ The current line number or 0 if no line information is available (for example, HasLineInfo returns false).
+
+
+
+ Gets the current line position.
+
+ The current line position or 0 if no line information is available (for example, HasLineInfo returns false).
+
+
+
+ Instructs the how to serialize the collection.
+
+
+
+
+ Instructs the how to serialize the object.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class with the specified container Id.
+
+ The container Id.
+
+
+
+ Gets or sets the id.
+
+ The id.
+
+
+
+ Gets or sets the title.
+
+ The title.
+
+
+
+ Gets or sets the description.
+
+ The description.
+
+
+
+ Gets the collection's items converter.
+
+ The collection's items converter.
+
+
+
+ Gets or sets a value that indicates whether to preserve object references.
+
+
+ true to keep object reference; otherwise, false. The default is false.
+
+
+
+
+ Gets or sets a value that indicates whether to preserve collection's items references.
+
+
+ true to keep collection's items object references; otherwise, false. The default is false.
+
+
+
+
+ Gets or sets the reference loop handling used when serializing the collection's items.
+
+ The reference loop handling.
+
+
+
+ Gets or sets the type name handling used when serializing the collection's items.
+
+ The type name handling.
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class with a flag indicating whether the array can contain null items
+
+ A flag indicating whether the array can contain null items.
+
+
+
+ Initializes a new instance of the class with the specified container Id.
+
+ The container Id.
+
+
+
+ Gets or sets a value indicating whether null items are allowed in the collection.
+
+ true if null items are allowed in the collection; otherwise, false.
+
+
+
+ Instructs the to use the specified constructor when deserializing that object.
+
+
+
+
+ Provides methods for converting between common language runtime types and JSON types.
+
+
+
+
+
+
+
+ Represents JavaScript's boolean value true as a string. This field is read-only.
+
+
+
+
+ Represents JavaScript's boolean value false as a string. This field is read-only.
+
+
+
+
+ Represents JavaScript's null as a string. This field is read-only.
+
+
+
+
+ Represents JavaScript's undefined as a string. This field is read-only.
+
+
+
+
+ Represents JavaScript's positive infinity as a string. This field is read-only.
+
+
+
+
+ Represents JavaScript's negative infinity as a string. This field is read-only.
+
+
+
+
+ Represents JavaScript's NaN as a string. This field is read-only.
+
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation using the specified.
+
+ The value to convert.
+ The format the date will be converted to.
+ The time zone handling when the date is converted to a string.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation using the specified.
+
+ The value to convert.
+ The format the date will be converted to.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ The string delimiter character.
+ A JSON string representation of the .
+
+
+
+ Converts the to its JSON string representation.
+
+ The value to convert.
+ A JSON string representation of the .
+
+
+
+ Serializes the specified object to a JSON string.
+
+ The object to serialize.
+ A JSON string representation of the object.
+
+
+
+ Serializes the specified object to a JSON string using formatting.
+
+ The object to serialize.
+ Indicates how the output is formatted.
+
+ A JSON string representation of the object.
+
+
+
+
+ Serializes the specified object to a JSON string using a collection of .
+
+ The object to serialize.
+ A collection converters used while serializing.
+ A JSON string representation of the object.
+
+
+
+ Serializes the specified object to a JSON string using formatting and a collection of .
+
+ The object to serialize.
+ Indicates how the output is formatted.
+ A collection converters used while serializing.
+ A JSON string representation of the object.
+
+
+
+ Serializes the specified object to a JSON string using .
+
+ The object to serialize.
+ The used to serialize the object.
+ If this is null, default serialization settings will be used.
+
+ A JSON string representation of the object.
+
+
+
+
+ Serializes the specified object to a JSON string using a type, formatting and .
+
+ The object to serialize.
+ The used to serialize the object.
+ If this is null, default serialization settings will be used.
+
+ The type of the value being serialized.
+ This parameter is used when is Auto to write out the type name if the type of the value does not match.
+ Specifing the type is optional.
+
+
+ A JSON string representation of the object.
+
+
+
+
+ Serializes the specified object to a JSON string using formatting and .
+
+ The object to serialize.
+ Indicates how the output is formatted.
+ The used to serialize the object.
+ If this is null, default serialization settings will be used.
+
+ A JSON string representation of the object.
+
+
+
+
+ Serializes the specified object to a JSON string using a type, formatting and .
+
+ The object to serialize.
+ Indicates how the output is formatted.
+ The used to serialize the object.
+ If this is null, default serialization settings will be used.
+
+ The type of the value being serialized.
+ This parameter is used when is Auto to write out the type name if the type of the value does not match.
+ Specifing the type is optional.
+
+
+ A JSON string representation of the object.
+
+
+
+
+ Asynchronously serializes the specified object to a JSON string.
+ Serialization will happen on a new thread.
+
+ The object to serialize.
+
+ A task that represents the asynchronous serialize operation. The value of the TResult parameter contains a JSON string representation of the object.
+
+
+
+
+ Asynchronously serializes the specified object to a JSON string using formatting.
+ Serialization will happen on a new thread.
+
+ The object to serialize.
+ Indicates how the output is formatted.
+
+ A task that represents the asynchronous serialize operation. The value of the TResult parameter contains a JSON string representation of the object.
+
+
+
+
+ Asynchronously serializes the specified object to a JSON string using formatting and a collection of .
+ Serialization will happen on a new thread.
+
+ The object to serialize.
+ Indicates how the output is formatted.
+ The used to serialize the object.
+ If this is null, default serialization settings will be used.
+
+ A task that represents the asynchronous serialize operation. The value of the TResult parameter contains a JSON string representation of the object.
+
+
+
+
+ Deserializes the JSON to a .NET object.
+
+ The JSON to deserialize.
+ The deserialized object from the JSON string.
+
+
+
+ Deserializes the JSON to a .NET object using .
+
+ The JSON to deserialize.
+
+ The used to deserialize the object.
+ If this is null, default serialization settings will be used.
+
+ The deserialized object from the JSON string.
+
+
+
+ Deserializes the JSON to the specified .NET type.
+
+ The JSON to deserialize.
+ The of object being deserialized.
+ The deserialized object from the JSON string.
+
+
+
+ Deserializes the JSON to the specified .NET type.
+
+ The type of the object to deserialize to.
+ The JSON to deserialize.
+ The deserialized object from the JSON string.
+
+
+
+ Deserializes the JSON to the given anonymous type.
+
+
+ The anonymous type to deserialize to. This can't be specified
+ traditionally and must be infered from the anonymous type passed
+ as a parameter.
+
+ The JSON to deserialize.
+ The anonymous type object.
+ The deserialized anonymous type from the JSON string.
+
+
+
+ Deserializes the JSON to the given anonymous type using .
+
+
+ The anonymous type to deserialize to. This can't be specified
+ traditionally and must be infered from the anonymous type passed
+ as a parameter.
+
+ The JSON to deserialize.
+ The anonymous type object.
+
+ The used to deserialize the object.
+ If this is null, default serialization settings will be used.
+
+ The deserialized anonymous type from the JSON string.
+
+
+
+ Deserializes the JSON to the specified .NET type using a collection of .
+
+ The type of the object to deserialize to.
+ The JSON to deserialize.
+ Converters to use while deserializing.
+ The deserialized object from the JSON string.
+
+
+
+ Deserializes the JSON to the specified .NET type using .
+
+ The type of the object to deserialize to.
+ The object to deserialize.
+
+ The used to deserialize the object.
+ If this is null, default serialization settings will be used.
+
+ The deserialized object from the JSON string.
+
+
+
+ Deserializes the JSON to the specified .NET type using a collection of .
+
+ The JSON to deserialize.
+ The type of the object to deserialize.
+ Converters to use while deserializing.
+ The deserialized object from the JSON string.
+
+
+
+ Deserializes the JSON to the specified .NET type using .
+
+ The JSON to deserialize.
+ The type of the object to deserialize to.
+
+ The used to deserialize the object.
+ If this is null, default serialization settings will be used.
+
+ The deserialized object from the JSON string.
+
+
+
+ Asynchronously deserializes the JSON to the specified .NET type.
+ Deserialization will happen on a new thread.
+
+ The type of the object to deserialize to.
+ The JSON to deserialize.
+
+ A task that represents the asynchronous deserialize operation. The value of the TResult parameter contains the deserialized object from the JSON string.
+
+
+
+
+ Asynchronously deserializes the JSON to the specified .NET type using .
+ Deserialization will happen on a new thread.
+
+ The type of the object to deserialize to.
+ The JSON to deserialize.
+
+ The used to deserialize the object.
+ If this is null, default serialization settings will be used.
+
+
+ A task that represents the asynchronous deserialize operation. The value of the TResult parameter contains the deserialized object from the JSON string.
+
+
+
+
+ Asynchronously deserializes the JSON to the specified .NET type.
+ Deserialization will happen on a new thread.
+
+ The JSON to deserialize.
+
+ A task that represents the asynchronous deserialize operation. The value of the TResult parameter contains the deserialized object from the JSON string.
+
+
+
+
+ Asynchronously deserializes the JSON to the specified .NET type using .
+ Deserialization will happen on a new thread.
+
+ The JSON to deserialize.
+ The type of the object to deserialize to.
+
+ The used to deserialize the object.
+ If this is null, default serialization settings will be used.
+
+
+ A task that represents the asynchronous deserialize operation. The value of the TResult parameter contains the deserialized object from the JSON string.
+
+
+
+
+ Populates the object with values from the JSON string.
+
+ The JSON to populate values from.
+ The target object to populate values onto.
+
+
+
+ Populates the object with values from the JSON string using .
+
+ The JSON to populate values from.
+ The target object to populate values onto.
+
+ The used to deserialize the object.
+ If this is null, default serialization settings will be used.
+
+
+
+
+ Asynchronously populates the object with values from the JSON string using .
+
+ The JSON to populate values from.
+ The target object to populate values onto.
+
+ The used to deserialize the object.
+ If this is null, default serialization settings will be used.
+
+
+ A task that represents the asynchronous populate operation.
+
+
+
+
+ Serializes the XML node to a JSON string.
+
+ The node to serialize.
+ A JSON string of the XmlNode.
+
+
+
+ Serializes the XML node to a JSON string using formatting.
+
+ The node to serialize.
+ Indicates how the output is formatted.
+ A JSON string of the XmlNode.
+
+
+
+ Serializes the XML node to a JSON string using formatting and omits the root object if is true.
+
+ The node to serialize.
+ Indicates how the output is formatted.
+ Omits writing the root object.
+ A JSON string of the XmlNode.
+
+
+
+ Deserializes the XmlNode from a JSON string.
+
+ The JSON string.
+ The deserialized XmlNode
+
+
+
+ Deserializes the XmlNode from a JSON string nested in a root elment specified by .
+
+ The JSON string.
+ The name of the root element to append when deserializing.
+ The deserialized XmlNode
+
+
+
+ Deserializes the XmlNode from a JSON string nested in a root elment specified by
+ and writes a .NET array attribute for collections.
+
+ The JSON string.
+ The name of the root element to append when deserializing.
+
+ A flag to indicate whether to write the Json.NET array attribute.
+ This attribute helps preserve arrays when converting the written XML back to JSON.
+
+ The deserialized XmlNode
+
+
+
+ Serializes the to a JSON string.
+
+ The node to convert to JSON.
+ A JSON string of the XNode.
+
+
+
+ Serializes the to a JSON string using formatting.
+
+ The node to convert to JSON.
+ Indicates how the output is formatted.
+ A JSON string of the XNode.
+
+
+
+ Serializes the to a JSON string using formatting and omits the root object if is true.
+
+ The node to serialize.
+ Indicates how the output is formatted.
+ Omits writing the root object.
+ A JSON string of the XNode.
+
+
+
+ Deserializes the from a JSON string.
+
+ The JSON string.
+ The deserialized XNode
+
+
+
+ Deserializes the from a JSON string nested in a root elment specified by .
+
+ The JSON string.
+ The name of the root element to append when deserializing.
+ The deserialized XNode
+
+
+
+ Deserializes the from a JSON string nested in a root elment specified by
+ and writes a .NET array attribute for collections.
+
+ The JSON string.
+ The name of the root element to append when deserializing.
+
+ A flag to indicate whether to write the Json.NET array attribute.
+ This attribute helps preserve arrays when converting the written XML back to JSON.
+
+ The deserialized XNode
+
+
+
+ Gets or sets a function that creates default .
+ Default settings are automatically used by serialization methods on ,
+ and and on .
+ To serialize without using any default settings create a with
+ .
+
+
+
+
+ Instructs the to use the specified when serializing the member or class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Type of the converter.
+
+
+
+ Gets the type of the converter.
+
+ The type of the converter.
+
+
+
+ Represents a collection of .
+
+
+
+
+ Instructs the how to serialize the collection.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class with the specified container Id.
+
+ The container Id.
+
+
+
+ The exception thrown when an error occurs during Json serialization or deserialization.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class
+ with a specified error message.
+
+ The error message that explains the reason for the exception.
+
+
+
+ Initializes a new instance of the class
+ with a specified error message and a reference to the inner exception that is the cause of this exception.
+
+ The error message that explains the reason for the exception.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of the class.
+
+ The that holds the serialized object data about the exception being thrown.
+ The that contains contextual information about the source or destination.
+ The parameter is null.
+ The class name is null or is zero (0).
+
+
+
+ Instructs the to deserialize properties with no matching class member into the specified collection
+ and write values during serialization.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Gets or sets a value that indicates whether to write extension data when serializing the object.
+
+
+ true to write extension data when serializing the object; otherwise, false. The default is true.
+
+
+
+
+ Gets or sets a value that indicates whether to read extension data when deserializing the object.
+
+
+ true to read extension data when deserializing the object; otherwise, false. The default is true.
+
+
+
+
+ Instructs the not to serialize the public field or public read/write property value.
+
+
+
+
+ Instructs the how to serialize the object.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class with the specified member serialization.
+
+ The member serialization.
+
+
+
+ Initializes a new instance of the class with the specified container Id.
+
+ The container Id.
+
+
+
+ Gets or sets the member serialization.
+
+ The member serialization.
+
+
+
+ Gets or sets a value that indicates whether the object's properties are required.
+
+
+ A value indicating whether the object's properties are required.
+
+
+
+
+ Instructs the to always serialize the member with the specified name.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class with the specified name.
+
+ Name of the property.
+
+
+
+ Gets or sets the converter used when serializing the property's collection items.
+
+ The collection's items converter.
+
+
+
+ Gets or sets the null value handling used when serializing this property.
+
+ The null value handling.
+
+
+
+ Gets or sets the default value handling used when serializing this property.
+
+ The default value handling.
+
+
+
+ Gets or sets the reference loop handling used when serializing this property.
+
+ The reference loop handling.
+
+
+
+ Gets or sets the object creation handling used when deserializing this property.
+
+ The object creation handling.
+
+
+
+ Gets or sets the type name handling used when serializing this property.
+
+ The type name handling.
+
+
+
+ Gets or sets whether this property's value is serialized as a reference.
+
+ Whether this property's value is serialized as a reference.
+
+
+
+ Gets or sets the order of serialization and deserialization of a member.
+
+ The numeric order of serialization or deserialization.
+
+
+
+ Gets or sets a value indicating whether this property is required.
+
+
+ A value indicating whether this property is required.
+
+
+
+
+ Gets or sets the name of the property.
+
+ The name of the property.
+
+
+
+ Gets or sets the the reference loop handling used when serializing the property's collection items.
+
+ The collection's items reference loop handling.
+
+
+
+ Gets or sets the the type name handling used when serializing the property's collection items.
+
+ The collection's items type name handling.
+
+
+
+ Gets or sets whether this property's collection items are serialized as a reference.
+
+ Whether this property's collection items are serialized as a reference.
+
+
+
+ The exception thrown when an error occurs while reading Json text.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class
+ with a specified error message.
+
+ The error message that explains the reason for the exception.
+
+
+
+ Initializes a new instance of the class
+ with a specified error message and a reference to the inner exception that is the cause of this exception.
+
+ The error message that explains the reason for the exception.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of the class.
+
+ The that holds the serialized object data about the exception being thrown.
+ The that contains contextual information about the source or destination.
+ The parameter is null.
+ The class name is null or is zero (0).
+
+
+
+ Gets the line number indicating where the error occurred.
+
+ The line number indicating where the error occurred.
+
+
+
+ Gets the line position indicating where the error occurred.
+
+ The line position indicating where the error occurred.
+
+
+
+ Gets the path to the JSON where the error occurred.
+
+ The path to the JSON where the error occurred.
+
+
+
+ The exception thrown when an error occurs during Json serialization or deserialization.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class
+ with a specified error message.
+
+ The error message that explains the reason for the exception.
+
+
+
+ Initializes a new instance of the class
+ with a specified error message and a reference to the inner exception that is the cause of this exception.
+
+ The error message that explains the reason for the exception.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of the class.
+
+ The that holds the serialized object data about the exception being thrown.
+ The that contains contextual information about the source or destination.
+ The parameter is null.
+ The class name is null or is zero (0).
+
+
+
+ Serializes and deserializes objects into and from the JSON format.
+ The enables you to control how objects are encoded into JSON.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Creates a new instance.
+ The will not use default settings.
+
+
+ A new instance.
+ The will not use default settings.
+
+
+
+
+ Creates a new instance using the specified .
+ The will not use default settings.
+
+ The settings to be applied to the .
+
+ A new instance using the specified .
+ The will not use default settings.
+
+
+
+
+ Creates a new instance.
+ The will use default settings.
+
+
+ A new instance.
+ The will use default settings.
+
+
+
+
+ Creates a new instance using the specified .
+ The will use default settings.
+
+ The settings to be applied to the .
+
+ A new instance using the specified .
+ The will use default settings.
+
+
+
+
+ Populates the JSON values onto the target object.
+
+ The that contains the JSON structure to reader values from.
+ The target object to populate values onto.
+
+
+
+ Populates the JSON values onto the target object.
+
+ The that contains the JSON structure to reader values from.
+ The target object to populate values onto.
+
+
+
+ Deserializes the Json structure contained by the specified .
+
+ The that contains the JSON structure to deserialize.
+ The being deserialized.
+
+
+
+ Deserializes the Json structure contained by the specified
+ into an instance of the specified type.
+
+ The containing the object.
+ The of object being deserialized.
+ The instance of being deserialized.
+
+
+
+ Deserializes the Json structure contained by the specified
+ into an instance of the specified type.
+
+ The containing the object.
+ The type of the object to deserialize.
+ The instance of being deserialized.
+
+
+
+ Deserializes the Json structure contained by the specified
+ into an instance of the specified type.
+
+ The containing the object.
+ The of object being deserialized.
+ The instance of being deserialized.
+
+
+
+ Serializes the specified and writes the Json structure
+ to a Stream using the specified .
+
+ The used to write the Json structure.
+ The to serialize.
+
+
+
+ Serializes the specified and writes the Json structure
+ to a Stream using the specified .
+
+ The used to write the Json structure.
+ The to serialize.
+
+ The type of the value being serialized.
+ This parameter is used when is Auto to write out the type name if the type of the value does not match.
+ Specifing the type is optional.
+
+
+
+
+ Serializes the specified and writes the Json structure
+ to a Stream using the specified .
+
+ The used to write the Json structure.
+ The to serialize.
+
+ The type of the value being serialized.
+ This parameter is used when is Auto to write out the type name if the type of the value does not match.
+ Specifing the type is optional.
+
+
+
+
+ Serializes the specified and writes the Json structure
+ to a Stream using the specified .
+
+ The used to write the Json structure.
+ The to serialize.
+
+
+
+ Occurs when the errors during serialization and deserialization.
+
+
+
+
+ Gets or sets the used by the serializer when resolving references.
+
+
+
+
+ Gets or sets the used by the serializer when resolving type names.
+
+
+
+
+ Gets or sets the used by the serializer when writing trace messages.
+
+ The trace writer.
+
+
+
+ Gets or sets how type name writing and reading is handled by the serializer.
+
+
+
+
+ Gets or sets how a type name assembly is written and resolved by the serializer.
+
+ The type name assembly format.
+
+
+
+ Gets or sets how object references are preserved by the serializer.
+
+
+
+
+ Get or set how reference loops (e.g. a class referencing itself) is handled.
+
+
+
+
+ Get or set how missing members (e.g. JSON contains a property that isn't a member on the object) are handled during deserialization.
+
+
+
+
+ Get or set how null values are handled during serialization and deserialization.
+
+
+
+
+ Get or set how null default are handled during serialization and deserialization.
+
+
+
+
+ Gets or sets how objects are created during deserialization.
+
+ The object creation handling.
+
+
+
+ Gets or sets how constructors are used during deserialization.
+
+ The constructor handling.
+
+
+
+ Gets or sets how metadata properties are used during deserialization.
+
+ The metadata properties handling.
+
+
+
+ Gets a collection that will be used during serialization.
+
+ Collection that will be used during serialization.
+
+
+
+ Gets or sets the contract resolver used by the serializer when
+ serializing .NET objects to JSON and vice versa.
+
+
+
+
+ Gets or sets the used by the serializer when invoking serialization callback methods.
+
+ The context.
+
+
+
+ Indicates how JSON text output is formatted.
+
+
+
+
+ Get or set how dates are written to JSON text.
+
+
+
+
+ Get or set how time zones are handling during serialization and deserialization.
+
+
+
+
+ Get or set how date formatted strings, e.g. "\/Date(1198908717056)\/" and "2012-03-21T05:40Z", are parsed when reading JSON.
+
+
+
+
+ Get or set how floating point numbers, e.g. 1.0 and 9.9, are parsed when reading JSON text.
+
+
+
+
+ Get or set how special floating point numbers, e.g. ,
+ and ,
+ are written as JSON text.
+
+
+
+
+ Get or set how strings are escaped when writing JSON text.
+
+
+
+
+ Get or set how and values are formatting when writing JSON text.
+
+
+
+
+ Gets or sets the culture used when reading JSON. Defaults to .
+
+
+
+
+ Gets or sets the maximum depth allowed when reading JSON. Reading past this depth will throw a .
+
+
+
+
+ Gets a value indicating whether there will be a check for additional JSON content after deserializing an object.
+
+
+ true if there will be a check for additional JSON content after deserializing an object; otherwise, false.
+
+
+
+
+ Specifies the settings on a object.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Gets or sets how reference loops (e.g. a class referencing itself) is handled.
+
+ Reference loop handling.
+
+
+
+ Gets or sets how missing members (e.g. JSON contains a property that isn't a member on the object) are handled during deserialization.
+
+ Missing member handling.
+
+
+
+ Gets or sets how objects are created during deserialization.
+
+ The object creation handling.
+
+
+
+ Gets or sets how null values are handled during serialization and deserialization.
+
+ Null value handling.
+
+
+
+ Gets or sets how null default are handled during serialization and deserialization.
+
+ The default value handling.
+
+
+
+ Gets or sets a collection that will be used during serialization.
+
+ The converters.
+
+
+
+ Gets or sets how object references are preserved by the serializer.
+
+ The preserve references handling.
+
+
+
+ Gets or sets how type name writing and reading is handled by the serializer.
+
+ The type name handling.
+
+
+
+ Gets or sets how metadata properties are used during deserialization.
+
+ The metadata properties handling.
+
+
+
+ Gets or sets how a type name assembly is written and resolved by the serializer.
+
+ The type name assembly format.
+
+
+
+ Gets or sets how constructors are used during deserialization.
+
+ The constructor handling.
+
+
+
+ Gets or sets the contract resolver used by the serializer when
+ serializing .NET objects to JSON and vice versa.
+
+ The contract resolver.
+
+
+
+ Gets or sets the used by the serializer when resolving references.
+
+ The reference resolver.
+
+
+
+ Gets or sets the used by the serializer when writing trace messages.
+
+ The trace writer.
+
+
+
+ Gets or sets the used by the serializer when resolving type names.
+
+ The binder.
+
+
+
+ Gets or sets the error handler called during serialization and deserialization.
+
+ The error handler called during serialization and deserialization.
+
+
+
+ Gets or sets the used by the serializer when invoking serialization callback methods.
+
+ The context.
+
+
+
+ Get or set how and values are formatting when writing JSON text.
+
+
+
+
+ Gets or sets the maximum depth allowed when reading JSON. Reading past this depth will throw a .
+
+
+
+
+ Indicates how JSON text output is formatted.
+
+
+
+
+ Get or set how dates are written to JSON text.
+
+
+
+
+ Get or set how time zones are handling during serialization and deserialization.
+
+
+
+
+ Get or set how date formatted strings, e.g. "\/Date(1198908717056)\/" and "2012-03-21T05:40Z", are parsed when reading JSON.
+
+
+
+
+ Get or set how special floating point numbers, e.g. ,
+ and ,
+ are written as JSON.
+
+
+
+
+ Get or set how floating point numbers, e.g. 1.0 and 9.9, are parsed when reading JSON text.
+
+
+
+
+ Get or set how strings are escaped when writing JSON text.
+
+
+
+
+ Gets or sets the culture used when reading JSON. Defaults to .
+
+
+
+
+ Gets a value indicating whether there will be a check for additional content after deserializing an object.
+
+
+ true if there will be a check for additional content after deserializing an object; otherwise, false.
+
+
+
+
+ Represents a reader that provides fast, non-cached, forward-only access to JSON text data.
+
+
+
+
+ Initializes a new instance of the class with the specified .
+
+ The TextReader containing the XML data to read.
+
+
+
+ Reads the next JSON token from the stream.
+
+
+ true if the next token was read successfully; false if there are no more tokens to read.
+
+
+
+
+ Reads the next JSON token from the stream as a .
+
+
+ A or a null reference if the next JSON token is null. This method will return null at the end of an array.
+
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Changes the state to closed.
+
+
+
+
+ Gets a value indicating whether the class can return line information.
+
+
+ true if LineNumber and LinePosition can be provided; otherwise, false.
+
+
+
+
+ Gets the current line number.
+
+
+ The current line number or 0 if no line information is available (for example, HasLineInfo returns false).
+
+
+
+
+ Gets the current line position.
+
+
+ The current line position or 0 if no line information is available (for example, HasLineInfo returns false).
+
+
+
+
+ Represents a writer that provides a fast, non-cached, forward-only way of generating Json data.
+
+
+
+
+ Creates an instance of the JsonWriter class using the specified .
+
+ The TextWriter to write to.
+
+
+
+ Flushes whatever is in the buffer to the underlying streams and also flushes the underlying stream.
+
+
+
+
+ Closes this stream and the underlying stream.
+
+
+
+
+ Writes the beginning of a Json object.
+
+
+
+
+ Writes the beginning of a Json array.
+
+
+
+
+ Writes the start of a constructor with the given name.
+
+ The name of the constructor.
+
+
+
+ Writes the specified end token.
+
+ The end token to write.
+
+
+
+ Writes the property name of a name/value pair on a Json object.
+
+ The name of the property.
+
+
+
+ Writes the property name of a name/value pair on a JSON object.
+
+ The name of the property.
+ A flag to indicate whether the text should be escaped when it is written as a JSON property name.
+
+
+
+ Writes indent characters.
+
+
+
+
+ Writes the JSON value delimiter.
+
+
+
+
+ Writes an indent space.
+
+
+
+
+ Writes a value.
+ An error will raised if the value cannot be written as a single JSON token.
+
+ The value to write.
+
+
+
+ Writes a null value.
+
+
+
+
+ Writes an undefined value.
+
+
+
+
+ Writes raw JSON.
+
+ The raw JSON to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes out a comment /*...*/
containing the specified text.
+
+ Text to place inside the comment.
+
+
+
+ Writes out the given white space.
+
+ The string of white space characters.
+
+
+
+ Gets or sets how many IndentChars to write for each level in the hierarchy when is set to Formatting.Indented.
+
+
+
+
+ Gets or sets which character to use to quote attribute values.
+
+
+
+
+ Gets or sets which character to use for indenting when is set to Formatting.Indented.
+
+
+
+
+ Gets or sets a value indicating whether object names will be surrounded with quotes.
+
+
+
+
+ Specifies the type of Json token.
+
+
+
+
+ This is returned by the if a method has not been called.
+
+
+
+
+ An object start token.
+
+
+
+
+ An array start token.
+
+
+
+
+ A constructor start token.
+
+
+
+
+ An object property name.
+
+
+
+
+ A comment.
+
+
+
+
+ Raw JSON.
+
+
+
+
+ An integer.
+
+
+
+
+ A float.
+
+
+
+
+ A string.
+
+
+
+
+ A boolean.
+
+
+
+
+ A null token.
+
+
+
+
+ An undefined token.
+
+
+
+
+ An object end token.
+
+
+
+
+ An array end token.
+
+
+
+
+ A constructor end token.
+
+
+
+
+ A Date.
+
+
+
+
+ Byte data.
+
+
+
+
+ Represents a reader that provides validation.
+
+
+
+
+ Initializes a new instance of the class that
+ validates the content returned from the given .
+
+ The to read from while validating.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A .
+
+
+
+ Reads the next JSON token from the stream as a .
+
+
+ A or a null reference if the next JSON token is null.
+
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A .
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A .
+
+
+
+ Reads the next JSON token from the stream.
+
+
+ true if the next token was read successfully; false if there are no more tokens to read.
+
+
+
+
+ Sets an event handler for receiving schema validation errors.
+
+
+
+
+ Gets the text value of the current JSON token.
+
+
+
+
+
+ Gets the depth of the current token in the JSON document.
+
+ The depth of the current token in the JSON document.
+
+
+
+ Gets the path of the current JSON token.
+
+
+
+
+ Gets the quotation mark character used to enclose the value of a string.
+
+
+
+
+
+ Gets the type of the current JSON token.
+
+
+
+
+
+ Gets the Common Language Runtime (CLR) type for the current JSON token.
+
+
+
+
+
+ Gets or sets the schema.
+
+ The schema.
+
+
+
+ Gets the used to construct this .
+
+ The specified in the constructor.
+
+
+
+ The exception thrown when an error occurs while reading Json text.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class
+ with a specified error message.
+
+ The error message that explains the reason for the exception.
+
+
+
+ Initializes a new instance of the class
+ with a specified error message and a reference to the inner exception that is the cause of this exception.
+
+ The error message that explains the reason for the exception.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of the class.
+
+ The that holds the serialized object data about the exception being thrown.
+ The that contains contextual information about the source or destination.
+ The parameter is null.
+ The class name is null or is zero (0).
+
+
+
+ Gets the path to the JSON where the error occurred.
+
+ The path to the JSON where the error occurred.
+
+
+
+ Contains the LINQ to JSON extension methods.
+
+
+
+
+ Returns a collection of tokens that contains the ancestors of every token in the source collection.
+
+ The type of the objects in source, constrained to .
+ An of that contains the source collection.
+ An of that contains the ancestors of every node in the source collection.
+
+
+
+ Returns a collection of tokens that contains the descendants of every token in the source collection.
+
+ The type of the objects in source, constrained to .
+ An of that contains the source collection.
+ An of that contains the descendants of every node in the source collection.
+
+
+
+ Returns a collection of child properties of every object in the source collection.
+
+ An of that contains the source collection.
+ An of that contains the properties of every object in the source collection.
+
+
+
+ Returns a collection of child values of every object in the source collection with the given key.
+
+ An of that contains the source collection.
+ The token key.
+ An of that contains the values of every node in the source collection with the given key.
+
+
+
+ Returns a collection of child values of every object in the source collection.
+
+ An of that contains the source collection.
+ An of that contains the values of every node in the source collection.
+
+
+
+ Returns a collection of converted child values of every object in the source collection with the given key.
+
+ The type to convert the values to.
+ An of that contains the source collection.
+ The token key.
+ An that contains the converted values of every node in the source collection with the given key.
+
+
+
+ Returns a collection of converted child values of every object in the source collection.
+
+ The type to convert the values to.
+ An of that contains the source collection.
+ An that contains the converted values of every node in the source collection.
+
+
+
+ Converts the value.
+
+ The type to convert the value to.
+ A cast as a of .
+ A converted value.
+
+
+
+ Converts the value.
+
+ The source collection type.
+ The type to convert the value to.
+ A cast as a of .
+ A converted value.
+
+
+
+ Returns a collection of child tokens of every array in the source collection.
+
+ The source collection type.
+ An of that contains the source collection.
+ An of that contains the values of every node in the source collection.
+
+
+
+ Returns a collection of converted child tokens of every array in the source collection.
+
+ An of that contains the source collection.
+ The type to convert the values to.
+ The source collection type.
+ An that contains the converted values of every node in the source collection.
+
+
+
+ Returns the input typed as .
+
+ An of that contains the source collection.
+ The input typed as .
+
+
+
+ Returns the input typed as .
+
+ The source collection type.
+ An of that contains the source collection.
+ The input typed as .
+
+
+
+ Represents a collection of objects.
+
+ The type of token
+
+
+
+ Gets the with the specified key.
+
+
+
+
+
+ Represents a JSON array.
+
+
+
+
+
+
+
+ Represents a token that can contain other tokens.
+
+
+
+
+ Represents an abstract JSON token.
+
+
+
+
+ Compares the values of two tokens, including the values of all descendant tokens.
+
+ The first to compare.
+ The second to compare.
+ true if the tokens are equal; otherwise false.
+
+
+
+ Adds the specified content immediately after this token.
+
+ A content object that contains simple content or a collection of content objects to be added after this token.
+
+
+
+ Adds the specified content immediately before this token.
+
+ A content object that contains simple content or a collection of content objects to be added before this token.
+
+
+
+ Returns a collection of the ancestor tokens of this token.
+
+ A collection of the ancestor tokens of this token.
+
+
+
+ Returns a collection of the sibling tokens after this token, in document order.
+
+ A collection of the sibling tokens after this tokens, in document order.
+
+
+
+ Returns a collection of the sibling tokens before this token, in document order.
+
+ A collection of the sibling tokens before this token, in document order.
+
+
+
+ Gets the with the specified key converted to the specified type.
+
+ The type to convert the token to.
+ The token key.
+ The converted token value.
+
+
+
+ Returns a collection of the child tokens of this token, in document order.
+
+ An of containing the child tokens of this , in document order.
+
+
+
+ Returns a collection of the child tokens of this token, in document order, filtered by the specified type.
+
+ The type to filter the child tokens on.
+ A containing the child tokens of this , in document order.
+
+
+
+ Returns a collection of the child values of this token, in document order.
+
+ The type to convert the values to.
+ A containing the child values of this , in document order.
+
+
+
+ Removes this token from its parent.
+
+
+
+
+ Replaces this token with the specified token.
+
+ The value.
+
+
+
+ Writes this token to a .
+
+ A into which this method will write.
+ A collection of which will be used when writing the token.
+
+
+
+ Returns the indented JSON for this token.
+
+
+ The indented JSON for this token.
+
+
+
+
+ Returns the JSON for this token using the given formatting and converters.
+
+ Indicates how the output is formatted.
+ A collection of which will be used when writing the token.
+ The JSON for this token using the given formatting and converters.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an explicit conversion from to .
+
+ The value.
+ The result of the conversion.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Performs an implicit conversion from to .
+
+ The value to create a from.
+ The initialized with the specified value.
+
+
+
+ Creates an for this token.
+
+ An that can be used to read this token and its descendants.
+
+
+
+ Creates a from an object.
+
+ The object that will be used to create .
+ A with the value of the specified object
+
+
+
+ Creates a from an object using the specified .
+
+ The object that will be used to create .
+ The that will be used when reading the object.
+ A with the value of the specified object
+
+
+
+ Creates the specified .NET type from the .
+
+ The object type that the token will be deserialized to.
+ The new object created from the JSON value.
+
+
+
+ Creates the specified .NET type from the .
+
+ The object type that the token will be deserialized to.
+ The new object created from the JSON value.
+
+
+
+ Creates the specified .NET type from the using the specified .
+
+ The object type that the token will be deserialized to.
+ The that will be used when creating the object.
+ The new object created from the JSON value.
+
+
+
+ Creates the specified .NET type from the using the specified .
+
+ The object type that the token will be deserialized to.
+ The that will be used when creating the object.
+ The new object created from the JSON value.
+
+
+
+ Creates a from a .
+
+ An positioned at the token to read into this .
+
+ An that contains the token and its descendant tokens
+ that were read from the reader. The runtime type of the token is determined
+ by the token type of the first token encountered in the reader.
+
+
+
+
+ Load a from a string that contains JSON.
+
+ A that contains JSON.
+ A populated from the string that contains JSON.
+
+
+
+ Creates a from a .
+
+ An positioned at the token to read into this .
+
+ An that contains the token and its descendant tokens
+ that were read from the reader. The runtime type of the token is determined
+ by the token type of the first token encountered in the reader.
+
+
+
+
+ Selects a using a JPath expression. Selects the token that matches the object path.
+
+
+ A that contains a JPath expression.
+
+ A , or null.
+
+
+
+ Selects a using a JPath expression. Selects the token that matches the object path.
+
+
+ A that contains a JPath expression.
+
+ A flag to indicate whether an error should be thrown if no tokens are found when evaluating part of the expression.
+ A .
+
+
+
+ Selects a collection of elements using a JPath expression.
+
+
+ A that contains a JPath expression.
+
+ An that contains the selected elements.
+
+
+
+ Selects a collection of elements using a JPath expression.
+
+
+ A that contains a JPath expression.
+
+ A flag to indicate whether an error should be thrown if no tokens are found when evaluating part of the expression.
+ An that contains the selected elements.
+
+
+
+ Returns the responsible for binding operations performed on this object.
+
+ The expression tree representation of the runtime value.
+
+ The to bind this object.
+
+
+
+
+ Returns the responsible for binding operations performed on this object.
+
+ The expression tree representation of the runtime value.
+
+ The to bind this object.
+
+
+
+
+ Creates a new instance of the . All child tokens are recursively cloned.
+
+ A new instance of the .
+
+
+
+ Gets a comparer that can compare two tokens for value equality.
+
+ A that can compare two nodes for value equality.
+
+
+
+ Gets or sets the parent.
+
+ The parent.
+
+
+
+ Gets the root of this .
+
+ The root of this .
+
+
+
+ Gets the node type for this .
+
+ The type.
+
+
+
+ Gets a value indicating whether this token has child tokens.
+
+
+ true if this token has child values; otherwise, false.
+
+
+
+
+ Gets the next sibling token of this node.
+
+ The that contains the next sibling token.
+
+
+
+ Gets the previous sibling token of this node.
+
+ The that contains the previous sibling token.
+
+
+
+ Gets the path of the JSON token.
+
+
+
+
+ Gets the with the specified key.
+
+ The with the specified key.
+
+
+
+ Get the first child token of this token.
+
+ A containing the first child token of the .
+
+
+
+ Get the last child token of this token.
+
+ A containing the last child token of the .
+
+
+
+ Raises the event.
+
+ The instance containing the event data.
+
+
+
+ Raises the event.
+
+ The instance containing the event data.
+
+
+
+ Raises the event.
+
+ The instance containing the event data.
+
+
+
+ Returns a collection of the child tokens of this token, in document order.
+
+
+ An of containing the child tokens of this , in document order.
+
+
+
+
+ Returns a collection of the child values of this token, in document order.
+
+ The type to convert the values to.
+
+ A containing the child values of this , in document order.
+
+
+
+
+ Returns a collection of the descendant tokens for this token in document order.
+
+ An containing the descendant tokens of the .
+
+
+
+ Adds the specified content as children of this .
+
+ The content to be added.
+
+
+
+ Adds the specified content as the first children of this .
+
+ The content to be added.
+
+
+
+ Creates an that can be used to add tokens to the .
+
+ An that is ready to have content written to it.
+
+
+
+ Replaces the children nodes of this token with the specified content.
+
+ The content.
+
+
+
+ Removes the child nodes from this token.
+
+
+
+
+ Merge the specified content into this .
+
+ The content to be merged.
+
+
+
+ Merge the specified content into this using .
+
+ The content to be merged.
+ The used to merge the content.
+
+
+
+ Occurs when the list changes or an item in the list changes.
+
+
+
+
+ Occurs before an item is added to the collection.
+
+
+
+
+ Occurs when the items list of the collection has changed, or the collection is reset.
+
+
+
+
+ Gets the container's children tokens.
+
+ The container's children tokens.
+
+
+
+ Gets a value indicating whether this token has child tokens.
+
+
+ true if this token has child values; otherwise, false.
+
+
+
+
+ Get the first child token of this token.
+
+
+ A containing the first child token of the .
+
+
+
+
+ Get the last child token of this token.
+
+
+ A containing the last child token of the .
+
+
+
+
+ Gets the count of child JSON tokens.
+
+ The count of child JSON tokens
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class from another object.
+
+ A object to copy from.
+
+
+
+ Initializes a new instance of the class with the specified content.
+
+ The contents of the array.
+
+
+
+ Initializes a new instance of the class with the specified content.
+
+ The contents of the array.
+
+
+
+ Loads an from a .
+
+ A that will be read for the content of the .
+ A that contains the JSON that was read from the specified .
+
+
+
+ Load a from a string that contains JSON.
+
+ A that contains JSON.
+ A populated from the string that contains JSON.
+
+
+
+
+
+
+ Creates a from an object.
+
+ The object that will be used to create .
+ A with the values of the specified object
+
+
+
+ Creates a from an object.
+
+ The object that will be used to create .
+ The that will be used to read the object.
+ A with the values of the specified object
+
+
+
+ Writes this token to a .
+
+ A into which this method will write.
+ A collection of which will be used when writing the token.
+
+
+
+ Determines the index of a specific item in the .
+
+ The object to locate in the .
+
+ The index of if found in the list; otherwise, -1.
+
+
+
+
+ Inserts an item to the at the specified index.
+
+ The zero-based index at which should be inserted.
+ The object to insert into the .
+
+ is not a valid index in the .
+ The is read-only.
+
+
+
+ Removes the item at the specified index.
+
+ The zero-based index of the item to remove.
+
+ is not a valid index in the .
+ The is read-only.
+
+
+
+ Returns an enumerator that iterates through the collection.
+
+
+ A that can be used to iterate through the collection.
+
+
+
+
+ Adds an item to the .
+
+ The object to add to the .
+ The is read-only.
+
+
+
+ Removes all items from the .
+
+ The is read-only.
+
+
+
+ Determines whether the contains a specific value.
+
+ The object to locate in the .
+
+ true if is found in the ; otherwise, false.
+
+
+
+
+ Copies to.
+
+ The array.
+ Index of the array.
+
+
+
+ Removes the first occurrence of a specific object from the .
+
+ The object to remove from the .
+
+ true if was successfully removed from the ; otherwise, false. This method also returns false if is not found in the original .
+
+ The is read-only.
+
+
+
+ Gets the container's children tokens.
+
+ The container's children tokens.
+
+
+
+ Gets the node type for this .
+
+ The type.
+
+
+
+ Gets the with the specified key.
+
+ The with the specified key.
+
+
+
+ Gets or sets the at the specified index.
+
+
+
+
+
+ Gets a value indicating whether the is read-only.
+
+ true if the is read-only; otherwise, false.
+
+
+
+ Represents a JSON constructor.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class from another object.
+
+ A object to copy from.
+
+
+
+ Initializes a new instance of the class with the specified name and content.
+
+ The constructor name.
+ The contents of the constructor.
+
+
+
+ Initializes a new instance of the class with the specified name and content.
+
+ The constructor name.
+ The contents of the constructor.
+
+
+
+ Initializes a new instance of the class with the specified name.
+
+ The constructor name.
+
+
+
+ Writes this token to a .
+
+ A into which this method will write.
+ A collection of which will be used when writing the token.
+
+
+
+ Loads an from a .
+
+ A that will be read for the content of the .
+ A that contains the JSON that was read from the specified .
+
+
+
+ Gets the container's children tokens.
+
+ The container's children tokens.
+
+
+
+ Gets or sets the name of this constructor.
+
+ The constructor name.
+
+
+
+ Gets the node type for this .
+
+ The type.
+
+
+
+ Gets the with the specified key.
+
+ The with the specified key.
+
+
+
+ Represents a collection of objects.
+
+ The type of token
+
+
+
+ An empty collection of objects.
+
+
+
+
+ Initializes a new instance of the struct.
+
+ The enumerable.
+
+
+
+ Returns an enumerator that iterates through the collection.
+
+
+ A that can be used to iterate through the collection.
+
+
+
+
+ Returns an enumerator that iterates through a collection.
+
+
+ An object that can be used to iterate through the collection.
+
+
+
+
+ Determines whether the specified is equal to this instance.
+
+ The to compare with this instance.
+
+ true if the specified is equal to this instance; otherwise, false.
+
+
+
+
+ Returns a hash code for this instance.
+
+
+ A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table.
+
+
+
+
+ Gets the with the specified key.
+
+
+
+
+
+ Represents a JSON object.
+
+
+
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class from another object.
+
+ A object to copy from.
+
+
+
+ Initializes a new instance of the class with the specified content.
+
+ The contents of the object.
+
+
+
+ Initializes a new instance of the class with the specified content.
+
+ The contents of the object.
+
+
+
+ Gets an of this object's properties.
+
+ An of this object's properties.
+
+
+
+ Gets a the specified name.
+
+ The property name.
+ A with the specified name or null.
+
+
+
+ Gets an of this object's property values.
+
+ An of this object's property values.
+
+
+
+ Loads an from a .
+
+ A that will be read for the content of the .
+ A that contains the JSON that was read from the specified .
+
+
+
+ Load a from a string that contains JSON.
+
+ A that contains JSON.
+ A populated from the string that contains JSON.
+
+
+
+
+
+
+ Creates a from an object.
+
+ The object that will be used to create .
+ A with the values of the specified object
+
+
+
+ Creates a from an object.
+
+ The object that will be used to create .
+ The that will be used to read the object.
+ A with the values of the specified object
+
+
+
+ Writes this token to a .
+
+ A into which this method will write.
+ A collection of which will be used when writing the token.
+
+
+
+ Gets the with the specified property name.
+
+ Name of the property.
+ The with the specified property name.
+
+
+
+ Gets the with the specified property name.
+ The exact property name will be searched for first and if no matching property is found then
+ the will be used to match a property.
+
+ Name of the property.
+ One of the enumeration values that specifies how the strings will be compared.
+ The with the specified property name.
+
+
+
+ Tries to get the with the specified property name.
+ The exact property name will be searched for first and if no matching property is found then
+ the will be used to match a property.
+
+ Name of the property.
+ The value.
+ One of the enumeration values that specifies how the strings will be compared.
+ true if a value was successfully retrieved; otherwise, false.
+
+
+
+ Adds the specified property name.
+
+ Name of the property.
+ The value.
+
+
+
+ Removes the property with the specified name.
+
+ Name of the property.
+ true if item was successfully removed; otherwise, false.
+
+
+
+ Tries the get value.
+
+ Name of the property.
+ The value.
+ true if a value was successfully retrieved; otherwise, false.
+
+
+
+ Returns an enumerator that iterates through the collection.
+
+
+ A that can be used to iterate through the collection.
+
+
+
+
+ Raises the event with the provided arguments.
+
+ Name of the property.
+
+
+
+ Raises the event with the provided arguments.
+
+ Name of the property.
+
+
+
+ Returns the properties for this instance of a component.
+
+
+ A that represents the properties for this component instance.
+
+
+
+
+ Returns the properties for this instance of a component using the attribute array as a filter.
+
+ An array of type that is used as a filter.
+
+ A that represents the filtered properties for this component instance.
+
+
+
+
+ Returns a collection of custom attributes for this instance of a component.
+
+
+ An containing the attributes for this object.
+
+
+
+
+ Returns the class name of this instance of a component.
+
+
+ The class name of the object, or null if the class does not have a name.
+
+
+
+
+ Returns the name of this instance of a component.
+
+
+ The name of the object, or null if the object does not have a name.
+
+
+
+
+ Returns a type converter for this instance of a component.
+
+
+ A that is the converter for this object, or null if there is no for this object.
+
+
+
+
+ Returns the default event for this instance of a component.
+
+
+ An that represents the default event for this object, or null if this object does not have events.
+
+
+
+
+ Returns the default property for this instance of a component.
+
+
+ A that represents the default property for this object, or null if this object does not have properties.
+
+
+
+
+ Returns an editor of the specified type for this instance of a component.
+
+ A that represents the editor for this object.
+
+ An of the specified type that is the editor for this object, or null if the editor cannot be found.
+
+
+
+
+ Returns the events for this instance of a component using the specified attribute array as a filter.
+
+ An array of type that is used as a filter.
+
+ An that represents the filtered events for this component instance.
+
+
+
+
+ Returns the events for this instance of a component.
+
+
+ An that represents the events for this component instance.
+
+
+
+
+ Returns an object that contains the property described by the specified property descriptor.
+
+ A that represents the property whose owner is to be found.
+
+ An that represents the owner of the specified property.
+
+
+
+
+ Returns the responsible for binding operations performed on this object.
+
+ The expression tree representation of the runtime value.
+
+ The to bind this object.
+
+
+
+
+ Gets the container's children tokens.
+
+ The container's children tokens.
+
+
+
+ Occurs when a property value changes.
+
+
+
+
+ Occurs when a property value is changing.
+
+
+
+
+ Gets the node type for this .
+
+ The type.
+
+
+
+ Gets the with the specified key.
+
+ The with the specified key.
+
+
+
+ Gets or sets the with the specified property name.
+
+
+
+
+
+ Specifies the settings used when merging JSON.
+
+
+
+
+ Gets or sets the method used when merging JSON arrays.
+
+ The method used when merging JSON arrays.
+
+
+
+ Represents a JSON property.
+
+
+
+
+ Initializes a new instance of the class from another object.
+
+ A object to copy from.
+
+
+
+ Initializes a new instance of the class.
+
+ The property name.
+ The property content.
+
+
+
+ Initializes a new instance of the class.
+
+ The property name.
+ The property content.
+
+
+
+ Writes this token to a .
+
+ A into which this method will write.
+ A collection of which will be used when writing the token.
+
+
+
+ Loads an from a .
+
+ A that will be read for the content of the .
+ A that contains the JSON that was read from the specified .
+
+
+
+ Gets the container's children tokens.
+
+ The container's children tokens.
+
+
+
+ Gets the property name.
+
+ The property name.
+
+
+
+ Gets or sets the property value.
+
+ The property value.
+
+
+
+ Gets the node type for this .
+
+ The type.
+
+
+
+ Represents a view of a .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The name.
+
+
+
+ When overridden in a derived class, returns whether resetting an object changes its value.
+
+
+ true if resetting the component changes its value; otherwise, false.
+
+ The component to test for reset capability.
+
+
+
+
+ When overridden in a derived class, gets the current value of the property on a component.
+
+
+ The value of a property for a given component.
+
+ The component with the property for which to retrieve the value.
+
+
+
+
+ When overridden in a derived class, resets the value for this property of the component to the default value.
+
+ The component with the property value that is to be reset to the default value.
+
+
+
+
+ When overridden in a derived class, sets the value of the component to a different value.
+
+ The component with the property value that is to be set.
+ The new value.
+
+
+
+
+ When overridden in a derived class, determines a value indicating whether the value of this property needs to be persisted.
+
+
+ true if the property should be persisted; otherwise, false.
+
+ The component with the property to be examined for persistence.
+
+
+
+
+ When overridden in a derived class, gets the type of the component this property is bound to.
+
+
+ A that represents the type of component this property is bound to. When the or methods are invoked, the object specified might be an instance of this type.
+
+
+
+
+ When overridden in a derived class, gets a value indicating whether this property is read-only.
+
+
+ true if the property is read-only; otherwise, false.
+
+
+
+
+ When overridden in a derived class, gets the type of the property.
+
+
+ A that represents the type of the property.
+
+
+
+
+ Gets the hash code for the name of the member.
+
+
+
+ The hash code for the name of the member.
+
+
+
+
+ Represents a raw JSON string.
+
+
+
+
+ Represents a value in JSON (string, integer, date, etc).
+
+
+
+
+ Initializes a new instance of the class from another object.
+
+ A object to copy from.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Initializes a new instance of the class with the given value.
+
+ The value.
+
+
+
+ Creates a comment with the given value.
+
+ The value.
+ A comment with the given value.
+
+
+
+ Creates a string with the given value.
+
+ The value.
+ A string with the given value.
+
+
+
+ Creates a null value.
+
+ A null value.
+
+
+
+ Creates a null value.
+
+ A null value.
+
+
+
+ Writes this token to a .
+
+ A into which this method will write.
+ A collection of which will be used when writing the token.
+
+
+
+ Indicates whether the current object is equal to another object of the same type.
+
+
+ true if the current object is equal to the parameter; otherwise, false.
+
+ An object to compare with this object.
+
+
+
+ Determines whether the specified is equal to the current .
+
+ The to compare with the current .
+
+ true if the specified is equal to the current ; otherwise, false.
+
+
+ The parameter is null.
+
+
+
+
+ Serves as a hash function for a particular type.
+
+
+ A hash code for the current .
+
+
+
+
+ Returns a that represents this instance.
+
+
+ A that represents this instance.
+
+
+
+
+ Returns a that represents this instance.
+
+ The format.
+
+ A that represents this instance.
+
+
+
+
+ Returns a that represents this instance.
+
+ The format provider.
+
+ A that represents this instance.
+
+
+
+
+ Returns a that represents this instance.
+
+ The format.
+ The format provider.
+
+ A that represents this instance.
+
+
+
+
+ Returns the responsible for binding operations performed on this object.
+
+ The expression tree representation of the runtime value.
+
+ The to bind this object.
+
+
+
+
+ Compares the current instance with another object of the same type and returns an integer that indicates whether the current instance precedes, follows, or occurs in the same position in the sort order as the other object.
+
+ An object to compare with this instance.
+
+ A 32-bit signed integer that indicates the relative order of the objects being compared. The return value has these meanings:
+ Value
+ Meaning
+ Less than zero
+ This instance is less than .
+ Zero
+ This instance is equal to .
+ Greater than zero
+ This instance is greater than .
+
+
+ is not the same type as this instance.
+
+
+
+
+ Gets a value indicating whether this token has child tokens.
+
+
+ true if this token has child values; otherwise, false.
+
+
+
+
+ Gets the node type for this .
+
+ The type.
+
+
+
+ Gets or sets the underlying token value.
+
+ The underlying token value.
+
+
+
+ Initializes a new instance of the class from another object.
+
+ A object to copy from.
+
+
+
+ Initializes a new instance of the class.
+
+ The raw json.
+
+
+
+ Creates an instance of with the content of the reader's current token.
+
+ The reader.
+ An instance of with the content of the reader's current token.
+
+
+
+ Compares tokens to determine whether they are equal.
+
+
+
+
+ Determines whether the specified objects are equal.
+
+ The first object of type to compare.
+ The second object of type to compare.
+
+ true if the specified objects are equal; otherwise, false.
+
+
+
+
+ Returns a hash code for the specified object.
+
+ The for which a hash code is to be returned.
+ A hash code for the specified object.
+ The type of is a reference type and is null.
+
+
+
+ Represents a reader that provides fast, non-cached, forward-only access to serialized Json data.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The token to read from.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+
+ A or a null reference if the next JSON token is null. This method will return null at the end of an array.
+
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream as a .
+
+ A . This method will return null at the end of an array.
+
+
+
+ Reads the next JSON token from the stream.
+
+
+ true if the next token was read successfully; false if there are no more tokens to read.
+
+
+
+
+ Gets the path of the current JSON token.
+
+
+
+
+ Specifies the type of token.
+
+
+
+
+ No token type has been set.
+
+
+
+
+ A JSON object.
+
+
+
+
+ A JSON array.
+
+
+
+
+ A JSON constructor.
+
+
+
+
+ A JSON object property.
+
+
+
+
+ A comment.
+
+
+
+
+ An integer value.
+
+
+
+
+ A float value.
+
+
+
+
+ A string value.
+
+
+
+
+ A boolean value.
+
+
+
+
+ A null value.
+
+
+
+
+ An undefined value.
+
+
+
+
+ A date value.
+
+
+
+
+ A raw JSON value.
+
+
+
+
+ A collection of bytes value.
+
+
+
+
+ A Guid value.
+
+
+
+
+ A Uri value.
+
+
+
+
+ A TimeSpan value.
+
+
+
+
+ Represents a writer that provides a fast, non-cached, forward-only way of generating Json data.
+
+
+
+
+ Initializes a new instance of the class writing to the given .
+
+ The container being written to.
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Flushes whatever is in the buffer to the underlying streams and also flushes the underlying stream.
+
+
+
+
+ Closes this stream and the underlying stream.
+
+
+
+
+ Writes the beginning of a Json object.
+
+
+
+
+ Writes the beginning of a Json array.
+
+
+
+
+ Writes the start of a constructor with the given name.
+
+ The name of the constructor.
+
+
+
+ Writes the end.
+
+ The token.
+
+
+
+ Writes the property name of a name/value pair on a Json object.
+
+ The name of the property.
+
+
+
+ Writes a value.
+ An error will raised if the value cannot be written as a single JSON token.
+
+ The value to write.
+
+
+
+ Writes a null value.
+
+
+
+
+ Writes an undefined value.
+
+
+
+
+ Writes raw JSON.
+
+ The raw JSON to write.
+
+
+
+ Writes out a comment /*...*/
containing the specified text.
+
+ Text to place inside the comment.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Writes a value.
+
+ The value to write.
+
+
+
+ Gets the token being writen.
+
+ The token being writen.
+
+
+
+ Specifies how JSON arrays are merged together.
+
+
+
+ Concatenate arrays.
+
+
+ Union arrays, skipping items that already exist.
+
+
+ Replace all array items.
+
+
+ Merge array items together, matched by index.
+
+
+
+ Specifies the member serialization options for the .
+
+
+
+
+ All public members are serialized by default. Members can be excluded using or .
+ This is the default member serialization mode.
+
+
+
+
+ Only members must be marked with or are serialized.
+ This member serialization mode can also be set by marking the class with .
+
+
+
+
+ All public and private fields are serialized. Members can be excluded using or .
+ This member serialization mode can also be set by marking the class with
+ and setting IgnoreSerializableAttribute on to false.
+
+
+
+
+ Specifies metadata property handling options for the .
+
+
+
+
+ Read metadata properties located at the start of a JSON object.
+
+
+
+
+ Read metadata properties located anywhere in a JSON object. Note that this setting will impact performance.
+
+
+
+
+ Do not try to read metadata properties.
+
+
+
+
+ Specifies missing member handling options for the .
+
+
+
+
+ Ignore a missing member and do not attempt to deserialize it.
+
+
+
+
+ Throw a when a missing member is encountered during deserialization.
+
+
+
+
+ Specifies null value handling options for the .
+
+
+
+
+
+
+
+
+ Include null values when serializing and deserializing objects.
+
+
+
+
+ Ignore null values when serializing and deserializing objects.
+
+
+
+
+ Specifies how object creation is handled by the .
+
+
+
+
+ Reuse existing objects, create new objects when needed.
+
+
+
+
+ Only reuse existing objects.
+
+
+
+
+ Always create new objects.
+
+
+
+
+ Specifies reference handling options for the .
+ Note that references cannot be preserved when a value is set via a non-default constructor such as types that implement ISerializable.
+
+
+
+
+
+
+
+ Do not preserve references when serializing types.
+
+
+
+
+ Preserve references when serializing into a JSON object structure.
+
+
+
+
+ Preserve references when serializing into a JSON array structure.
+
+
+
+
+ Preserve references when serializing.
+
+
+
+
+ Specifies reference loop handling options for the .
+
+
+
+
+ Throw a when a loop is encountered.
+
+
+
+
+ Ignore loop references and do not serialize.
+
+
+
+
+ Serialize loop references.
+
+
+
+
+ Indicating whether a property is required.
+
+
+
+
+ The property is not required. The default state.
+
+
+
+
+ The property must be defined in JSON but can be a null value.
+
+
+
+
+ The property must be defined in JSON and cannot be a null value.
+
+
+
+
+ Contains the JSON schema extension methods.
+
+
+
+
+ Determines whether the is valid.
+
+ The source to test.
+ The schema to test with.
+
+ true if the specified is valid; otherwise, false.
+
+
+
+
+ Determines whether the is valid.
+
+ The source to test.
+ The schema to test with.
+ When this method returns, contains any error messages generated while validating.
+
+ true if the specified is valid; otherwise, false.
+
+
+
+
+ Validates the specified .
+
+ The source to test.
+ The schema to test with.
+
+
+
+ Validates the specified .
+
+ The source to test.
+ The schema to test with.
+ The validation event handler.
+
+
+
+ An in-memory representation of a JSON Schema.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Reads a from the specified .
+
+ The containing the JSON Schema to read.
+ The object representing the JSON Schema.
+
+
+
+ Reads a from the specified .
+
+ The containing the JSON Schema to read.
+ The to use when resolving schema references.
+ The object representing the JSON Schema.
+
+
+
+ Load a from a string that contains schema JSON.
+
+ A that contains JSON.
+ A populated from the string that contains JSON.
+
+
+
+ Parses the specified json.
+
+ The json.
+ The resolver.
+ A populated from the string that contains JSON.
+
+
+
+ Writes this schema to a .
+
+ A into which this method will write.
+
+
+
+ Writes this schema to a using the specified .
+
+ A into which this method will write.
+ The resolver used.
+
+
+
+ Returns a that represents the current .
+
+
+ A that represents the current .
+
+
+
+
+ Gets or sets the id.
+
+
+
+
+ Gets or sets the title.
+
+
+
+
+ Gets or sets whether the object is required.
+
+
+
+
+ Gets or sets whether the object is read only.
+
+
+
+
+ Gets or sets whether the object is visible to users.
+
+
+
+
+ Gets or sets whether the object is transient.
+
+
+
+
+ Gets or sets the description of the object.
+
+
+
+
+ Gets or sets the types of values allowed by the object.
+
+ The type.
+
+
+
+ Gets or sets the pattern.
+
+ The pattern.
+
+
+
+ Gets or sets the minimum length.
+
+ The minimum length.
+
+
+
+ Gets or sets the maximum length.
+
+ The maximum length.
+
+
+
+ Gets or sets a number that the value should be divisble by.
+
+ A number that the value should be divisble by.
+
+
+
+ Gets or sets the minimum.
+
+ The minimum.
+
+
+
+ Gets or sets the maximum.
+
+ The maximum.
+
+
+
+ Gets or sets a flag indicating whether the value can not equal the number defined by the "minimum" attribute.
+
+ A flag indicating whether the value can not equal the number defined by the "minimum" attribute.
+
+
+
+ Gets or sets a flag indicating whether the value can not equal the number defined by the "maximum" attribute.
+
+ A flag indicating whether the value can not equal the number defined by the "maximum" attribute.
+
+
+
+ Gets or sets the minimum number of items.
+
+ The minimum number of items.
+
+
+
+ Gets or sets the maximum number of items.
+
+ The maximum number of items.
+
+
+
+ Gets or sets the of items.
+
+ The of items.
+
+
+
+ Gets or sets a value indicating whether items in an array are validated using the instance at their array position from .
+
+
+ true if items are validated using their array position; otherwise, false.
+
+
+
+
+ Gets or sets the of additional items.
+
+ The of additional items.
+
+
+
+ Gets or sets a value indicating whether additional items are allowed.
+
+
+ true if additional items are allowed; otherwise, false.
+
+
+
+
+ Gets or sets whether the array items must be unique.
+
+
+
+
+ Gets or sets the of properties.
+
+ The of properties.
+
+
+
+ Gets or sets the of additional properties.
+
+ The of additional properties.
+
+
+
+ Gets or sets the pattern properties.
+
+ The pattern properties.
+
+
+
+ Gets or sets a value indicating whether additional properties are allowed.
+
+
+ true if additional properties are allowed; otherwise, false.
+
+
+
+
+ Gets or sets the required property if this property is present.
+
+ The required property if this property is present.
+
+
+
+ Gets or sets the a collection of valid enum values allowed.
+
+ A collection of valid enum values allowed.
+
+
+
+ Gets or sets disallowed types.
+
+ The disallow types.
+
+
+
+ Gets or sets the default value.
+
+ The default value.
+
+
+
+ Gets or sets the collection of that this schema extends.
+
+ The collection of that this schema extends.
+
+
+
+ Gets or sets the format.
+
+ The format.
+
+
+
+ Returns detailed information about the schema exception.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class
+ with a specified error message.
+
+ The error message that explains the reason for the exception.
+
+
+
+ Initializes a new instance of the class
+ with a specified error message and a reference to the inner exception that is the cause of this exception.
+
+ The error message that explains the reason for the exception.
+ The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.
+
+
+
+ Initializes a new instance of the class.
+
+ The that holds the serialized object data about the exception being thrown.
+ The that contains contextual information about the source or destination.
+ The parameter is null.
+ The class name is null or is zero (0).
+
+
+
+ Gets the line number indicating where the error occurred.
+
+ The line number indicating where the error occurred.
+
+
+
+ Gets the line position indicating where the error occurred.
+
+ The line position indicating where the error occurred.
+
+
+
+ Gets the path to the JSON where the error occurred.
+
+ The path to the JSON where the error occurred.
+
+
+
+ Generates a from a specified .
+
+
+
+
+ Generate a from the specified type.
+
+ The type to generate a from.
+ A generated from the specified type.
+
+
+
+ Generate a from the specified type.
+
+ The type to generate a from.
+ The used to resolve schema references.
+ A generated from the specified type.
+
+
+
+ Generate a from the specified type.
+
+ The type to generate a from.
+ Specify whether the generated root will be nullable.
+ A generated from the specified type.
+
+
+
+ Generate a from the specified type.
+
+ The type to generate a from.
+ The used to resolve schema references.
+ Specify whether the generated root will be nullable.
+ A generated from the specified type.
+
+
+
+ Gets or sets how undefined schemas are handled by the serializer.
+
+
+
+
+ Gets or sets the contract resolver.
+
+ The contract resolver.
+
+
+
+ Resolves from an id.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Gets a for the specified reference.
+
+ The id.
+ A for the specified reference.
+
+
+
+ Gets or sets the loaded schemas.
+
+ The loaded schemas.
+
+
+
+ The value types allowed by the .
+
+
+
+
+ No type specified.
+
+
+
+
+ String type.
+
+
+
+
+ Float type.
+
+
+
+
+ Integer type.
+
+
+
+
+ Boolean type.
+
+
+
+
+ Object type.
+
+
+
+
+ Array type.
+
+
+
+
+ Null type.
+
+
+
+
+ Any type.
+
+
+
+
+ Specifies undefined schema Id handling options for the .
+
+
+
+
+ Do not infer a schema Id.
+
+
+
+
+ Use the .NET type name as the schema Id.
+
+
+
+
+ Use the assembly qualified .NET type name as the schema Id.
+
+
+
+
+ Returns detailed information related to the .
+
+
+
+
+ Gets the associated with the validation error.
+
+ The JsonSchemaException associated with the validation error.
+
+
+
+ Gets the path of the JSON location where the validation error occurred.
+
+ The path of the JSON location where the validation error occurred.
+
+
+
+ Gets the text description corresponding to the validation error.
+
+ The text description.
+
+
+
+ Represents the callback method that will handle JSON schema validation events and the .
+
+
+
+
+ Resolves member mappings for a type, camel casing property names.
+
+
+
+
+ Used by to resolves a for a given .
+
+
+
+
+ Used by to resolves a for a given .
+
+
+
+
+
+
+
+
+ Resolves the contract for a given type.
+
+ The type to resolve a contract for.
+ The contract for a given type.
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ If set to true the will use a cached shared with other resolvers of the same type.
+ Sharing the cache will significantly performance because expensive reflection will only happen once but could cause unexpected
+ behavior if different instances of the resolver are suppose to produce different results. When set to false it is highly
+ recommended to reuse instances with the .
+
+
+
+
+ Resolves the contract for a given type.
+
+ The type to resolve a contract for.
+ The contract for a given type.
+
+
+
+ Gets the serializable members for the type.
+
+ The type to get serializable members for.
+ The serializable members for the type.
+
+
+
+ Creates a for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Creates the constructor parameters.
+
+ The constructor to create properties for.
+ The type's member properties.
+ Properties for the given .
+
+
+
+ Creates a for the given .
+
+ The matching member property.
+ The constructor parameter.
+ A created for the given .
+
+
+
+ Resolves the default for the contract.
+
+ Type of the object.
+ The contract's default .
+
+
+
+ Creates a for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Creates a for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Creates a for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Creates a for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Creates a for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Creates a for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Creates a for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Determines which contract type is created for the given type.
+
+ Type of the object.
+ A for the given type.
+
+
+
+ Creates properties for the given .
+
+ The type to create properties for.
+ /// The member serialization mode for the type.
+ Properties for the given .
+
+
+
+ Creates the used by the serializer to get and set values from a member.
+
+ The member.
+ The used by the serializer to get and set values from a member.
+
+
+
+ Creates a for the given .
+
+ The member's parent .
+ The member to create a for.
+ A created for the given .
+
+
+
+ Resolves the name of the property.
+
+ Name of the property.
+ Name of the property.
+
+
+
+ Gets the resolved name of the property.
+
+ Name of the property.
+ Name of the property.
+
+
+
+ Gets a value indicating whether members are being get and set using dynamic code generation.
+ This value is determined by the runtime permissions available.
+
+
+ true if using dynamic code generation; otherwise, false.
+
+
+
+
+ Gets or sets the default members search flags.
+
+ The default members search flags.
+
+
+
+ Gets or sets a value indicating whether compiler generated members should be serialized.
+
+
+ true if serialized compiler generated members; otherwise, false.
+
+
+
+
+ Gets or sets a value indicating whether to ignore the interface when serializing and deserializing types.
+
+
+ true if the interface will be ignored when serializing and deserializing types; otherwise, false.
+
+
+
+
+ Gets or sets a value indicating whether to ignore the attribute when serializing and deserializing types.
+
+
+ true if the attribute will be ignored when serializing and deserializing types; otherwise, false.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Resolves the name of the property.
+
+ Name of the property.
+ The property name camel cased.
+
+
+
+ Used to resolve references when serializing and deserializing JSON by the .
+
+
+
+
+ Resolves a reference to its object.
+
+ The serialization context.
+ The reference to resolve.
+ The object that
+
+
+
+ Gets the reference for the sepecified object.
+
+ The serialization context.
+ The object to get a reference for.
+ The reference to the object.
+
+
+
+ Determines whether the specified object is referenced.
+
+ The serialization context.
+ The object to test for a reference.
+
+ true if the specified object is referenced; otherwise, false.
+
+
+
+
+ Adds a reference to the specified object.
+
+ The serialization context.
+ The reference.
+ The object to reference.
+
+
+
+ The default serialization binder used when resolving and loading classes from type names.
+
+
+
+
+ When overridden in a derived class, controls the binding of a serialized object to a type.
+
+ Specifies the name of the serialized object.
+ Specifies the name of the serialized object.
+
+ The type of the object the formatter creates a new instance of.
+
+
+
+
+ When overridden in a derived class, controls the binding of a serialized object to a type.
+
+ The type of the object the formatter creates a new instance of.
+ Specifies the name of the serialized object.
+ Specifies the name of the serialized object.
+
+
+
+ Represents a trace writer that writes to the application's instances.
+
+
+
+
+ Represents a trace writer.
+
+
+
+
+ Writes the specified trace level, message and optional exception.
+
+ The at which to write this trace.
+ The trace message.
+ The trace exception. This parameter is optional.
+
+
+
+ Gets the that will be used to filter the trace messages passed to the writer.
+ For example a filter level of Info
will exclude Verbose
messages and include Info
,
+ Warning
and Error
messages.
+
+ The that will be used to filter the trace messages passed to the writer.
+
+
+
+ Writes the specified trace level, message and optional exception.
+
+ The at which to write this trace.
+ The trace message.
+ The trace exception. This parameter is optional.
+
+
+
+ Gets the that will be used to filter the trace messages passed to the writer.
+ For example a filter level of Info
will exclude Verbose
messages and include Info
,
+ Warning
and Error
messages.
+
+
+ The that will be used to filter the trace messages passed to the writer.
+
+
+
+
+ Get and set values for a using dynamic methods.
+
+
+
+
+ Provides methods to get and set values.
+
+
+
+
+ Sets the value.
+
+ The target to set the value on.
+ The value to set on the target.
+
+
+
+ Gets the value.
+
+ The target to get the value from.
+ The value.
+
+
+
+ Initializes a new instance of the class.
+
+ The member info.
+
+
+
+ Sets the value.
+
+ The target to set the value on.
+ The value to set on the target.
+
+
+
+ Gets the value.
+
+ The target to get the value from.
+ The value.
+
+
+
+ Provides information surrounding an error.
+
+
+
+
+ Gets the error.
+
+ The error.
+
+
+
+ Gets the original object that caused the error.
+
+ The original object that caused the error.
+
+
+
+ Gets the member that caused the error.
+
+ The member that caused the error.
+
+
+
+ Gets the path of the JSON location where the error occurred.
+
+ The path of the JSON location where the error occurred.
+
+
+
+ Gets or sets a value indicating whether this is handled.
+
+ true if handled; otherwise, false.
+
+
+
+ Provides data for the Error event.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The current object.
+ The error context.
+
+
+
+ Gets the current object the error event is being raised against.
+
+ The current object the error event is being raised against.
+
+
+
+ Gets the error context.
+
+ The error context.
+
+
+
+ Get and set values for a using dynamic methods.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The member info.
+
+
+
+ Sets the value.
+
+ The target to set the value on.
+ The value to set on the target.
+
+
+
+ Gets the value.
+
+ The target to get the value from.
+ The value.
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Gets the underlying type for the contract.
+
+ The underlying type for the contract.
+
+
+
+ Gets or sets the type created during deserialization.
+
+ The type created during deserialization.
+
+
+
+ Gets or sets whether this type contract is serialized as a reference.
+
+ Whether this type contract is serialized as a reference.
+
+
+
+ Gets or sets the default for this contract.
+
+ The converter.
+
+
+
+ Gets or sets all methods called immediately after deserialization of the object.
+
+ The methods called immediately after deserialization of the object.
+
+
+
+ Gets or sets all methods called during deserialization of the object.
+
+ The methods called during deserialization of the object.
+
+
+
+ Gets or sets all methods called after serialization of the object graph.
+
+ The methods called after serialization of the object graph.
+
+
+
+ Gets or sets all methods called before serialization of the object.
+
+ The methods called before serialization of the object.
+
+
+
+ Gets or sets all method called when an error is thrown during the serialization of the object.
+
+ The methods called when an error is thrown during the serialization of the object.
+
+
+
+ Gets or sets the method called immediately after deserialization of the object.
+
+ The method called immediately after deserialization of the object.
+
+
+
+ Gets or sets the method called during deserialization of the object.
+
+ The method called during deserialization of the object.
+
+
+
+ Gets or sets the method called after serialization of the object graph.
+
+ The method called after serialization of the object graph.
+
+
+
+ Gets or sets the method called before serialization of the object.
+
+ The method called before serialization of the object.
+
+
+
+ Gets or sets the method called when an error is thrown during the serialization of the object.
+
+ The method called when an error is thrown during the serialization of the object.
+
+
+
+ Gets or sets the default creator method used to create the object.
+
+ The default creator method used to create the object.
+
+
+
+ Gets or sets a value indicating whether the default creator is non public.
+
+ true if the default object creator is non-public; otherwise, false.
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Gets or sets the default collection items .
+
+ The converter.
+
+
+
+ Gets or sets a value indicating whether the collection items preserve object references.
+
+ true if collection items preserve object references; otherwise, false.
+
+
+
+ Gets or sets the collection item reference loop handling.
+
+ The reference loop handling.
+
+
+
+ Gets or sets the collection item type name handling.
+
+ The type name handling.
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Gets the of the collection items.
+
+ The of the collection items.
+
+
+
+ Gets a value indicating whether the collection type is a multidimensional array.
+
+ true if the collection type is a multidimensional array; otherwise, false.
+
+
+
+ Handles serialization callback events.
+
+ The object that raised the callback event.
+ The streaming context.
+
+
+
+ Handles serialization error callback events.
+
+ The object that raised the callback event.
+ The streaming context.
+ The error context.
+
+
+
+ Sets extension data for an object during deserialization.
+
+ The object to set extension data on.
+ The extension data key.
+ The extension data value.
+
+
+
+ Gets extension data for an object during serialization.
+
+ The object to set extension data on.
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Gets or sets the property name resolver.
+
+ The property name resolver.
+
+
+
+ Gets the of the dictionary keys.
+
+ The of the dictionary keys.
+
+
+
+ Gets the of the dictionary values.
+
+ The of the dictionary values.
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Gets the object's properties.
+
+ The object's properties.
+
+
+
+ Gets or sets the property name resolver.
+
+ The property name resolver.
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Gets or sets the ISerializable object constructor.
+
+ The ISerializable object constructor.
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Gets or sets the object member serialization.
+
+ The member object serialization.
+
+
+
+ Gets or sets a value that indicates whether the object's properties are required.
+
+
+ A value indicating whether the object's properties are required.
+
+
+
+
+ Gets the object's properties.
+
+ The object's properties.
+
+
+
+ Gets the constructor parameters required for any non-default constructor
+
+
+
+
+ Gets a collection of instances that define the parameters used with .
+
+
+
+
+ Gets or sets the override constructor used to create the object.
+ This is set when a constructor is marked up using the
+ JsonConstructor attribute.
+
+ The override constructor.
+
+
+
+ Gets or sets the parametrized constructor used to create the object.
+
+ The parametrized constructor.
+
+
+
+ Gets or sets the function used to create the object. When set this function will override .
+ This function is called with a collection of arguments which are defined by the collection.
+
+ The function used to create the object.
+
+
+
+ Gets or sets the extension data setter.
+
+
+
+
+ Gets or sets the extension data getter.
+
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Maps a JSON property to a .NET member or constructor parameter.
+
+
+
+
+ Returns a that represents this instance.
+
+
+ A that represents this instance.
+
+
+
+
+ Gets or sets the name of the property.
+
+ The name of the property.
+
+
+
+ Gets or sets the type that declared this property.
+
+ The type that declared this property.
+
+
+
+ Gets or sets the order of serialization and deserialization of a member.
+
+ The numeric order of serialization or deserialization.
+
+
+
+ Gets or sets the name of the underlying member or parameter.
+
+ The name of the underlying member or parameter.
+
+
+
+ Gets the that will get and set the during serialization.
+
+ The that will get and set the during serialization.
+
+
+
+ Gets or sets the type of the property.
+
+ The type of the property.
+
+
+
+ Gets or sets the for the property.
+ If set this converter takes presidence over the contract converter for the property type.
+
+ The converter.
+
+
+
+ Gets or sets the member converter.
+
+ The member converter.
+
+
+
+ Gets or sets a value indicating whether this is ignored.
+
+ true if ignored; otherwise, false.
+
+
+
+ Gets or sets a value indicating whether this is readable.
+
+ true if readable; otherwise, false.
+
+
+
+ Gets or sets a value indicating whether this is writable.
+
+ true if writable; otherwise, false.
+
+
+
+ Gets or sets a value indicating whether this has a member attribute.
+
+ true if has a member attribute; otherwise, false.
+
+
+
+ Gets the default value.
+
+ The default value.
+
+
+
+ Gets or sets a value indicating whether this is required.
+
+ A value indicating whether this is required.
+
+
+
+ Gets or sets a value indicating whether this property preserves object references.
+
+
+ true if this instance is reference; otherwise, false.
+
+
+
+
+ Gets or sets the property null value handling.
+
+ The null value handling.
+
+
+
+ Gets or sets the property default value handling.
+
+ The default value handling.
+
+
+
+ Gets or sets the property reference loop handling.
+
+ The reference loop handling.
+
+
+
+ Gets or sets the property object creation handling.
+
+ The object creation handling.
+
+
+
+ Gets or sets or sets the type name handling.
+
+ The type name handling.
+
+
+
+ Gets or sets a predicate used to determine whether the property should be serialize.
+
+ A predicate used to determine whether the property should be serialize.
+
+
+
+ Gets or sets a predicate used to determine whether the property should be serialized.
+
+ A predicate used to determine whether the property should be serialized.
+
+
+
+ Gets or sets an action used to set whether the property has been deserialized.
+
+ An action used to set whether the property has been deserialized.
+
+
+
+ Gets or sets the converter used when serializing the property's collection items.
+
+ The collection's items converter.
+
+
+
+ Gets or sets whether this property's collection items are serialized as a reference.
+
+ Whether this property's collection items are serialized as a reference.
+
+
+
+ Gets or sets the the type name handling used when serializing the property's collection items.
+
+ The collection's items type name handling.
+
+
+
+ Gets or sets the the reference loop handling used when serializing the property's collection items.
+
+ The collection's items reference loop handling.
+
+
+
+ A collection of objects.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The type.
+
+
+
+ When implemented in a derived class, extracts the key from the specified element.
+
+ The element from which to extract the key.
+ The key for the specified element.
+
+
+
+ Adds a object.
+
+ The property to add to the collection.
+
+
+
+ Gets the closest matching object.
+ First attempts to get an exact case match of propertyName and then
+ a case insensitive match.
+
+ Name of the property.
+ A matching property if found.
+
+
+
+ Gets a property by property name.
+
+ The name of the property to get.
+ Type property name string comparison.
+ A matching property if found.
+
+
+
+ Contract details for a used by the .
+
+
+
+
+ Initializes a new instance of the class.
+
+ The underlying type for the contract.
+
+
+
+ Represents a trace writer that writes to memory. When the trace message limit is
+ reached then old trace messages will be removed as new messages are added.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Writes the specified trace level, message and optional exception.
+
+ The at which to write this trace.
+ The trace message.
+ The trace exception. This parameter is optional.
+
+
+
+ Returns an enumeration of the most recent trace messages.
+
+ An enumeration of the most recent trace messages.
+
+
+
+ Returns a of the most recent trace messages.
+
+
+ A of the most recent trace messages.
+
+
+
+
+ Gets the that will be used to filter the trace messages passed to the writer.
+ For example a filter level of Info
will exclude Verbose
messages and include Info
,
+ Warning
and Error
messages.
+
+
+ The that will be used to filter the trace messages passed to the writer.
+
+
+
+
+ Represents a method that constructs an object.
+
+ The object type to create.
+
+
+
+ When applied to a method, specifies that the method is called when an error occurs serializing an object.
+
+
+
+
+ Get and set values for a using reflection.
+
+
+
+
+ Initializes a new instance of the class.
+
+ The member info.
+
+
+
+ Sets the value.
+
+ The target to set the value on.
+ The value to set on the target.
+
+
+
+ Gets the value.
+
+ The target to get the value from.
+ The value.
+
+
+
+ Specifies how strings are escaped when writing JSON text.
+
+
+
+
+ Only control characters (e.g. newline) are escaped.
+
+
+
+
+ All non-ASCII and control characters (e.g. newline) are escaped.
+
+
+
+
+ HTML (<, >, &, ', ") and control characters (e.g. newline) are escaped.
+
+
+
+
+ Specifies type name handling options for the .
+
+
+
+
+ Do not include the .NET type name when serializing types.
+
+
+
+
+ Include the .NET type name when serializing into a JSON object structure.
+
+
+
+
+ Include the .NET type name when serializing into a JSON array structure.
+
+
+
+
+ Always include the .NET type name when serializing.
+
+
+
+
+ Include the .NET type name when the type of the object being serialized is not the same as its declared type.
+
+
+
+
+ Determines whether the collection is null or empty.
+
+ The collection.
+
+ true if the collection is null or empty; otherwise, false.
+
+
+
+
+ Adds the elements of the specified collection to the specified generic IList.
+
+ The list to add to.
+ The collection of elements to add.
+
+
+
+ Returns the index of the first occurrence in a sequence by using a specified IEqualityComparer.
+
+ The type of the elements of source.
+ A sequence in which to locate a value.
+ The object to locate in the sequence
+ An equality comparer to compare values.
+ The zero-based index of the first occurrence of value within the entire sequence, if found; otherwise, –1.
+
+
+
+ Converts the value to the specified type. If the value is unable to be converted, the
+ value is checked whether it assignable to the specified type.
+
+ The value to convert.
+ The culture to use when converting.
+ The type to convert or cast the value to.
+
+ The converted type. If conversion was unsuccessful, the initial value
+ is returned if assignable to the target type.
+
+
+
+
+ Helper method for generating a MetaObject which calls a
+ specific method on Dynamic that returns a result
+
+
+
+
+ Helper method for generating a MetaObject which calls a
+ specific method on Dynamic, but uses one of the arguments for
+ the result.
+
+
+
+
+ Helper method for generating a MetaObject which calls a
+ specific method on Dynamic, but uses one of the arguments for
+ the result.
+
+
+
+
+ Returns a Restrictions object which includes our current restrictions merged
+ with a restriction limiting our type
+
+
+
+
+ Gets a dictionary of the names and values of an Enum type.
+
+
+
+
+
+ Gets a dictionary of the names and values of an Enum type.
+
+ The enum type to get names and values for.
+
+
+
+
+ Gets the type of the typed collection's items.
+
+ The type.
+ The type of the typed collection's items.
+
+
+
+ Gets the member's underlying type.
+
+ The member.
+ The underlying type of the member.
+
+
+
+ Determines whether the member is an indexed property.
+
+ The member.
+
+ true if the member is an indexed property; otherwise, false.
+
+
+
+
+ Determines whether the property is an indexed property.
+
+ The property.
+
+ true if the property is an indexed property; otherwise, false.
+
+
+
+
+ Gets the member's value on the object.
+
+ The member.
+ The target object.
+ The member's value on the object.
+
+
+
+ Sets the member's value on the target object.
+
+ The member.
+ The target.
+ The value.
+
+
+
+ Determines whether the specified MemberInfo can be read.
+
+ The MemberInfo to determine whether can be read.
+ /// if set to true then allow the member to be gotten non-publicly.
+
+ true if the specified MemberInfo can be read; otherwise, false.
+
+
+
+
+ Determines whether the specified MemberInfo can be set.
+
+ The MemberInfo to determine whether can be set.
+ if set to true then allow the member to be set non-publicly.
+ if set to true then allow the member to be set if read-only.
+
+ true if the specified MemberInfo can be set; otherwise, false.
+
+
+
+
+ Builds a string. Unlike StringBuilder this class lets you reuse it's internal buffer.
+
+
+
+
+ Determines whether the string is all white space. Empty string will return false.
+
+ The string to test whether it is all white space.
+
+ true if the string is all white space; otherwise, false.
+
+
+
+
+ Nulls an empty string.
+
+ The string.
+ Null if the string was null, otherwise the string unchanged.
+
+
+
+ Specifies the state of the .
+
+
+
+
+ An exception has been thrown, which has left the in an invalid state.
+ You may call the method to put the in the Closed state.
+ Any other method calls results in an being thrown.
+
+
+
+
+ The method has been called.
+
+
+
+
+ An object is being written.
+
+
+
+
+ A array is being written.
+
+
+
+
+ A constructor is being written.
+
+
+
+
+ A property is being written.
+
+
+
+
+ A write method has not been called.
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/Owin.dll b/samples/angular-aad-webapi/api/api.securecall/bin/Owin.dll
new file mode 100644
index 000000000..ba6e21eda
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/Owin.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.IdentityModel.Tokens.Jwt.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.IdentityModel.Tokens.Jwt.dll
new file mode 100644
index 000000000..660b1657a
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.IdentityModel.Tokens.Jwt.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.IdentityModel.Tokens.Jwt.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.IdentityModel.Tokens.Jwt.xml
new file mode 100644
index 000000000..149d73947
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.IdentityModel.Tokens.Jwt.xml
@@ -0,0 +1,2502 @@
+
+
+
+ System.IdentityModel.Tokens.Jwt
+
+
+
+
+ Helper class for adding DateTimes and Timespans.
+
+
+
+
+ Add a DateTime and a TimeSpan.
+ The maximum time is DateTime.MaxTime. It is not an error if time + timespan > MaxTime.
+ Just return MaxTime.
+
+ Initial value.
+ to add.
+ as the sum of time and timespan.
+
+
+
+ Gets the Maximum value for a DateTime specifying kind.
+
+ DateTimeKind to use.
+ DateTime of specified kind.
+
+
+
+ Gets the Minimum value for a DateTime specifying kind.
+
+ DateTimeKind to use.
+ DateTime of specified kind.
+
+
+
+ Error codes and messages
+
+
+
+
+ Serializes the list of strings into string as follows:
+ 'str1','str2','str3' ...
+
+
+ The strings used to build a comma delimited string.
+
+
+ The single .
+
+
+
+
+ Provides signing and verifying operations when working with an
+
+
+
+
+ This class defines the object model for types that provide signature services.
+
+
+
+
+ Produces a signature over the 'input'
+
+ bytes to sign.
+ signed bytes
+
+
+
+ Verifies that a signature created over the 'input' matches the signature.
+
+ bytes to verify.
+ signature to compare against.
+ true if the computed signature matches the signature parameter, false otherwise.
+
+
+
+ Calls and
+
+
+
+
+ Can be over written in descendants to dispose of internal components.
+
+ true, if called from Dispose(), false, if invoked inside a finalizer
+
+
+
+ Gets or sets a user context for a .
+
+
+
+
+ Initializes a new instance of the class used to create and verify signatures.
+
+
+ The that will be used for cryptographic operations.
+
+
+ The signature algorithm to apply.
+
+
+ If this is required to create signatures then set this to true.
+
+ Creating signatures requires that the has access to a private key.
+ Verifying signatures (the default), does not require access to the private key.
+
+
+
+ 'key' is null.
+
+
+ 'algorithm' is null.
+
+
+ 'algorithm' contains only whitespace.
+
+
+ willCreateSignatures is true and .KeySize is less than .
+
+
+ .KeySize is less than . Note: this is always checked.
+
+
+ Is thrown if the throws.
+
+
+ Is thrown if the returns null.
+
+
+ Is thrown if the throws.
+
+
+ Is thrown if the returns null.
+
+
+ Is thrown if the throws.
+
+
+ Is thrown if the returns null.
+
+
+ Is thrown if the throws.
+
+
+ Is thrown if the throws.
+
+
+
+
+ Produces a signature over the 'input' using the and algorithm passed to .
+
+ bytes to be signed.
+ a signature over the input.
+ 'input' is null.
+ 'input.Length' == 0.
+ if has been called.
+ if the internal is null. This can occur if the constructor parameter 'willBeUsedforSigning' was not 'true'.
+ if the internal is null. This can occur if a derived type deletes it or does not create it.
+
+
+
+ Verifies that a signature over the' input' matches the signature.
+
+ the bytes to generate the signature over.
+ the value to verify against.
+ true if signature matches, false otherwise.
+ 'input' is null.
+ 'signature' is null.
+ 'input.Length' == 0.
+ 'signature.Length' == 0.
+ if has been called.
+ if the internal is null. This can occur if a derived type does not call the base constructor.
+ if the internal is null. This can occur if a derived type deletes it or does not create it.
+
+
+
+ Calls to release this managed resources.
+
+ true, if called from Dispose(), false, if invoked inside a finalizer.
+
+
+
+ Encodes and Decodes strings as Base64Url encoding.
+
+
+
+
+ The following functions perform base64url encoding which differs from regular base64 encoding as follows
+ * padding is skipped so the pad character '=' doesn't have to be percent encoded
+ * the 62nd and 63rd regular base64 encoding characters ('+' and '/') are replace with ('-' and '_')
+ The changes make the encoding alphabet file and URL safe.
+
+ string to encode.
+ Base64Url encoding of the UTF8 bytes.
+
+
+
+ Converts a subset of an array of 8-bit unsigned integers to its equivalent string representation that is encoded with base-64-url digits. Parameters specify
+ the subset as an offset in the input array, and the number of elements in the array to convert.
+
+ An array of 8-bit unsigned integers.
+ An offset in inArray.
+ The number of elements of inArray to convert.
+ The string representation in base 64 url encodingof length elements of inArray, starting at position offset.
+ 'inArray' is null.
+ offset or length is negative OR offset plus length is greater than the length of inArray.
+
+
+
+ Converts a subset of an array of 8-bit unsigned integers to its equivalent string representation that is encoded with base-64-url digits. Parameters specify
+ the subset as an offset in the input array, and the number of elements in the array to convert.
+
+ An array of 8-bit unsigned integers.
+ The string representation in base 64 url encodingof length elements of inArray, starting at position offset.
+ 'inArray' is null.
+ offset or length is negative OR offset plus length is greater than the length of inArray.
+
+
+
+ Converts the specified string, which encodes binary data as base-64-url digits, to an equivalent 8-bit unsigned integer array.
+ base64Url encoded string.
+ UTF8 bytes.
+
+
+
+ Decodes the string from Base64UrlEncoded to UTF8.
+
+ string to decode.
+ UTF8 string.
+
+
+
+ Defines the inbound and outbound mapping for claim claim types from jwt to .net claim
+
+
+
+
+ Initializes static members of the class.
+
+
+
+
+ Gets the InboundClaimTypeMap used by JwtSecurityTokenHandler when producing claims from jwt.
+
+
+
+
+ Gets the OutboundClaimTypeMap is used by JwtSecurityTokenHandler to shorten claim types when creating a jwt.
+
+
+
+
+ Provides common code for services to use in generating diagnostics and taking actions.
+
+
+
+
+ Returns true if the provided exception matches any of a list of hard system faults that should be allowed
+ through to outer exception handlers.
+
+ The exception to check.
+
+ Typically this method is used when there is a need to catch all exceptions, but to ensure that .NET runtime
+ and execution engine exceptions are not absorbed by the catch block. Use of this method also avoids FxCop
+ warnings about not using general catch blocks.
+ Please note that use of this method is expensive because of the amount of reflection it performs.
+ If you can refactor your code to catch more specific exceptions than Exception to avoid using this method,
+ you should.
+ Example of use:
+
+ try
+ {
+ // Code needing a full Exception catch block
+ }
+ catch (Exception ex)
+ {
+ if (DiagnosticUtility.IsFatal(ex))
+ {
+ throw;
+ }
+ // Perform any needed logging and handling for absorbed exception.
+ }
+
+
+ true if the exception should NOT be trapped
+
+
+
+ Returns the absolute DateTime or the Seconds since Unix Epoch, where Epoch is UTC 1970-01-01T0:0:0Z.
+
+
+
+
+ DateTime as UTV for UnixEpoch
+
+
+
+
+ Per JWT spec:
+ Gets the number of seconds from 1970-01-01T0:0:0Z as measured in UTC until the desired date/time.
+
+ The DateTime to convert to seconds.
+ if dateTimeUtc less than UnixEpoch, return 0
+ the number of seconds since Unix Epoch.
+
+
+
+ Creates a DateTime from epoch time.
+
+ Number of seconds.
+ The DateTime in UTC.
+
+
+
+ ISecurityTokenValidator
+
+
+
+
+ Returns true if the token can be read, false otherwise.
+
+
+
+
+ Validates a token passed as a string using
+
+
+
+
+ Gets and sets the maximum size in bytes, that a will be processed.
+
+
+
+
+ Interface that defines a simple cache for tacking replaying of security tokens.
+
+
+
+
+ Try to add a securityToken.
+
+ the security token to add.
+ the time when security token expires.
+ true if the security token was successfully added.
+
+
+
+ Try to find securityToken
+
+ the security token to find.
+ true if the security token is found.
+
+
+
+ Definition for a delegate that can be set on to control serialization of objects into JSON.
+
+ Object to serialize
+ The serialized object.
+
+
+
+ Definition for a delegate that can be set on to control deserialization JSON into objects.
+
+ JSON to deserialize.
+ type expected.
+ The deserialized object.
+
+
+
+ Dictionary extensions for serializations
+
+
+
+
+ Serializes an object to JSON.
+
+ The object to serialize
+ the object as JSON.
+
+
+
+ Deserialzes JSON into an instance of type T.
+
+ the object type.
+ the JSON to deserialze.
+ a new instance of type T.
+
+
+
+ Deserialzes JSON into an instance of .
+
+ the JSON to deserialze.
+ a new instance .
+
+
+
+ Deserialzes JSON into an instance of .
+
+ the JSON to deserialze.
+ a new instance .
+
+
+
+ Gets or sets a to use when serializing objects to JSON.
+
+ if 'value' is null.
+
+
+
+ Gets or sets a to use when deserializing objects from JSON.
+
+ if 'value' is null.
+
+
+
+ contains the element and attribute names used in config when parsing the JwtSecurityTokenHandler from XML.
+
+
+
+
+ Constants for Json Web tokens.
+
+
+
+
+ Short header type.
+
+
+
+
+ Long header type.
+
+
+
+
+ Short token type.
+
+
+
+
+ Long token type.
+
+
+
+
+ Token format: 'header.payload.signature'. Signature is optional, but '.' is required.
+
+
+
+
+ When mapping json to .Net Claim(s), if the value was not a string (or an enumeration of strings), the ClaimValue will serialized using the current JSON serializer, a property will be added with the .Net type and the ClaimTypeValue will be set to 'JsonClaimValueType'.
+
+
+
+
+ List of algorithms see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-26#section-3
+
+
+
+
+ List of header parameter names see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5.
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ see: http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-5
+
+
+
+
+ List of registered claims from different sources
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+ http://openid.net/specs/openid-connect-core-1_0.html#IDToken
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://openid.net/specs/openid-connect-core-1_0.html#IDToken
+
+
+
+
+ http://openid.net/specs/openid-connect-core-1_0.html#IDToken
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://openid.net/specs/openid-connect-core-1_0.html#IDToken
+
+
+
+
+ http://openid.net/specs/openid-connect-core-1_0.html#IDToken
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-20#section-4
+
+
+
+
+ Initializes a new instance of which contains JSON objects representing the cryptographic operations applied to the JWT and optionally any additional properties of the JWT.
+ The member names within the JWT Header are referred to as Header Parameter Names.
+ These names MUST be unique and the values must be (s). The corresponding values are referred to as Header Parameter Values.
+
+
+
+
+ Initializes a new instance of the class. Default string comparer .
+
+
+
+
+ Initializes a new instance of the class. With the Header Parameters as follows:
+ { { typ, JWT }, { alg, Mapped( } }
+ See: Algorithm Mapping below.
+
+ The that will be or were used to sign the .
+
+ For each in signingCredentials.SigningKeyIdentifier
+ if the clause is a Header Parameter { clause.Name, clause.Id } will be added.
+ For example, if clause.Name == 'kid' and clause.Id == 'SecretKey99'. The JSON object { kid, SecretKey99 } would be added.
+ In addition, if the is a the JSON object { x5t, Base64UrlEncoded( } will be added.
+ This simplifies the common case where a X509Certificate is used.
+ =================
+ Algorithm Mapping
+ =================
+ describes the algorithm that is discoverable by the CLR runtime.
+ The { alg, 'value' } placed in the header reflects the JWT specification.
+ contains a signature mapping where the 'value' above will be translated according to this mapping.
+ Current mapping is:
+ 'http://www.w3.org/2001/04/xmldsig-more#rsa-sha256' => 'RS256'
+ 'http://www.w3.org/2001/04/xmldsig-more#hmac-sha256' => 'HS256'
+
+
+
+
+ Serializes this instance to JSON.
+
+ this instance as JSON.
+ use to customize JSON serialization.
+
+
+
+ Encodes this instance as Base64UrlEncoded JSON.
+
+ Base64UrlEncoded JSON.
+ use to customize JSON serialization.
+
+
+
+ Deserializes Base64UrlEncoded JSON into a instance.
+
+ base64url encoded JSON to deserialize.
+ an instance of .
+ use to customize JSON serialization.
+
+
+
+ Deserialzes JSON into a instance.
+
+ the JSON to deserialize.
+ an instance of .
+ use to customize JSON serialization.
+
+
+
+ Gets the signature algorithm that was used to create the signature.
+
+ If the signature algorithm is not found, null is returned.
+
+
+
+ Gets the passed in the constructor.
+
+ This value may be null.
+
+
+
+ Gets the mime type (Typ) of the token.
+
+ If the mime type is not found, null is returned.
+
+
+
+ Gets a that contains a for each key found.
+
+
+ Keys are identified by matching a 'Reserved Header Parameter Name' found in the in JSON Web Signature specification.
+ Names recognized are: jku, jkw, kid, x5c, x5t, x5u
+ 'x5t' adds a passing a the Base64UrlDecoded( Value ) to the constructor.
+ 'jku', 'jkw', 'kid', 'x5u', 'x5c' each add a with the { Name, Value } passed to the .
+
+ If no keys are found, an empty will be returned.
+
+
+
+
+ Initializes a new instance of which contains JSON objects representing the claims contained in the JWT. Each claim is a JSON object of the form { Name, Value }.
+
+
+
+
+ Initializes a new instance of the class with no claims. Default string comparer .
+ Creates a empty
+
+
+
+
+ Initializes a new instance of the class with . Default string comparer .
+ the claims to add.
+
+
+
+
+ Initializes a new instance of the class with claims added for each parameter specified. Default string comparer .
+
+ if this value is not null, a { iss, 'issuer' } claim will be added.
+ if this value is not null, a { aud, 'audience' } claim will be added
+ if this value is not null then for each a { 'Claim.Type', 'Claim.Value' } is added. If duplicate claims are found then a { 'Claim.Type', List<object> } will be created to contain the duplicate values.
+ if notbefore.HasValue is 'true' a { nbf, 'value' } claim is added.
+ if expires.HasValue is 'true' a { exp, 'value' } claim is added.
+ Comparison is set to
+ The 4 parameters: 'issuer', 'audience', 'notBefore', 'expires' take precednece over (s) in 'claims'. The values in 'claims' will be overridden.
+ if 'expires' <= 'notbefore'.
+
+
+
+ Adds a JSON object representing the to the
+
+ { 'Claim.Type', 'Claim.Value' } is added. If a JSON object is found with the name == then a { 'Claim.Type', List<object> } will be created to contain the duplicate values.
+ See for details on how is applied.
+ 'claim' is null.
+
+
+
+ Adds a number of to the as JSON { name, value } pairs.
+
+ for each a JSON pair { 'Claim.Type', 'Claim.Value' } is added. If duplicate claims are found then a { 'Claim.Type', List<object> } will be created to contain the duplicate values.
+ Each added will have translated according to the mapping found in . Adding and removing to
+ will affect the name component of the Json claim
+ Any in the that is null, will be ignored.
+ 'claims' is null.
+
+
+
+ Gets the DateTime using the number of seconds from 1970-01-01T0:0:0Z (UTC)
+
+ Claim in the payload that should map to an integer.
+ If the claim is not found, the function returns: DateTime.MinValue
+
+ if an overflow exception is thrown by the runtime.
+ the DateTime representation of a claim.
+
+
+
+ Serializes this instance to JSON.
+
+ this instance as JSON.
+ use to customize JSON serialization.
+
+
+
+ Encodes this instance as Base64UrlEncoded JSON.
+
+ Base64UrlEncoded JSON.
+ use to customize JSON serialization.
+
+
+
+ Deserializes Base64UrlEncoded JSON into a instance.
+
+ base64url encoded JSON to deserialize.
+ an instance of .
+ use to customize JSON serialization.
+
+
+
+ Deserialzes JSON into a instance.
+
+ the JSON to deserialize.
+ an instance of .
+ use to customize JSON serialization.
+
+
+
+ Gets the 'value' of the 'actor' claim { actort, 'value' }.
+
+ If the 'actor' claim is not found, null is returned.
+
+
+
+ Gets the 'value' of the 'acr' claim { acr, 'value' }.
+
+ If the 'acr' claim is not found, null is returned.
+
+
+
+ Gets the 'value' of the 'amr' claim { amr, 'value' }.
+
+ If the 'amr' claim is not found, null is returned.
+
+
+
+ Gets the 'value' of the 'auth_time' claim { auth_time, 'value' }.
+
+ If the 'auth_time' claim is not found, null is returned.
+
+
+
+ Gets the 'value' of the 'audience' claim { aud, 'value' } as a list of strings.
+
+ If the 'audience' claim is not found, an empty enumerable is returned.
+
+
+
+ Gets the 'value' of the 'azp' claim { azp, 'value' }.
+
+ If the 'azp' claim is not found, null is returned.
+
+
+
+ Gets 'value' of the 'c_hash' claim { c_hash, 'value' }.
+
+ If the 'c_hash' claim is not found, null is returned.
+
+
+
+ Gets the 'value' of the 'expiration' claim { exp, 'value' }.
+
+ If the 'expiration' claim is not found OR could not be converted to , null is returned.
+
+
+
+ Gets the 'value' of the 'JWT ID' claim { jti, 'value' }.
+
+ If the 'JWT ID' claim is not found, null is returned.
+
+
+
+ Gets the 'value' of the 'Issued At' claim { iat, 'value' }.
+
+ If the 'Issued At' claim is not found OR cannot be converted to null is returned.
+
+
+
+ Gets 'value' of the 'issuer' claim { iss, 'value' }.
+
+ If the 'issuer' claim is not found, null is returned.
+
+
+
+ Gets the 'value' of the 'expiration' claim { nbf, 'value' }.
+
+ If the 'notbefore' claim is not found OR could not be converted to , null is returned.
+
+
+
+ Gets 'value' of the 'nonce' claim { nonce, 'value' }.
+
+ If the 'nonce' claim is not found, null is returned.
+
+
+
+ Gets "value" of the 'subject' claim { sub, 'value' }.
+
+ If the 'subject' claim is not found, null is returned.
+
+
+
+ Gets 'value' of the 'notbefore' claim { nbf, 'value' } converted to a assuming 'value' is seconds since UnixEpoch (UTC 1970-01-01T0:0:0Z).
+
+ If the 'notbefore' claim is not found, then is returned.
+
+
+
+ Gets 'value' of the 'expiration' claim { exp, 'value' } converted to a assuming 'value' is seconds since UnixEpoch (UTC 1970-01-01T0:0:0Z).
+
+ If the 'expiration' claim is not found, then is returned.
+
+
+
+ Gets a for each JSON { name, value }.
+
+ Each (s) returned will have the translated according to the mapping found in . Adding and removing to will affect the value of the .
+ and will be set to the value of ( if null).
+
+
+
+ A designed for representing a JSON Web Token (JWT).
+
+
+
+
+ Initializes a new instance of from a string in JWS Compact serialized format.
+
+ A JSON Web Token that has been serialized in JWS Compact serialized format.
+ 'jwtEncodedString' is null.
+ 'jwtEncodedString' contains only whitespace.
+ 'jwtEncodedString' is not in JWS Compact serialized format.
+
+ The contents of this have not been validated, the JSON Web Token is simply decoded. Validation can be accomplished using
+
+
+
+
+ Initializes a new instance of the class where the contains the crypto algorithms applied to the encoded and . The jwtEncodedString is the result of those operations.
+
+ Contains JSON objects representing the cryptographic operations applied to the JWT and optionally any additional properties of the JWT
+ Contains JSON objects representing the claims contained in the JWT. Each claim is a JSON object of the form { Name, Value }
+ base64urlencoded JwtHeader
+ base64urlencoded JwtPayload
+ base64urlencoded JwtSignature
+ 'header' is null.
+ 'payload' is null.
+ 'rawSignature' is null.
+ 'rawHeader' or 'rawPayload' is null or whitespace.
+
+
+
+ Initializes a new instance of the class where the contains the crypto algorithms applied to the encoded and . The jwtEncodedString is the result of those operations.
+
+ Contains JSON objects representing the cryptographic operations applied to the JWT and optionally any additional properties of the JWT
+ Contains JSON objects representing the claims contained in the JWT. Each claim is a JSON object of the form { Name, Value }
+ 'header' is null.
+ 'payload' is null.
+
+
+
+ Initializes a new instance of the class specifying optional parameters.
+
+ if this value is not null, a { iss, 'issuer' } claim will be added.
+ if this value is not null, a { aud, 'audience' } claim will be added
+ if this value is not null then for each a { 'Claim.Type', 'Claim.Value' } is added. If duplicate claims are found then a { 'Claim.Type', List<object> } will be created to contain the duplicate values.
+ if expires.HasValue a { exp, 'value' } claim is added.
+ if notbefore.HasValue a { nbf, 'value' } claim is added.
+ The that will be used to sign the . See for details pertaining to the Header Parameter(s).
+ if 'expires' <= 'notbefore'.
+
+
+
+ Decodes the and
+
+ A string containing the header and payload in JSON format
+
+
+
+ Decodes the string into the header, payload and signature
+
+ Base64Url encoded string.
+
+
+
+ Gets the 'value' of the 'actor' claim { actort, 'value' }.
+
+ If the 'actor' claim is not found, null is returned.
+
+
+
+ Gets the list of 'audience' claim { aud, 'value' }.
+
+ If the 'audience' claim is not found, enumeration will be empty.
+
+
+
+ Gets the (s) for this token.
+
+ (s) returned will NOT have the translated according to
+
+
+
+ Gets the Base64UrlEncoded associated with this instance.
+
+
+
+
+ Gets the Base64UrlEncoded associated with this instance.
+
+
+
+
+ Gets the associated with this instance.
+
+
+
+
+ Gets the 'value' of the 'JWT ID' claim { jti, ''value' }.
+
+ If the 'JWT ID' claim is not found, null is returned.
+
+
+
+ Gets the 'value' of the 'issuer' claim { iss, 'value' }.
+
+ If the 'issuer' claim is not found, null is returned.
+
+
+
+ Gets the associated with this instance.
+
+
+
+
+ Gets the original raw data of this instance when it was created.
+
+ The original JSON Compact serialized format passed to one of the two constructors
+ or
+
+
+
+ Gets the original raw data of this instance when it was created.
+
+ The original JSON Compact serialized format passed to one of the two constructors
+ or
+
+
+
+ Gets the original raw data of this instance when it was created.
+
+ The original JSON Compact serialized format passed to one of the two constructors
+ or
+
+
+
+ Gets the original raw data of this instance when it was created.
+
+ The original JSON Compact serialized format passed to one of the two constructors
+ or
+
+
+
+ Gets the s for this instance.
+
+ By default an empty collection is returned.
+
+
+
+ Gets the signature algorithm associated with this instance.
+
+ if there is a associated with this instance, a value will be returned. Null otherwise.
+
+
+
+ Gets the associated with this instance.
+
+
+
+
+ Gets or sets the that signed this instance.
+
+ .ValidateSignature(...) sets this value when a is used to successfully validate a signature.
+
+
+
+ Gets or sets the that contains a that signed this instance.
+
+ .ValidateSignature(...) sets this value when a is used to successfully validate a signature.
+
+
+
+ Gets "value" of the 'subject' claim { sub, 'value' }.
+
+ If the 'subject' claim is not found, null is returned.
+
+
+
+ Gets 'value' of the 'notbefore' claim { nbf, 'value' } converted to a assuming 'value' is seconds since UnixEpoch (UTC 1970-01-01T0:0:0Z).
+
+ If the 'notbefore' claim is not found, then is returned.
+
+
+
+ Gets 'value' of the 'expiration' claim { exp, 'value' } converted to a assuming 'value' is seconds since UnixEpoch (UTC 1970-01-01T0:0:0Z).
+
+ If the 'expiration' claim is not found, then is returned.
+
+
+
+ A designed for creating and validating Json Web Tokens. See http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-07.
+
+
+
+
+ Default lifetime of tokens created. When creating tokens, if 'expires' and 'notbefore' are both null, then a default will be set to: expires = DateTime.UtcNow, notbefore = DateTime.UtcNow + TimeSpan.FromMinutes(TokenLifetimeInMinutes).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Obsolete method, use when processing tokens.
+
+ use . when processing tokens.
+
+
+
+ Determines if the is positioned on a well formed <BinarySecurityToken> element.
+
+ positioned at xml.
+
+ 'true' if the reader is positioned at an element <BinarySecurityToken>.
+ in the namespace: 'http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd'
+ With an attribute of 'valueType' equal to one of:
+ "urn:ietf:params:oauth:token-type:jwt", "JWT"
+
+ For example: <wsse:BinarySecurityToken valueType = "JWT"> ...
+
+ 'false' otherwise.
+
+ The 'EncodingType' attribute is optional, if it is set, it must be equal to: "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary".
+ 'reader' is null.
+
+
+
+ Determines if the string is a well formed Json Web token (see http://tools.ietf.org/html/draft-ietf-oauth-json-web-token-07)
+
+ string that should represent a valid JSON Web Token.
+ Uses ( token, @"^[A-Za-z0-9-_]+\.[A-Za-z0-9-_]+\.[A-Za-z0-9-_]*$" ).
+
+
+ 'true' if the token is in JSON compact serialization format.
+ 'false' if token.Length * 2 > .
+
+ 'tokenString' is null.
+
+
+
+ Creating is not NotSupported.
+
+ to create a .
+
+
+
+ Creates a based on values found in the .
+
+ Contains the parameters used to create the token.
+ A .
+
+ If is not null, will be signed.
+
+ 'tokenDescriptor' is null.
+
+
+
+ Uses the constructor, first creating the and .
+ If is not null, will be signed.
+
+ the issuer of the token.
+ the audience for this token.
+ the source of the (s) for this token.
+ the notbefore time for this token.
+ the expiration time for this token.
+ contains cryptographic material for generating a signature.
+ optional .
+ If is not null, then a claim { actort, 'value' } will be added to the payload. for details on how the value is created.
+ See for details on how the HeaderParameters are added to the header.
+ See for details on how the values are added to the payload.
+ If signautureProvider is not null, then it will be used to create the signature and will not be called.
+ A .
+ if 'expires' <= 'notBefore'.
+
+
+
+ Gets the token type identifier(s) supported by this handler.
+
+ A collection of strings that identify the tokens this instance can handle.
+ When receiving a wrapped inside a <wsse:BinarySecurityToken> element. The <wsse:BinarySecurityToken> element must have the ValueType attribute set to one of these values
+ in order for this handler to recognize that it can read the token.
+
+
+
+ Reads a JSON web token wrapped inside a WS-Security BinarySecurityToken xml element.
+
+ The pointing at the jwt.
+ An instance of
+ First calls .CanReadToken
+ The reader must be positioned at an element named:
+ BinarySecurityToken'.
+ in the namespace: 'http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd'
+ with a 'ValueType' attribute equal to one of: "urn:ietf:params:oauth:token-type:jwt", "JWT".
+
+ For example <wsse:BinarySecurityToken valueType = "JWT"> ...
+
+
+ The 'EncodingType' attribute is optional, if it is set, it must be equal to: "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary"
+
+
+ 'reader' is null.
+ if returns false.
+
+
+
+ Reads a token encoded in JSON Compact serialized format.
+
+ A 'JSON Web Token' (JWT) that has been encoded as a JSON object. May be signed
+ using 'JSON Web Signature' (JWS).
+
+ The JWT must be encoded using Base64Url encoding of the UTF-8 representation of the JWT: Header, Payload and Signature.
+ The contents of the JWT returned are not validated in any way, the token is simply decoded. Use ValidateToken to validate the JWT.
+
+ A
+
+
+
+ Obsolete method, use .
+
+ use .
+
+
+
+ Reads and validates a token encoded in JSON Compact serialized format.
+
+ A 'JSON Web Token' (JWT) that has been encoded as a JSON object. May be signed using 'JSON Web Signature' (JWS).
+ Contains validation parameters for the .
+ The that was validated.
+ 'securityToken' is null or whitespace.
+ 'validationParameters' is null.
+ 'securityToken.Length' > .
+ A from the jwt. Does not include the header claims.
+
+
+
+ Writes the wrapped in a WS-Security BinarySecurityToken using the .
+
+ used to write token.
+ The that will be written.
+ 'writer' is null.
+ 'token' is null.
+ 'token' is not a not .
+ The current contents are encoded. If is not null, the encoding will contain a signature.
+
+
+
+ Writes the as a JSON Compact serialized format string.
+
+ to serialize.
+
+ If the are not null, the encoding will contain a signature.
+
+ 'token' is null.
+ 'token' is not a not .
+ The as a signed (if exist) encoded string.
+
+
+
+ Produces a signature over the 'input' using the and algorithm specified.
+
+ string to be signed
+ the to use.
+ the algorithm to use.
+ if provided, the will be used to sign the token
+ The signature over the bytes obtained from UTF8Encoding.GetBytes( 'input' ).
+ The used to created the signature is obtained by calling .
+ 'input' is null.
+ returns null.
+
+
+
+ Validates that the signature, if found and / or required is valid.
+
+ A 'JSON Web Token' (JWT) that has been encoded as a JSON object. May be signed
+ using 'JSON Web Signature' (JWS).
+ that contains signing keys.
+ thrown if 'token is null or whitespace.
+ thrown if 'validationParameters is null.
+ thrown if a signature is not found and is true.
+ thrown if the 'token' has a key identifier and none of the (s) provided result in a validated signature.
+ This can indicate that a key refresh is required.
+ thrown if after trying all the (s), none result in a validated signture AND the 'token' does not have a key identifier.
+ that has the signature validated if token was signed and is true.
+ If the 'token' is signed, the signature is validated even if is false.
+ If the 'token' signature is validated, then the will be set to the key that signed the 'token'.
+
+
+
+ Produces a readable string for a key, used in error messages.
+
+
+
+
+
+
+ Creates a from a .
+
+ The to use as a source.
+ The value to set
+ contains parameters for validating the token.
+ A containing the .
+
+
+
+ Creates the 'value' for the actor claim: { actort, 'value' }
+
+ as actor.
+ representing the actor.
+ If is not null:
+ if 'type' is 'string', return as string.
+ if 'type' is 'BootstrapContext' and 'BootstrapContext.SecurityToken' is 'JwtSecurityToken'
+ if 'JwtSecurityToken.RawData' != null, return RawData.
+ else return .
+ if 'BootstrapContext.Token' != null, return 'Token'.
+ default: new ( ( actor.Claims ).
+
+ 'actor' is null.
+
+
+
+ Determines if the audiences found in a are valid.
+
+ The audiences found in the .
+ The being validated.
+ required for validation.
+ see for additional details.
+
+
+
+ Validates the lifetime of a .
+
+ The value of the 'nbf' claim if it exists in the 'jwt'.
+ The value of the 'exp' claim if it exists in the 'jwt'.
+ The being validated.
+ required for validation.
+ for additional details.
+
+
+
+ Determines if an issuer found in a is valid.
+
+ The issuer to validate
+ The that is being validated.
+ required for validation.
+ The issuer to use when creating the (s) in the .
+ for additional details.
+
+
+
+ Returns a to use when validating the signature of a token.
+
+ the representation of the token that is being validated.
+ the that is being validated.
+ the found in the token.
+ A required for validation.
+ Returns a to use for signature validation.
+ if 'keyIdentifier' is null.
+ if 'validationParameters' is null.
+ If key fails to resolve, then null is returned
+
+
+
+ Validates the is an expected value.
+
+ The that signed the .
+ The to validate.
+ the current .
+ If the is a then the X509Certificate2 will be validated using .
+
+
+ Gets or sets the used to map Inbound Cryptographic Algorithms.
+ Strings that describe Cryptographic Algorithms that are understood by the runtime are not necessarily the same values used in the JsonWebToken specification.
+ When a signature is validated, the algorithm is obtained from the HeaderParameter { alg, 'value' }.
+ The 'value' is translated according to this mapping and the translated 'value' is used when performing cryptographic operations.
+ Default mapping is:
+ RS256 => http://www.w3.org/2001/04/xmldsig-more#rsa-sha256
+ HS256 => http://www.w3.org/2001/04/xmldsig-more#hmac-sha256
+
+ 'value' is null.
+
+
+ Gets or sets the used to map Outbound Cryptographic Algorithms.
+ Strings that describe Cryptographic Algorithms understood by the runtime are not necessarily the same in the JsonWebToken specification.
+ This property contains mappings the will be used to when creating a and setting the HeaderParameter { alg, 'value' }.
+ The 'value' set is translated according to this mapping.
+
+ Default mapping is:
+ http://www.w3.org/2001/04/xmldsig-more#rsa-sha256 => RS256
+ http://www.w3.org/2001/04/xmldsig-more#hmac-sha256 => HS256
+
+ 'value' is null.
+
+
+
+ Gets or sets the that is used when setting the for claims in the extracted when validating a .
+ The is set to the JSON claim 'name' after translating using this mapping.
+
+ 'value is null.
+
+
+
+ Gets or sets the that is used when creating a from (s).
+ The JSON claim 'name' value is set to after translating using this mapping.
+
+ This mapping is applied only when using or . Adding values directly will not result in translation.
+ 'value is null.
+
+
+ Gets or sets the used to filter claims when populating a claims form a .
+ When a is validated, claims with types found in this will not be added to the .
+ 'value' is null.
+
+
+
+ Gets or sets the property name of the will contain the original JSON claim 'name' if a mapping occurred when the (s) were created.
+ See for more information.
+
+ if .IsIsNullOrWhiteSpace('value') is true.
+
+
+
+ Gets or sets the property name of the will contain .Net type that was recogninzed when JwtPayload.Claims serialized the value to JSON.
+ See for more information.
+
+ if .IsIsNullOrWhiteSpace('value') is true.
+
+
+
+ Returns 'true' which indicates this instance can validate a .
+
+
+
+
+ Returns 'true', which indicates this instance can write .
+
+
+
+
+ Gets and sets the token lifetime in minutes.
+
+ 'value' less than 1.
+
+
+
+ Gets and sets the maximum size in bytes, that a will be processed.
+
+ 'value' less than 1.
+
+
+
+ Gets or sets the for creating (s).
+
+ This extensibility point can be used to insert custom (s).
+ is called to obtain a (s) when needed.
+ 'value' is null.
+
+
+
+ Gets the supported by this handler.
+
+
+
+
+ represents a collection of named sets of (s) that can be matched by a
+ and return a that contains (s).
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+ Populates this instance with a named collection of (s) and an optional that will be called when a
+ or cannot be resolved.
+
+
+ A named collection of (s).
+
+
+ A to call when resolving fails, before calling base.
+
+
+ if 'keys' is null an empty collection will be created. A named collection of (s) can be added by accessing the property .
+
+
+
+
+ Populates the from xml.
+
+ xml for processing.
+ 'nodeList' is null.
+ Only (s) with == 'securityKey' will be processed. Unprocessed nodes will added to a list and can be accessed using the property.
+
+
+
+ When processing xml in each that has = "securityKey' is passed here for processing.
+
+ contains xml to map to a named .
+
+ A single is expected with up to three attributes: {'expected values'}.
+ <securityKey
+ symmetricKey {required}
+ name {required}
+ EncodingType or encodingType {optional}
+ >
+ </securityKey>
+ If "EncodingType' type is specified only:
+ 'http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary'
+ 'Base64Binary'
+ 'base64Binary'
+ are allowed and have the same meaning.
+ When a symmetricKey is found, Convert.FromBase64String( value ) is applied to create the key.
+
+ 'element' is null.
+ attribute 'symmetricKey' is not found.
+ value of 'symmetricKey' is empty or whitespace.
+ attribute 'name' is not found.
+ value of 'name' is empty or whitespace.
+ value of 'encodingType' is not valid.
+
+
+
+ Finds the first in a named collection that match the .
+
+
+ The to resolve to a
+
+
+ The resolved .
+
+
+ If there is no match, then and 'base' are called in order.
+
+
+ true if key resolved, false otherwise.
+
+
+
+
+ Finds a named collection of (s) that match the and returns a that contains the (s).
+
+ The to resolve to a
+ The resolved .
+
+
+ A can contain multiple (s). This method will return the named collection that matches the first
+
+
+ If there is no match, then and 'base' are called in order.
+
+
+
+ true is the keyIdentifier is resolved, false otherwise.
+
+
+
+
+ Finds a named collection of (s) that match the and returns a that contains the (s).
+
+ The to resolve to a
+ The resolved .
+ If there is no match, then and 'base' are called in order.
+ true if token was resolved.
+ if 'keyIdentifierClause' is null.
+
+
+
+ Gets the named collection of (s).
+
+
+
+
+ Gets or sets the to call when or fails to resolve, before calling base.
+
+ 'value' is null.
+ 'object.ReferenceEquals( this, value)' is true.
+
+
+
+ Gets the unprocessed (s) from .
+
+ processes only (s) that have the == 'securityKey'. Unprocessed (s) are accessible here.
+
+
+
+ A that can be used to match .
+
+
+
+
+ Initializes a new instance of the class. The 'name' for matching key identifiers found in the securityToken.
+
+ Used to identify a named collection of keys.
+ Additional information for matching.
+ if 'name' is null or whitespace.
+ if 'id' is null or whitespace
+
+
+
+ Determines if a matches this instance.
+
+ The to match.
+ true if:
+ 1. keyIdentifierClause is a .
+ 2. string.Equals( keyIdentifierClause.Name, this.Name, StringComparison.Ordinal).
+ 2. string.Equals( keyIdentifierClause.Id, this.Id, StringComparison.Ordinal).
+ Otherwise calls base.Matches( keyIdentifierClause ).
+
+ 'keyIdentifierClause' is null.
+
+
+
+ Gets the name of the (s) this represents.
+
+
+
+
+ A that contains multiple that have a name.
+
+
+
+
+ Initializes a new instance of the class that contains a single .
+
+ A name for the .
+ the identifier for this token.
+ A
+ if 'name' is null or whitespace.
+ if 'id' is null or whitespace.
+ if 'key' is null.
+
+
+
+ Initializes a new instance of the class that contains a (System.IdentityModel.Tokens.SecurityKey) that can be matched by name.
+
+ the identifier for this token.
+ A name for the (System.IdentityModel.Tokens.SecurityKey).
+ A collection of
+ if 'name' is null or whitespace.
+ if 'id' is null or whitespace.
+ if 'keys' is null.
+
+
+
+ Gets the first that matches a
+
+ the to match.
+ The first that matches the .
+ null if there is no match.
+ Only are matched.
+ 'keyIdentifierClause' is null.
+
+
+
+ Answers if the is a match.
+
+ The
+ true if matched.
+ A successful match occurs when == .
+ Only are matched.
+ 'keyIdentifierClause' is null.
+
+
+
+ Gets the id of the security token.
+
+
+
+
+ Gets the Name of the security token.
+
+
+
+
+ Gets the creation time as a .
+
+ The default is: .
+
+
+
+ Gets the expiration time as a
+
+ The default is: .
+
+
+
+ Gets the (s).
+
+
+
+
+ This exception is thrown when 'audience' of a token was not valid.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+ A that represents the root cause of the exception.
+
+
+
+ Initializes a new instance of the class.
+
+ the that holds the serialized object data.
+ The contextual information about the source or destination.
+
+
+
+ This exception is thrown when 'issuer' of a token was not valid.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+ A that represents the root cause of the exception.
+
+
+
+ Initializes a new instance of the class.
+
+ the that holds the serialized object data.
+ The contextual information about the source or destination.
+
+
+
+ This exception is thrown when 'lifetime' of a token was not valid.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+ A that represents the root cause of the exception.
+
+
+
+ Initializes a new instance of the class.
+
+ the that holds the serialized object data.
+ The contextual information about the source or destination.
+
+
+
+ This exception is thrown when a security is missing an ExpirationTime.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+ A that represents the root cause of the exception.
+
+
+
+ Initializes a new instance of the class.
+
+ the that holds the serialized object data.
+ The contextual information about the source or destination.
+
+
+
+ This exception is thrown when an add to the TokenReplayCache fails.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+ A that represents the root cause of the exception.
+
+
+
+ Initializes a new instance of the class.
+
+ the that holds the serialized object data.
+ The contextual information about the source or destination.
+
+
+
+ This exception is thrown when a security token contained a key identifier but the key was not found by the runtime.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+
+
+
+ Initializes a new instance of the class.
+
+ Addtional information to be included in the exception and displayed to user.
+ A that represents the root cause of the exception.
+
+
+
+ Initializes a new instance of the class.
+
+ the that holds the serialized object data.
+ The contextual information about the source or destination.
+
+
+
+ Creates s by specifying a and algorithm.
+ Supports both and .
+
+
+
+
+ This is the minimum .KeySize when creating signatures.
+
+
+
+
+ This is the minimum .KeySize when verifying signatures.
+
+
+
+
+ This is the minimum .KeySize when creating and verifying signatures.
+
+
+
+
+ Creates a that supports the and algorithm.
+
+
+ The to use for signing.
+
+
+ The algorithm to use for signing.
+
+
+ 'key' is null.
+
+
+ 'algorithm' is null.
+
+
+ 'algorithm' contains only whitespace.
+
+
+ '' is smaller than .
+
+
+ '' is smaller than .
+
+
+ '' is not a or a .
+
+
+ AsymmetricSignatureProviders require access to a PrivateKey for Signing.
+
+
+ The .
+
+
+
+
+ Returns a instance supports the and algorithm.
+
+
+ The to use for signing.
+
+
+ The algorithm to use for signing.
+
+
+ 'key' is null.
+
+
+ 'algorithm' is null.
+
+
+ 'algorithm' contains only whitespace.
+
+
+ '' is smaller than .
+
+
+ '' is smaller than .
+
+
+ '' is not a or a .
+
+
+ The .
+
+
+
+
+ When finished with a call this method for cleanup. The default behavior is to call
+
+ to be released.
+
+
+
+ Gets or sets the minimum .KeySize"/>.
+
+ 'value' is smaller than .
+
+
+
+ Gets or sets the minimum .KeySize for creating signatures.
+
+ 'value' is smaller than .
+
+
+
+ Gets or sets the minimum .KeySize for verifying signatures.
+ 'value' is smaller than .
+
+
+
+
+ Provides signing and verifying operations using a and specifying an algorithm.
+
+
+
+
+ Initializes a new instance of the class that uses an to create and / or verify signatures over a array of bytes.
+
+ The used for signing.
+ The signature algorithm to use.
+ 'key' is null.
+ 'algorithm' is null.
+ 'algorithm' contains only whitespace.
+ '.KeySize' is smaller than .
+ throws.
+ returns null.
+ throws.
+
+
+
+ Produces a signature over the 'input' using the and 'algorithm' passed to .
+
+ bytes to sign.
+ signed bytes
+ 'input' is null.
+ 'input.Length' == 0.
+ has been called.
+ is null. This can occur if a derived type deletes it or does not create it.
+
+
+
+ Verifies that a signature created over the 'input' matches the signature. Using and 'algorithm' passed to .
+
+ bytes to verify.
+ signature to compare against.
+ true if computed signature matches the signature parameter, false otherwise.
+ 'input' is null.
+ 'signature' is null.
+ 'input.Length' == 0.
+ 'signature.Length' == 0.
+ has been called.
+ if the internal is null. This can occur if a derived type deletes it or does not create it.
+
+
+
+ Disposes of internal components.
+
+ true, if called from Dispose(), false, if invoked inside a finalizer.
+
+
+
+ Compares two byte arrays for equality. Hash size is fixed normally it is 32 bytes.
+ The attempt here is to take the same time if an attacker shortens the signature OR changes some of the signed contents.
+
+
+ One set of bytes to compare.
+
+
+ The other set of bytes to compare with.
+
+
+ true if the bytes are equal, false otherwise.
+
+
+
+
+ Definition for AudienceValidator.
+
+ The audiences found in the .
+ The being validated.
+ required for validation.
+
+
+
+ Definition for IssuerSigningKeyRetriever. When validating signatures, this method will return key to use.
+
+ the representation of the token that is being validated.
+ the that is being validated. It may be null.
+ the found in the token. It may be null.
+ required for validation.
+
+
+
+
+ Definition for IssuerValidator.
+
+ The issuer to validate.
+ The that is being validated.
+ required for validation.
+ The issuer to use when creating the "Claim"(s) in a "ClaimsIdentity".
+
+
+
+ Definition for LifetimeValidator.
+
+ The 'notBefore' time found in the .
+ The 'expiration' time found in the .
+ The being validated.
+ required for validation.
+
+
+
+ Contains a set of parameters that are used by a when validating a .
+
+
+
+
+ Default for the maximm token size.
+
+ 2 MB (mega bytes).
+
+
+
+ This is the fallback authenticationtype that a will use if nothing is set.
+
+
+
+
+ Default for the clock skew.
+
+ 300 seconds (5 minutes).
+
+
+
+ Copy constructor for .
+
+
+
+
+ Initializes a new instance of the class.
+
+
+
+
+ Returns a new instance of with values copied from this object.
+
+ A new object copied from this object
+ This is a shallow Clone.
+
+
+
+ Creates a using:
+
+ 'NameClaimType' is calculated: If NameClaimTypeRetriever call that else use NameClaimType. If the result is a null or empty string, use .
+ 'RoleClaimType' is calculated: If RoleClaimTypeRetriever call that else use RoleClaimType. If the result is a null or empty string, use .
+
+ A with Authentication, NameClaimType and RoleClaimType set.
+
+
+
+ Gets or sets a delegate that will be used to validate the audience of the tokens
+
+
+
+
+ Gets or sets the AuthenticationType when creating a during token validation.
+
+ if 'value' is null or whitespace.
+
+
+
+ Gets or sets the for validating X509Certificate2(s).
+
+
+
+
+ Gets or sets the that is to be used for decrypting inbound tokens.
+
+ if 'value' is null.
+
+
+
+ Gets or sets the clock skew to apply when validating times
+
+ if 'value' is less than 0.
+
+
+
+ Gets or sets the that is to be used for validating signed tokens.
+
+
+
+
+ Gets or sets the that is to be used for validating signed tokens.
+
+
+
+
+ Gets or sets a delegate that will be used to retreive (s) used for checking signatures.
+
+ Each will be used to check the signature. Returning multiple key can be helpful when the does not contain a key identifier.
+ This can occur when the issuer has multiple keys available. This sometimes occurs during key rollover.
+
+
+
+ Gets or sets the that are to be used for validating signed tokens.
+
+
+
+
+ Gets or sets the that is used for validating signed tokens.
+
+
+
+
+ Gets or sets the that are to be used for validating signed tokens.
+
+
+
+
+ Gets or sets a delegate that will be used to validate the issuer of the token. The delegate returns the issuer to use.
+
+
+
+
+ Gets or sets a delegate that will be used to validate the lifetime of the token
+
+
+
+
+ Gets or sets the passed to .
+
+
+ Controls the value returns. It will return the first where the equals .
+
+
+
+
+ Gets or sets the passed to .
+
+
+ Controls the (s) returned from .
+ Each returned will have a equal to .
+
+
+
+
+ Gets or sets a delegate that will be called to obtain the NameClaimType to use when creating a ClaimsIdentity
+ when validating a token.
+
+
+
+
+ Gets or sets a value indicating whether tokens must have an 'expiration' value.
+
+
+
+
+ Gets or sets a value indicating whether a can be valid if not signed.
+
+
+
+
+ Gets or sets a delegate that will be called to obtain the RoleClaimType to use when creating a ClaimsIdentity
+ when validating a token.
+
+
+
+
+ Gets or sets a boolean to control if the original token is saved when a session is created. ///
+ The SecurityTokenValidator will use this value to save the orginal string that was validated.
+
+
+
+ Gets or set the that will be checked to help in detecting that a token has been 'seen' before.
+
+
+
+
+ Gets or sets a value indicating whether the should be validated.
+
+
+
+
+ Gets or sets a boolean to control if the audience will be validated during token validation.
+
+
+
+
+ Gets or sets a boolean to control if the issuer will be validated during token validation.
+
+
+
+
+ Gets or sets a boolean to control if the lifetime will be validated during token validation.
+
+
+
+
+ Gets or sets a boolean that controls if validation of the that signed the securityToken is called.
+
+
+
+
+ Gets or sets a string that represents a valid audience that will be used during token validation.
+
+
+
+
+ Gets or sets the that contains valid audiences that will be used during token validation.
+
+
+
+
+ Gets or sets a that represents a valid issuer that will be used during token validation.
+
+
+
+
+ Gets or sets the that contains valid issuers that will be used during token validation.
+
+
+
+
+ AudienceValidator
+
+
+
+
+ Determines if the audiences found in a are valid.
+
+ The audiences found in the .
+ The being validated.
+ required for validation.
+ if 'vaidationParameters' is null.
+ if 'audiences' is null and is true.
+ if is null or whitespace and is null.
+ if none of the 'audiences' matched either or one of .
+ An EXACT match is required.
+
+
+
+ Determines if an issuer found in a is valid.
+
+ The issuer to validate
+ The that is being validated.
+ required for validation.
+ The issuer to use when creating the "Claim"(s) in a "ClaimsIdentity".
+ if 'vaidationParameters' is null.
+ if 'issuer' is null or whitespace and is true.
+ if is null or whitespace and is null.
+ if 'issuer' failed to matched either or one of .
+ An EXACT match is required.
+
+
+
+ Validates the that signed a .
+
+ The that signed the .
+ The being validated.
+ required for validation.
+ if 'vaidationParameters' is null.
+
+
+
+ Validates the lifetime of a .
+
+ The 'notBefore' time found in the .
+ The 'expiration' time found in the .
+ The being validated.
+ required for validation.
+ if 'vaidationParameters' is null.
+ if 'expires.HasValue' is false and is true.
+ if 'notBefore' is > 'expires'.
+ if 'notBefore' is > DateTime.UtcNow.
+ if 'expires' is < DateTime.UtcNow.
+ All time comparisons apply .
+
+
+
+ Validates if a token has been replayed.
+
+ The being validated.
+ When does the security token expire.
+ required for validation.
+ if 'securityToken' is null or whitespace.
+ if 'validationParameters' is null or whitespace.
+ if is not null and expirationTime.HasValue is false. When a TokenReplayCache is set, tokens require an expiration time.
+ if the 'securityToken' is found in the cache.
+ if the 'securityToken' could not be added to the .
+
+
+
+ Defines constants needed from WS-Security 1.0.
+
+
+
+
+ Defines constants needed from WS-SecureUtility standard schema.
+
+
+
+
+ This class also resets the chainPolicy.VerificationTime = DateTime.Now each time a certificate is validated otherwise certificates created after the validator is created will not chain.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ The certificate validation mode.
+
+
+ The revocation mode.
+
+
+ The trusted store location.
+
+ thrown if the certificationValidationMode is custom or unknown.
+
+
+
+
+ Validates a .
+
+
+ The to validate.
+
+
+
+
+ Security key that allows access to cert
+
+
+
+
+ Instantiates a using a
+
+ cert to use.
+
+
+
+ Gets the .
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Net.Http.Formatting.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Net.Http.Formatting.dll
new file mode 100644
index 000000000..3b76acd6b
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Net.Http.Formatting.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Net.Http.Formatting.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Net.Http.Formatting.xml
new file mode 100644
index 000000000..3fb65976c
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Net.Http.Formatting.xml
@@ -0,0 +1,2094 @@
+
+
+
+ System.Net.Http.Formatting
+
+
+
+
+ implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. The supports one or more byte ranges regardless of whether the ranges are consecutive or not. If there is only one range then a single partial response body containing a Content-Range header is generated. If there are more than one ranges then a multipart/byteranges response is generated where each body part contains a range indicated by the associated Content-Range header field.
+
+
+
+ implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. If none of the requested ranges overlap with the current extend of the selected resource represented by the content parameter then an is thrown indicating the valid Content-Range of the content.
+ The stream over which to generate a byte range view.
+ The range or ranges, typically obtained from the Range HTTP request header field.
+ The media type of the content stream.
+
+
+
+ implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. If none of the requested ranges overlap with the current extend of the selected resource represented by the content parameter then an is thrown indicating the valid Content-Range of the content.
+ The stream over which to generate a byte range view.
+ The range or ranges, typically obtained from the Range HTTP request header field.
+ The media type of the content stream.
+ The buffer size used when copying the content stream.
+
+
+
+ implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. If none of the requested ranges overlap with the current extend of the selected resource represented by the content parameter then an is thrown indicating the valid Content-Range of the content.
+ The stream over which to generate a byte range view.
+ The range or ranges, typically obtained from the Range HTTP request header field.
+ The media type of the content stream.
+
+
+
+ implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. If none of the requested ranges overlap with the current extend of the selected resource represented by the content parameter then an is thrown indicating the valid Content-Range of the content.
+ The stream over which to generate a byte range view.
+ The range or ranges, typically obtained from the Range HTTP request header field.
+ The media type of the content stream.
+ The buffer size used when copying the content stream.
+
+
+ Releases the resources used by the current instance of the class.
+ true to release managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Asynchronously serialize and write the byte range to an HTTP content stream.
+ The task object representing the asynchronous operation.
+ The target stream.
+ Information about the transport.
+
+
+ Determines whether a byte array has a valid length in bytes.
+ true if length is a valid length; otherwise, false.
+ The length in bytes of the byte array.
+
+
+ Extension methods that aid in making formatted requests using .
+
+
+
+
+
+
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with the given value serialized as JSON.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The type of value.
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with the given value serialized as JSON.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+
+
+
+
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with the given value serialized as XML.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The type of value.
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with the given value serialized as XML.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ The type of value.
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used.
+ The type of value.
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+ Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+
+
+
+
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with the given value serialized as JSON.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The type of value.
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with the given value serialized as JSON.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+
+
+
+
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with the given value serialized as XML.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The type of value.
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with the given value serialized as XML.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ The type of value.
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used.
+ The type of value.
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+ Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter.
+ A task object representing the asynchronous operation.
+ The client used to make the request.
+ The Uri the request is sent to.
+ The value that will be placed in the request's entity body.
+ The formatter used to serialize the value.
+ A cancellation token that can be used by other objects or threads to receive notice of cancellation.
+ The type of value.
+
+
+ Represents the factory for creating new instance of .
+
+
+ Creates a new instance of the .
+ A new instance of the .
+ The list of HTTP handler that delegates the processing of HTTP response messages to another handler.
+
+
+ Creates a new instance of the .
+ A new instance of the .
+ The inner handler which is responsible for processing the HTTP response messages.
+ The list of HTTP handler that delegates the processing of HTTP response messages to another handler.
+
+
+ Creates a new instance of the which should be pipelined.
+ A new instance of the which should be pipelined.
+ The inner handler which is responsible for processing the HTTP response messages.
+ The list of HTTP handler that delegates the processing of HTTP response messages to another handler.
+
+
+ Specifies extension methods to allow strongly typed objects to be read from HttpContent instances.
+
+
+ Returns a Task that will yield an object of the specified type <typeparamref name="T" /> from the content instance.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The type of the object to read.
+
+
+ Returns a Task that will yield an object of the specified type <typeparamref name="T" /> from the content instance.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The collection of MediaTyepFormatter instances to use.
+ The type of the object to read.
+
+
+ Returns a Task that will yield an object of the specified type <typeparamref name="T" /> from the content instance.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The collection of MediaTypeFormatter instances to use.
+ The IFormatterLogger to log events to.
+ The type of the object to read.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The collection of MediaTypeFormatter instances to use.
+ The IFormatterLogger to log events to.
+ The token to cancel the operation.
+ The type of the object to read.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The collection of MediaTypeFormatter instances to use.
+ The token to cancel the operation.
+ The type of the object to read.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The token to cancel the operation.
+ The type of the object to read.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance.
+ A Task that will yield an object instance of the specified type.
+ The HttpContent instance from which to read.
+ The type of the object to read.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The type of the object to read.
+ The collection of MediaTypeFormatter instances to use.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The type of the object to read.
+ The collection of MediaTypeFormatter instances to use.
+ The IFormatterLogger to log events to.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The type of the object to read.
+ The collection of MediaTypeFormatter instances to use.
+ The IFormatterLogger to log events to.
+ The token to cancel the operation.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The type of the object to read.
+ The collection of MediaTypeFormatter instances to use.
+ The token to cancel the operation.
+
+
+ Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content.
+ An object instance of the specified type.
+ The HttpContent instance from which to read.
+ The type of the object to read.
+ The token to cancel the operation.
+
+
+ Extension methods to read HTML form URL-encoded datafrom instances.
+
+
+ Determines whether the specified content is HTML form URL-encoded data.
+ true if the specified content is HTML form URL-encoded data; otherwise, false.
+ The content.
+
+
+ Asynchronously reads HTML form URL-encoded from an instance and stores the results in a object.
+ A task object representing the asynchronous operation.
+ The content.
+
+
+ Asynchronously reads HTML form URL-encoded from an instance and stores the results in a object.
+ A task object representing the asynchronous operation.
+ The content.
+ The token to cancel the operation.
+
+
+ Provides extension methods to read and entities from instances.
+
+
+ Determines whether the specified content is HTTP request message content.
+ true if the specified content is HTTP message content; otherwise, false.
+ The content to check.
+
+
+ Determines whether the specified content is HTTP response message content.
+ true if the specified content is HTTP message content; otherwise, false.
+ The content to check.
+
+
+ Reads the as an .
+ The parsed instance.
+ The content to read.
+
+
+ Reads the as an .
+ The parsed instance.
+ The content to read.
+ The URI scheme to use for the request URI.
+
+
+ Reads the as an .
+ The parsed instance.
+ The content to read.
+ The URI scheme to use for the request URI.
+ The size of the buffer.
+
+
+ Reads the as an .
+ The parsed instance.
+ The content to read.
+ The URI scheme to use for the request URI.
+ The size of the buffer.
+ The maximum length of the HTTP header.
+
+
+
+
+
+
+ Reads the as an .
+ The parsed instance.
+ The content to read.
+
+
+ Reads the as an .
+ The parsed instance.
+ The content to read.
+ The size of the buffer.
+
+
+ Reads the as an .
+ The parsed instance.
+ The content to read.
+ The size of the buffer.
+ The maximum length of the HTTP header.
+
+
+
+
+
+ Extension methods to read MIME multipart entities from instances.
+
+
+ Determines whether the specified content is MIME multipart content.
+ true if the specified content is MIME multipart content; otherwise, false.
+ The content.
+
+
+ Determines whether the specified content is MIME multipart content with the specified subtype.
+ true if the specified content is MIME multipart content with the specified subtype; otherwise, false.
+ The content.
+ The MIME multipart subtype to match.
+
+
+ Reads all body parts within a MIME multipart message and produces a set of instances as a result.
+ A representing the tasks of getting the collection of instances where each instance represents a body part.
+ An existing instance to use for the object's content.
+
+
+ Reads all body parts within a MIME multipart message and produces a set of instances as a result.
+ A representing the tasks of getting the collection of instances where each instance represents a body part.
+ An existing instance to use for the object's content.
+ The token to cancel the operation.
+
+
+ Reads all body parts within a MIME multipart message and produces a set of instances as a result using the streamProvider instance to determine where the contents of each body part is written.
+ A representing the tasks of getting the collection of instances where each instance represents a body part.
+ An existing instance to use for the object's content.
+ A stream provider providing output streams for where to write body parts as they are parsed.
+ The type of the MIME multipart.
+
+
+ Reads all body parts within a MIME multipart message and produces a set of instances as a result using the streamProvider instance to determine where the contents of each body part is written and bufferSize as read buffer size.
+ A representing the tasks of getting the collection of instances where each instance represents a body part.
+ An existing instance to use for the object's content.
+ A stream provider providing output streams for where to write body parts as they are parsed.
+ Size of the buffer used to read the contents.
+ The type of the MIME multipart.
+
+
+ Reads all body parts within a MIME multipart message and produces a set of instances as a result using the streamProvider instance to determine where the contents of each body part is written and bufferSize as read buffer size.
+ A representing the tasks of getting the collection of instances where each instance represents a body part.
+ An existing instance to use for the object's content.
+ A stream provider providing output streams for where to write body parts as they are parsed.
+ Size of the buffer used to read the contents.
+ The token to cancel the operation.
+ The type of the MIME multipart.
+
+
+ Reads all body parts within a MIME multipart message and produces a set of instances as a result using the streamProvider instance to determine where the contents of each body part is written.
+ A representing the tasks of getting the collection of instances where each instance represents a body part.
+ An existing instance to use for the object's content.
+ A stream provider providing output streams for where to write body parts as they are parsed.
+ The token to cancel the operation.
+ The type of the MIME multipart.
+
+
+ Derived class which can encapsulate an or an as an entity with media type "application/http".
+
+
+ Initializes a new instance of the class encapsulating an .
+ The instance to encapsulate.
+
+
+ Initializes a new instance of the class encapsulating an .
+ The instance to encapsulate.
+
+
+ Releases unmanaged and - optionally - managed resources
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Gets the HTTP request message.
+
+
+ Gets the HTTP response message.
+
+
+ Asynchronously serializes the object's content to the given stream.
+ A instance that is asynchronously serializing the object's content.
+ The to which to write.
+ The associated .
+
+
+ Computes the length of the stream if possible.
+ true if the length has been computed; otherwise false.
+ The computed length of the stream.
+
+
+ Provides extension methods for the class.
+
+
+ Gets any cookie headers present in the request.
+ A collection of instances.
+ The request headers.
+
+
+ Gets any cookie headers present in the request that contain a cookie state whose name that matches the specified value.
+ A collection of instances.
+ The request headers.
+ The cookie state name to match.
+
+
+
+
+ Provides extension methods for the class.
+
+
+ Adds cookies to a response. Each Set-Cookie header is represented as one instance. A contains information about the domain, path, and other cookie information as well as one or more instances. Each instance contains a cookie name and whatever cookie state is associate with that name. The state is in the form of a which on the wire is encoded as HTML Form URL-encoded data. This representation allows for multiple related "cookies" to be carried within the same Cookie header while still providing separation between each cookie state. A sample Cookie header is shown below. In this example, there are two with names state1 and state2 respectively. Further, each cookie state contains two name/value pairs (name1/value1 and name2/value2) and (name3/value3 and name4/value4). <code> Set-Cookie: state1:name1=value1&name2=value2; state2:name3=value3&name4=value4; domain=domain1; path=path1; </code>
+ The response headers
+ The cookie values to add to the response.
+
+
+ An exception thrown by in case none of the requested ranges overlap with the current extend of the selected resource. The current extend of the resource is indicated in the ContentRange property.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+
+
+ The current extend of the resource indicated in terms of a ContentRange header field.
+
+
+ Represents a multipart file data.
+
+
+ Initializes a new instance of the class.
+ The headers of the multipart file data.
+ The name of the local file for the multipart file data.
+
+
+ Gets or sets the headers of the multipart file data.
+ The headers of the multipart file data.
+
+
+ Gets or sets the name of the local file for the multipart file data.
+ The name of the local file for the multipart file data.
+
+
+ Represents an suited for writing each MIME body parts of the MIME multipart message to a file using a .
+
+
+ Initializes a new instance of the class.
+ The root path where the content of MIME multipart body parts are written to.
+
+
+ Initializes a new instance of the class.
+ The root path where the content of MIME multipart body parts are written to.
+ The number of bytes buffered for writes to the file.
+
+
+ Gets or sets the number of bytes buffered for writes to the file.
+ The number of bytes buffered for writes to the file.
+
+
+ Gets or sets the multipart file data.
+ The multipart file data.
+
+
+ Gets the name of the local file which will be combined with the root path to create an absolute file name where the contents of the current MIME body part will be stored.
+ A relative filename with no path component.
+ The headers for the current MIME body part.
+
+
+ Gets the stream instance where the message body part is written to.
+ The instance where the message body part is written to.
+ The content of HTTP.
+ The header fields describing the body part.
+
+
+ Gets or sets the root path where the content of MIME multipart body parts are written to.
+ The root path where the content of MIME multipart body parts are written to.
+
+
+ A implementation suited for use with HTML file uploads for writing file content to a remote storage . The stream provider looks at the Content-Disposition header field and determines an output remote based on the presence of a filename parameter. If a filename parameter is present in the Content-Disposition header field, then the body part is written to a remote provided by . Otherwise it is written to a .
+
+
+ Initializes a new instance of the class.
+
+
+ Read the non-file contents as form data.
+ A representing the post processing.
+
+
+ Read the non-file contents as form data.
+ A representing the post processing.
+ The token to monitor for cancellation requests.
+
+
+ Gets a collection of file data passed as part of the multipart form data.
+
+
+ Gets a of form data passed as part of the multipart form data.
+
+
+ Provides a for . Override this method to provide a remote stream to which the data should be written.
+ A result specifying a remote stream where the file will be written to and a location where the file can be accessed. It cannot be null and the stream must be writable.
+ The parent MIME multipart instance.
+ The header fields describing the body part's content.
+
+
+
+ Represents an suited for use with HTML file uploads for writing file content to a .
+
+
+ Initializes a new instance of the class.
+ The root path where the content of MIME multipart body parts are written to.
+
+
+ Initializes a new instance of the class.
+ The root path where the content of MIME multipart body parts are written to.
+ The number of bytes buffered for writes to the file.
+
+
+ Reads the non-file contents as form data.
+ A task that represents the asynchronous operation.
+
+
+
+ Gets a of form data passed as part of the multipart form data.
+ The of form data.
+
+
+ Gets the streaming instance where the message body part is written.
+ The instance where the message body part is written.
+ The HTTP content that contains this body part.
+ Header fields describing the body part.
+
+
+ Represents a multipart memory stream provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns the for the .
+ The for the .
+ A object.
+ The HTTP content headers.
+
+
+ Represents the provider for the multipart related multistream.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the related stream for the provider.
+ The content headers.
+ The parent content.
+ The http content headers.
+
+
+ Gets the root content of the .
+ The root content of the .
+
+
+ Represents a multipart file data for remote storage.
+
+
+ Initializes a new instance of the class.
+ The headers of the multipart file data.
+ The remote file's location.
+ The remote file's name.
+
+
+ Gets the remote file's name.
+
+
+ Gets the headers of the multipart file data.
+
+
+ Gets the remote file's location.
+
+
+ Represents a stream provider that examines the headers provided by the MIME multipart parser as part of the MIME multipart extension methods (see ) and decides what kind of stream to return for the body part to be written to.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the contents for this .
+ The contents for this .
+
+
+ Executes the post processing operation for this .
+ The asynchronous task for this operation.
+
+
+ Executes the post processing operation for this .
+ The asynchronous task for this operation.
+ The token to cancel the operation.
+
+
+ Gets the stream where to write the body part to. This method is called when a MIME multipart body part has been parsed.
+ The instance where the message body part is written to.
+ The content of the HTTP.
+ The header fields describing the body part.
+
+
+ Contains a value as well as an associated that will be used to serialize the value when writing this content.
+
+
+ Initializes a new instance of the class.
+ The type of object this instance will contain.
+ The value of the object this instance will contain.
+ The formatter to use when serializing the value.
+
+
+ Initializes a new instance of the class.
+ The type of object this instance will contain.
+ The value of the object this instance will contain.
+ The formatter to use when serializing the value.
+ The authoritative value of the Content-Type header. Can be null, in which case the default content type of the formatter will be used.
+
+
+ Initializes a new instance of the class.
+ The type of object this instance will contain.
+ The value of the object this instance will contain.
+ The formatter to use when serializing the value.
+ The authoritative value of the Content-Type header.
+
+
+ Gets the media-type formatter associated with this content instance.
+ The media type formatter associated with this content instance.
+
+
+ Gets the type of object managed by this instance.
+ The object type.
+
+
+ Asynchronously serializes the object's content to the given stream.
+ The task object representing the asynchronous operation.
+ The stream to write to.
+ The associated .
+
+
+ Computes the length of the stream if possible.
+ true if the length has been computed; otherwise, false.
+ Receives the computed length of the stream.
+
+
+ Gets or sets the value of the content.
+ The content value.
+
+
+ Generic form of .
+ The type of object this class will contain.
+
+
+ Initializes a new instance of the class.
+ The value of the object this instance will contain.
+ The formatter to use when serializing the value.
+
+
+ Initializes a new instance of the <see cref="T:System.Net.Http.ObjectContent`1" /> class.
+ The value of the object this instance will contain.
+ The formatter to use when serializing the value.
+ The authoritative value of the Content-Type header. Can be null, in which case the default content type of the formatter will be used.
+
+
+ Initializes a new instance of the class.
+ The value of the object this instance will contain.
+ The formatter to use when serializing the value.
+ The authoritative value of the Content-Type header.
+
+
+ Enables scenarios where a data producer wants to write directly (either synchronously or asynchronously) using a stream.
+
+
+ Initializes a new instance of the class.
+ An action that is called when an output stream is available, allowing the action to write to it directly.
+
+
+ Initializes a new instance of the class.
+ An action that is called when an output stream is available, allowing the action to write to it directly.
+ The media type.
+
+
+ Initializes a new instance of the class.
+ An action that is called when an output stream is available, allowing the action to write to it directly.
+ The media type.
+
+
+ Initializes a new instance of the class.
+ An action that is called when an output stream is available, allowing the action to write to it directly.
+
+
+ Initializes a new instance of the class.
+ An action that is called when an output stream is available, allowing the action to write to it directly.
+ The media type.
+
+
+ Initializes a new instance of the class.
+ An action that is called when an output stream is available, allowing the action to write to it directly.
+ The media type.
+
+
+ Asynchronously serializes the push content into stream.
+ The serialized push content.
+ The stream where the push content will be serialized.
+ The context.
+
+
+ Determines whether the stream content has a valid length in bytes.
+ true if length is a valid length; otherwise, false.
+ The length in bytes of the stream content.
+
+
+ Represents the result for .
+
+
+ Initializes a new instance of the class.
+ The remote stream instance where the file will be written to.
+ The remote file's location.
+ The remote file's name.
+
+
+ Gets the remote file's location.
+
+
+ Gets the remote file's location.
+
+
+ Gets the remote stream instance where the file will be written to.
+
+
+ Defines an exception type for signalling that a request's media type was not supported.
+
+
+ Initializes a new instance of the class.
+ The message that describes the error.
+ The unsupported media type.
+
+
+ Gets or sets the media type.
+ The media type.
+
+
+ Contains extension methods to allow strongly typed objects to be read from the query component of instances.
+
+
+ Parses the query portion of the specified URI.
+ A that contains the query parameters.
+ The URI to parse.
+
+
+ Reads HTML form URL encoded data provided in the URI query string as an object of a specified type.
+ true if the query component of the URI can be read as the specified type; otherwise, false.
+ The URI to read.
+ The type of object to read.
+ When this method returns, contains an object that is initialized from the query component of the URI. This parameter is treated as uninitialized.
+
+
+ Reads HTML form URL encoded data provided in the URI query string as an object of a specified type.
+ true if the query component of the URI can be read as the specified type; otherwise, false.
+ The URI to read.
+ When this method returns, contains an object that is initialized from the query component of the URI. This parameter is treated as uninitialized.
+ The type of object to read.
+
+
+ Reads HTML form URL encoded data provided in the query component as a object.
+ true if the query component can be read as ; otherwise false.
+ The instance from which to read.
+ An object to be initialized with this instance or null if the conversion cannot be performed.
+
+
+ Abstract media type formatter class to support Bson and Json.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The instance to copy settings from.
+
+
+ Determines whether this formatter can read objects of the specified type.
+ true if objects of this type can be read, otherwise false.
+ The type of object that will be read.
+
+
+ Determines whether this formatter can write objects of the specified type.
+ true if objects of this type can be written, otherwise false.
+ The type of object to write.
+
+
+ Creates a instance with the default settings used by the .
+ Returns .
+
+
+ Called during deserialization to get the .
+ The reader to use during deserialization.
+ The type of the object to read.
+ The stream from which to read.
+ The encoding to use when reading.
+
+
+ Called during serialization and deserialization to get the .
+ The JsonSerializer used during serialization and deserialization.
+
+
+ Called during serialization to get the .
+ The writer to use during serialization.
+ The type of the object to write.
+ The stream to write to.
+ The encoding to use when writing.
+
+
+ Gets or sets the maximum depth allowed by this formatter.
+ The maximum depth allowed by this formatter.
+
+
+ Called during deserialization to read an object of the specified type from the specified stream.
+ The object that has been read.
+ The type of the object to read.
+ The stream from which to read.
+ The encoding to use when reading.
+ The logger to log events to.
+
+
+ Called during deserialization to read an object of the specified type from the specified stream.
+ A task whose result will be the object instance that has been read.
+ The type of the object to read.
+ The stream from which to read.
+ The for the content being read.
+ The logger to log events to.
+
+
+ Gets or sets the JsonSerializerSettings used to configure the JsonSerializer.
+ The JsonSerializerSettings used to configure the JsonSerializer.
+
+
+ Called during serialization to write an object of the specified type to the specified stream.
+ The type of the object to write.
+ The object to write.
+ The stream to write to.
+ The encoding to use when writing.
+
+
+ Called during serialization to write an object of the specified type to the specified stream.
+ Returns .
+ The type of the object to write.
+ The object to write.
+ The stream to write to.
+ The for the content being written.
+ The transport context.
+ The token to monitor for cancellation.
+
+
+ Represents a media type formatter to handle Bson.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The formatter to copy settings from.
+
+
+ Called during deserialization to get the .
+ The reader to use during deserialization.
+ The type of the object to read.
+ The stream from which to read.
+ The encoding to use when reading.
+
+
+ Called during serialization to get the .
+ The writer to use during serialization.
+ The type of the object to write.
+ The stream to write to.
+ The encoding to use when writing.
+
+
+ Gets the default media type for Json, namely "application/bson".
+ The default media type for Json, namely "application/bson".
+
+
+ Gets or sets the maximum depth allowed by this formatter.
+ The maximum depth allowed by this formatter.
+
+
+ Called during deserialization to read an object of the specified type from the specified stream.
+ The object that has been read.
+ The type of the object to read.
+ The stream from which to read.
+ The encoding to use when reading.
+ The logger to log events to.
+
+
+ Called during deserialization to read an object of the specified type from the specified stream.
+ A task whose result will be the object instance that has been read.
+ The type of the object to read.
+ The stream from which to read.
+ The for the content being read.
+ The logger to log events to.
+
+
+ Called during serialization to write an object of the specified type to the specified stream.
+ The type of the object to write.
+ The object to write.
+ The stream to write to.
+ The encoding to use when writing.
+
+
+ Represents a helper class to allow a synchronous formatter on top of the asynchronous formatter infrastructure.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The instance to copy settings from.
+
+
+ Gets or sets the suggested size of buffer to use with streams in bytes.
+ The suggested size of buffer to use with streams in bytes.
+
+
+ Reads synchronously from the buffered stream.
+ An object of the given .
+ The type of the object to deserialize.
+ The stream from which to read.
+ The , if available. Can be null.
+ The to log events to.
+
+
+ Reads synchronously from the buffered stream.
+ An object of the given .
+ The type of the object to deserialize.
+ The stream from which to read.
+ The , if available. Can be null.
+ The to log events to.
+ The token to cancel the operation.
+
+
+ Reads asynchronously from the buffered stream.
+ A task object representing the asynchronous operation.
+ The type of the object to deserialize.
+ The stream from which to read.
+ The , if available. Can be null.
+ The to log events to.
+
+
+ Reads asynchronously from the buffered stream.
+ A task object representing the asynchronous operation.
+ The type of the object to deserialize.
+ The stream from which to read.
+ The , if available. Can be null.
+ The to log events to.
+ The token to cancel the operation.
+
+
+ Writes synchronously to the buffered stream.
+ The type of the object to serialize.
+ The object value to write. Can be null.
+ The stream to which to write.
+ The , if available. Can be null.
+
+
+ Writes synchronously to the buffered stream.
+ The type of the object to serialize.
+ The object value to write. Can be null.
+ The stream to which to write.
+ The , if available. Can be null.
+ The token to cancel the operation.
+
+
+ Writes asynchronously to the buffered stream.
+ A task object representing the asynchronous operation.
+ The type of the object to serialize.
+ The object value to write. It may be null.
+ The stream to which to write.
+ The , if available. Can be null.
+ The transport context.
+
+
+ Writes asynchronously to the buffered stream.
+ A task object representing the asynchronous operation.
+ The type of the object to serialize.
+ The object value to write. It may be null.
+ The stream to which to write.
+ The , if available. Can be null.
+ The transport context.
+ The token to cancel the operation.
+
+
+ Represents the result of content negotiation performed using <see cref="M:System.Net.Http.Formatting.IContentNegotiator.Negotiate(System.Type,System.Net.Http.HttpRequestMessage,System.Collections.Generic.IEnumerable{System.Net.Http.Formatting.MediaTypeFormatter})" />
+
+
+ Create the content negotiation result object.
+ The formatter.
+ The preferred media type. Can be null.
+
+
+ The formatter chosen for serialization.
+
+
+ The media type that is associated with the formatter chosen for serialization. Can be null.
+
+
+ The default implementation of , which is used to select a for an or .
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ true to exclude formatters that match only on the object type; otherwise, false.
+
+
+ Determines how well each formatter matches an HTTP request.
+ Returns a collection of objects that represent all of the matches.
+ The type to be serialized.
+ The request.
+ The set of objects from which to choose.
+
+
+ If true, exclude formatters that match only on the object type; otherwise, false.
+ Returns a .
+
+
+ Matches a set of Accept header fields against the media types that a formatter supports.
+ Returns a object that indicates the quality of the match, or null if there is no match.
+ A list of Accept header values, sorted in descending order of q factor. You can create this list by calling the method.
+ The formatter to match against.
+
+
+ Matches a request against the objects in a media-type formatter.
+ Returns a object that indicates the quality of the match, or null if there is no match.
+ The request to match.
+ The media-type formatter.
+
+
+ Match the content type of a request against the media types that a formatter supports.
+ Returns a object that indicates the quality of the match, or null if there is no match.
+ The request to match.
+ The formatter to match against.
+
+
+ Selects the first supported media type of a formatter.
+ Returns a with set to MatchOnCanWriteType, or null if there is no match. A indicating the quality of the match or null is no match.
+ The type to match.
+ The formatter to match against.
+
+
+ Performs content negotiating by selecting the most appropriate out of the passed in for the given that can serialize an object of the given .
+ The result of the negotiation containing the most appropriate instance, or null if there is no appropriate formatter.
+ The type to be serialized.
+ The request.
+ The set of objects from which to choose.
+
+
+ Determines the best character encoding for writing the response.
+ Returns the that is the best match.
+ The request.
+ The selected media formatter.
+
+
+ Select the best match among the candidate matches found.
+ Returns the object that represents the best match.
+ The collection of matches.
+
+
+ Determine whether to match on type or not. This is used to determine whether to generate a 406 response or use the default media type formatter in case there is no match against anything in the request. If ExcludeMatchOnTypeOnly is true then we don't match on type unless there are no accept headers.
+ True if not ExcludeMatchOnTypeOnly and accept headers with a q-factor bigger than 0.0 are present.
+ The sorted accept header values to match.
+
+
+ Sorts Accept header values in descending order of q factor.
+ Returns the sorted list of MediaTypeWithQualityHeaderValue objects.
+ A collection of StringWithQualityHeaderValue objects, representing the header fields.
+
+
+ Sorts a list of Accept-Charset, Accept-Encoding, Accept-Language or related header values in descending order or q factor.
+ Returns the sorted list of StringWithQualityHeaderValue objects.
+ A collection of StringWithQualityHeaderValue objects, representing the header fields.
+
+
+ Evaluates whether a match is better than the current match.
+ Returns whichever object is a better match.
+ The current match.
+ The match to evaluate against the current match.
+
+
+ Helper class to serialize <see cref="T:System.Collections.Generic.IEnumerable`1" /> types by delegating them through a concrete implementation."/>.
+ The interface implementing to proxy.
+
+
+ Initialize a DelegatingEnumerable. This constructor is necessary for to work.
+
+
+ Initialize a DelegatingEnumerable with an <see cref="T:System.Collections.Generic.IEnumerable`1" />. This is a helper class to proxy <see cref="T:System.Collections.Generic.IEnumerable`1" /> interfaces for .
+ The <see cref="T:System.Collections.Generic.IEnumerable`1" /> instance to get the enumerator from.
+
+
+ This method is not implemented but is required method for serialization to work. Do not use.
+ The item to add. Unused.
+
+
+ Get the enumerator of the associated <see cref="T:System.Collections.Generic.IEnumerable`1" />.
+ The enumerator of the <see cref="T:System.Collections.Generic.IEnumerable`1" /> source.
+
+
+ Get the enumerator of the associated <see cref="T:System.Collections.Generic.IEnumerable`1" />.
+ The enumerator of the <see cref="T:System.Collections.Generic.IEnumerable`1" /> source.
+
+
+ Represent the collection of form data.
+
+
+ Initializes a new instance of class.
+ The pairs.
+
+
+ Initializes a new instance of class.
+ The query.
+
+
+ Initializes a new instance of class.
+ The URI
+
+
+ Gets the collection of form data.
+ The collection of form data.
+ The key.
+
+
+ Gets an enumerable that iterates through the collection.
+ The enumerable that iterates through the collection.
+
+
+ Gets the values of the collection of form data.
+ The values of the collection of form data.
+ The key.
+
+
+ Gets values associated with a given key. If there are multiple values, they're concatenated.
+ Values associated with a given key. If there are multiple values, they're concatenated.
+
+
+ Reads the collection of form data as a collection of name value.
+ The collection of form data as a collection of name value.
+
+
+ Gets an enumerable that iterates through the collection.
+ The enumerable that iterates through the collection.
+
+
+
+ class for handling HTML form URL-ended data, also known as application/x-www-form-urlencoded.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The instance to copy settings from.
+
+
+ Queries whether the can deserializean object of the specified type.
+ true if the can deserialize the type; otherwise, false.
+ The type to deserialize.
+
+
+ Queries whether the can serializean object of the specified type.
+ true if the can serialize the type; otherwise, false.
+ The type to serialize.
+
+
+ Gets the default media type for HTML form-URL-encoded data, which is application/x-www-form-urlencoded.
+ The default media type for HTML form-URL-encoded data
+
+
+ Gets or sets the maximum depth allowed by this formatter.
+ The maximum depth.
+
+
+ Gets or sets the size of the buffer when reading the incoming stream.
+ The buffer size.
+
+
+ Asynchronously deserializes an object of the specified type.
+ A whose result will be the object instance that has been read.
+ The type of object to deserialize.
+ The to read.
+ The for the content being read.
+ The to log events to.
+
+
+ Performs content negotiation. This is the process of selecting a response writer (formatter) in compliance with header values in the request.
+
+
+ Performs content negotiating by selecting the most appropriate out of the passed in formatters for the given request that can serialize an object of the given type.
+ The result of the negotiation containing the most appropriate instance, or null if there is no appropriate formatter.
+ The type to be serialized.
+ Request message, which contains the header values used to perform negotiation.
+ The set of objects from which to choose.
+
+
+ Specifies a callback interface that a formatter can use to log errors while reading.
+
+
+ Logs an error.
+ The path to the member for which the error is being logged.
+ The error message.
+
+
+ Logs an error.
+ The path to the member for which the error is being logged.
+ The error message to be logged.
+
+
+ Defines method that determines whether a given member is required on deserialization.
+
+
+ Determines whether a given member is required on deserialization.
+ true if should be treated as a required member; otherwise false.
+ The to be deserialized.
+
+
+ Represents the default used by . It uses the formatter's to select required members and recognizes the type annotation.
+
+
+ Initializes a new instance of the class.
+ The formatter to use for resolving required members.
+
+
+ Creates a property on the specified class by using the specified parameters.
+ A to create on the specified class by using the specified parameters.
+ The member info.
+ The member serialization.
+
+
+ Represents the class to handle JSON.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The instance to copy settings from.
+
+
+ Determines whether this can read objects of the specified .
+ true if objects of this can be read, otherwise false.
+ The type of object that will be read.
+
+
+ Determines whether this can write objects of the specified .
+ true if objects of this can be written, otherwise false.
+ The type of object that will be written.
+
+
+ Called during deserialization to get the .
+ The object used for serialization.
+ The type of object that will be serialized or deserialized.
+
+
+ Called during deserialization to get the .
+ The reader to use during deserialization.
+ The type of the object to read.
+ The stream from which to read.
+ The encoding to use when reading.
+
+
+ Called during serialization to get the .
+ The writer to use during serialization.
+ The type of the object to write.
+ The stream to write to.
+ The encoding to use when writing.
+
+
+ Gets the default media type for JSON, namely "application/json".
+ The for JSON.
+
+
+ Gets or sets a value indicating whether to indent elements when writing data.
+ true if to indent elements when writing data; otherwise, false.
+
+
+ Gets or sets the maximum depth allowed by this formatter.
+ The maximum depth allowed by this formatter.
+
+
+ Called during deserialization to read an object of the specified type from the specified stream.
+ The object that has been read.
+ The type of the object to read.
+ The stream from which to read.
+ The encoding to use when reading.
+ The logger to log events to.
+
+
+ Gets or sets a value indicating whether to use by default.
+ true if to by default; otherwise, false.
+
+
+ Called during serialization to write an object of the specified type to the specified stream.
+ The type of the object to write.
+ The object to write.
+ The stream to write to.
+ The encoding to use when writing.
+
+
+ Called during serialization to write an object of the specified type to the specified stream.
+ Returns .
+ The type of the object to write.
+ The object to write.
+ The stream to write to.
+ The for the content being written.
+ The transport context.
+ The token to monitor for cancellation.
+
+
+ Base class to handle serializing and deserializing strongly-typed objects using .
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The instance to copy settings from.
+
+
+ Queries whether this can deserializean object of the specified type.
+ true if the can deserialize the type; otherwise, false.
+ The type to deserialize.
+
+
+ Queries whether this can serializean object of the specified type.
+ true if the can serialize the type; otherwise, false.
+ The type to serialize.
+
+
+ Gets the default value for the specified type.
+ The default value.
+ The type for which to get the default value.
+
+
+ Returns a specialized instance of the that can format a response for the given parameters.
+ Returns .
+ The type to format.
+ The request.
+ The media type.
+
+
+ Gets or sets the maximum number of keys stored in a T: .
+ The maximum number of keys.
+
+
+ Gets the mutable collection of objects that match HTTP requests to media types.
+ The collection.
+
+
+ Asynchronously deserializes an object of the specified type.
+ A whose result will be an object of the given type.
+ The type of the object to deserialize.
+ The to read.
+ The , if available. It may be null.
+ The to log events to.
+ Derived types need to support reading.
+
+
+ Asynchronously deserializes an object of the specified type.
+ A whose result will be an object of the given type.
+ The type of the object to deserialize.
+ The to read.
+ The , if available. It may be null.
+ The to log events to.
+ The token to cancel the operation.
+
+
+ Gets or sets the instance used to determine required members.
+ The instance.
+
+
+ Determines the best character encoding for reading or writing an HTTP entity body, given a set of content headers.
+ The encoding that is the best match.
+ The content headers.
+
+
+ Sets the default headers for content that will be formatted using this formatter. This method is called from the constructor. This implementation sets the Content-Type header to the value of mediaType if it is not null. If it is null it sets the Content-Type to the default media type of this formatter. If the Content-Type does not specify a charset it will set it using this formatters configured .
+ The type of the object being serialized. See .
+ The content headers that should be configured.
+ The authoritative media type. Can be null.
+
+
+ Gets the mutable collection of character encodings supported bythis .
+ The collection of objects.
+
+
+ Gets the mutable collection of media types supported bythis .
+ The collection of objects.
+
+
+ Asynchronously writes an object of the specified type.
+ A that will perform the write.
+ The type of the object to write.
+ The object value to write. It may be null.
+ The to which to write.
+ The if available. It may be null.
+ The if available. It may be null.
+ Derived types need to support writing.
+
+
+ Asynchronously writes an object of the specified type.
+ A that will perform the write.
+ The type of the object to write.
+ The object value to write. It may be null.
+ The to which to write.
+ The if available. It may be null.
+ The if available. It may be null.
+ The token to cancel the operation.
+ Derived types need to support writing.
+
+
+ Collection class that contains instances.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ A collection of instances to place in the collection.
+
+
+ Adds the elements of the specified collection to the end of the .
+ The items that should be added to the end of the . The items collection itself cannot be , but it can contain elements that are .
+
+
+ Removes all items in the collection.
+
+
+ Helper to search a collection for a formatter that can read the .NET type in the given mediaType.
+ The formatter that can read the type. Null if no formatter found.
+ The .NET type to read
+ The media type to match on.
+
+
+ Helper to search a collection for a formatter that can write the .NET type in the given mediaType.
+ The formatter that can write the type. Null if no formatter found.
+ The .NET type to read
+ The media type to match on.
+
+
+ Gets the to use for application/x-www-form-urlencoded data.
+ The to use for application/x-www-form-urlencoded data.
+
+
+ Inserts the specified item at the specified index in the collection.
+ The index to insert at.
+ The item to insert.
+
+
+ Inserts the elements of a collection into the at the specified index.
+ The zero-based index at which the new elements should be inserted.
+ The items that should be inserted into the . The items collection itself cannot be , but it can contain elements that are .
+
+
+ Returns true if the type is one of those loosely defined types that should be excluded from validation.
+ true if the type should be excluded; otherwise, false.
+ The .NET to validate.
+
+
+ Gets the to use for JSON.
+ The to use for JSON.
+
+
+ Removes the item at the specified index.
+ The index of the item to remove.
+
+
+ Assigns the item at the specified index in the collection.
+ The index to insert at.
+ The item to assign.
+
+
+ Gets the to use for XML.
+ The to use for XML.
+
+
+
+
+
+
+ This class describes how well a particular matches a request.
+
+
+ Initializes a new instance of the class.
+ The matching formatter.
+ The media type. Can be null in which case the media type application/octet-stream is used.
+ The quality of the match. Can be null in which case it is considered a full match with a value of 1.0
+ The kind of match.
+
+
+ Gets the media type formatter.
+
+
+ Gets the matched media type.
+
+
+ Gets the quality of the match
+
+
+ Gets the kind of match that occurred.
+
+
+ Contains information about the degree to which a matches the explicit or implicit preferences found in an incoming request.
+
+
+ Matched on a type, meaning that the formatter is able to serialize the type.
+
+
+ Matched on an explicit “*/*” range in the Accept header.
+
+
+ Matched on an explicit literal accept header, such as “application/json”.
+
+
+ Matched on an explicit subtype range in an Accept header, such as “application/*”.
+
+
+ Matched on the media type of the entity body in the HTTP request message.
+
+
+ Matched on after having applied the various s.
+
+
+ No match was found
+
+
+ An abstract base class used to create an association between or instances that have certain characteristics and a specific .
+
+
+ Initializes a new instance of a with the given mediaType value.
+ The that is associated with or instances that have the given characteristics of the .
+
+
+ Initializes a new instance of a with the given mediaType value.
+ The that is associated with or instances that have the given characteristics of the .
+
+
+ Gets the that is associated with or instances that have the given characteristics of the .
+
+
+ Returns the quality of the match of the associated with request.
+ The quality of the match. It must be between 0.0 and 1.0. A value of 0.0 signifies no match. A value of 1.0 signifies a complete match.
+ The to evaluate for the characteristics associated with the of the .
+
+
+ Class that provides s from query strings.
+
+
+ Initializes a new instance of the class.
+ The name of the query string parameter to match, if present.
+ The value of the query string parameter specified by queryStringParameterName.
+ The to use if the query parameter specified by queryStringParameterName is present and assigned the value specified by queryStringParameterValue.
+
+
+ Initializes a new instance of the class.
+ The name of the query string parameter to match, if present.
+ The value of the query string parameter specified by queryStringParameterName.
+ The media type to use if the query parameter specified by queryStringParameterName is present and assigned the value specified by queryStringParameterValue.
+
+
+ Gets the query string parameter name.
+
+
+ Gets the query string parameter value.
+
+
+ Returns a value indicating whether the current instance can return a from request.
+ If this instance can produce a from request it returns 1.0 otherwise 0.0.
+ The to check.
+
+
+ This class provides a mapping from an arbitrary HTTP request header field to a used to select instances for handling the entity body of an or . <remarks>This class only checks header fields associated with for a match. It does not check header fields associated with or instances.</remarks>
+
+
+ Initializes a new instance of the class.
+ Name of the header to match.
+ The header value to match.
+ The to use when matching headerValue.
+ if set to true then headerValue is considered a match if it matches a substring of the actual header value.
+ The to use if headerName and headerValue is considered a match.
+
+
+ Initializes a new instance of the class.
+ Name of the header to match.
+ The header value to match.
+ The value comparison to use when matching headerValue.
+ if set to true then headerValue is considered a match if it matches a substring of the actual header value.
+ The media type to use if headerName and headerValue is considered a match.
+
+
+ Gets the name of the header to match.
+
+
+ Gets the header value to match.
+
+
+ Gets the to use when matching .
+
+
+ Gets a value indicating whether is a matched as a substring of the actual header value. this instance is value substring.
+ truefalse
+
+
+ Returns a value indicating whether the current instance can return a from request.
+ The quality of the match. It must be between 0.0 and 1.0. A value of 0.0 signifies no match. A value of 1.0 signifies a complete match.
+ The to check.
+
+
+ A that maps the X-Requested-With http header field set by AJAX XmlHttpRequest (XHR) to the media type application/json if no explicit Accept header fields are present in the request.
+
+
+ Initializes a new instance of class
+
+
+ Returns a value indicating whether the current instance can return a from request.
+ The quality of the match. A value of 0.0 signifies no match. A value of 1.0 signifies a complete match and that the request was made using XmlHttpRequest without an Accept header.
+ The to check.
+
+
+
+ class to handle Xml.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The instance to copy settings from.
+
+
+ Queries whether the can deserializean object of the specified type.
+ true if the can deserialize the type; otherwise, false.
+ The type to deserialize.
+
+
+ Queries whether the can serializean object of the specified type.
+ true if the can serialize the type; otherwise, false.
+ The type to serialize.
+
+
+ Called during deserialization to get the DataContractSerializer serializer.
+ The object used for serialization.
+ The type of object that will be serialized or deserialized.
+
+
+ Called during deserialization to get the XML reader to use for reading objects from the stream.
+ The to use for reading objects.
+ The to read from.
+ The for the content being read.
+
+
+ Called during deserialization to get the XML serializer.
+ The object used for serialization.
+ The type of object that will be serialized or deserialized.
+
+
+ Called during serialization to get the XML writer to use for writing objects to the stream.
+ The to use for writing objects.
+ The to write to.
+ The for the content being written.
+
+
+ Gets the default media type for the XML formatter.
+ The default media type, which is “application/xml”.
+
+
+ Called during deserialization to get the XML serializer to use for deserializing objects.
+ An instance of or to use for deserializing the object.
+ The type of object to deserialize.
+ The for the content being read.
+
+
+ Called during serialization to get the XML serializer to use for serializing objects.
+ An instance of or to use for serializing the object.
+ The type of object to serialize.
+ The object to serialize.
+ The for the content being written.
+
+
+ Gets or sets a value indicating whether to indent elements when writing data.
+ true to indent elements; otherwise, false.
+
+
+ This method is to support infrastructure and is not intended to be used directly from your code.
+ Returns .
+
+
+ This method is to support infrastructure and is not intended to be used directly from your code.
+ Returns .
+
+
+ This method is to support infrastructure and is not intended to be used directly from your code.
+ Returns .
+
+
+ This method is to support infrastructure and is not intended to be used directly from your code.
+ Returns .
+
+
+ Gets and sets the maximum nested node depth.
+ The maximum nested node depth.
+
+
+ Called during deserialization to read an object of the specified type from the specified readStream.
+ A whose result will be the object instance that has been read.
+ The type of object to read.
+ The from which to read.
+ The for the content being read.
+ The to log events to.
+
+
+ Unregisters the serializer currently associated with the given type.
+ true if a serializer was previously registered for the type; otherwise, false.
+ The type of object whose serializer should be removed.
+
+
+ Registers an to read or write objects of a specified type.
+ The instance.
+ The type of object that will be serialized or deserialized with.
+
+
+ Registers an to read or write objects of a specified type.
+ The type of object that will be serialized or deserialized with.
+ The instance.
+
+
+ Registers an to read or write objects of a specified type.
+ The type of object that will be serialized or deserialized with.
+ The instance.
+
+
+ Registers an to read or write objects of a specified type.
+ The instance.
+ The type of object that will be serialized or deserialized with.
+
+
+ Gets or sets a value indicating whether the XML formatter uses the as the default serializer, instead of using the .
+ If true, the formatter uses the by default; otherwise, it uses the by default.
+
+
+ Gets the settings to be used while writing.
+ The settings to be used while writing.
+
+
+ Called during serialization to write an object of the specified type to the specified writeStream.
+ A that will write the value to the stream.
+ The type of object to write.
+ The object to write.
+ The to which to write.
+ The for the content being written.
+ The .
+ The token to monitor cancellation.
+
+
+ Represents the event arguments for the HTTP progress.
+
+
+ Initializes a new instance of the class.
+ The percentage of the progress.
+ The user token.
+ The number of bytes transferred.
+ The total number of bytes transferred.
+
+
+
+
+ Generates progress notification for both request entities being uploaded and response entities being downloaded.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The inner message handler.
+
+
+ Occurs when event entities are being downloaded.
+
+
+ Occurs when event entities are being uploaded.
+
+
+ Raises the event that handles the request of the progress.
+ The request.
+ The event handler for the request.
+
+
+ Raises the event that handles the response of the progress.
+ The request.
+ The event handler for the request.
+
+
+ Sends the specified progress message to an HTTP server for delivery.
+ The sent progress message.
+ The request.
+ The cancellation token.
+
+
+ Provides value for the cookie header.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The value of the name.
+ The values.
+
+
+ Initializes a new instance of the class.
+ The value of the name.
+ The value.
+
+
+ Creates a shallow copy of the cookie value.
+ A shallow copy of the cookie value.
+
+
+ Gets a collection of cookies sent by the client.
+ A collection object representing the client’s cookie variables.
+
+
+ Gets or sets the domain to associate the cookie with.
+ The name of the domain to associate the cookie with.
+
+
+ Gets or sets the expiration date and time for the cookie.
+ The time of day (on the client) at which the cookie expires.
+
+
+ Gets or sets a value that specifies whether a cookie is accessible by client-side script.
+ true if the cookie has the HttpOnly attribute and cannot be accessed through a client-side script; otherwise, false.
+
+
+ Gets a shortcut to the cookie property.
+ The cookie value.
+
+
+ Gets or sets the maximum age permitted for a resource.
+ The maximum age permitted for a resource.
+
+
+ Gets or sets the virtual path to transmit with the current cookie.
+ The virtual path to transmit with the cookie.
+
+
+ Gets or sets a value indicating whether to transmit the cookie using Secure Sockets Layer (SSL)—that is, over HTTPS only.
+ true to transmit the cookie over an SSL connection (HTTPS); otherwise, false.
+
+
+ Returns a string that represents the current object.
+ A string that represents the current object.
+
+
+ Indicates a value whether the string representation will be converted.
+ true if the string representation will be converted; otherwise, false.
+ The input value.
+ The parsed value to convert.
+
+
+ Contains cookie name and its associated cookie state.
+
+
+ Initializes a new instance of the class.
+ The name of the cookie.
+
+
+ Initializes a new instance of the class.
+ The name of the cookie.
+ The collection of name-value pair for the cookie.
+
+
+ Initializes a new instance of the class.
+ The name of the cookie.
+ The value of the cookie.
+
+
+ Returns a new object that is a copy of the current instance.
+ A new object that is a copy of the current instance.
+
+
+ Gets or sets the cookie value with the specified cookie name, if the cookie data is structured.
+ The cookie value with the specified cookie name.
+
+
+ Gets or sets the name of the cookie.
+ The name of the cookie.
+
+
+ Returns the string representation the current object.
+ The string representation the current object.
+
+
+ Gets or sets the cookie value, if cookie data is a simple string value.
+ The value of the cookie.
+
+
+ Gets or sets the collection of name-value pair, if the cookie data is structured.
+ The collection of name-value pair for the cookie.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Cors.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Cors.dll
new file mode 100644
index 000000000..f17ca2040
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Cors.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Helpers.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Helpers.dll
new file mode 100644
index 000000000..b13e61360
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Helpers.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Helpers.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Helpers.xml
new file mode 100644
index 000000000..d5cfa6deb
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Helpers.xml
@@ -0,0 +1,839 @@
+
+
+
+ System.Web.Helpers
+
+
+
+ Displays data in the form of a graphical chart.
+
+
+ Initializes a new instance of the class.
+ The width, in pixels, of the complete chart image.
+ The height, in pixels, of the complete chart image.
+ (Optional) The template (theme) to apply to the chart.
+ (Optional) The template (theme) path and file name to apply to the chart.
+
+
+ Adds a legend to the chart.
+ The chart.
+ The text of the legend title.
+ The unique name of the legend.
+
+
+ Provides data points and series attributes for the chart.
+ The chart.
+ The unique name of the series.
+ The chart type of a series.
+ The name of the chart area that is used to plot the data series.
+ The axis label text for the series.
+ The name of the series that is associated with the legend.
+ The granularity of data point markers.
+ The values to plot along the x-axis.
+ The name of the field for x-values.
+ The values to plot along the y-axis.
+ A comma-separated list of name or names of the field or fields for y-values.
+
+
+ Adds a title to the chart.
+ The chart.
+ The title text.
+ The unique name of the title.
+
+
+ Binds a chart to a data table, where one series is created for each unique value in a column.
+ The chart.
+ The chart data source.
+ The name of the column that is used to group data into the series.
+ The name of the column for x-values.
+ A comma-separated list of names of the columns for y-values.
+ Other data point properties that can be bound.
+ The order in which the series will be sorted. The default is "Ascending".
+
+
+ Creates and binds series data to the specified data table, and optionally populates multiple x-values.
+ The chart.
+ The chart data source. This can be can be any object.
+ The name of the table column used for the series x-values.
+
+
+ Gets or sets the name of the file that contains the chart image.
+ The name of the file.
+
+
+ Returns a chart image as a byte array.
+ The chart.
+ The image format. The default is "jpeg".
+
+
+ Retrieves the specified chart from the cache.
+ The chart.
+ The ID of the cache item that contains the chart to retrieve. The key is set when you call the method.
+
+
+ Gets or sets the height, in pixels, of the chart image.
+ The chart height.
+
+
+ Saves a chart image to the specified file.
+ The chart.
+ The location and name of the image file.
+ The image file format, such as "png" or "jpeg".
+
+
+ Saves a chart in the system cache.
+ The ID of the cache item that contains the chart.
+ The ID of the chart in the cache.
+ The number of minutes to keep the chart image in the cache. The default is 20.
+ true to indicate that the chart cache item's expiration is reset each time the item is accessed, or false to indicate that the expiration is based on an absolute interval since the time that the item was added to the cache. The default is true.
+
+
+ Saves a chart as an XML file.
+ The chart.
+ The path and name of the XML file.
+
+
+ Sets values for the horizontal axis.
+ The chart.
+ The title of the x-axis.
+ The minimum value for the x-axis.
+ The maximum value for the x-axis.
+
+
+ Sets values for the vertical axis.
+ The chart.
+ The title of the y-axis.
+ The minimum value for the y-axis.
+ The maximum value for the y-axis.
+
+
+ Creates a object based on the current object.
+ The chart.
+ The format of the image to save the object as. The default is "jpeg". The parameter is not case sensitive.
+
+
+ Gets or set the width, in pixels, of the chart image.
+ The chart width.
+
+
+ Renders the output of the object as an image.
+ The chart.
+ The format of the image. The default is "jpeg".
+
+
+ Renders the output of a object that has been cached as an image.
+ The chart.
+ The ID of the chart in the cache.
+ The format of the image. The default is "jpeg".
+
+
+ Specifies visual themes for a object.
+
+
+ A theme for 2D charting that features a visual container with a blue gradient, rounded edges, drop-shadowing, and high-contrast gridlines.
+
+
+ A theme for 2D charting that features a visual container with a green gradient, rounded edges, drop-shadowing, and low-contrast gridlines.
+
+
+ A theme for 2D charting that features no visual container and no gridlines.
+
+
+ A theme for 3D charting that features no visual container, limited labeling and, sparse, high-contrast gridlines.
+
+
+ A theme for 2D charting that features a visual container that has a yellow gradient, rounded edges, drop-shadowing, and high-contrast gridlines.
+
+
+ Provides methods to generate hash values and encrypt passwords or other sensitive data.
+
+
+ Generates a cryptographically strong sequence of random byte values.
+ The generated salt value as a base-64-encoded string.
+ The number of cryptographically random bytes to generate.
+
+
+ Returns a hash value for the specified byte array.
+ The hash value for as a string of hexadecimal characters.
+ The data to provide a hash value for.
+ The algorithm that is used to generate the hash value. The default is "sha256".
+
+ is null.
+
+
+ Returns a hash value for the specified string.
+ The hash value for as a string of hexadecimal characters.
+ The data to provide a hash value for.
+ The algorithm that is used to generate the hash value. The default is "sha256".
+
+ is null.
+
+
+ Returns an RFC 2898 hash value for the specified password.
+ The hash value for as a base-64-encoded string.
+ The password to generate a hash value for.
+
+ is null.
+
+
+ Returns a SHA-1 hash value for the specified string.
+ The SHA-1 hash value for as a string of hexadecimal characters.
+ The data to provide a hash value for.
+
+ is null.
+
+
+ Returns a SHA-256 hash value for the specified string.
+ The SHA-256 hash value for as a string of hexadecimal characters.
+ The data to provide a hash value for.
+
+ is null.
+
+
+ Determines whether the specified RFC 2898 hash and password are a cryptographic match.
+ true if the hash value is a cryptographic match for the password; otherwise, false.
+ The previously-computed RFC 2898 hash value as a base-64-encoded string.
+ The plaintext password to cryptographically compare with .
+
+ or is null.
+
+
+ Represents a series of values as a JavaScript-like array by using the dynamic capabilities of the Dynamic Language Runtime (DLR).
+
+
+ Initializes a new instance of the class using the specified array element values.
+ An array of objects that contains the values to add to the instance.
+
+
+ Returns an enumerator that can be used to iterate through the elements of the instance.
+ An enumerator that can be used to iterate through the elements of the JSON array.
+
+
+ Returns the value at the specified index in the instance.
+ The value at the specified index.
+
+
+ Returns the number of elements in the instance.
+ The number of elements in the JSON array.
+
+
+ Converts a instance to an array of objects.
+ The array of objects that represents the JSON array.
+ The JSON array to convert.
+
+
+ Converts a instance to an array of objects.
+ The array of objects that represents the JSON array.
+ The JSON array to convert.
+
+
+ Returns an enumerator that can be used to iterate through a collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Converts the instance to a compatible type.
+ true if the conversion was successful; otherwise, false.
+ Provides information about the conversion operation.
+ When this method returns, contains the result of the type conversion operation. This parameter is passed uninitialized.
+
+
+ Tests the instance for dynamic members (which are not supported) in a way that does not cause an exception to be thrown.
+ true in all cases.
+ Provides information about the get operation.
+ When this method returns, contains null. This parameter is passed uninitialized.
+
+
+ Represents a collection of values as a JavaScript-like object by using the capabilities of the Dynamic Language Runtime.
+
+
+ Initializes a new instance of the class using the specified field values.
+ A dictionary of property names and values to add to the instance as dynamic members.
+
+
+ Returns a list that contains the name of all dynamic members (JSON fields) of the instance.
+ A list that contains the name of every dynamic member (JSON field).
+
+
+ Converts the instance to a compatible type.
+ true in all cases.
+ Provides information about the conversion operation.
+ When this method returns, contains the result of the type conversion operation. This parameter is passed uninitialized.
+ The instance could not be converted to the specified type.
+
+
+ Gets the value of a field using the specified index.
+ true in all cases.
+ Provides information about the indexed get operation.
+ An array that contains a single object that indexes the field by name. The object must be convertible to a string that specifies the name of the JSON field to return. If multiple indexes are specified, contains null when this method returns.
+ When this method returns, contains the value of the indexed field, or null if the get operation was unsuccessful. This parameter is passed uninitialized.
+
+
+ Gets the value of a field using the specified name.
+ true in all cases.
+ Provides information about the get operation.
+ When this method returns, contains the value of the field, or null if the get operation was unsuccessful. This parameter is passed uninitialized.
+
+
+ Sets the value of a field using the specified index.
+ true in all cases.
+ Provides information about the indexed set operation.
+ An array that contains a single object that indexes the field by name. The object must be convertible to a string that specifies the name of the JSON field to return. If multiple indexes are specified, no field is changed or added.
+ The value to set the field to.
+
+
+ Sets the value of a field using the specified name.
+ true in all cases.
+ Provides information about the set operation.
+ The value to set the field to.
+
+
+ Provides methods for working with data in JavaScript Object Notation (JSON) format.
+
+
+ Converts data in JavaScript Object Notation (JSON) format into the specified strongly typed data list.
+ The JSON-encoded data converted to a strongly typed list.
+ The JSON-encoded string to convert.
+ The type of the strongly typed list to convert JSON data into.
+
+
+ Converts data in JavaScript Object Notation (JSON) format into a data object.
+ The JSON-encoded data converted to a data object.
+ The JSON-encoded string to convert.
+
+
+ Converts data in JavaScript Object Notation (JSON) format into a data object of a specified type.
+ The JSON-encoded data converted to the specified type.
+ The JSON-encoded string to convert.
+ The type that the data should be converted to.
+
+
+ Converts a data object to a string that is in the JavaScript Object Notation (JSON) format.
+ Returns a string of data converted to the JSON format.
+ The data object to convert.
+
+
+ Converts a data object to a string in JavaScript Object Notation (JSON) format and adds the string to the specified object.
+ The data object to convert.
+ The object that contains the converted JSON data.
+
+
+ Renders the property names and values of the specified object and of any subobjects that it references.
+
+
+ Renders the property names and values of the specified object and of any subobjects.
+ For a simple variable, returns the type and the value. For an object that contains multiple items, returns the property name or key and the value for each property.
+ The object to render information for.
+ Optional. Specifies the depth of nested subobjects to render information for. The default is 10.
+ Optional. Specifies the maximum number of characters that the method displays for object values. The default is 1000.
+
+ is less than zero.
+
+ is less than or equal to zero.
+
+
+ Displays information about the web server environment that hosts the current web page.
+
+
+ Displays information about the web server environment.
+ A string of name-value pairs that contains information about the web server.
+
+
+ Specifies the direction in which to sort a list of items.
+
+
+ Sort from smallest to largest —for example, from 1 to 10.
+
+
+ Sort from largest to smallest — for example, from 10 to 1.
+
+
+ Provides a cache to store frequently accessed data.
+
+
+ Retrieves the specified item from the object.
+ The item retrieved from the cache, or null if the item is not found.
+ The identifier for the cache item to retrieve.
+
+
+ Removes the specified item from the object.
+ The item removed from the object. If the item is not found, returns null.
+ The identifier for the cache item to remove.
+
+
+ Inserts an item into the object.
+ The identifier for the cache item.
+ The data to insert into the cache.
+ Optional. The number of minutes to keep an item in the cache. The default is 20.
+ Optional. true to indicate that the cache item expiration is reset each time the item is accessed, or false to indicate that the expiration is based the absolute time since the item was added to the cache. The default is true. In that case, if you also use the default value for the parameter, a cached item expires 20 minutes after it was last accessed.
+ The value of is less than or equal to zero.
+ Sliding expiration is enabled and the value of is greater than a year.
+
+
+ Displays data on a web page using an HTML table element.
+
+
+ Initializes a new instance of the class.
+ The data to display.
+ A collection that contains the names of the data columns to display. By default, this value is auto-populated according to the values in the parameter.
+ The name of the data column that is used to sort the grid by default.
+ The number of rows that are displayed on each page of the grid when paging is enabled. The default is 10.
+ true to specify that paging is enabled for the instance; otherwise false. The default is true.
+ true to specify that sorting is enabled for the instance; otherwise, false. The default is true.
+ The value of the HTML id attribute that is used to mark the HTML element that gets dynamic Ajax updates that are associated with the instance.
+ The name of the JavaScript function that is called after the HTML element specified by the property has been updated. If the name of a function is not provided, no function will be called. If the specified function does not exist, a JavaScript error will occur if it is invoked.
+ The prefix that is applied to all query-string fields that are associated with the instance. This value is used in order to support multiple instances on the same web page.
+ The name of the query-string field that is used to specify the current page of the instance.
+ The name of the query-string field that is used to specify the currently selected row of the instance.
+ The name of the query-string field that is used to specify the name of the data column that the instance is sorted by.
+ The name of the query-string field that is used to specify the direction in which the instance is sorted.
+
+
+ Adds a specific sort function for a given column.
+ The current grid, with the new custom sorter applied.
+ The column name (as used for sorting)
+ The function used to select a key to sort by, for each element in the grid's source.
+ The type of elements in the grid's source.
+ The column type, usually inferred from the keySelector function's return type.
+
+
+ Gets the name of the JavaScript function to call after the HTML element that is associated with the instance has been updated in response to an Ajax update request.
+ The name of the function.
+
+
+ Gets the value of the HTML id attribute that marks an HTML element on the web page that gets dynamic Ajax updates that are associated with the instance.
+ The value of the id attribute.
+
+
+ Binds the specified data to the instance.
+ The bound and populated instance.
+ The data to display.
+ A collection that contains the names of the data columns to bind.
+ true to enable sorting and paging of the instance; otherwise, false.
+ The number of rows to display on each page of the grid.
+
+
+ Gets a value that indicates whether the instance supports sorting.
+ true if the instance supports sorting; otherwise, false.
+
+
+ Creates a new instance.
+ The new column.
+ The name of the data column to associate with the instance.
+ The text that is rendered in the header of the HTML table column that is associated with the instance.
+ The function that is used to format the data values that are associated with the instance.
+ A string that specifies the name of the CSS class that is used to style the HTML table cells that are associated with the instance.
+ true to enable sorting in the instance by the data values that are associated with the instance; otherwise, false. The default is true.
+
+
+ Gets a collection that contains the name of each data column that is bound to the instance.
+ The collection of data column names.
+
+
+ Returns an array that contains the specified instances.
+ An array of columns.
+ A variable number of column instances.
+
+
+ Gets the prefix that is applied to all query-string fields that are associated with the instance.
+ The query-string field prefix of the instance.
+
+
+ Returns a JavaScript statement that can be used to update the HTML element that is associated with the instance on the specified web page.
+ A JavaScript statement that can be used to update the HTML element in a web page that is associated with the instance.
+ The URL of the web page that contains the instance that is being updated. The URL can include query-string arguments.
+
+
+ Returns the HTML markup that is used to render the instance and using the specified paging options.
+ The HTML markup that represents the fully-populated instance.
+ The name of the CSS class that is used to style the whole table.
+ The name of the CSS class that is used to style the table header.
+ The name of the CSS class that is used to style the table footer.
+ The name of the CSS class that is used to style each table row.
+ The name of the CSS class that is used to style even-numbered table rows.
+ The name of the CSS class that is used to style the selected table row. (Only one row can be selected at a time.)
+ The table caption.
+ true to display the table header; otherwise, false. The default is true.
+ true to insert additional rows in the last page when there are insufficient data items to fill the last page; otherwise, false. The default is false. Additional rows are populated using the text specified by the parameter.
+ The text that is used to populate additional rows in a page when there are insufficient data items to fill the last page. The parameter must be set to true to display these additional rows.
+ A collection of instances that specify how each column is displayed. This includes which data column is associated with each grid column, and how to format the data values that each grid column contains.
+ A collection that contains the names of the data columns to exclude when the grid auto-populates columns.
+ A bitwise combination of the enumeration values that specify methods that are provided for moving between pages of the instance.
+ The text for the HTML link element that is used to link to the first page of the instance. The flag of the parameter must be set to display this page navigation element.
+ The text for the HTML link element that is used to link to previous page of the instance. The flag of the parameter must be set to display this page navigation element.
+ The text for the HTML link element that is used to link to the next page of the instance. The flag of the parameter must be set to display this page navigation element.
+ The text for the HTML link element that is used to link to the last page of the instance. The flag of the parameter must be set to display this page navigation element.
+ The number of numeric page links that are provided to nearby pages. The text of each numeric page link contains the page number. The flag of the parameter must be set to display these page navigation elements.
+ An object that represents a collection of attributes (names and values) to set for the HTML table element that represents the instance.
+
+
+ Returns a URL that can be used to display the specified data page of the instance.
+ A URL that can be used to display the specified data page of the grid.
+ The index of the page to display.
+
+
+ Returns a URL that can be used to sort the instance by the specified column.
+ A URL that can be used to sort the grid.
+ The name of the data column to sort by.
+
+
+ Gets a value that indicates whether a row in the instance is selected.
+ true if a row is currently selected; otherwise, false.
+
+
+ Returns a value that indicates whether the instance can use Ajax calls to refresh the display.
+ true if the instance supports Ajax calls; otherwise, false..
+
+
+ Gets the number of pages that the instance contains.
+ The page count.
+
+
+ Gets the full name of the query-string field that is used to specify the current page of the instance.
+ The full name of the query string field that is used to specify the current page of the grid.
+
+
+ Gets or sets the index of the current page of the instance.
+ The index of the current page.
+
+
+ Returns the HTML markup that is used to provide the specified paging support for the instance.
+ The HTML markup that provides paging support for the grid.
+ A bitwise combination of the enumeration values that specify the methods that are provided for moving between the pages of the grid. The default is the bitwise OR of the and flags.
+ The text for the HTML link element that navigates to the first page of the grid.
+ The text for the HTML link element that navigates to the previous page of the grid.
+ The text for the HTML link element that navigates to the next page of the grid.
+ The text for the HTML link element that navigates to the last page of the grid.
+ The number of numeric page links to display. The default is 5.
+
+
+ Gets a list that contains the rows that are on the current page of the instance after the grid has been sorted.
+ The list of rows.
+
+
+ Gets the number of rows that are displayed on each page of the instance.
+ The number of rows that are displayed on each page of the grid.
+
+
+ Gets or sets the index of the selected row relative to the current page of the instance.
+ The index of the selected row relative to the current page.
+
+
+ Gets the currently selected row of the instance.
+ The currently selected row.
+
+
+ Gets the full name of the query-string field that is used to specify the selected row of the instance.
+ The full name of the query string field that is used to specify the selected row of the grid.
+
+
+ Gets or sets the name of the data column that the instance is sorted by.
+ The name of the data column that is used to sort the grid.
+
+
+ Gets or sets the direction in which the instance is sorted.
+ The sort direction.
+
+
+ Gets the full name of the query-string field that is used to specify the sort direction of the instance.
+ The full name of the query string field that is used to specify the sort direction of the grid.
+
+
+ Gets the full name of the query-string field that is used to specify the name of the data column that the instance is sorted by.
+ The full name of the query-string field that is used to specify the name of the data column that the grid is sorted by.
+
+
+ Returns the HTML markup that is used to render the instance.
+ The HTML markup that represents the fully-populated instance.
+ The name of the CSS class that is used to style the whole table.
+ The name of the CSS class that is used to style the table header.
+ The name of the CSS class that is used to style the table footer.
+ The name of the CSS class that is used to style each table row.
+ The name of the CSS class that is used to style even-numbered table rows.
+ The name of the CSS class that is used use to style the selected table row.
+ The table caption.
+ true to display the table header; otherwise, false. The default is true.
+ true to insert additional rows in the last page when there are insufficient data items to fill the last page; otherwise, false. The default is false. Additional rows are populated using the text specified by the parameter.
+ The text that is used to populate additional rows in the last page when there are insufficient data items to fill the last page. The parameter must be set to true to display these additional rows.
+ A collection of instances that specify how each column is displayed. This includes which data column is associated with each grid column, and how to format the data values that each grid column contains.
+ A collection that contains the names of the data columns to exclude when the grid auto-populates columns.
+ A function that returns the HTML markup that is used to render the table footer.
+ An object that represents a collection of attributes (names and values) to set for the HTML table element that represents the instance.
+
+
+ Gets the total number of rows that the instance contains.
+ The total number of rows in the grid. This value includes all rows from every page, but does not include the additional rows inserted in the last page when there are insufficient data items to fill the last page.
+
+
+ Represents a column in a instance.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a value that indicates whether the column can be sorted.
+ true to indicate that the column can be sorted; otherwise, false.
+
+
+ Gets or sets the name of the data item that is associated with the column.
+ The name of the data item.
+
+
+ Gets or sets a function that is used to format the data item that is associated with the column.
+ The function that is used to format that data item that is associated with the column.
+
+
+ Gets or sets the text that is rendered in the header of the column.
+ The text that is rendered to the column header.
+
+
+ Gets or sets the CSS class attribute that is rendered as part of the HTML table cells that are associated with the column.
+ The CSS class attribute that is applied to cells that are associated with the column.
+
+
+ Specifies flags that describe the methods that are provided for moving between the pages of a instance.This enumeration has a attribute that allows a bitwise combination of its member values.
+
+
+ Indicates that all methods for moving between pages are provided.
+
+
+ Indicates that methods for moving directly to the first or last page are provided.
+
+
+ Indicates that methods for moving to the next or previous page are provided.
+
+
+ Indicates that methods for moving to a nearby page by using a page number are provided.
+
+
+ Represents a row in a instance.
+
+
+ Initializes a new instance of the class using the specified instance, row value, and index.
+ The instance that contains the row.
+ An object that contains a property member for each value in the row.
+ The index of the row.
+
+
+ Returns an enumerator that can be used to iterate through the values of the instance.
+ An enumerator that can be used to iterate through the values of the row.
+
+
+ Returns an HTML element (a link) that users can use to select the row.
+ The link that users can click to select the row.
+ The inner text of the link element. If is empty or null, "Select" is used.
+
+
+ Returns the URL that can be used to select the row.
+ The URL that is used to select a row.
+
+
+ Returns the value at the specified index in the instance.
+ The value at the specified index.
+ The zero-based index of the value in the row to return.
+
+ is less than 0 or greater than or equal to the number of values in the row.
+
+
+ Returns the value that has the specified name in the instance.
+ The specified value.
+ The name of the value in the row to return.
+
+ is Nothing or empty.
+
+ specifies a value that does not exist.
+
+
+ Returns an enumerator that can be used to iterate through a collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Returns a string that represents all of the values of the instance.
+ A string that represents the row's values.
+
+
+ Returns the value of a member that is described by the specified binder.
+ true if the value of the item was successfully retrieved; otherwise, false.
+ The getter of the bound property member.
+ When this method returns, contains an object that holds the value of the item described by . This parameter is passed uninitialized.
+
+
+ Gets an object that contains a property member for each value in the row.
+ An object that contains each value in the row as a property.
+
+
+ Gets the instance that the row belongs to.
+ The instance that contains the row.
+
+
+ Represents an object that lets you display and manage images in a web page.
+
+
+ Initializes a new instance of the class using a byte array to represent the image.
+ The image.
+
+
+ Initializes a new instance of the class using a stream to represent the image.
+ The image.
+
+
+ Initializes a new instance of the class using a path to represent the image location.
+ The path of the file that contains the image.
+
+
+ Adds a watermark image using a path to the watermark image.
+ The watermarked image.
+ The path of a file that contains the watermark image.
+ The width, in pixels, of the watermark image.
+ The height, in pixels, of the watermark image.
+ The horizontal alignment for watermark image. Values can be "Left", "Right", or "Center".
+ The vertical alignment for the watermark image. Values can be "Top", "Middle", or "Bottom".
+ The opacity for the watermark image, specified as a value between 0 and 100.
+ The size, in pixels, of the padding around the watermark image.
+
+
+ Adds a watermark image using the specified image object.
+ The watermarked image.
+ A object.
+ The width, in pixels, of the watermark image.
+ The height, in pixels, of the watermark image.
+ The horizontal alignment for watermark image. Values can be "Left", "Right", or "Center".
+ The vertical alignment for the watermark image. Values can be "Top", "Middle", or "Bottom".
+ The opacity for the watermark image, specified as a value between 0 and 100.
+ The size, in pixels, of the padding around the watermark image.
+
+
+ Adds watermark text to the image.
+ The watermarked image.
+ The text to use as a watermark.
+ The color of the watermark text.
+ The font size of the watermark text.
+ The font style of the watermark text.
+ The font type of the watermark text.
+ The horizontal alignment for watermark text. Values can be "Left", "Right", or "Center".
+ The vertical alignment for the watermark text. Values can be "Top", "Middle", or "Bottom".
+ The opacity for the watermark image, specified as a value between 0 and 100.
+ The size, in pixels, of the padding around the watermark text.
+
+
+ Copies the object.
+ The image.
+
+
+ Crops an image.
+ The cropped image.
+ The number of pixels to remove from the top.
+ The number of pixels to remove from the left.
+ The number of pixels to remove from the bottom.
+ The number of pixels to remove from the right.
+
+
+ Gets or sets the file name of the object.
+ The file name.
+
+
+ Flips an image horizontally.
+ The flipped image.
+
+
+ Flips an image vertically.
+ The flipped image.
+
+
+ Returns the image as a byte array.
+ The image.
+ The value of the object.
+
+
+ Returns an image that has been uploaded using the browser.
+ The image.
+ (Optional) The name of the file that has been posted. If no file name is specified, the first file that was uploaded is returned.
+
+
+ Gets the height, in pixels, of the image.
+ The height.
+
+
+ Gets the format of the image (for example, "jpeg" or "png").
+ The file format of the image.
+
+
+ Resizes an image.
+ The resized image.
+ The width, in pixels, of the object.
+ The height, in pixels, of the object.
+ true to preserve the aspect ratio of the image; otherwise, false.
+ true to prevent the enlargement of the image; otherwise, false.
+
+
+ Rotates an image to the left.
+ The rotated image.
+
+
+ Rotates an image to the right.
+ The rotated image.
+
+
+ Saves the image using the specified file name.
+ The image.
+ The path to save the image to.
+ The format to use when the image file is saved, such as "gif", or "png".
+ true to force the correct file-name extension to be used for the format that is specified in ; otherwise, false. If there is a mismatch between the file type and the specified file-name extension, and if is true, the correct extension will be appended to the file name. For example, a PNG file named Photograph.txt is saved using the name Photograph.txt.png.
+
+
+ Gets the width, in pixels, of the image.
+ The width.
+
+
+ Renders an image to the browser.
+ The image.
+ (Optional) The file format to use when the image is written.
+
+
+ Provides a way to construct and send an email message using Simple Mail Transfer Protocol (SMTP).
+
+
+ Gets or sets a value that indicates whether Secure Sockets Layer (SSL) is used to encrypt the connection when an email message is sent.
+ true if SSL is used to encrypt the connection; otherwise, false.
+
+
+ Gets or sets the email address of the sender.
+ The email address of the sender.
+
+
+ Gets or sets the password of the sender's email account.
+ The sender's password.
+
+
+ Sends the specified message to an SMTP server for delivery.
+ The email address of the recipient or recipients. Separate multiple recipients using a semicolon (;).
+ The subject line for the email message.
+ The body of the email message. If is true, HTML in the body is interpreted as markup.
+ (Optional) The email address of the message sender, or null to not specify a sender. The default value is null.
+ (Optional) The email addresses of additional recipients to send a copy of the message to, or null if there are no additional recipients. Separate multiple recipients using a semicolon (;). The default value is null.
+ (Optional) A collection of file names that specifies the files to attach to the email message, or null if there are no files to attach. The default value is null.
+ (Optional) true to specify that the email message body is in HTML format; false to indicate that the body is in plain-text format. The default value is true.
+ (Optional) A collection of headers to add to the normal SMTP headers included in this email message, or null to send no additional headers. The default value is null.
+ (Optional) The email addresses of additional recipients to send a "blind" copy of the message to, or null if there are no additional recipients. Separate multiple recipients using a semicolon (;). The default value is null.
+ (Optional) The encoding to use for the body of the message. Possible values are property values for the class, such as . The default value is null.
+ (Optional) The encoding to use for the header of the message. Possible values are property values for the class, such as . The default value is null.
+ (Optional) A value ("Normal", "Low", "High") that specifies the priority of the message. The default is "Normal".
+ (Optional) The email address that will be used when the recipient replies to the message. The default value is null, which indicates that the reply address is the value of the From property.
+
+
+ Gets or sets the port that is used for SMTP transactions.
+ The port that is used for SMTP transactions.
+
+
+ Gets or sets the name of the SMTP server that is used to transmit the email message.
+ The SMTP server.
+
+
+ Gets or sets a value that indicates whether the default credentials are sent with the requests.
+ true if credentials are sent with the email message; otherwise, false.
+
+
+ Gets or sets the name of email account that is used to send email.
+ The name of the user account.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Cors.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Cors.dll
new file mode 100644
index 000000000..7ff4759a5
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Cors.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Cors.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Cors.xml
new file mode 100644
index 000000000..d50c99f3c
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Cors.xml
@@ -0,0 +1,179 @@
+
+
+
+ System.Web.Http.Cors
+
+
+
+ CORS-related extension methods for .
+
+
+ Enables the support for CORS.
+ The .
+
+
+ Enables the support for CORS.
+ The .
+ The default .
+ httpConfiguration
+
+
+ Gets the from the .
+ The .
+ The .
+ httpConfiguration
+
+
+ Gets the from the .
+ The .
+ The .
+ httpConfiguration
+
+
+ Sets the on the .
+ The .
+ The .
+ httpConfiguration or corsEngine
+
+
+ Sets the on the .
+ The .
+ The .
+ httpConfiguration or corsPolicyProviderFactory
+
+
+ An implementation of that returns the from the controller or action attribute.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the default .
+ The default .
+
+
+ Gets the for the request.
+ The .
+ The request.
+ request
+
+
+ CORS-related extension methods for .
+
+
+ Gets the for a given request.
+ The .
+ The .
+ request
+
+
+ CORS-related extension methods for .
+
+
+ Writes the CORS headers on the response.
+ The .
+ The .
+ response or corsResult
+
+
+ Custom for handling CORS requests.
+
+
+ Initializes a new instance of the class.
+ The .
+ httpConfiguration
+
+
+ Handles the preflight request specified by CORS.
+ The
+ The request.
+ The cors request context.
+ The cancellation token.
+ request or corsRequestContext
+
+
+ Handles the actual CORS request.
+ The .
+ The .
+ The .
+ The .
+ request or corsRequestContext
+
+
+ Sends an HTTP request to the inner handler to send to the server as an asynchronous operation.
+ Returns . The task object representing the asynchronous operation.
+ The HTTP request message to send to the server.
+ A cancellation token to cancel operation.
+
+
+ This class defines an attribute that can be applied to an action or a controller to disable CORS.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the CORS policy asynchronously.
+ The newly created task for this operation.
+ The request.
+ The cancellation token assigned for this task.
+
+
+ This class defines an attribute that can be applied to an action or a controller to enable CORS. By default, it allows all origins, methods and headers.
+
+
+ Initializes a new instance of the class.
+ Comma-separated list of origins that are allowed to access the resource. Use "*" to allow all.
+ Comma-separated list of headers that are supported by the resource. Use "*" to allow all. Use null or empty string to allow none.
+ Comma-separated list of methods that are supported by the resource. Use "*" to allow all. Use null or empty string to allow none.
+
+
+ Initializes a new instance of the class.
+ Comma-separated list of origins that are allowed to access the resource. Use "*" to allow all.
+ Comma-separated list of headers that are supported by the resource. Use "*" to allow all. Use null or empty string to allow none.
+ Comma-separated list of methods that are supported by the resource. Use "*" to allow all. Use null or empty string to allow none.
+ Comma-separated list of headers that the resource might use and can be exposed. Use null or empty string to expose none.
+
+
+ Gets the headers that the resource might use and can be exposed.
+
+
+
+ Gets the headers that are supported by the resource.
+
+
+ Gets the methods that are supported by the resource.
+
+
+ Gets the origins that are allowed to access the resource.
+
+
+ Gets or sets the number of seconds the results of a preflight request can be cached.
+
+
+ Gets or sets a value indicating whether the resource supports user credentials in the request.
+
+
+ Provides an abstraction for getting the .
+
+
+ Gets the .
+ The .
+ The request.
+ The cancellation token.
+
+
+ Provides an abstraction for getting the .
+
+
+ Gets the for the request.
+ The .
+ The request.
+
+
+ Category names traced by the default CORS tracing implementation.
+
+
+ The trace category for CORS-related events.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Owin.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Owin.dll
new file mode 100644
index 000000000..a6c3dfd5c
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Owin.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Owin.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Owin.xml
new file mode 100644
index 000000000..354d754f9
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.Owin.xml
@@ -0,0 +1,195 @@
+
+
+
+ System.Web.Http.Owin
+
+
+
+ Provides extension methods for the class.
+
+
+ Gets the OWIN context for the specified request.
+ The OWIN environment for the specified context, if available; otherwise .
+ The HTTP request message.
+
+
+ Gets the OWIN environment for the specified request.
+ The OWIN environment for the specified request, if available; otherwise .
+ The HTTP request message.
+
+
+ Sets the OWIN context for the specified request.
+ The HTTP request message.
+ The OWIN context to set.
+
+
+ Sets the OWIN environment for the specified request.
+ The HTTP request message.
+ The OWIN environment to set.
+
+
+ Represents an authentication attribute that authenticates via OWIN middleware.
+
+
+ Initializes a new instance of the class.
+ The authentication type of the OWIN middleware to use.
+
+
+
+
+ Gets the authentication type of the OWIN middleware to use.
+
+
+
+ Represents an authentication filter that authenticates via OWIN middleware.
+
+
+ Initializes a new instance of the class.
+ The authentication type of the OWIN middleware to use.
+
+
+ Gets a value indicating whether the filter allows multiple authentication.
+ true if the filter allows multiple authentication; otherwise, false.
+
+
+ Asynchronously authenticates the request.
+ The task that completes the authentication.
+ The authentication context.
+ The cancellation token.
+
+
+ Gets the authentication type of the OWIN middleware to use.
+ The authentication type of the OWIN middleware to use.
+
+
+ Asynchronously challenges an authentication.
+ The task that completes the challenge.
+ The context.
+ The cancellation token.
+
+
+ Provides extension methods for the class.
+
+
+ Enables suppression of the host's default authentication.
+ The server configuration.
+
+
+ Represents an OWIN component that submits requests to an when invoked.
+
+
+ Initializes a new instance of the class.
+ The next component in the pipeline.
+ The to submit requests to.
+ The that determines whether or not to buffer requests and responses.
+
+
+ Initializes a new instance of the class.
+ The next component in the pipeline.
+ The options to configure this adapter.
+
+
+ Gets the cancellation token that triggers cleanup of this component.
+ The cancellation token.
+
+
+ Gets the that determines whether or not to buffer requests and responses.
+ The that determines whether or not to buffer requests and responses.
+
+
+ Releases all resources used by the current instance of the class.
+
+
+ Releases unmanaged and optionally managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Gets the to use to process unhandled exceptions.
+ The to use to process unhandled exceptions.
+
+
+ Gets the to use to log unhandled exceptions.
+ The to use to log unhandled exceptions.
+
+
+ Returns .
+
+
+ Gets the to submit requests to.
+ The to submit requests to.
+
+
+ Represents the options for configuring an .
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the that triggers cleanup of the .
+ The that triggers cleanup of the .
+
+
+ Gets or sets the that determines whether or not to buffer requests and responses.
+ The that determines whether or not to buffer requests and responses.
+
+
+ Gets or sets the to use to process unhandled exceptions.
+ The to use to process unhandled exceptions.
+
+
+ Gets or sets the to use to log unhandled exceptions.
+ The to use to log unhandled exceptions.
+
+
+ Gets or sets the to submit requests to.
+ The to submit requests to.
+
+
+ Provides the default implementation of used by the OWIN Web API adapter.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the host should buffer the HttpRequestMessage entity body.
+ true if buffering should be used; otherwise a streamed request should be used.
+ The host context.
+
+
+ Determines whether the host should buffer the HttpResponseMessage entity body.
+ true if buffering should be used; otherwise a streamed response should be used.
+ The response.
+
+
+ Provides the catch blocks used within this assembly.
+
+
+ Gets the catch block in System.Web.Http.Owin.HttpMessageHandlerAdapter.BufferContent.
+ The catch block in System.Web.Http.Owin.HttpMessageHandlerAdapter.BufferContent.
+
+
+ Gets the catch block in System.Web.Http.Owin.HttpMessageHandlerAdapter.BufferError.
+ The catch block in System.Web.Http.Owin.HttpMessageHandlerAdapter.BufferError.
+
+
+ Gets the catch block in System.Web.Http.Owin.HttpMessageHandlerAdapter.ComputeContentLength.
+ The catch block in System.Web.Http.Owin.HttpMessageHandlerAdapter.ComputeContentLength.
+
+
+ Gets the catch block in System.Web.Http.Owin.HttpMessageHandlerAdapter.StreamContent.
+ The catch block in System.Web.Http.Owin.HttpMessageHandlerAdapter.StreamContent.
+
+
+ Represents a message handler that treats all OWIN authentication middleware as passive.
+
+
+ Initializes a new instance of the class.
+
+
+ Asynchronously sends a message request.
+ The task that completes the asynchronous operation.
+ The message request.
+ The cancellation token.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.WebHost.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.WebHost.dll
new file mode 100644
index 000000000..4f2b581e4
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.WebHost.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.WebHost.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.WebHost.xml
new file mode 100644
index 000000000..89aabcce6
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.WebHost.xml
@@ -0,0 +1,135 @@
+
+
+
+ System.Web.Http.WebHost
+
+
+
+ Provides a global for ASP.NET applications.
+
+
+
+
+
+ Gets the global .
+
+
+ Extension methods for
+
+
+ Maps the specified route template.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+
+
+ Maps the specified route template and sets default route.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+ An object that contains default route values.
+
+
+ Maps the specified route template and sets default route values and constraints.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+ An object that contains default route values.
+ A set of expressions that specify values for routeTemplate.
+
+
+ Maps the specified route template and sets default route values, constraints, and end-point message handler.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+ An object that contains default route values.
+ A set of expressions that specify values for routeTemplate.
+ The handler to which the request will be dispatched.
+
+
+ A that passes ASP.NET requests into the pipeline and write the result back.
+
+
+ Initializes a new instance of the class.
+ The route data.
+
+
+ Initializes a new instance of the class.
+ The route data.
+ The message handler to dispatch requests to.
+
+
+ Provides code that handles an asynchronous task
+ The asynchronous task.
+ The HTTP context.
+
+
+ A that returns instances of that can pass requests to a given instance.
+
+
+ Initializes a new instance of the class.
+
+
+ Provides the object that processes the request.
+ An object that processes the request.
+ An object that encapsulates information about the request.
+
+
+ Gets the singleton instance.
+
+
+ Provides the object that processes the request.
+ An object that processes the request.
+ An object that encapsulates information about the request.
+
+
+ Provides a registration point for the simple membership pre-application start code.
+
+
+ Registers the simple membership pre-application start code.
+
+
+ Represents the web host buffer policy selector.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a value that indicates whether the host should buffer the entity body of the HTTP request.
+ true if buffering should be used; otherwise a streamed request should be used.
+ The host context.
+
+
+ Uses a buffered output stream for the web host.
+ A buffered output stream.
+ The response.
+
+
+ Provides the catch blocks used within this assembly.
+
+
+ Gets the label for the catch block in System.Web.Http.WebHost.HttpControllerHandler.WriteBufferedResponseContentAsync.
+ The label for the catch block in System.Web.Http.WebHost.HttpControllerHandler.WriteBufferedResponseContentAsync.
+
+
+ Gets the label for the catch block in System.Web.Http.WebHost.HttpControllerHandler.WriteErrorResponseContentAsync.
+ The label for the catch block in System.Web.Http.WebHost.HttpControllerHandler.WriteErrorResponseContentAsync.
+
+
+ Gets the label for the catch block in System.Web.Http.WebHost.HttpControllerHandler.ComputeContentLength.
+ The label for the catch block in System.Web.Http.WebHost.HttpControllerHandler.ComputeContentLength.
+
+
+ Gets the label for the catch block in System.Web.Http.WebHost.HttpControllerHandler.WriteStreamedResponseContentAsync.
+ The label for the catch block in System.Web.Http.WebHost.HttpControllerHandler.WriteStreamedResponseContentAsync.
+
+
+ Gets the label for the catch block in System.Web.Http.WebHost.WebHostExceptionCatchBlocks.HttpWebRoute.GetRouteData.
+ The catch block in System.Web.Http.WebHost.WebHostExceptionCatchBlocks.HttpWebRoute.GetRouteData.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.dll
new file mode 100644
index 000000000..e1dbdd182
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.xml
new file mode 100644
index 000000000..365dd7b93
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Http.xml
@@ -0,0 +1,6664 @@
+
+
+
+ System.Web.Http
+
+
+
+
+ Creates an that represents an exception.
+ The request must be associated with an instance.An whose content is a serialized representation of an instance.
+ The HTTP request.
+ The status code of the response.
+ The exception.
+
+
+ Creates an that represents an error message.
+ The request must be associated with an instance.An whose content is a serialized representation of an instance.
+ The HTTP request.
+ The status code of the response.
+ The error message.
+
+
+ Creates an that represents an exception with an error message.
+ The request must be associated with an instance.An whose content is a serialized representation of an instance.
+ The HTTP request.
+ The status code of the response.
+ The error message.
+ The exception.
+
+
+ Creates an that represents an error.
+ The request must be associated with an instance.An whose content is a serialized representation of an instance.
+ The HTTP request.
+ The status code of the response.
+ The HTTP error.
+
+
+ Creates an that represents an error in the model state.
+ The request must be associated with an instance.An whose content is a serialized representation of an instance.
+ The HTTP request.
+ The status code of the response.
+ The model state.
+
+
+ Creates an wired up to the associated .
+ An initialized wired up to the associated .
+ The HTTP request message which led to this response message.
+ The HTTP response status code.
+ The content of the HTTP response message.
+ The type of the HTTP response message.
+
+
+ Creates an wired up to the associated .
+ An initialized wired up to the associated .
+ The HTTP request message which led to this response message.
+ The HTTP response status code.
+ The content of the HTTP response message.
+ The media type formatter.
+ The type of the HTTP response message.
+
+
+ Creates an wired up to the associated .
+ An initialized wired up to the associated .
+ The HTTP request message which led to this response message.
+ The HTTP response status code.
+ The content of the HTTP response message.
+ The media type formatter.
+ The media type header value.
+ The type of the HTTP response message.
+
+
+ Creates an wired up to the associated .
+ An initialized wired up to the associated .
+ The HTTP request message which led to this response message.
+ The HTTP response status code.
+ The content of the HTTP response message.
+ The media type formatter.
+ The media type.
+ The type of the HTTP response message.
+
+
+ Creates an wired up to the associated .
+ An initialized wired up to the associated .
+ The HTTP request message which led to this response message.
+ The HTTP response status code.
+ The content of the HTTP response message.
+ The media type header value.
+ The type of the HTTP response message.
+
+
+ Creates an wired up to the associated .
+ An initialized wired up to the associated .
+ The HTTP request message which led to this response message.
+ The HTTP response status code.
+ The content of the HTTP response message.
+ The media type.
+ The type of the HTTP response message.
+
+
+ Creates an wired up to the associated .
+ An initialized wired up to the associated .
+ The HTTP request message which led to this response message.
+ The HTTP response status code.
+ The content of the HTTP response message.
+ The HTTP configuration which contains the dependency resolver used to resolve services.
+ The type of the HTTP response message.
+
+
+
+
+
+ Disposes of all tracked resources associated with the which were added via the method.
+ The HTTP request.
+
+
+
+ Gets the current X.509 certificate from the given HTTP request.
+ The current , or null if a certificate is not available.
+ The HTTP request.
+
+
+ Retrieves the for the given request.
+ The for the given request.
+ The HTTP request.
+
+
+ Retrieves the which has been assigned as the correlation ID associated with the given . The value will be created and set the first time this method is called.
+ The object that represents the correlation ID associated with the request.
+ The HTTP request.
+
+
+ Retrieves the for the given request or null if not available.
+ The for the given request or null if not available.
+ The HTTP request.
+
+
+ Gets the parsed query string as a collection of key-value pairs.
+ The query string as a collection of key-value pairs.
+ The HTTP request.
+
+
+
+
+ Retrieves the for the given request or null if not available.
+ The for the given request or null if not available.
+ The HTTP request.
+
+
+ Retrieves the for the given request or null if not available.
+ The for the given request or null if not available.
+ The HTTP request.
+
+
+ Gets a instance for an HTTP request.
+ A instance that is initialized for the specified HTTP request.
+ The HTTP request.
+
+
+
+
+
+ Adds the given to a list of resources that will be disposed by a host once the is disposed.
+ The HTTP request controlling the lifecycle of .
+ The resource to dispose when is being disposed.
+
+
+
+
+
+
+ Represents the message extensions for the HTTP response from an ASP.NET operation.
+
+
+ Attempts to retrieve the value of the content for the .
+ The result of the retrieval of value of the content.
+ The response of the operation.
+ The value of the content.
+ The type of the value to retrieve.
+
+
+ Represents extensions for adding items to a .
+
+
+
+
+ Provides s from path extensions appearing in a .
+
+
+ Initializes a new instance of the class.
+ The extension corresponding to mediaType. This value should not include a dot or wildcards.
+ The that will be returned if uriPathExtension is matched.
+
+
+ Initializes a new instance of the class.
+ The extension corresponding to mediaType. This value should not include a dot or wildcards.
+ The media type that will be returned if uriPathExtension is matched.
+
+
+ Returns a value indicating whether this instance can provide a for the of request.
+ If this instance can match a file extension in request it returns 1.0 otherwise 0.0.
+ The to check.
+
+
+ Gets the path extension.
+ The path extension.
+
+
+ The path extension key.
+
+
+ Represents an attribute that specifies which HTTP methods an action method will respond to.
+
+
+ Initializes a new instance of the class by using the action method it will respond to.
+ The HTTP method that the action method will respond to.
+
+
+ Initializes a new instance of the class by using a list of HTTP methods that the action method will respond to.
+ The HTTP methods that the action method will respond to.
+
+
+ Gets or sets the list of HTTP methods that the action method will respond to.
+ Gets or sets the list of HTTP methods that the action method will respond to.
+
+
+ Represents an attribute that is used for the name of an action.
+
+
+ Initializes a new instance of the class.
+ The name of the action.
+
+
+ Gets or sets the name of the action.
+ The name of the action.
+
+
+ Specifies that actions and controllers are skipped by during authorization.
+
+
+ Initializes a new instance of the class.
+
+
+ Defines properties and methods for API controller.
+
+
+
+ Gets the action context.
+ The action context.
+
+
+ Creates a .
+ A .
+
+
+ Creates an (400 Bad Request) with the specified error message.
+ An with the specified model state.
+ The user-visible error message.
+
+
+ Creates an with the specified model state.
+ An with the specified model state.
+ The model state to include in the error.
+
+
+ Gets the of the current .
+ The of the current .
+
+
+ Creates a (409 Conflict).
+ A .
+
+
+ Creates a <see cref="T:System.Web.Http.NegotiatedContentResult`1" /> with the specified values.
+ A <see cref="T:System.Web.Http.NegotiatedContentResult`1" /> with the specified values.
+ The HTTP status code for the response message.
+ The content value to negotiate and format in the entity body.
+ The type of content in the entity body.
+
+
+ Creates a <see cref="T:System.Web.Http.FormattedContentResult`1" /> with the specified values.
+ A <see cref="T:System.Web.Http.FormattedContentResult`1" /> with the specified values.
+ The HTTP status code for the response message.
+ The content value to format in the entity body.
+ The formatter to use to format the content.
+ The type of content in the entity body.
+
+
+ Creates a <see cref="T:System.Web.Http.FormattedContentResult`1" /> with the specified values.
+ A <see cref="T:System.Web.Http.FormattedContentResult`1" /> with the specified values.
+ The HTTP status code for the response message.
+ The content value to format in the entity body.
+ The formatter to use to format the content.
+ The value for the Content-Type header, or <see langword="null" /> to have the formatter pick a default value.
+ The type of content in the entity body.
+
+
+ Creates a <see cref="T:System.Web.Http.FormattedContentResult`1" /> with the specified values.
+ A <see cref="T:System.Web.Http.FormattedContentResult`1" /> with the specified values.
+ The HTTP status code for the response message.
+ The content value to format in the entity body.
+ The formatter to use to format the content.
+ The value for the Content-Type header.
+ The type of content in the entity body.
+
+
+ Gets the of the current .
+ The of the current .
+
+
+ Creates a (201 Created) with the specified values.
+ A with the specified values.
+ The location at which the content has been created.
+ The content value to negotiate and format in the entity body.
+ The type of content in the entity body.
+
+
+ Creates a (201 Created) with the specified values.
+ A with the specified values.
+ The location at which the content has been created.
+ The content value to negotiate and format in the entity body.
+ The type of content in the entity body.
+
+
+ Creates a (201 Created) with the specified values.
+ A with the specified values.
+ The name of the route to use for generating the URL.
+ The route data to use for generating the URL.
+ The content value to negotiate and format in the entity body.
+ The type of content in the entity body.
+
+
+ Creates a (201 Created) with the specified values.
+ A with the specified values.
+ The name of the route to use for generating the URL.
+ The route data to use for generating the URL.
+ The content value to negotiate and format in the entity body.
+ The type of content in the entity body.
+
+
+ Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
+
+
+ Releases the unmanaged resources that are used by the object and, optionally, releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Executes asynchronously a single HTTP operation.
+ The newly started task.
+ The controller context for a single HTTP operation.
+ The cancellation token assigned for the HTTP operation.
+
+
+ Initializes the instance with the specified controllerContext.
+ The object that is used for the initialization.
+
+
+ Creates an (500 Internal Server Error).
+ A .
+
+
+ Creates an (500 Internal Server Error) with the specified exception.
+ An with the specified exception.
+ The exception to include in the error.
+
+
+ Creates a (200 OK) with the specified value.
+ A with the specified value.
+ The content value to serialize in the entity body.
+ The type of content in the entity body.
+
+
+ Creates a (200 OK) with the specified values.
+ A with the specified values.
+ The content value to serialize in the entity body.
+ The serializer settings.
+ The type of content in the entity body.
+
+
+ Creates a (200 OK) with the specified values.
+ A with the specified values.
+ The content value to serialize in the entity body.
+ The serializer settings.
+ The content encoding.
+ The type of content in the entity body.
+
+
+ Gets the model state after the model binding process.
+ The model state after the model binding process.
+
+
+ Creates a .
+ A .
+
+
+ Creates an (200 OK).
+ An .
+
+
+ Creates an with the specified values.
+ An with the specified values.
+ The content value to negotiate and format in the entity body.
+ The type of content in the entity body.
+
+
+ Creates a redirect result (302 Found) with the specified value.
+ A redirect result (302 Found) with the specified value.
+ The location to redirect to.
+
+
+ Creates a redirect result (302 Found) with the specified value.
+ A redirect result (302 Found) with the specified value.
+ The location to redirect to.
+
+
+ Creates a redirect to route result (302 Found) with the specified values.
+ A redirect to route result (302 Found) with the specified values.
+ The name of the route to use for generating the URL.
+ The route data to use for generating the URL.
+
+
+ Creates a redirect to route result (302 Found) with the specified values.
+ A redirect to route result (302 Found) with the specified values.
+ The name of the route to use for generating the URL.
+ The route data to use for generating the URL.
+
+
+ Gets or sets the HttpRequestMessage of the current .
+ The HttpRequestMessage of the current .
+
+
+ Gets the request context.
+ The request context.
+
+
+ Creates a with the specified response.
+ A for the specified response.
+ The HTTP response message.
+
+
+ Creates a with the specified status code.
+ A with the specified status code.
+ The HTTP status code for the response message
+
+
+ Creates an (401 Unauthorized) with the specified values.
+ An with the specified values.
+ The WWW-Authenticate challenges.
+
+
+ Creates an (401 Unauthorized) with the specified values.
+ An with the specified values.
+ The WWW-Authenticate challenges.
+
+
+ Gets an instance of a , which is used to generate URLs to other APIs.
+ A , which is used to generate URLs to other APIs.
+
+
+ Returns the current principal associated with this request.
+ The current principal associated with this request.
+
+
+ Validates the given entity and adds the validation errors to the model state under the empty prefix, if any.
+ The entity being validated.
+ The type of the entity to be validated.
+
+
+ Validates the given entity and adds the validation errors to the model state, if any.
+ The entity being validated.
+ The key prefix under which the model state errors would be added in the model state.
+ The type of the entity to be validated.
+
+
+ Specifies the authorization filter that verifies the request's .
+
+
+ Initializes a new instance of the class.
+
+
+ Processes requests that fail authorization.
+ The context.
+
+
+ Indicates whether the specified control is authorized.
+ true if the control is authorized; otherwise, false.
+ The context.
+
+
+ Calls when an action is being authorized.
+ The context.
+ The context parameter is null.
+
+
+ Gets or sets the authorized roles.
+ The roles string.
+
+
+ Gets a unique identifier for this attribute.
+ A unique identifier for this attribute.
+
+
+ Gets or sets the authorized users.
+ The users string.
+
+
+ An attribute that specifies that an action parameter comes only from the entity body of the incoming .
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a parameter binding.
+ The parameter binding.
+ The parameter description.
+
+
+ An attribute that specifies that an action parameter comes from the URI of the incoming .
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the value provider factories for the model binder.
+ A collection of objects.
+ The configuration.
+
+
+ Represents attributes that specifies that HTTP binding should exclude a property.
+
+
+ Initializes a new instance of the class.
+
+
+ Represents the required attribute for http binding.
+
+
+ Initializes a new instance of the class.
+
+
+ Represents a configuration of instances.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class with an HTTP route collection.
+ The HTTP route collection to associate with this instance.
+
+
+ Gets or sets the dependency resolver associated with thisinstance.
+ The dependency resolver.
+
+
+ Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
+
+
+ Releases the unmanaged resources that are used by the object and, optionally, releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Invoke the Intializer hook. It is considered immutable from this point forward. It's safe to call this multiple times.
+
+
+ Gets the list of filters that apply to all requests served using this instance.
+ The list of filters.
+
+
+ Gets the media-type formatters for this instance.
+ A collection of objects.
+
+
+ Gets or sets a value indicating whether error details should be included in error messages.
+ The value that indicates that error detail policy.
+
+
+ Gets or sets the action that will perform final initialization of the instance before it is used to process requests.
+ The action that will perform final initialization of the instance.
+
+
+ Gets an ordered list of instances to be invoked as an travels up the stack and an travels down in stack in return.
+ The message handler collection.
+
+
+ Gets the collection of rules for how parameters should be bound.
+ A collection of functions that can produce a parameter binding for a given parameter.
+
+
+ Gets the properties associated with this instance.
+ The that contains the properties.
+
+
+ Gets the associated with this instance.
+ The .
+
+
+ Gets the container of default services associated with this instance.
+ The that contains the default services for this instance.
+
+
+ Gets the root virtual path.
+ The root virtual path.
+
+
+ Contains extension methods for the class.
+
+
+
+
+ Maps the attribute-defined routes for the application.
+ The server configuration.
+ The to use for discovering and building routes.
+
+
+ Maps the attribute-defined routes for the application.
+ The server configuration.
+ The constraint resolver.
+
+
+ Maps the attribute-defined routes for the application.
+ The server configuration.
+ The to use for resolving inline constraints.
+ The to use for discovering and building routes.
+
+
+
+ Specifies that an action supports the DELETE HTTP method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the http methods that correspond to this attribute.
+ The http methods that correspond to this attribute.
+
+
+ Defines a serializable container for storing error information. This information is stored as key/value pairs. The dictionary keys to look up standard error information are available on the type.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class for .
+ The exception to use for error information.
+ true to include the exception information in the error; false otherwise
+
+
+ Initializes a new instance of the class containing error message .
+ The error message to associate with this instance.
+
+
+ Initializes a new instance of the class for .
+ The invalid model state to use for error information.
+ true to include exception messages in the error; false otherwise
+
+
+ Gets or sets the message of the if available.
+ The message of the if available.
+
+
+ Gets or sets the type of the if available.
+ The type of the if available.
+
+
+ Gets a particular property value from this error instance.
+ A particular property value from this error instance.
+ The name of the error property.
+ The type of the property.
+
+
+ Gets the inner associated with this instance if available.
+ The inner associated with this instance if available.
+
+
+ Gets or sets the high-level, user-visible message explaining the cause of the error. Information carried in this field should be considered public in that it will go over the wire regardless of the . As a result care should be taken not to disclose sensitive information about the server or the application.
+ The high-level, user-visible message explaining the cause of the error. Information carried in this field should be considered public in that it will go over the wire regardless of the . As a result care should be taken not to disclose sensitive information about the server or the application.
+
+
+ Gets or sets a detailed description of the error intended for the developer to understand exactly what failed.
+ A detailed description of the error intended for the developer to understand exactly what failed.
+
+
+ Gets the containing information about the errors that occurred during model binding.
+ The containing information about the errors that occurred during model binding.
+
+
+ Gets or sets the stack trace information associated with this instance if available.
+ The stack trace information associated with this instance if available.
+
+
+ This method is reserved and should not be used.
+ Always returns null.
+
+
+ Generates an instance from its XML representation.
+ The XmlReader stream from which the object is deserialized.
+
+
+ Converts an instance into its XML representation.
+ The XmlWriter stream to which the object is serialized.
+
+
+ Provides keys to look up error information stored in the dictionary.
+
+
+ Provides a key for the ErrorCode.
+
+
+ Provides a key for the ExceptionMessage.
+
+
+ Provides a key for the ExceptionType.
+
+
+ Provides a key for the InnerException.
+
+
+ Provides a key for the MessageDetail.
+
+
+ Provides a key for the Message.
+
+
+ Provides a key for the MessageLanguage.
+
+
+ Provides a key for the ModelState.
+
+
+ Provides a key for the StackTrace.
+
+
+ Specifies that an action supports the GET HTTP method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the http methods that correspond to this attribute.
+ The http methods that correspond to this attribute.
+
+
+ Specifies that an action supports the HEAD HTTP method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the http methods that correspond to this attribute.
+ The http methods that correspond to this attribute.
+
+
+ Represents an attribute that is used to restrict an HTTP method so that the method handles only HTTP OPTIONS requests.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the http methods that correspond to this attribute.
+ The http methods that correspond to this attribute.
+
+
+ Specifies that an action supports the PATCH HTTP method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the http methods that correspond to this attribute.
+ The http methods that correspond to this attribute.
+
+
+ Specifies that an action supports the POST HTTP method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the http methods that correspond to this attribute.
+ The http methods that correspond to this attribute.
+
+
+ Represents an attribute that is used to restrict an HTTP method so that the method handles only HTTP PUT requests.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the http methods that correspond to this attribute.
+ The http methods that correspond to this attribute.
+
+
+ An exception that allows for a given to be returned to the client.
+
+
+ Initializes a new instance of the class.
+ The HTTP response to return to the client.
+
+
+ Initializes a new instance of the class.
+ The status code of the response.
+
+
+ Gets the HTTP response to return to the client.
+ The that represents the HTTP response.
+
+
+ A collection of instances.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The virtual path root.
+
+
+ Adds an instance to the collection.
+ The name of the route.
+ The instance to add to the collection.
+
+
+ Removes all items from the collection.
+
+
+ Determines whether the collection contains a specific .
+ true if the is found in the collection; otherwise, false.
+ The object to locate in the collection.
+
+
+ Determines whether the collection contains an element with the specified key.
+ true if the collection contains an element with the key; otherwise, false.
+ The key to locate in the collection.
+
+
+ Copies the instances of the collection to an array, starting at a particular array index.
+ The array that is the destination of the elements copied from the collection.
+ The zero-based index in at which copying begins.
+
+
+ Copies the route names and instances of the collection to an array, starting at a particular array index.
+ The array that is the destination of the elements copied from the collection.
+ The zero-based index in at which copying begins.
+
+
+ Gets the number of items in the collection.
+ The number of items in the collection.
+
+
+ Creates an instance.
+ The new instance.
+ The route template.
+ An object that contains the default route parameters.
+ An object that contains the route constraints.
+ The route data tokens.
+
+
+ Creates an instance.
+ The new instance.
+ The route template.
+ An object that contains the default route parameters.
+ An object that contains the route constraints.
+ The route data tokens.
+ The message handler for the route.
+
+
+ Creates an instance.
+ The new instance.
+ The route template.
+ An object that contains the default route parameters.
+ An object that contains the route constraints.
+
+
+ Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
+
+
+ Releases the unmanaged resources that are used by the object and, optionally, releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Returns an enumerator that iterates through the collection.
+ An that can be used to iterate through the collection.
+
+
+ Gets the route data for a specified HTTP request.
+ An instance that represents the route data.
+ The HTTP request.
+
+
+ Gets a virtual path.
+ An instance that represents the virtual path.
+ The HTTP request.
+ The route name.
+ The route values.
+
+
+ Inserts an instance into the collection.
+ The zero-based index at which should be inserted.
+ The route name.
+ The to insert. The value cannot be null.
+
+
+ Gets a value indicating whether the collection is read-only.
+ true if the collection is read-only; otherwise, false.
+
+
+ Gets or sets the element at the specified index.
+ The at the specified index.
+ The index.
+
+
+ Gets or sets the element with the specified route name.
+ The at the specified index.
+ The route name.
+
+
+ Called internally to get the enumerator for the collection.
+ An that can be used to iterate through the collection.
+
+
+ Removes an instance from the collection.
+ true if the element is successfully removed; otherwise, false. This method also returns false if was not found in the collection.
+ The name of the route to remove.
+
+
+ Adds an item to the collection.
+ The object to add to the collection.
+
+
+ Removes the first occurrence of a specific object from the collection.
+ true if was successfully removed from the collection; otherwise, false. This method also returns false if is not found in the original collection.
+ The object to remove from the collection.
+
+
+ Returns an enumerator that iterates through the collection.
+ An object that can be used to iterate through the collection.
+
+
+ Gets the with the specified route name.
+ true if the collection contains an element with the specified name; otherwise, false.
+ The route name.
+ When this method returns, contains the instance, if the route name is found; otherwise, null. This parameter is passed uninitialized.
+
+
+ Validates that a constraint is valid for an created by a call to the method.
+ The route template.
+ The constraint name.
+ The constraint object.
+
+
+ Gets the virtual path root.
+ The virtual path root.
+
+
+ Extension methods for
+
+
+ Ignores the specified route.
+ Returns .
+ A collection of routes for the application.
+ The name of the route to ignore.
+ The route template for the route.
+
+
+ Ignores the specified route.
+ Returns .
+ A collection of routes for the application.
+ The name of the route to ignore.
+ The route template for the route.
+ A set of expressions that specify values for the route template.
+
+
+ Maps the specified route for handling HTTP batch requests.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+ The for handling batch requests.
+
+
+ Maps the specified route template.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+
+
+ Maps the specified route template and sets default route values.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+ An object that contains default route values.
+
+
+ Maps the specified route template and sets default route values and constraints.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+ An object that contains default route values.
+ A set of expressions that specify values for .
+
+
+ Maps the specified route template and sets default route values, constraints, and end-point message handler.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The route template for the route.
+ An object that contains default route values.
+ A set of expressions that specify values for .
+ The handler to which the request will be dispatched.
+
+
+ Defines an implementation of an which dispatches an incoming and creates an as a result.
+
+
+ Initializes a new instance of the class, using the default configuration and dispatcher.
+
+
+ Initializes a new instance of the class with a specified dispatcher.
+ The HTTP dispatcher that will handle incoming requests.
+
+
+ Initializes a new instance of the class with a specified configuration.
+ The used to configure this instance.
+
+
+ Initializes a new instance of the class with a specified configuration and dispatcher.
+ The used to configure this instance.
+ The HTTP dispatcher that will handle incoming requests.
+
+
+ Gets the used to configure this instance.
+ The used to configure this instance.
+
+
+ Gets the HTTP dispatcher that handles incoming requests.
+ The HTTP dispatcher that handles incoming requests.
+
+
+ Releases the unmanaged resources that are used by the object and, optionally, releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Prepares the server for operation.
+
+
+ Dispatches an incoming .
+ A task representing the asynchronous operation.
+ The request to dispatch.
+ The token to monitor for cancellation requests.
+
+
+ Defines a command that asynchronously creates an .
+
+
+ Creates an asynchronously.
+ A task that, when completed, contains the .
+ The token to monitor for cancellation requests.
+
+
+ Specifies whether error details, such as exception messages and stack traces, should be included in error messages.
+
+
+ Always include error details.
+
+
+ Use the default behavior for the host environment. For ASP.NET hosting, use the value from the customErrors element in the Web.config file. For self-hosting, use the value .
+
+
+ Only include error details when responding to a local request.
+
+
+ Never include error details.
+
+
+ Represents an attribute that is used to indicate that a controller method is not an action method.
+
+
+ Initializes a new instance of the class.
+
+
+ Represents a filter attribute that overrides action filters defined at a higher level.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a value indicating whether the action filter allows multiple attribute.
+ true if the action filter allows multiple attribute; otherwise, false.
+
+
+ Gets the type of filters to override.
+ The type of filters to override.
+
+
+ Represents a filter attribute that overrides authentication filters defined at a higher level.
+
+
+
+
+
+ Represents a filter attribute that overrides authorization filters defined at a higher level.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a Boolean value indicating whether more than one instance of the indicated attribute can be specified for a single program element.
+ true if more than one instance is allowed to be specified; otherwise, false.
+
+
+ Gets the type to filters override attributes.
+ The type to filters override attributes.
+
+
+ Represents a filter attribute that overrides exception filters defined at a higher level.
+
+
+
+
+
+ Attribute on a parameter or type that produces a . If the attribute is on a type-declaration, then it's as if that attribute is present on all action parameters of that type.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the parameter binding.
+ The parameter binding.
+ The parameter description.
+
+
+ Place on an action to expose it directly via a route.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The route template describing the URI pattern to match against.
+
+
+ Returns .
+
+
+ Returns .
+
+
+
+ Returns .
+
+
+ The class can be used to indicate properties about a route parameter (the literals and placeholders located within segments of a ). It can for example be used to indicate that a route parameter is optional.
+
+
+ An optional parameter.
+
+
+ Returns a that represents this instance.
+ A that represents this instance.
+
+
+ Annotates a controller with a route prefix that applies to all actions within the controller.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The route prefix for the controller.
+
+
+ Gets the route prefix.
+
+
+ Provides type-safe accessors for services obtained from a object.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Returns the registered unhandled exception handler, if any.
+ The registered unhandled exception hander, if present; otherwise, null.
+ The services container.
+
+
+ Returns the collection of registered unhandled exception loggers.
+ The collection of registered unhandled exception loggers.
+ The services container.
+
+
+ Gets the collection.
+ Returns a collection of objects.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance, or null if no instance was registered.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the collection.
+ Returns a collection of objects.
+ The services container.
+
+
+ Gets the service.
+ Returns an instance.
+ The services container.
+
+
+ Gets the collection.
+ Returns a collection ofobjects.
+ The services container.
+
+
+ Gets the service.
+ Returns aninstance.
+ The services container.
+
+
+ Gets the service.
+ Returns aninstance.
+ The services container.
+
+
+ Gets the collection.
+ Returns a collection of objects.
+ The services container.
+
+
+ Represents an containing zero or one entities. Use together with an [EnableQuery] from the System.Web.Http.OData or System.Web.OData namespace.
+
+
+ Initializes a new instance of the class.
+ The containing zero or one entities.
+
+
+ Creates a from an . A helper method to instantiate a object without having to explicitly specify the type .
+ The created .
+ The containing zero or one entities.
+ The type of the data in the data source.
+
+
+ The containing zero or one entities.
+
+
+ Represents an containing zero or one entities. Use together with an [EnableQuery] from the System.Web.Http.OData or System.Web.OData namespace.
+ The type of the data in the data source.
+
+
+ Initializes a new instance of the class.
+ The containing zero or one entities.
+
+
+ The containing zero or one entities.
+
+
+ Defines the order of execution for batch requests.
+
+
+ Executes the batch requests non-sequentially.
+
+
+ Executes the batch requests sequentially.
+
+
+ Provides extension methods for the class.
+
+
+ Copies the properties from another .
+ The sub-request.
+ The batch request that contains the properties to copy.
+
+
+ Represents the default implementation of that encodes the HTTP request/response messages as MIME multipart.
+
+
+ Initializes a new instance of the class.
+ The for handling the individual batch requests.
+
+
+ Creates the batch response message.
+ The batch response message.
+ The responses for the batch requests.
+ The original request containing all the batch requests.
+ The cancellation token.
+
+
+ Executes the batch request messages.
+ A collection of for the batch requests.
+ The collection of batch request messages.
+ The cancellation token.
+
+
+ Gets or sets the execution order for the batch requests. The default execution order is sequential.
+ The execution order for the batch requests. The default execution order is sequential.
+
+
+ Converts the incoming batch request into a collection of request messages.
+ A collection of .
+ The request containing the batch request messages.
+ The cancellation token.
+
+
+ Processes the batch requests.
+ The result of the operation.
+ The batch request.
+ The cancellation token.
+
+
+ Gets the supported content types for the batch request.
+ The supported content types for the batch request.
+
+
+ Validates the incoming request that contains the batch request messages.
+ The request containing the batch request messages.
+
+
+ Defines the abstraction for handling HTTP batch requests.
+
+
+ Initializes a new instance of the class.
+ The for handling the individual batch requests.
+
+
+ Gets the invoker to send the batch requests to the .
+ The invoker to send the batch requests to the .
+
+
+ Processes the incoming batch request as a single .
+ The batch response.
+ The batch request.
+ The cancellation token.
+
+
+ Sends the batch handler asynchronously.
+ The result of the operation.
+ the send request.
+ The cancelation token.
+
+
+ Invokes the action methods of a controller.
+
+
+ Initializes a new instance of the class.
+
+
+ Asynchronously invokes the specified action by using the specified controller context.
+ The invoked action.
+ The controller context.
+ The cancellation token.
+
+
+ Represents a reflection based action selector.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the action mappings for the .
+ The action mappings.
+ The information that describes a controller.
+
+
+ Selects an action for the .
+ The selected action.
+ The controller context.
+
+
+ Represents a container for services that can be specific to a controller. This shadows the services from its parent . A controller can either set a service here, or fall through to the more global set of services.
+
+
+ Initializes a new instance of the class.
+ The parent services container.
+
+
+ Removes a single-instance service from the default services.
+ The type of service.
+
+
+ Gets a service of the specified type.
+ The first instance of the service, or null if the service is not found.
+ The type of service.
+
+
+ Gets the list of service objects for a given service type, and validates the service type.
+ The list of service objects of the specified type.
+ The service type.
+
+
+ Gets the list of service objects for a given service type.
+ The list of service objects of the specified type, or an empty list if the service is not found.
+ The type of service.
+
+
+ Queries whether a service type is single-instance.
+ true if the service type has at most one instance, or false if the service type supports multiple instances.
+ The service type.
+
+
+ Replaces a single-instance service object.
+ The service type.
+ The service object that replaces the previous instance.
+
+
+ Describes *how* the binding will happen and does not actually bind.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The back pointer to the action this binding is for.
+ The synchronous bindings for each parameter.
+
+
+ Gets or sets the back pointer to the action this binding is for.
+ The back pointer to the action this binding is for.
+
+
+ Executes asynchronously the binding for the given request context.
+ Task that is signaled when the binding is complete.
+ The action context for the binding. This contains the parameter dictionary that will get populated.
+ The cancellation token for cancelling the binding operation. Or a binder can also bind a parameter to this.
+
+
+ Gets or sets the synchronous bindings for each parameter.
+ The synchronous bindings for each parameter.
+
+
+ Contains information for the executing action.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The controller context.
+ The action descriptor.
+
+
+ Gets a list of action arguments.
+ A list of action arguments.
+
+
+ Gets or sets the action descriptor for the action context.
+ The action descriptor.
+
+
+ Gets or sets the controller context.
+ The controller context.
+
+
+ Gets the model state dictionary for the context.
+ The model state dictionary.
+
+
+ Gets the request message for the action context.
+ The request message for the action context.
+
+
+ Gets the current request context.
+ The current request context.
+
+
+ Gets or sets the response message for the action context.
+ The response message for the action context.
+
+
+ Contains extension methods for .
+
+
+
+
+
+
+
+
+
+
+ Provides information about the action methods.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class with specified information that describes the controller of the action..
+ The information that describes the controller of the action.
+
+
+ Gets or sets the binding that describes the action.
+ The binding that describes the action.
+
+
+ Gets the name of the action.
+ The name of the action.
+
+
+ Gets or sets the action configuration.
+ The action configuration.
+
+
+ Gets the information that describes the controller of the action.
+ The information that describes the controller of the action.
+
+
+ Executes the described action and returns a that once completed will contain the return value of the action.
+ A that once completed will contain the return value of the action.
+ The controller context.
+ A list of arguments.
+ The cancellation token.
+
+
+ Returns the custom attributes associated with the action descriptor.
+ The custom attributes associated with the action descriptor.
+ The action descriptor.
+
+
+ Gets the custom attributes for the action.
+ The collection of custom attributes applied to this action.
+ true to search this action's inheritance chain to find the attributes; otherwise, false.
+ The type of attribute to search for.
+
+
+ Retrieves the filters for the given configuration and action.
+ The filters for the given configuration and action.
+
+
+ Retrieves the filters for the action descriptor.
+ The filters for the action descriptor.
+
+
+ Retrieves the parameters for the action descriptor.
+ The parameters for the action descriptor.
+
+
+ Gets the properties associated with this instance.
+ The properties associated with this instance.
+
+
+ Gets the converter for correctly transforming the result of calling ExecuteAsync(HttpControllerContext, IDictionaryString, Object)" into an instance of .
+ The action result converter.
+
+
+ Gets the return type of the descriptor.
+ The return type of the descriptor.
+
+
+ Gets the collection of supported HTTP methods for the descriptor.
+ The collection of supported HTTP methods for the descriptor.
+
+
+ Contains information for a single HTTP operation.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The request context.
+ The HTTP request.
+ The controller descriptor.
+ The controller.
+
+
+ Initializes a new instance of the class.
+ The configuration.
+ The route data.
+ The request.
+
+
+ Gets or sets the configuration.
+ The configuration.
+
+
+ Gets or sets the HTTP controller.
+ The HTTP controller.
+
+
+ Gets or sets the controller descriptor.
+ The controller descriptor.
+
+
+ Gets or sets the request.
+ The request.
+
+
+ Gets or sets the request context.
+
+
+ Gets or sets the route data.
+ The route data.
+
+
+ Represents information that describes the HTTP controller.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The configuration.
+ The controller name.
+ The controller type.
+
+
+ Gets or sets the configurations associated with the controller.
+ The configurations associated with the controller.
+
+
+ Gets or sets the name of the controller.
+ The name of the controller.
+
+
+ Gets or sets the type of the controller.
+ The type of the controller.
+
+
+ Creates a controller instance for the given .
+ The created controller instance.
+ The request message.
+
+
+ Retrieves a collection of custom attributes of the controller.
+ A collection of custom attributes.
+ The type of the object.
+
+
+ Returns a collection of attributes that can be assigned to <typeparamref name="T" /> for this descriptor's controller.
+ A collection of attributes associated with this controller.
+ true to search this controller's inheritance chain to find the attributes; otherwise, false.
+ Used to filter the collection of attributes. Use a value of to retrieve all attributes.
+
+
+ Returns a collection of filters associated with the controller.
+ A collection of filters associated with the controller.
+
+
+ Gets the properties associated with this instance.
+ The properties associated with this instance.
+
+
+ Contains settings for an HTTP controller.
+
+
+ Initializes a new instance of the class.
+ A configuration object that is used to initialize the instance.
+
+
+ Gets the collection of instances for the controller.
+ The collection of instances.
+
+
+ Gets the collection of parameter bindingfunctions for for the controller.
+ The collection of parameter binding functions.
+
+
+ Gets the collection of service instances for the controller.
+ The collection of service instances.
+
+
+ Describes how a parameter is bound. The binding should be static (based purely on the descriptor) and can be shared across requests.
+
+
+ Initializes a new instance of the class.
+ An that describes the parameters.
+
+
+ Gets the that was used to initialize this instance.
+ The instance.
+
+
+ If the binding is invalid, gets an error message that describes the binding error.
+ An error message. If the binding was successful, the value is null.
+
+
+ Asynchronously executes the binding for the given request.
+ A task object representing the asynchronous operation.
+ Metadata provider to use for validation.
+ The action context for the binding. The action context contains the parameter dictionary that will get populated with the parameter.
+ Cancellation token for cancelling the binding operation.
+
+
+ Gets the parameter value from argument dictionary of the action context.
+ The value for this parameter in the given action context, or null if the parameter has not yet been set.
+ The action context.
+
+
+ Gets a value that indicates whether the binding was successful.
+ true if the binding was successful; otherwise, false.
+
+
+ Sets the result of this parameter binding in the argument dictionary of the action context.
+ The action context.
+ The parameter value.
+
+
+ Returns a value indicating whether this instance will read the entity body of the HTTP message.
+ true if this will read the entity body; otherwise, false.
+
+
+ Represents the HTTP parameter descriptor.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The action descriptor.
+
+
+ Gets or sets the action descriptor.
+ The action descriptor.
+
+
+ Gets or sets the for the .
+ The for the .
+
+
+ Gets the default value of the parameter.
+ The default value of the parameter.
+
+
+ Retrieves a collection of the custom attributes from the parameter.
+ A collection of the custom attributes from the parameter.
+ The type of the custom attributes.
+
+
+ Gets a value that indicates whether the parameter is optional.
+ true if the parameter is optional; otherwise, false.
+
+
+ Gets or sets the parameter binding attribute.
+ The parameter binding attribute.
+
+
+ Gets the name of the parameter.
+ The name of the parameter.
+
+
+ Gets the type of the parameter.
+ The type of the parameter.
+
+
+ Gets the prefix of this parameter.
+ The prefix of this parameter.
+
+
+ Gets the properties of this parameter.
+ The properties of this parameter.
+
+
+ Represents the context associated with a request.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the client certificate.
+ Returns .
+
+
+ Gets or sets the configuration.
+ Returns .
+
+
+ Gets or sets a value indicating whether error details, such as exception messages and stack traces, should be included in the response for this request.
+ Returns .
+
+
+ Gets or sets a value indicating whether the request originates from a local address.
+ Returns .
+
+
+ .Gets or sets the principal
+ Returns .
+
+
+ Gets or sets the route data.
+ Returns .
+
+
+ Gets or sets the factory used to generate URLs to other APIs.
+ Returns .
+
+
+ Gets or sets the virtual path root.
+ Returns .
+
+
+
+
+ A contract for a conversion routine that can take the result of an action returned from <see cref="M:System.Web.Http.Controllers.HttpActionDescriptor.ExecuteAsync(System.Web.Http.Controllers.HttpControllerContext,System.Collections.Generic.IDictionary{System.String,System.Object})" /> and convert it to an instance of .
+
+
+ Converts the specified object to another object.
+ The converted object.
+ The controller context.
+ The action result.
+
+
+ Defines the method for retrieval of action binding associated with parameter value.
+
+
+ Gets the .
+ A object.
+ The action descriptor.
+
+
+ If a controller is decorated with an attribute with this interface, then it gets invoked to initialize the controller settings.
+
+
+ Callback invoked to set per-controller overrides for this controllerDescriptor.
+ The controller settings to initialize.
+ The controller descriptor. Note that the can be associated with the derived controller type given that is inherited.
+
+
+ Contains method that is used to invoke HTTP operation.
+
+
+ Executes asynchronously the HTTP operation.
+ The newly started task.
+ The execution context.
+ The cancellation token assigned for the HTTP operation.
+
+
+ Contains the logic for selecting an action method.
+
+
+ Returns a map, keyed by action string, of all that the selector can select. This is primarily called by to discover all the possible actions in the controller.
+ A map of that the selector can select, or null if the selector does not have a well-defined mapping of .
+ The controller descriptor.
+
+
+ Selects the action for the controller.
+ The action for the controller.
+ The context of the controller.
+
+
+ Represents an HTTP controller.
+
+
+ Executes the controller for synchronization.
+ The controller.
+ The current context for a test controller.
+ The notification that cancels the operation.
+
+
+ Defines extension methods for .
+
+
+ Binds parameter that results as an error.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+ The error message that describes the reason for fail bind.
+
+
+ Bind the parameter as if it had the given attribute on the declaration.
+ The HTTP parameter binding object.
+ The parameter to provide binding for.
+ The attribute that describes the binding.
+
+
+ Binds parameter by parsing the HTTP body content.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+
+
+ Binds parameter by parsing the HTTP body content.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+ The list of formatters which provides selection of an appropriate formatter for serializing the parameter into object.
+
+
+ Binds parameter by parsing the HTTP body content.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+ The list of formatters which provides selection of an appropriate formatter for serializing the parameter into object.
+ The body model validator used to validate the parameter.
+
+
+ Binds parameter by parsing the HTTP body content.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+ The list of formatters which provides selection of an appropriate formatter for serializing the parameter into object.
+
+
+ Binds parameter by parsing the query string.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+
+
+ Binds parameter by parsing the query string.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+ The value provider factories which provide query string parameter data.
+
+
+ Binds parameter by parsing the query string.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+ The model binder used to assemble the parameter into an object.
+
+
+ Binds parameter by parsing the query string.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+ The model binder used to assemble the parameter into an object.
+ The value provider factories which provide query string parameter data.
+
+
+ Binds parameter by parsing the query string.
+ The HTTP parameter binding object.
+ The parameter descriptor that describes the parameter to bind.
+ The value provider factories which provide query string parameter data.
+
+
+ Represents a reflected synchronous or asynchronous action method.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class with the specified descriptor and method details..
+ The controller descriptor.
+ The action-method information.
+
+
+ Gets the name of the action.
+ The name of the action.
+
+
+
+ Executes the described action and returns a that once completed will contain the return value of the action.
+ A [T:System.Threading.Tasks.Task`1"] that once completed will contain the return value of the action.
+ The context.
+ The arguments.
+ A cancellation token to cancel the action.
+
+
+ Returns an array of custom attributes defined for this member, identified by type.
+ An array of custom attributes or an empty array if no custom attributes exist.
+ true to search this action's inheritance chain to find the attributes; otherwise, false.
+ The type of the custom attributes.
+
+
+ Retrieves information about action filters.
+ The filter information.
+
+
+
+ Retrieves the parameters of the action method.
+ The parameters of the action method.
+
+
+ Gets or sets the action-method information.
+ The action-method information.
+
+
+ Gets the return type of this method.
+ The return type of this method.
+
+
+ Gets or sets the supported http methods.
+ The supported http methods.
+
+
+ Represents the reflected HTTP parameter descriptor.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The action descriptor.
+ The parameter information.
+
+
+ Gets the default value for the parameter.
+ The default value for the parameter.
+
+
+ Retrieves a collection of the custom attributes from the parameter.
+ A collection of the custom attributes from the parameter.
+ The type of the custom attributes.
+
+
+ Gets a value that indicates whether the parameter is optional.
+ true if the parameter is optional; otherwise false.
+
+
+ Gets or sets the parameter information.
+ The parameter information.
+
+
+ Gets the name of the parameter.
+ The name of the parameter.
+
+
+ Gets the type of the parameter.
+ The type of the parameter.
+
+
+ Represents a converter for actions with a return type of .
+
+
+ Initializes a new instance of the class.
+
+
+ Converts a object to another object.
+ The converted object.
+ The controller context.
+ The action result.
+
+
+ An abstract class that provides a container for services used by ASP.NET Web API.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds a service to the end of services list for the given service type.
+ The service type.
+ The service instance.
+
+
+ Adds the services of the specified collection to the end of the services list for the given service type.
+ The service type.
+ The services to add.
+
+
+ Removes all the service instances of the given service type.
+ The service type to clear from the services list.
+
+
+ Removes all instances of a multi-instance service type.
+ The service type to remove.
+
+
+ Removes a single-instance service type.
+ The service type to remove.
+
+
+ Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
+
+
+ Searches for a service that matches the conditions defined by the specified predicate, and returns the zero-based index of the first occurrence.
+ The zero-based index of the first occurrence, if found; otherwise, -1.
+ The service type.
+ The delegate that defines the conditions of the element to search for.
+
+
+ Gets a service instance of a specified type.
+ The service type.
+
+
+ Gets a mutable list of service instances of a specified type.
+ A mutable list of service instances.
+ The service type.
+
+
+ Gets a collection of service instanes of a specified type.
+ A collection of service instances.
+ The service type.
+
+
+ Inserts a service into the collection at the specified index.
+ The service type.
+ The zero-based index at which the service should be inserted. If is passed, ensures the element is added to the end.
+ The service to insert.
+
+
+ Inserts the elements of the collection into the service list at the specified index.
+ The service type.
+ The zero-based index at which the new elements should be inserted. If is passed, ensures the elements are added to the end.
+ The collection of services to insert.
+
+
+ Determine whether the service type should be fetched with GetService or GetServices.
+ true iff the service is singular.
+ type of service to query
+
+
+ Removes the first occurrence of the given service from the service list for the given service type.
+ true if the item is successfully removed; otherwise, false.
+ The service type.
+ The service instance to remove.
+
+
+ Removes all the elements that match the conditions defined by the specified predicate.
+ The number of elements removed from the list.
+ The service type.
+ The delegate that defines the conditions of the elements to remove.
+
+
+ Removes the service at the specified index.
+ The service type.
+ The zero-based index of the service to remove.
+
+
+ Replaces all existing services for the given service type with the given service instance. This works for both singular and plural services.
+ The service type.
+ The service instance.
+
+
+ Replaces all instances of a multi-instance service with a new instance.
+ The type of service.
+ The service instance that will replace the current services of this type.
+
+
+ Replaces all existing services for the given service type with the given service instances.
+ The service type.
+ The service instances.
+
+
+ Replaces a single-instance service of a specified type.
+ The service type.
+ The service instance.
+
+
+ Removes the cached values for a single service type.
+ The service type.
+
+
+ A converter for creating responses from actions that return an arbitrary value.
+ The declared return type of an action.
+
+
+ Initializes a new instance of the class.
+
+
+ Converts the result of an action with arbitrary return type to an instance of .
+ The newly created object.
+ The action controller context.
+ The execution result.
+
+
+ Represents a converter for creating a response from actions that do not return a value.
+
+
+ Initializes a new instance of the class.
+
+
+ Converts the created response from actions that do not return a value.
+ The converted response.
+ The context of the controller.
+ The result of the action.
+
+
+ Represents a dependency injection container.
+
+
+ Starts a resolution scope.
+ The dependency scope.
+
+
+ Represents an interface for the range of the dependencies.
+
+
+ Retrieves a service from the scope.
+ The retrieved service.
+ The service to be retrieved.
+
+
+ Retrieves a collection of services from the scope.
+ The retrieved collection of services.
+ The collection of services to be retrieved.
+
+
+ Describes an API defined by relative URI path and HTTP method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the action descriptor that will handle the API.
+ The action descriptor.
+
+
+ Gets or sets the documentation of the API.
+ The documentation.
+
+
+ Gets or sets the HTTP method.
+ The HTTP method.
+
+
+ Gets the ID. The ID is unique within .
+ The ID.
+
+
+ Gets the parameter descriptions.
+ The parameter descriptions.
+
+
+ Gets or sets the relative path.
+ The relative path.
+
+
+ Gets or sets the response description.
+ The response description.
+
+
+ Gets or sets the registered route for the API.
+ The route.
+
+
+ Gets the supported request body formatters.
+ The supported request body formatters.
+
+
+ Gets the supported response formatters.
+ The supported response formatters.
+
+
+ Explores the URI space of the service based on routes, controllers and actions available in the system.
+
+
+ Initializes a new instance of the class.
+ The configuration.
+
+
+ Gets the API descriptions. The descriptions are initialized on the first access.
+
+
+ Gets or sets the documentation provider. The provider will be responsible for documenting the API.
+ The documentation provider.
+
+
+ Gets a collection of HttpMethods supported by the action. Called when initializing the .
+ A collection of HttpMethods supported by the action.
+ The route.
+ The action descriptor.
+
+
+ Determines whether the action should be considered for generation. Called when initializing the .
+ true if the action should be considered for generation, false otherwise.
+ The action variable value from the route.
+ The action descriptor.
+ The route.
+
+
+ Determines whether the controller should be considered for generation. Called when initializing the .
+ true if the controller should be considered for generation, false otherwise.
+ The controller variable value from the route.
+ The controller descriptor.
+ The route.
+
+
+ This attribute can be used on the controllers and actions to influence the behavior of .
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a value indicating whether to exclude the controller or action from the instances generated by .
+ true if the controller or action should be ignored; otherwise, false.
+
+
+ Describes a parameter on the API defined by relative URI path and HTTP method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the documentation.
+ The documentation.
+
+
+ Gets or sets the name.
+ The name.
+
+
+ Gets or sets the parameter descriptor.
+ The parameter descriptor.
+
+
+ Gets or sets the source of the parameter. It may come from the request URI, request body or other places.
+ The source.
+
+
+ Describes where the parameter come from.
+
+
+ The parameter come from Body.
+
+
+ The parameter come from Uri.
+
+
+ The location is unknown.
+
+
+ Defines the interface for getting a collection of .
+
+
+ Gets the API descriptions.
+
+
+ Defines the provider responsible for documenting the service.
+
+
+ Gets the documentation based on .
+ The documentation for the controller.
+ The action descriptor.
+
+
+
+ Gets the documentation based on .
+ The documentation for the controller.
+ The parameter descriptor.
+
+
+
+ Describes the API response.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the declared response type.
+ The declared response type.
+
+
+ Gets or sets the response documentation.
+ The response documentation.
+
+
+ Gets or sets the actual response type.
+ The actual response type.
+
+
+ Use this to specify the entity type returned by an action when the declared return type is or . The will be read by when generating .
+
+
+ Initializes a new instance of the class.
+ The response type.
+
+
+ Gets the response type.
+
+
+ Provides an implementation of with no external dependencies.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a list of assemblies available for the application.
+ A <see cref="T:System.Collections.ObjectModel.Collection`1" /> of assemblies.
+
+
+ Represents a default implementation of an . A different implementation can be registered via the . We optimize for the case where we have an instance per instance but can support cases where there are many instances for one as well. In the latter case the lookup is slightly slower because it goes through the dictionary.
+
+
+ Initializes a new instance of the class.
+
+
+ Creates the specified by using the given .
+ An instance of type .
+ The request message.
+ The controller descriptor.
+ The type of the controller.
+
+
+ Represents a default instance for choosing a given a . A different implementation can be registered via the .
+
+
+ Initializes a new instance of the class.
+ The configuration.
+
+
+ Specifies the suffix string in the controller name.
+
+
+ Returns a map, keyed by controller string, of all that the selector can select.
+ A map of all that the selector can select, or null if the selector does not have a well-defined mapping of .
+
+
+ Gets the name of the controller for the specified .
+ The name of the controller for the specified .
+ The HTTP request message.
+
+
+ Selects a for the given .
+ The instance for the given .
+ The HTTP request message.
+
+
+ Provides an implementation of with no external dependencies.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance using a predicate to filter controller types.
+ The predicate.
+
+
+ Returns a list of controllers available for the application.
+ An <see cref="T:System.Collections.Generic.ICollection`1" /> of controllers.
+ The assemblies resolver.
+
+
+ Gets a value whether the resolver type is a controller type predicate.
+ true if the resolver type is a controller type predicate; otherwise, false.
+
+
+ Dispatches an incoming to an implementation for processing.
+
+
+ Initializes a new instance of the class with the specified configuration.
+ The http configuration.
+
+
+ Gets the HTTP configuration.
+ The HTTP configuration.
+
+
+ Dispatches an incoming to an .
+ A representing the ongoing operation.
+ The request to dispatch
+ The cancellation token.
+
+
+ This class is the default endpoint message handler which examines the of the matched route, and chooses which message handler to call. If is null, then it delegates to .
+
+
+ Initializes a new instance of the class, using the provided and as the default handler.
+ The server configuration.
+
+
+ Initializes a new instance of the class, using the provided and .
+ The server configuration.
+ The default handler to use when the has no .
+
+
+ Sends an HTTP request as an asynchronous operation.
+ The task object representing the asynchronous operation.
+ The HTTP request message to send.
+ The cancellation token to cancel operation.
+
+
+ Provides an abstraction for managing the assemblies of an application. A different implementation can be registered via the .
+
+
+ Returns a list of assemblies available for the application.
+ An <see cref="T:System.Collections.Generic.ICollection`1" /> of assemblies.
+
+
+ Defines the methods that are required for an .
+
+
+ Creates an object.
+ An object.
+ The message request.
+ The HTTP controller descriptor.
+ The type of the controller.
+
+
+ Defines the methods that are required for an factory.
+
+
+ Returns a map, keyed by controller string, of all that the selector can select. This is primarily called by to discover all the possible controllers in the system.
+ A map of all that the selector can select, or null if the selector does not have a well-defined mapping of .
+
+
+ Selects a for the given .
+ An instance.
+ The request message.
+
+
+ Provides an abstraction for managing the controller types of an application. A different implementation can be registered via the DependencyResolver.
+
+
+ Returns a list of controllers available for the application.
+ An <see cref="T:System.Collections.Generic.ICollection`1" /> of controllers.
+ The resolver for failed assemblies.
+
+
+ Provides the catch blocks used within this assembly.
+
+
+ Gets the catch block in System.Web.Http.ExceptionHandling.ExceptionCatchBlocks.HttpBatchHandler.SendAsync.
+ The catch block in System.Web.Http.ExceptionHandling.ExceptionCatchBlocks.HttpBatchHandler.SendAsync.
+
+
+ Gets the catch block in System.Web.Http.ExceptionHandling.ExceptionCatchBlocks.HttpControllerDispatcher.SendAsync.
+ The catch block in System.Web.Http.ExceptionHandling.ExceptionCatchBlocks.HttpControllerDispatcher.SendAsync.
+
+
+ Gets the catch block in System.Web.Http.ExceptionHandling.ExceptionCatchBlocks.HttpServer.SendAsync.
+ The catch block in System.Web.Http.ExceptionHandling.ExceptionCatchBlocks.HttpServer.SendAsync.
+
+
+ Gets the catch block in System.Web.Http.ApiController.ExecuteAsync when using .
+ The catch block in System.Web.Http.ApiController.ExecuteAsync when using .
+
+
+ Represents an exception and the contextual data associated with it when it was caught.
+
+
+ Initializes a new instance of the class.
+ The caught exception.
+ The catch block where the exception was caught.
+
+
+ Initializes a new instance of the class.
+ The caught exception.
+ The catch block where the exception was caught.
+ The request being processed when the exception was caught.
+
+
+ Initializes a new instance of the class.
+ The caught exception.
+ The catch block where the exception was caught.
+ The request being processed when the exception was caught.
+ The repsonse being returned when the exception was caught.
+
+
+ Initializes a new instance of the class.
+ The caught exception.
+ The catch block where the exception was caught.
+ The action context in which the exception occurred.
+
+
+ Gets the action context in which the exception occurred, if available.
+ The action context in which the exception occurred, if available.
+
+
+ Gets the catch block in which the exception was caught.
+ The catch block in which the exception was caught.
+
+
+ Gets the controller context in which the exception occurred, if available.
+ The controller context in which the exception occurred, if available.
+
+
+ Gets the caught exception.
+ The caught exception.
+
+
+ Gets the request being processed when the exception was caught.
+ The request being processed when the exception was caught.
+
+
+ Gets the request context in which the exception occurred.
+ The request context in which the exception occurred.
+
+
+ Gets the response being sent when the exception was caught.
+ The response being sent when the exception was caught.
+
+
+ Represents the catch block location for an exception context.
+
+
+ Initializes a new instance of the class.
+ The label for the catch block where the exception was caught.
+ A value indicating whether the catch block where the exception was caught is the last one before the host.
+ A value indicating whether exceptions in the catch block can be handled after they are logged.
+
+
+ Gets a value indicating whether exceptions in the catch block can be handled after they are logged.
+ A value indicating whether exceptions in the catch block can be handled after they are logged.
+
+
+ Gets a value indicating whether the catch block where the exception was caught is the last one before the host.
+ A value indicating whether the catch block where the exception was caught is the last one before the host.
+
+
+ Gets a label for the catch block in which the exception was caught.
+ A label for the catch block in which the exception was caught.
+
+
+ Returns .
+
+
+ Represents an unhandled exception handler.
+
+
+ Initializes a new instance of the class.
+
+
+ When overridden in a derived class, handles the exception synchronously.
+ The exception handler context.
+
+
+ When overridden in a derived class, handles the exception asynchronously.
+ A task representing the asynchronous exception handling operation.
+ The exception handler context.
+ The token to monitor for cancellation requests.
+
+
+ Determines whether the exception should be handled.
+ true if the exception should be handled; otherwise, false.
+ The exception handler context.
+
+
+ Returns .
+
+
+ Represents the context within which unhandled exception handling occurs.
+
+
+ Initializes a new instance of the class.
+ The exception context.
+
+
+ Gets the catch block in which the exception was caught.
+ The catch block in which the exception was caught.
+
+
+ Gets the caught exception.
+ The caught exception.
+
+
+ Gets the exception context providing the exception and related data.
+ The exception context providing the exception and related data.
+
+
+ Gets the request being processed when the exception was caught.
+ The request being processed when the exception was caught.
+
+
+ Gets the request context in which the exception occurred.
+ The request context in which the exception occurred.
+
+
+ Gets or sets the result providing the response message when the exception is handled.
+ The result providing the response message when the exception is handled.
+
+
+ Provides extension methods for .
+
+
+ Calls an exception handler and determines the response handling it, if any.
+ A task that, when completed, contains the response message to return when the exception is handled, or null when the exception remains unhandled.
+ The unhandled exception handler.
+ The exception context.
+ The token to monitor for cancellation requests.
+
+
+ Represents an unhandled exception logger.
+
+
+ Initializes a new instance of the class.
+
+
+ When overridden in a derived class, logs the exception synchronously.
+ The exception logger context.
+
+
+ When overridden in a derived class, logs the exception asynchronously.
+ A task representing the asynchronous exception logging operation.
+ The exception logger context.
+ The token to monitor for cancellation requests.
+
+
+ Determines whether the exception should be logged.
+ true if the exception should be logged; otherwise, false.
+ The exception logger context.
+
+
+ Returns .
+
+
+ Represents the context within which unhandled exception logging occurs.
+
+
+ Initializes a new instance of the class.
+ The exception context.
+
+
+ Gets or sets a value indicating whether the exception can subsequently be handled by an to produce a new response message.
+ A value indicating whether the exception can subsequently be handled by an to produce a new response message.
+
+
+ Gets the catch block in which the exception was caught.
+ The catch block in which the exception was caught.
+
+
+ Gets the caught exception.
+ The caught exception.
+
+
+ Gets the exception context providing the exception and related data.
+ The exception context providing the exception and related data.
+
+
+ Gets the request being processed when the exception was caught.
+ The request being processed when the exception was caught.
+
+
+ Gets the request context in which the exception occurred.
+ The request context in which the exception occurred.
+
+
+ Provides extension methods for .
+
+
+ Calls an exception logger.
+ A task representing the asynchronous exception logging operation.
+ The unhandled exception logger.
+ The exception context.
+ The token to monitor for cancellation requests.
+
+
+ Creates exception services to call logging and handling from catch blocks.
+
+
+ Gets an exception handler that calls the registered handler service, if any, and ensures exceptions do not accidentally propagate to the host.
+ An exception handler that calls any registered handler and ensures exceptions do not accidentally propagate to the host.
+ The services container.
+
+
+ Gets an exception handler that calls the registered handler service, if any, and ensures exceptions do not accidentally propagate to the host.
+ An exception handler that calls any registered handler and ensures exceptions do not accidentally propagate to the host.
+ The configuration.
+
+
+ Gets an exception logger that calls all registered logger services.
+ A composite logger.
+ The services container.
+
+
+ Gets an exception logger that calls all registered logger services.
+ A composite logger.
+ The configuration.
+
+
+ Defines an unhandled exception handler.
+
+
+ Process an unhandled exception, either allowing it to propagate or handling it by providing a response message to return instead.
+ A task representing the asynchronous exception handling operation.
+ The exception handler context.
+ The token to monitor for cancellation requests.
+
+
+ Defines an unhandled exception logger.
+
+
+ Logs an unhandled exception.
+ A task representing the asynchronous exception logging operation.
+ The exception logger context.
+ The token to monitor for cancellation requests.
+
+
+ Provides information about an action method, such as its name, controller, parameters, attributes, and filters.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns the filters that are associated with this action method.
+ The filters that are associated with this action method.
+ The configuration.
+ The action descriptor.
+
+
+ Represents the base class for all action-filter attributes.
+
+
+ Initializes a new instance of the class.
+
+
+ Occurs after the action method is invoked.
+ The action executed context.
+
+
+
+ Occurs before the action method is invoked.
+ The action context.
+
+
+
+ Executes the filter action asynchronously.
+ The newly created task for this operation.
+ The action context.
+ The cancellation token assigned for this task.
+ The delegate function to continue after the action method is invoked.
+
+
+ Provides details for authorization filter.
+
+
+ Initializes a new instance of the class.
+
+
+ Calls when a process requests authorization.
+ The action context, which encapsulates information for using .
+
+
+
+ Executes the authorization filter during synchronization.
+ The authorization filter during synchronization.
+ The action context, which encapsulates information for using .
+ The cancellation token that cancels the operation.
+ A continuation of the operation.
+
+
+ Represents the configuration filter provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns the filters that are associated with this configuration method.
+ The filters that are associated with this configuration method.
+ The configuration.
+ The action descriptor.
+
+
+ Represents the attributes for the exception filter.
+
+
+ Initializes a new instance of the class.
+
+
+ Raises the exception event.
+ The context for the action.
+
+
+
+ Asynchronously executes the exception filter.
+ The result of the execution.
+ The context for the action.
+ The cancellation context.
+
+
+ Represents the base class for action-filter attributes.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a value that indicates whether multiple filters are allowed.
+ true if multiple filters are allowed; otherwise, false.
+
+
+ Provides information about the available action filters.
+
+
+ Initializes a new instance of the class.
+ The instance of this class.
+ The scope of this class.
+
+
+ Gets or sets an instance of the .
+ A .
+
+
+ Gets or sets the scope .
+ The scope of the FilterInfo.
+
+
+ Defines values that specify the order in which filters run within the same filter type and filter order.
+
+
+ Specifies an order after Controller.
+
+
+ Specifies an order before Action and after Global.
+
+
+ Specifies an action before Controller.
+
+
+ Represents the action of the HTTP executed context.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The action context.
+ The exception.
+
+
+ Gets or sets the HTTP action context.
+ The HTTP action context.
+
+
+ Gets or sets the exception that was raised during the execution.
+ The exception that was raised during the execution.
+
+
+ Gets the object for the context.
+ The object for the context.
+
+
+ Gets or sets the for the context.
+ The for the context.
+
+
+ Represents an authentication challenge context containing information for executing an authentication challenge.
+
+
+ Initializes a new instance of the class.
+ The action context.
+ The current action result.
+
+
+ Gets the action context.
+
+
+ Gets the request message.
+
+
+ Gets or sets the action result to execute.
+
+
+ Represents an authentication context containing information for performing authentication.
+
+
+ Initializes a new instance of the class.
+ The action context.
+ The current principal.
+
+
+ Gets the action context.
+ The action context.
+
+
+ Gets or sets an action result that will produce an error response (if authentication failed; otherwise, null).
+ An action result that will produce an error response.
+
+
+ Gets or sets the authenticated principal.
+ The authenticated principal.
+
+
+ Gets the request message.
+ The request message.
+
+
+ Represents a collection of HTTP filters.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds an item at the end of the collection.
+ The item to add to the collection.
+
+
+
+ Removes all item in the collection.
+
+
+ Determines whether the collection contains the specified item.
+ true if the collection contains the specified item; otherwise, false.
+ The item to check.
+
+
+ Gets the number of elements in the collection.
+ The number of elements in the collection.
+
+
+ Gets an enumerator that iterates through the collection.
+ An enumerator object that can be used to iterate through the collection.
+
+
+ Removes the specified item from the collection.
+ The item to remove in the collection.
+
+
+ Gets an enumerator that iterates through the collection.
+ An enumerator object that can be used to iterate through the collection.
+
+
+ Defines the methods that are used in an action filter.
+
+
+ Executes the filter action asynchronously.
+ The newly created task for this operation.
+ The action context.
+ The cancellation token assigned for this task.
+ The delegate function to continue after the action method is invoked.
+
+
+ Defines a filter that performs authentication.
+
+
+ Authenticates the request.
+ A Task that will perform authentication.
+ The authentication context.
+ The token to monitor for cancellation requests.
+
+
+
+ Defines the methods that are required for an authorization filter.
+
+
+ Executes the authorization filter to synchronize.
+ The authorization filter to synchronize.
+ The action context.
+ The cancellation token associated with the filter.
+ The continuation.
+
+
+ Defines the methods that are required for an exception filter.
+
+
+ Executes an asynchronous exception filter.
+ An asynchronous exception filter.
+ The action executed context.
+ The cancellation token.
+
+
+ Defines the methods that are used in a filter.
+
+
+ Gets or sets a value indicating whether more than one instance of the indicated attribute can be specified for a single program element.
+ true if more than one instance is allowed to be specified; otherwise, false. The default is false.
+
+
+ Provides filter information.
+
+
+ Returns an enumeration of filters.
+ An enumeration of filters.
+ The HTTP configuration.
+ The action descriptor.
+
+
+
+
+ Provides common keys for properties stored in the
+
+
+ Provides a key for the client certificate for this request.
+
+
+ Provides a key for the associated with this request.
+
+
+ Provides a key for the collection of resources that should be disposed when a request is disposed.
+
+
+ Provides a key for the associated with this request.
+
+
+ Provides a key for the associated with this request.
+
+
+ Provides a key for the associated with this request.
+
+
+ Provides a key that indicates whether error details are to be included in the response for this HTTP request.
+
+
+ Provides a key that indicates whether the request is a batch request.
+
+
+ Provides a key that indicates whether the request originates from a local address.
+
+
+ Provides a key that indicates whether the request failed to match a route.
+
+
+ Provides a key for the for this request.
+
+
+ Provides a key for the stored in . This is the correlation ID for that request.
+
+
+ Provides a key for the parsed query string stored in .
+
+
+ Provides a key for a delegate which can retrieve the client certificate for this request.
+
+
+ Provides a key for the current stored in Properties(). If Current() is null then no context is stored.
+
+
+ Interface for controlling the use of buffering requests and responses in the host. If a host provides support for buffering requests and/or responses then it can use this interface to determine the policy for when buffering is to be used.
+
+
+ Determines whether the host should buffer the entity body.
+ true if buffering should be used; otherwise a streamed request should be used.
+ The host context.
+
+
+ Determines whether the host should buffer the entity body.
+ true if buffering should be used; otherwise a streamed response should be used.
+ The HTTP response message.
+
+
+ Represents a message handler that suppresses host authentication results.
+
+
+ Initializes a new instance of the class.
+
+
+ Asynchronously sends a request message.
+ That task that completes the asynchronous operation.
+ The request message to send.
+ The cancellation token.
+
+
+ Represents the metadata class of the ModelMetadata.
+
+
+ Initializes a new instance of the class.
+ The provider.
+ The type of the container.
+ The model accessor.
+ The type of the model.
+ The name of the property.
+
+
+ Gets a dictionary that contains additional metadata about the model.
+ A dictionary that contains additional metadata about the model.
+
+
+ Gets or sets the type of the container for the model.
+ The type of the container for the model.
+
+
+ Gets or sets a value that indicates whether empty strings that are posted back in forms should be converted to null.
+ true if empty strings that are posted back in forms should be converted to null; otherwise, false. The default value is true.
+
+
+ Gets or sets the description of the model.
+ The description of the model. The default value is null.
+
+
+ Gets the display name for the model.
+ The display name for the model.
+
+
+ Gets a list of validators for the model.
+ A list of validators for the model.
+ The validator providers for the model.
+
+
+ Gets or sets a value that indicates whether the model is a complex type.
+ A value that indicates whether the model is considered a complex.
+
+
+ Gets a value that indicates whether the type is nullable.
+ true if the type is nullable; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the model is read-only.
+ true if the model is read-only; otherwise, false.
+
+
+ Gets the value of the model.
+ The model value can be null.
+
+
+ Gets the type of the model.
+ The type of the model.
+
+
+ Gets a collection of model metadata objects that describe the properties of the model.
+ A collection of model metadata objects that describe the properties of the model.
+
+
+ Gets the property name.
+ The property name.
+
+
+ Gets or sets the provider.
+ The provider.
+
+
+ Provides an abstract base class for a custom metadata provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a ModelMetadata object for each property of a model.
+ A ModelMetadata object for each property of a model.
+ The container.
+ The type of the container.
+
+
+ Gets a metadata for the specified property.
+ The metadata model for the specified property.
+ The model accessor.
+ The type of the container.
+ The property to get the metadata model for.
+
+
+ Gets the metadata for the specified model accessor and model type.
+ The metadata.
+ The model accessor.
+ The type of the mode.
+
+
+ Provides an abstract class to implement a metadata provider.
+ The type of the model metadata.
+
+
+ Initializes a new instance of the class.
+
+
+ When overridden in a derived class, creates the model metadata for the property using the specified prototype.
+ The model metadata for the property.
+ The prototype from which to create the model metadata.
+ The model accessor.
+
+
+ When overridden in a derived class, creates the model metadata for the property.
+ The model metadata for the property.
+ The set of attributes.
+ The type of the container.
+ The type of the model.
+ The name of the property.
+
+
+ Retrieves a list of properties for the model.
+ A list of properties for the model.
+ The model container.
+ The type of the container.
+
+
+ Retrieves the metadata for the specified property using the container type and property name.
+ The metadata for the specified property.
+ The model accessor.
+ The type of the container.
+ The name of the property.
+
+
+ Returns the metadata for the specified property using the type of the model.
+ The metadata for the specified property.
+ The model accessor.
+ The type of the container.
+
+
+ Provides prototype cache data for .
+
+
+ Initializes a new instance of the class.
+ The attributes that provides data for the initialization.
+
+
+ Gets or sets the metadata display attribute.
+ The metadata display attribute.
+
+
+ Gets or sets the metadata display format attribute.
+ The metadata display format attribute.
+
+
+
+ Gets or sets the metadata editable attribute.
+ The metadata editable attribute.
+
+
+ Gets or sets the metadata read-only attribute.
+ The metadata read-only attribute.
+
+
+ Provides a container for common metadata, for the class, for a data model.
+
+
+ Initializes a new instance of the class.
+ The prototype used to initialize the model metadata.
+ The model accessor.
+
+
+ Initializes a new instance of the class.
+ The metadata provider.
+ The type of the container.
+ The type of the model.
+ The name of the property.
+ The attributes that provides data for the initialization.
+
+
+ Retrieves a value that indicates whether empty strings that are posted back in forms should be converted to null.
+ true if empty strings that are posted back in forms should be converted to null; otherwise, false.
+
+
+ Retrieves the description of the model.
+ The description of the model.
+
+
+ Retrieves a value that indicates whether the model is read-only.
+ true if the model is read-only; otherwise, false.
+
+
+
+ Provides prototype cache data for the .
+ The type of prototype cache.
+
+
+ Initializes a new instance of the class.
+ The prototype.
+ The model accessor.
+
+
+ Initializes a new instance of the class.
+ The provider.
+ The type of container.
+ The type of the model.
+ The name of the property.
+ The prototype cache.
+
+
+ Indicates whether empty strings that are posted back in forms should be computed and converted to null.
+ true if empty strings that are posted back in forms should be computed and converted to null; otherwise, false.
+
+
+ Indicates the computation value.
+ The computation value.
+
+
+ Gets a value that indicates whether the model is a complex type.
+ A value that indicates whether the model is considered a complex type by the Web API framework.
+
+
+ Gets a value that indicates whether the model to be computed is read-only.
+ true if the model to be computed is read-only; otherwise, false.
+
+
+ Gets or sets a value that indicates whether empty strings that are posted back in forms should be converted to null.
+ true if empty strings that are posted back in forms should be converted to null; otherwise, false. The default value is true.
+
+
+ Gets or sets the description of the model.
+ The description of the model.
+
+
+ Gets a value that indicates whether the model is a complex type.
+ A value that indicates whether the model is considered a complex type by the Web API framework.
+
+
+ Gets or sets a value that indicates whether the model is read-only.
+ true if the model is read-only; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the prototype cache is updating.
+ true if the prototype cache is updating; otherwise, false.
+
+
+ Implements the default model metadata provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Creates the metadata from prototype for the specified property.
+ The metadata for the property.
+ The prototype.
+ The model accessor.
+
+
+ Creates the metadata for the specified property.
+ The metadata for the property.
+ The attributes.
+ The type of the container.
+ The type of the model.
+ The name of the property.
+
+
+ Represents an empty model metadata provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Creates metadata from prototype.
+ The metadata.
+ The model metadata prototype.
+ The model accessor.
+
+
+ Creates a prototype of the metadata provider of the .
+ A prototype of the metadata provider.
+ The attributes.
+ The type of container.
+ The type of model.
+ The name of the property.
+
+
+ Represents the binding directly to the cancellation token.
+
+
+ Initializes a new instance of the class.
+ The binding descriptor.
+
+
+ Executes the binding during synchronization.
+ The binding during synchronization.
+ The metadata provider.
+ The action context.
+ The notification after the cancellation of the operations.
+
+
+ Represents an attribute that invokes a custom model binder.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves the associated model binder.
+ A reference to an object that implements the interface.
+
+
+ Represents the default action value of the binder.
+
+
+ Initializes a new instance of the class.
+
+
+ Default implementation of the interface. This interface is the primary entry point for binding action parameters.
+ The associated with the .
+ The action descriptor.
+
+
+ Gets the associated with the .
+ The associated with the .
+ The parameter descriptor.
+
+
+ Defines a binding error.
+
+
+ Initializes a new instance of the class.
+ The error descriptor.
+ The message.
+
+
+ Gets the error message.
+ The error message.
+
+
+ Executes the binding method during synchronization.
+ The metadata provider.
+ The action context.
+ The cancellation Token value.
+
+
+ Represents parameter binding that will read from the body and invoke the formatters.
+
+
+ Initializes a new instance of the class.
+ The descriptor.
+ The formatter.
+ The body model validator.
+
+
+ Gets or sets an interface for the body model validator.
+ An interface for the body model validator.
+
+
+ Gets the error message.
+ The error message.
+
+
+ Asynchronously execute the binding of .
+ The result of the action.
+ The metadata provider.
+ The context associated with the action.
+ The cancellation token.
+
+
+ Gets or sets an enumerable object that represents the formatter for the parameter binding.
+ An enumerable object that represents the formatter for the parameter binding.
+
+
+ Asynchronously reads the content of .
+ The result of the action.
+ The request.
+ The type.
+ The formatter.
+ The format logger.
+
+
+
+ Gets whether the will read body.
+ True if the will read body; otherwise, false.
+
+
+ Represents the extensions for the collection of form data.
+
+
+ Reads the collection extensions with specified type.
+ The read collection extensions.
+ The form data.
+ The generic type.
+
+
+ Reads the collection extensions with specified type.
+ The collection extensions.
+ The form data.
+ The name of the model.
+ The required member selector.
+ The formatter logger.
+ The generic type.
+
+
+
+
+
+ Reads the collection extensions with specified type.
+ The collection extensions with specified type.
+ The form data.
+ The type of the object.
+
+
+ Reads the collection extensions with specified type and model name.
+ The collection extensions.
+ The form data.
+ The type of the object.
+ The name of the model.
+ The required member selector.
+ The formatter logger.
+
+
+ Deserialize the form data to the given type, using model binding.
+ best attempt to bind the object. The best attempt may be null.
+ collection with parsed form url data
+ target type to read as
+ null or empty to read the entire form as a single object. This is common for body data. Or the name of a model to do a partial binding against the form data. This is common for extracting individual fields.
+ The used to determine required members.
+ The to log events to.
+ The configuration to pick binder from. Can be null if the config was not created already. In that case a new config is created.
+
+
+
+
+
+
+
+ Enumerates the behavior of the HTTP binding.
+
+
+ Never use HTTP binding.
+
+
+ The optional binding behavior
+
+
+ HTTP binding is required.
+
+
+ Provides a base class for model-binding behavior attributes.
+
+
+ Initializes a new instance of the class.
+ The behavior.
+
+
+ Gets or sets the behavior category.
+ The behavior category.
+
+
+ Gets the unique identifier for this attribute.
+ The id for this attribute.
+
+
+ Parameter binds to the request.
+
+
+ Initializes a new instance of the class.
+ The parameter descriptor.
+
+
+ Asynchronously executes parameter binding.
+ The binded parameter.
+ The metadata provider.
+ The action context.
+ The cancellation token.
+
+
+ Defines the methods that are required for a model binder.
+
+
+ Binds the model to a value by using the specified controller context and binding context.
+ true if model binding is successful; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Represents a value provider for parameter binding.
+
+
+ Gets the instances used by this parameter binding.
+ The instances used by this parameter binding.
+
+
+ Represents the class for handling HTML form URL-ended data, also known as application/x-www-form-urlencoded.
+
+
+ Initializes a new instance of the class.
+
+
+
+ Determines whether this can read objects of the specified .
+ true if objects of this type can be read; otherwise false.
+ The type of object that will be read.
+
+
+ Reads an object of the specified from the specified stream. This method is called during deserialization.
+ A whose result will be the object instance that has been read.
+ The type of object to read.
+ The from which to read.
+ The content being read.
+ The to log events to.
+
+
+ Specify this parameter uses a model binder. This can optionally specify the specific model binder and value providers that drive that model binder. Derived attributes may provide convenience settings for the model binder or value provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The type of model binder.
+
+
+ Gets or sets the type of model binder.
+ The type of model binder.
+
+
+ Gets the binding for a parameter.
+ The that contains the binding.
+ The parameter to bind.
+
+
+ Get the IModelBinder for this type.
+ a non-null model binder.
+ The configuration.
+ model type that the binder is expected to bind.
+
+
+ Gets the model binder provider.
+ The instance.
+ The configuration object.
+
+
+ Gets the value providers that will be fed to the model binder.
+ A collection of instances.
+ The configuration object.
+
+
+ Gets or sets the name to consider as the parameter name during model binding.
+ The parameter name to consider.
+
+
+ Gets or sets a value that specifies whether the prefix check should be suppressed.
+ true if the prefix check should be suppressed; otherwise, false.
+
+
+ Provides a container for model-binder configuration.
+
+
+ Gets or sets the name of the resource file (class key) that contains localized string values.
+ The name of the resource file (class key).
+
+
+ Gets or sets the current provider for type-conversion error message.
+ The current provider for type-conversion error message.
+
+
+ Gets or sets the current provider for value-required error messages.
+ The error message provider.
+
+
+ Provides a container for model-binder error message provider.
+
+
+ Describes a parameter that gets bound via ModelBinding.
+
+
+ Initializes a new instance of the class.
+ The parameter descriptor.
+ The model binder.
+ The collection of value provider factory.
+
+
+ Gets the model binder.
+ The model binder.
+
+
+ Asynchronously executes the parameter binding via the model binder.
+ The task that is signaled when the binding is complete.
+ The metadata provider to use for validation.
+ The action context for the binding.
+ The cancellation token assigned for this task for cancelling the binding operation.
+
+
+ Gets the collection of value provider factory.
+ The collection of value provider factory.
+
+
+ Provides an abstract base class for model binder providers.
+
+
+ Initializes a new instance of the class.
+
+
+ Finds a binder for the given type.
+ A binder, which can attempt to bind this type. Or null if the binder knows statically that it will never be able to bind the type.
+ A configuration object.
+ The type of the model to bind against.
+
+
+ Provides the context in which a model binder functions.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The binding context.
+
+
+ Gets or sets a value that indicates whether the binder should use an empty prefix.
+ true if the binder should use an empty prefix; otherwise, false.
+
+
+ Gets or sets the model.
+ The model.
+
+
+ Gets or sets the model metadata.
+ The model metadata.
+
+
+ Gets or sets the name of the model.
+ The name of the model.
+
+
+ Gets or sets the state of the model.
+ The state of the model.
+
+
+ Gets or sets the type of the model.
+ The type of the model.
+
+
+ Gets the property metadata.
+ The property metadata.
+
+
+ Gets or sets the validation node.
+ The validation node.
+
+
+ Gets or sets the value provider.
+ The value provider.
+
+
+ Represents an error that occurs during model binding.
+
+
+ Initializes a new instance of the class by using the specified exception.
+ The exception.
+
+
+ Initializes a new instance of the class by using the specified exception and error message.
+ The exception.
+ The error message
+
+
+ Initializes a new instance of the class by using the specified error message.
+ The error message
+
+
+ Gets or sets the error message.
+ The error message.
+
+
+ Gets or sets the exception object.
+ The exception object.
+
+
+ Represents a collection of instances.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds the specified Exception object to the model-error collection.
+ The exception.
+
+
+ Adds the specified error message to the model-error collection.
+ The error message.
+
+
+ Encapsulates the state of model binding to a property of an action-method argument, or to the argument itself.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a object that contains any errors that occurred during model binding.
+ The model state errors.
+
+
+ Gets a object that encapsulates the value that was being bound during model binding.
+ The model state value.
+
+
+ Represents the state of an attempt to bind a posted form to an action method, which includes validation information.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using values that are copied from the specified model-state dictionary.
+ The dictionary.
+
+
+ Adds the specified item to the model-state dictionary.
+ The object to add to the model-state dictionary.
+
+
+ Adds an element that has the specified key and value to the model-state dictionary.
+ The key of the element to add.
+ The value of the element to add.
+
+
+ Adds the specified model error to the errors collection for the model-state dictionary that is associated with the specified key.
+ The key.
+ The exception.
+
+
+ Adds the specified error message to the errors collection for the model-state dictionary that is associated with the specified key.
+ The key.
+ The error message.
+
+
+ Removes all items from the model-state dictionary.
+
+
+ Determines whether the model-state dictionary contains a specific value.
+ true if item is found in the model-state dictionary; otherwise, false.
+ The object to locate in the model-state dictionary.
+
+
+ Determines whether the model-state dictionary contains the specified key.
+ true if the model-state dictionary contains the specified key; otherwise, false.
+ The key to locate in the model-state dictionary.
+
+
+ Copies the elements of the model-state dictionary to an array, starting at a specified index.
+ The array. The array must have zero-based indexing.
+ The zero-based index in array at which copying starts.
+
+
+ Gets the number of key/value pairs in the collection.
+ The number of key/value pairs in the collection.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Gets a value that indicates whether the collection is read-only.
+ true if the collection is read-only; otherwise, false.
+
+
+ Gets a value that indicates whether this instance of the model-state dictionary is valid.
+ true if this instance is valid; otherwise, false.
+
+
+ Determines whether there are any objects that are associated with or prefixed with the specified key.
+ true if the model-state dictionary contains a value that is associated with the specified key; otherwise, false.
+ The key.
+
+
+ Gets or sets the value that is associated with the specified key.
+ The model state item.
+ The key.
+
+
+ Gets a collection that contains the keys in the dictionary.
+ A collection that contains the keys of the model-state dictionary.
+
+
+ Copies the values from the specified object into this dictionary, overwriting existing values if keys are the same.
+ The dictionary.
+
+
+ Removes the first occurrence of the specified object from the model-state dictionary.
+ true if item was successfully removed the model-state dictionary; otherwise, false. This method also returns false if item is not found in the model-state dictionary.
+ The object to remove from the model-state dictionary.
+
+
+ Removes the element that has the specified key from the model-state dictionary.
+ true if the element is successfully removed; otherwise, false. This method also returns false if key was not found in the model-state dictionary.
+ The key of the element to remove.
+
+
+ Sets the value for the specified key by using the specified value provider dictionary.
+ The key.
+ The value.
+
+
+ Returns an enumerator that iterates through a collection.
+ An IEnumerator object that can be used to iterate through the collection.
+
+
+ Attempts to gets the value that is associated with the specified key.
+ true if the object contains an element that has the specified key; otherwise, false.
+ The key of the value to get.
+ The value associated with the specified key.
+
+
+ Gets a collection that contains the values in the dictionary.
+ A collection that contains the values of the model-state dictionary.
+
+
+ Collection of functions that can produce a parameter binding for a given parameter.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds function to the end of the collection. The function added is a wrapper around funcInner that checks that parameterType matches typeMatch.
+ type to match against HttpParameterDescriptor.ParameterType
+ inner function that is invoked if type match succeeds
+
+
+ Insert a function at the specified index in the collection. /// The function added is a wrapper around funcInner that checks that parameterType matches typeMatch.
+ index to insert at.
+ type to match against HttpParameterDescriptor.ParameterType
+ inner function that is invoked if type match succeeds
+
+
+ Execute each binding function in order until one of them returns a non-null binding.
+ the first non-null binding produced for the parameter. Of null if no binding is produced.
+ parameter to bind.
+
+
+ Maps a browser request to an array.
+ The type of the array.
+
+
+ Initializes a new instance of the class.
+
+
+ Indicates whether the model is binded.
+ true if the specified model is binded; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Converts the collection to an array.
+ true in all cases.
+ The action context.
+ The binding context.
+ The new collection.
+
+
+ Provides a model binder for arrays.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a model binder for arrays.
+ A model binder object or null if the attempt to get a model binder is unsuccessful.
+ The configuration.
+ The type of model.
+
+
+ Maps a browser request to a collection.
+ The type of the collection.
+
+
+ Initializes a new instance of the class.
+
+
+ Binds the model by using the specified execution context and binding context.
+ true if model binding is successful; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Provides a way for derived classes to manipulate the collection before returning it from the binder.
+ true in all cases.
+ The action context.
+ The binding context.
+ The new collection.
+
+
+ Provides a model binder for a collection.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves a model binder for a collection.
+ The model binder.
+ The configuration of the model.
+ The type of the model.
+
+
+ Represents a data transfer object (DTO) for a complex model.
+
+
+ Initializes a new instance of the class.
+ The model metadata.
+ The collection of property metadata.
+
+
+ Gets or sets the model metadata of the .
+ The model metadata of the .
+
+
+ Gets or sets the collection of property metadata of the .
+ The collection of property metadata of the .
+
+
+ Gets or sets the results of the .
+ The results of the .
+
+
+ Represents a model binder for object.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the specified model is binded.
+ true if the specified model is binded; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Represents a complex model that invokes a model binder provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves the associated model binder.
+ The model binder.
+ The configuration.
+ The type of the model to retrieve.
+
+
+ Represents the result for object.
+
+
+ Initializes a new instance of the class.
+ The object model.
+ The validation node.
+
+
+ Gets or sets the model for this object.
+ The model for this object.
+
+
+ Gets or sets the for this object.
+ The for this object.
+
+
+ Represents an that delegates to one of a collection of instances.
+
+
+ Initializes a new instance of the class.
+ An enumeration of binders.
+
+
+ Initializes a new instance of the class.
+ An array of binders.
+
+
+ Indicates whether the specified model is binded.
+ true if the model is binded; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Represents the class for composite model binder providers.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ A collection of
+
+
+ Gets the binder for the model.
+ The binder for the model.
+ The binder configuration.
+ The type of the model.
+
+
+ Gets the providers for the composite model binder.
+ The collection of providers.
+
+
+ Maps a browser request to a dictionary data object.
+ The type of the key.
+ The type of the value.
+
+
+ Initializes a new instance of the class.
+
+
+ Converts the collection to a dictionary.
+ true in all cases.
+ The action context.
+ The binding context.
+ The new collection.
+
+
+ Provides a model binder for a dictionary.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves the associated model binder.
+ The associated model binder.
+ The configuration to use.
+ The type of model.
+
+
+ Maps a browser request to a key/value pair data object.
+ The type of the key.
+ The type of the value.
+
+
+ Initializes a new instance of the class.
+
+
+ Binds the model by using the specified execution context and binding context.
+ true if model binding is successful; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Provides a model binder for a collection of key/value pairs.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves the associated model binder.
+ The associated model binder.
+ The configuration.
+ The type of model.
+
+
+ Maps a browser request to a mutable data object.
+
+
+ Initializes a new instance of the class.
+
+
+ Binds the model by using the specified action context and binding context.
+ true if binding is successful; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Retrieves a value that indicates whether a property can be updated.
+ true if the property can be updated; otherwise, false.
+ The metadata for the property to be evaluated.
+
+
+ Creates an instance of the model.
+ The newly created model object.
+ The action context.
+ The binding context.
+
+
+ Creates a model instance if an instance does not yet exist in the binding context.
+ The action context.
+ The binding context.
+
+
+ Retrieves metadata for properties of the model.
+ The metadata for properties of the model.
+ The action context.
+ The binding context.
+
+
+ Sets the value of a specified property.
+ The action context.
+ The binding context.
+ The metadata for the property to set.
+ The validation information about the property.
+ The validator for the model.
+
+
+ Provides a model binder for mutable objects.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves the model binder for the specified type.
+ The model binder.
+ The configuration.
+ The type of the model to retrieve.
+
+
+ Provides a simple model binder for this model binding class.
+
+
+ Initializes a new instance of the class.
+ The model type.
+ The model binder factory.
+
+
+ Initializes a new instance of the class by using the specified model type and the model binder.
+ The model type.
+ The model binder.
+
+
+ Returns a model binder by using the specified execution context and binding context.
+ The model binder, or null if the attempt to get a model binder is unsuccessful.
+ The configuration.
+ The model type.
+
+
+ Gets the type of the model.
+ The type of the model.
+
+
+ Gets or sets a value that specifies whether the prefix check should be suppressed.
+ true if the prefix check should be suppressed; otherwise, false.
+
+
+ Maps a browser request to a data object. This type is used when model binding requires conversions using a .NET Framework type converter.
+
+
+ Initializes a new instance of the class.
+
+
+ Binds the model by using the specified controller context and binding context.
+ true if model binding is successful; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Provides a model binder for a model that requires type conversion.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieve a model binder for a model that requires type conversion.
+ The model binder, or Nothing if the type cannot be converted or there is no value to convert.
+ The configuration of the binder.
+ The type of the model.
+
+
+ Maps a browser request to a data object. This class is used when model binding does not require type conversion.
+
+
+ Initializes a new instance of the class.
+
+
+ Binds the model by using the specified execution context and binding context.
+ true if model binding is successful; otherwise, false.
+ The action context.
+ The binding context.
+
+
+ Provides a model binder for a model that does not require type conversion.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves the associated model binder.
+ The associated model binder.
+ The configuration.
+ The type of model.
+
+
+ Represents an action result that returns response and performs content negotiation on an see with .
+
+
+ Initializes a new instance of the class.
+ The user-visible error message.
+ The content negotiator to handle content negotiation.
+ The request message which led to this result.
+ The formatters to use to negotiate and format the content.
+
+
+ Initializes a new instance of the class.
+ The user-visible error message.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the content negotiator to handle content negotiation.
+ Returns .
+
+
+ Returns .
+
+
+ Gets the formatters to use to negotiate and format the content.
+ Returns .
+
+
+ Gets the user-visible error message.
+ Returns .
+
+
+ Gets the request message which led to this result.
+ Returns .
+
+
+ Represents an action result that returns an empty response.
+
+
+ Initializes a new instance of the class.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Asynchronously executes the request.
+ The task that completes the execute operation.
+ The cancellation token.
+
+
+ Gets the request message which led to this result.
+ The request message which led to this result.
+
+
+ Represents an action result that returns an empty HttpStatusCode.Conflict response.
+
+
+ Initializes a new instance of the class.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Executes asynchronously the operation of the conflict result.
+ Asynchronously executes the specified task.
+ The cancellation token.
+
+
+ Gets the request message which led to this result.
+ The HTTP request message which led to this result.
+
+
+ Represents an action result that performs route generation and content negotiation and returns a response when content negotiation succeeds.
+ The type of content in the entity body.
+
+
+ Initializes a new instance of the class with the values provided.
+ The name of the route to use for generating the URL.
+ The route data to use for generating the URL.
+ The content value to negotiate and format in the entity body.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Initializes a new instance of the class with the values provided.
+ The name of the route to use for generating the URL.
+ The route data to use for generating the URL.
+ The content value to negotiate and format in the entity body.
+ The factory to use to generate the route URL.
+ The content negotiator to handle content negotiation.
+ The request message which led to this result.
+ The formatters to use to negotiate and format the content.
+
+
+ Gets the content value to negotiate and format in the entity body.
+
+
+ Gets the content negotiator to handle content negotiation.
+
+
+
+ Gets the formatters to use to negotiate and format the content.
+
+
+ Gets the request message which led to this result.
+
+
+ Gets the name of the route to use for generating the URL.
+
+
+ Gets the route data to use for generating the URL.
+
+
+ Gets the factory to use to generate the route URL.
+
+
+ Represents an action result that performs content negotiation and returns a response when it succeeds.
+ The type of content in the entity body.
+
+
+ Initializes a new instance of the class with the values provided.
+ The content value to negotiate and format in the entity body.
+ The location at which the content has been created.
+ The content negotiator to handle content negotiation.
+ The request message which led to this result.
+ The formatters to use to negotiate and format the content.
+
+
+ Initializes a new instance of the class with the values provided.
+ The location at which the content has been created.
+ The content value to negotiate and format in the entity body.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the content value to negotiate and format in the entity body.
+ The content value to negotiate and format in the entity body.
+
+
+ Gets the content negotiator to handle content negotiation.
+ The content negotiator to handle content negotiation.
+
+
+ Executes asynchronously the operation of the created negotiated content result.
+ Asynchronously executes a return value.
+ The cancellation token.
+
+
+ Gets the formatters to use to negotiate and format the content.
+ The formatters to use to negotiate and format the content.
+
+
+ Gets the location at which the content has been created.
+ The location at which the content has been created.
+
+
+ Gets the request message which led to this result.
+ The HTTP request message which led to this result.
+
+
+ Represents an action result that returns a response and performs content negotiation on an based on an .
+
+
+ Initializes a new instance of the class.
+ The exception to include in the error.
+ true if the error should include exception messages; otherwise, false .
+ The content negotiator to handle content negotiation.
+ The request message which led to this result.
+ The formatters to use to negotiate and format the content.
+
+
+ Initializes a new instance of the class.
+ The exception to include in the error.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the content negotiator to handle content negotiation.
+ Returns .
+
+
+ Gets the exception to include in the error.
+ Returns .
+
+
+ Returns .
+
+
+ Gets the formatters to use to negotiate and format the content.
+ Returns .
+
+
+ Gets a value indicating whether the error should include exception messages.
+ Returns .
+
+
+ Gets the request message which led to this result.
+ Returns .
+
+
+ Represents an action result that returns formatted content.
+ The type of content in the entity body.
+
+
+ Initializes a new instance of the class with the values provided.
+ The HTTP status code for the response message.
+ The content value to format in the entity body.
+ The formatter to use to format the content.
+ The value for the Content-Type header, or to have the formatter pick a default value.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class with the values provided.
+ The HTTP status code for the response message.
+ The content value to format in the entity body.
+ The formatter to use to format the content.
+ The value for the Content-Type header, or to have the formatter pick a default value.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the content value to format in the entity body.
+
+
+
+ Gets the formatter to use to format the content.
+
+
+ Gets the value for the Content-Type header, or to have the formatter pick a default value.
+
+
+ Gets the request message which led to this result.
+
+
+ Gets the HTTP status code for the response message.
+
+
+ Represents an action result that returns an empty response.
+
+
+ Initializes a new instance of the class.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Returns .
+
+
+ Gets the request message which led to this result.
+ Returns .
+
+
+ Represents an action result that returns a response and performs content negotiation on an based on a .
+
+
+ Initializes a new instance of the class.
+ The model state to include in the error.
+ true if the error should include exception messages; otherwise, false.
+ The content negotiator to handle content negotiation.
+ The request message which led to this result.
+ The formatters to use to negotiate and format the content.
+
+
+ Initializes a new instance of the class.
+ The model state to include in the error.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the content negotiator to handle content negotiation.
+ The content negotiator to handle content negotiation.
+
+
+ Creates a response message asynchronously.
+ A task that, when completed, contains the response message.
+ The token to monitor for cancellation requests.
+
+
+ Gets the formatters to use to negotiate and format the content.
+ The formatters to use to negotiate and format the content.
+
+
+ Gets a value indicating whether the error should include exception messages.
+ true if the error should include exception messages; otherwise, false.
+
+
+ Gets the model state to include in the error.
+ The model state to include in the error.
+
+
+ Gets the request message which led to this result.
+ The request message which led to this result.
+
+
+ Represents an action result that returns an response with JSON data.
+ The type of content in the entity body.
+
+
+ Initializes a new instance of the class with the values provided.
+ The content value to serialize in the entity body.
+ The serializer settings.
+ The content encoding.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class with the values provided.
+ The content value to serialize in the entity body.
+ The serializer settings.
+ The content encoding.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the content value to serialize in the entity body.
+ The content value to serialize in the entity body.
+
+
+ Gets the content encoding.
+ The content encoding.
+
+
+ Creates a response message asynchronously.
+ A task that, when completed, contains the response message.
+ The token to monitor for cancellation requests.
+
+
+ Gets the request message which led to this result.
+ The request message which led to this result.
+
+
+ Gets the serializer settings.
+ The serializer settings.
+
+
+ Represents an action result that performs content negotiation.
+ The type of content in the entity body.
+
+
+ Initializes a new instance of the class with the values provided.
+ The HTTP status code for the response message.
+ The content value to negotiate and format in the entity body.
+ The content negotiator to handle content negotiation.
+ The request message which led to this result.
+ The formatters to use to negotiate and format the content.
+
+
+ Initializes a new instance of the class with the values provided.
+ The HTTP status code for the response message.
+ The content value to negotiate and format in the entity body.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the content value to negotiate and format in the entity body.
+ The content value to negotiate and format in the entity body.
+
+
+ Gets the content negotiator to handle content negotiation.
+ The content negotiator to handle content negotiation.
+
+
+ Executes asynchronously an HTTP negotiated content results.
+ Asynchronously executes an HTTP negotiated content results.
+ The cancellation token.
+
+
+ Gets the formatters to use to negotiate and format the content.
+ The formatters to use to negotiate and format the content.
+
+
+ Gets the request message which led to this result.
+ The HTTP request message which led to this result.
+
+
+ Gets the HTTP status code for the response message.
+ The HTTP status code for the response message.
+
+
+ Represents an action result that returns an empty response.
+
+
+ Initializes a new instance of the class.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+
+ Gets the request message which led to this result.
+
+
+ Represents an action result that performs content negotiation and returns an HttpStatusCode.OK response when it succeeds.
+ The type of content in the entity body.
+
+
+ Initializes a new instance of the class with the values provided.
+ The content value to negotiate and format in the entity body.
+ The content negotiator to handle content negotiation.
+ The request message which led to this result.
+ The formatters to use to negotiate and format the content.
+
+
+ Initializes a new instance of the class with the values provided.
+ The content value to negotiate and format in the entity body.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the content value to negotiate and format in the entity body.
+
+
+ Gets the content negotiator to handle content negotiation.
+
+
+
+ Gets the formatters to use to negotiate and format the content.
+
+
+ Gets the request message which led to this result.
+
+
+ Represents an action result that returns an empty HttpStatusCode.OK response.
+
+
+ Initializes a new instance of the class.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Executes asynchronously.
+ Returns the task.
+ The cancellation token.
+
+
+ Gets a HTTP request message for the results.
+ A HTTP request message for the results.
+
+
+ Represents an action result for a <see cref="F:System.Net.HttpStatusCode.Redirect"/>.
+
+
+ Initializes a new instance of the <see cref="T:System.Web.Http.Results.RedirectResult"/> class with the values provided.
+ The location to which to redirect.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the <see cref="T:System.Web.Http.Results.RedirectResult"/> class with the values provided.
+ The location to which to redirect.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Returns .
+
+
+ Gets the location at which the content has been created.
+ Returns .
+
+
+ Gets the request message which led to this result.
+ Returns .
+
+
+ Represents an action result that performs route generation and returns a <see cref="F:System.Net.HttpStatusCode.Redirect"/> response.
+
+
+ Initializes a new instance of the <see cref="T:System.Web.Http.Results.RedirectToRouteResult"/> class with the values provided.
+ The name of the route to use for generating the URL.
+ The route data to use for generating the URL.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Initializes a new instance of the <see cref="T:System.Web.Http.Results.RedirectToRouteResult"/> class with the values provided.
+ The name of the route to use for generating the URL.
+ The route data to use for generating the URL.
+ The factory to use to generate the route URL.
+ The request message which led to this result.
+
+
+ Returns .
+
+
+ Gets the request message which led to this result.
+ Returns .
+
+
+ Gets the name of the route to use for generating the URL.
+ Returns .
+
+
+ Gets the route data to use for generating the URL.
+ Returns .
+
+
+ Gets the factory to use to generate the route URL.
+ Returns .
+
+
+ Represents an action result that returns a specified response message.
+
+
+ Initializes a new instance of the class.
+ The response message.
+
+
+
+ Gets the response message.
+
+
+ Represents an action result that returns a specified HTTP status code.
+
+
+ Initializes a new instance of the class.
+ The HTTP status code for the response message.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class.
+ The HTTP status code for the response message.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Creates a response message asynchronously.
+ A task that, when completed, contains the response message.
+ The token to monitor for cancellation requests.
+
+
+ Gets the request message which led to this result.
+ The request message which led to this result.
+
+
+ Gets the HTTP status code for the response message.
+ The HTTP status code for the response message.
+
+
+ Represents an action result that returns an response.
+
+
+ Initializes a new instance of the class.
+ The WWW-Authenticate challenges.
+ The request message which led to this result.
+
+
+ Initializes a new instance of the class.
+ The WWW-Authenticate challenges.
+ The controller from which to obtain the dependencies needed for execution.
+
+
+ Gets the WWW-Authenticate challenges.
+ Returns .
+
+
+ Returns .
+
+
+ Gets the request message which led to this result.
+ Returns .
+
+
+ A default implementation of .
+
+
+
+ Creates instances based on the provided factories and action. The route entries provide direct routing to the provided action.
+ A set of route entries.
+ The action descriptor.
+ The direct route factories.
+ The constraint resolver.
+
+
+ Gets a set of route factories for the given action descriptor.
+ A set of route factories.
+ The action descriptor.
+
+
+ Creates instances based on the provided factories, controller and actions. The route entries provided direct routing to the provided controller and can reach the set of provided actions.
+ A set of route entries.
+ The controller descriptor.
+ The action descriptors.
+ The direct route factories.
+ The constraint resolver.
+
+
+ Gets route factories for the given controller descriptor.
+ A set of route factories.
+ The controller descriptor.
+
+
+ Gets direct routes for the given controller descriptor and action descriptors based on attributes.
+ A set of route entries.
+ The controller descriptor.
+ The action descriptors for all actions.
+ The constraint resolver.
+
+
+ Gets the route prefix from the provided controller.
+ The route prefix or null.
+ The controller descriptor.
+
+
+ The default implementation of . Resolves constraints by parsing a constraint key and constraint arguments, using a map to resolve the constraint type, and calling an appropriate constructor for the constraint type.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the mutable dictionary that maps constraint keys to a particular constraint type.
+ The mutable dictionary that maps constraint keys to a particular constraint type.
+
+
+ Resolves the inline constraint.
+ The the inline constraint was resolved to.
+ The inline constraint to resolve.
+
+
+ Represents a context that supports creating a direct route.
+
+
+ Initializes a new instance of the class.
+ The route prefix, if any, defined by the controller.
+ The action descriptors to which to create a route.
+ The inline constraint resolver.
+ A value indicating whether the route is configured at the action or controller level.
+
+
+ Gets the action descriptors to which to create a route.
+ The action descriptors to which to create a route.
+
+
+ Creates a route builder that can build a route matching this context.
+ A route builder that can build a route matching this context.
+ The route template.
+
+
+ Creates a route builder that can build a route matching this context.
+ A route builder that can build a route matching this context.
+ The route template.
+ The inline constraint resolver to use, if any; otherwise, null.
+
+
+ Gets the inline constraint resolver.
+ The inline constraint resolver.
+
+
+ Gets the route prefix, if any, defined by the controller.
+ The route prefix, if any, defined by the controller.
+
+
+ Gets a value indicating whether the route is configured at the action or controller level.
+ true when the route is configured at the action level; otherwise false (if the route is configured at the controller level).
+
+
+ Enables you to define which HTTP verbs are allowed when ASP.NET routing determines whether a URL matches a route.
+
+
+ Initializes a new instance of the class by using the HTTP verbs that are allowed for the route.
+ The HTTP verbs that are valid for the route.
+
+
+ Gets or sets the collection of allowed HTTP verbs for the route.
+ A collection of allowed HTTP verbs for the route.
+
+
+ Determines whether the request was made with an HTTP verb that is one of the allowed verbs for the route.
+ When ASP.NET routing is processing a request, true if the request was made by using an allowed HTTP verb; otherwise, false. When ASP.NET routing is constructing a URL, true if the supplied values contain an HTTP verb that matches one of the allowed HTTP verbs; otherwise, false. The default is true.
+ The request that is being checked to determine whether it matches the URL.
+ The object that is being checked to determine whether it matches the URL.
+ The name of the parameter that is being checked.
+ An object that contains the parameters for a route.
+ An object that indicates whether the constraint check is being performed when an incoming request is processed or when a URL is generated.
+
+
+ Determines whether the request was made with an HTTP verb that is one of the allowed verbs for the route.
+ When ASP.NET routing is processing a request, true if the request was made by using an allowed HTTP verb; otherwise, false. When ASP.NET routing is constructing a URL, true if the supplied values contain an HTTP verb that matches one of the allowed HTTP verbs; otherwise, false. The default is true.
+ The request that is being checked to determine whether it matches the URL.
+ The object that is being checked to determine whether it matches the URL.
+ The name of the parameter that is being checked.
+ An object that contains the parameters for a route.
+ An object that indicates whether the constraint check is being performed when an incoming request is processed or when a URL is generated.
+
+
+ Represents a route class for self-host (i.e. hosted outside of ASP.NET).
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The route template.
+
+
+ Initializes a new instance of the class.
+ The route template.
+ The default values for the route parameters.
+
+
+ Initializes a new instance of the class.
+ The route template.
+ The default values for the route parameters.
+ The constraints for the route parameters.
+
+
+ Initializes a new instance of the class.
+ The route template.
+ The default values for the route parameters.
+ The constraints for the route parameters.
+ Any additional tokens for the route parameters.
+
+
+ Initializes a new instance of the class.
+ The route template.
+ The default values for the route parameters.
+ The constraints for the route parameters.
+ Any additional tokens for the route parameters.
+ The message handler that will be the recipient of the request.
+
+
+ Gets the constraints for the route parameters.
+ The constraints for the route parameters.
+
+
+ Gets any additional data tokens not used directly to determine whether a route matches an incoming .
+ Any additional data tokens not used directly to determine whether a route matches an incoming .
+
+
+ Gets the default values for route parameters if not provided by the incoming .
+ The default values for route parameters if not provided by the incoming .
+
+
+ Determines whether this route is a match for the incoming request by looking up the for the route.
+ The for a route if matches; otherwise null.
+ The virtual path root.
+ The HTTP request.
+
+
+ Attempts to generate a URI that represents the values passed in based on current values from the and new values using the specified .
+ A instance or null if URI cannot be generated.
+ The HTTP request message.
+ The route values.
+
+
+ Gets or sets the http route handler.
+ The http route handler.
+
+
+ Specifies the HTTP route key.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP request.
+ The constraints for the route parameters.
+ The name of the parameter.
+ The list of parameter values.
+ One of the enumeration values of the enumeration.
+
+
+ Gets the route template describing the URI pattern to match against.
+ The route template describing the URI pattern to match against.
+
+
+ Encapsulates information regarding the HTTP route.
+
+
+ Initializes a new instance of the class.
+ An object that defines the route.
+
+
+ Initializes a new instance of the class.
+ An object that defines the route.
+ The value.
+
+
+ Gets the object that represents the route.
+ the object that represents the route.
+
+
+ Gets a collection of URL parameter values and default values for the route.
+ An object that contains values that are parsed from the URL and from default values.
+
+
+ Removes all optional parameters that do not have a value from the route data.
+
+
+ If a route is really a union of other routes, return the set of sub routes.
+ Returns the set of sub routes contained within this route.
+ A union route data.
+
+
+ Removes all optional parameters that do not have a value from the route data.
+ The route data, to be mutated in-place.
+
+
+ Specifies an enumeration of route direction.
+
+
+ The UriGeneration direction.
+
+
+ The UriResolution direction.
+
+
+ Represents a route class for self-host of specified key/value pairs.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The dictionary.
+
+
+ Initializes a new instance of the class.
+ The key value.
+
+
+ Presents the data regarding the HTTP virtual path.
+
+
+ Initializes a new instance of the class.
+ The route of the virtual path.
+ The URL that was created from the route definition.
+
+
+ Gets or sets the route of the virtual path..
+ The route of the virtual path.
+
+
+ Gets or sets the URL that was created from the route definition.
+ The URL that was created from the route definition.
+
+
+ Defines a builder that creates direct routes to actions (attribute routes).
+
+
+ Gets the action descriptors to which to create a route.
+ The action descriptors to which to create a route.
+
+
+ Creates a route entry based on the current property values.
+ The route entry created.
+
+
+ Gets or sets the route constraints.
+ The route constraints.
+
+
+ Gets or sets the route data tokens.
+ The route data tokens.
+
+
+ Gets or sets the route defaults.
+ The route defaults.
+
+
+ Gets or sets the route name, if any; otherwise null.
+ The route name, if any; otherwise null.
+
+
+ Gets or sets the route order.
+ The route order.
+
+
+ Gets or sets the route precedence.
+ The route precedence.
+
+
+ Gets a value indicating whether the route is configured at the action or controller level.
+ true when the route is configured at the action level; otherwise false (if the route is configured at the controller level).
+
+
+ Gets or sets the route template.
+ The route template.
+
+
+ Defines a factory that creates a route directly to a set of action descriptors (an attribute route).
+
+
+ Creates a direct route entry.
+ The direct route entry.
+ The context to use to create the route.
+
+
+ Defines a provider for routes that directly target action descriptors (attribute routes).
+
+
+ Gets the direct routes for a controller.
+ A set of route entries for the controller.
+ The controller descriptor.
+ The action descriptors.
+ The inline constraint resolver.
+
+
+
+ defines the interface for a route expressing how to map an incoming to a particular controller and action.
+
+
+ Gets the constraints for the route parameters.
+ The constraints for the route parameters.
+
+
+ Gets any additional data tokens not used directly to determine whether a route matches an incoming .
+ The additional data tokens.
+
+
+ Gets the default values for route parameters if not provided by the incoming .
+ The default values for route parameters.
+
+
+ Determine whether this route is a match for the incoming request by looking up the <see cref="!:IRouteData" /> for the route.
+ The <see cref="!:RouteData" /> for a route if matches; otherwise null.
+ The virtual path root.
+ The request.
+
+
+ Gets a virtual path data based on the route and the values provided.
+ The virtual path data.
+ The request message.
+ The values.
+
+
+ Gets the message handler that will be the recipient of the request.
+ The message handler.
+
+
+ Gets the route template describing the URI pattern to match against.
+ The route template.
+
+
+ Represents a base class route constraint.
+
+
+ Determines whether this instance equals a specified route.
+ True if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Provides information about a route.
+
+
+ Gets the object that represents the route.
+ The object that represents the route.
+
+
+ Gets a collection of URL parameter values and default values for the route.
+ The values that are parsed from the URL and from default values.
+
+
+ Provides information for defining a route.
+
+
+ Gets the name of the route to generate.
+
+
+ Gets the order of the route relative to other routes.
+
+
+ Gets the route template describing the URI pattern to match against.
+
+
+ Defines the properties for HTTP route.
+
+
+ Gets the HTTP route.
+ The HTTP route.
+
+
+ Gets the URI that represents the virtual path of the current HTTP route.
+ The URI that represents the virtual path of the current HTTP route.
+
+
+ Defines an abstraction for resolving inline constraints as instances of .
+
+
+ Resolves the inline constraint.
+ The the inline constraint was resolved to.
+ The inline constraint to resolve.
+
+
+ Defines a route prefix.
+
+
+ Gets the route prefix.
+ The route prefix.
+
+
+ Represents a named route.
+
+
+ Initializes a new instance of the class.
+ The route name, if any; otherwise, null.
+ The route.
+
+
+ Gets the route name, if any; otherwise, null.
+ The route name, if any; otherwise, null.
+
+
+ Gets the route.
+ The route.
+
+
+ Represents an attribute route that may contain custom constraints.
+
+
+ Initializes a new instance of the class.
+ The route template.
+
+
+ Gets the route constraints, if any; otherwise null.
+ The route constraints, if any; otherwise null.
+
+
+ Creates the route entry
+ The created route entry.
+ The context.
+
+
+ Gets the route data tokens, if any; otherwise null.
+ The route data tokens, if any; otherwise null.
+
+
+ Gets the route defaults, if any; otherwise null.
+ The route defaults, if any; otherwise null.
+
+
+ Gets or sets the route name, if any; otherwise null.
+ The route name, if any; otherwise null.
+
+
+ Gets or sets the route order.
+ The route order.
+
+
+ Gets the route template.
+ The route template.
+
+
+ Represents a handler that specifies routing should not handle requests for a route template. When a route provides this class as a handler, requests matching against the route will be ignored.
+
+
+ Initializes a new instance of the class.
+
+
+ Represents a factory for creating URLs.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The HTTP request for this instance.
+
+
+ Creates an absolute URL using the specified path.
+ The generated URL.
+ The URL path, which may be a relative URL, a rooted URL, or a virtual path.
+
+
+ Returns a link for the specified route.
+ A link for the specified route.
+ The name of the route.
+ An object that contains the parameters for a route.
+
+
+ Returns a link for the specified route.
+ A link for the specified route.
+ The name of the route.
+ A route value.
+
+
+ Gets or sets the of the current instance.
+ The of the current instance.
+
+
+ Returns the route for the .
+ The route for the .
+ The name of the route.
+ A list of route values.
+
+
+ Returns the route for the .
+ The route for the .
+ The name of the route.
+ The route values.
+
+
+ Constrains a route parameter to contain only lowercase or uppercase letters A through Z in the English alphabet.
+
+
+ Initializes a new instance of the class.
+
+
+ Constrains a route parameter to represent only Boolean values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route by several child constraints.
+
+
+ Initializes a new instance of the class.
+ The child constraints that must match for this constraint to match.
+
+
+ Gets the child constraints that must match for this constraint to match.
+ The child constraints that must match for this constraint to match.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to represent only values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route of direction.
+
+
+ Constrains a route parameter to represent only decimal values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to represent only 64-bit floating-point values.
+
+
+
+
+ Constrains a route parameter to represent only 32-bit floating-point values.
+
+
+
+
+ Constrains a route parameter to represent only values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to represent only 32-bit integer values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to be a string of a given length or within a given range of lengths.
+
+
+
+ Initializes a new instance of the class that constrains a route parameter to be a string of a given length.
+ The minimum length of the route parameter.
+ The maximum length of the route parameter.
+
+
+ Gets the length of the route parameter, if one is set.
+
+
+
+ Gets the maximum length of the route parameter, if one is set.
+
+
+ Gets the minimum length of the route parameter, if one is set.
+
+
+ Constrains a route parameter to represent only 64-bit integer values.
+
+
+
+
+ Constrains a route parameter to be a string with a maximum length.
+
+
+ Initializes a new instance of the class.
+ The maximum length.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the maximum length of the route parameter.
+ The maximum length of the route parameter.
+
+
+ Constrains a route parameter to be an integer with a maximum value.
+
+
+
+
+ Gets the maximum value of the route parameter.
+
+
+ Constrains a route parameter to be a string with a maximum length.
+
+
+ Initializes a new instance of the class.
+ The minimum length.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the minimum length of the route parameter.
+ The minimum length of the route parameter.
+
+
+ Constrains a route parameter to be a long with a minimum value.
+
+
+ Initializes a new instance of the class.
+ The minimum value of the route parameter.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the minimum value of the route parameter.
+ The minimum value of the route parameter.
+
+
+ Constrains a route by an inner constraint that doesn't fail when an optional parameter is set to its default value.
+
+
+ Initializes a new instance of the class.
+ The inner constraint to match if the parameter is not an optional parameter without a value
+
+
+ Gets the inner constraint to match if the parameter is not an optional parameter without a value.
+ The inner constraint to match if the parameter is not an optional parameter without a value.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constraints a route parameter to be an integer within a given range of values.
+
+
+ Initializes a new instance of the class.
+ The minimum value.
+ The maximum value.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the maximum value of the route parameter.
+ The maximum value of the route parameter.
+
+
+ Gets the minimum value of the route parameter.
+ The minimum value of the route parameter.
+
+
+ Constrains a route parameter to match a regular expression.
+
+
+ Initializes a new instance of the class.
+ The pattern.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The request.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the regular expression pattern to match.
+ The regular expression pattern to match.
+
+
+ Provides a method for retrieving the innermost object of an object that might be wrapped by an <see cref="T:System.Web.Http.Services.IDecorator`1" />.
+
+
+ Gets the innermost object which does not implement <see cref="T:System.Web.Http.Services.IDecorator`1" />.
+ Object which needs to be unwrapped.
+
+
+
+ Represents a container for service instances used by the . Note that this container only supports known types, and methods to get or set arbitrary service types will throw when called. For creation of arbitrary types, please use instead. The supported types for this container are: Passing any type which is not on this to any method on this interface will cause an to be thrown.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class with a specified object.
+ The object.
+
+
+ Removes a single-instance service from the default services.
+ The type of the service.
+
+
+ Gets a service of the specified type.
+ The first instance of the service, or null if the service is not found.
+ The type of service.
+
+
+ Gets the list of service objects for a given service type, and validates the service type.
+ The list of service objects of the specified type.
+ The service type.
+
+
+ Gets the list of service objects for a given service type.
+ The list of service objects of the specified type, or an empty list if the service is not found.
+ The type of service.
+
+
+ Queries whether a service type is single-instance.
+ true if the service type has at most one instance, or false if the service type supports multiple instances.
+ The service type.
+
+
+ Replaces a single-instance service object.
+ The service type.
+ The service object that replaces the previous instance.
+
+
+ Removes the cached values for a single service type.
+ The service type.
+
+
+ Defines a decorator that exposes the inner decorated object.
+ This type parameter is covariant. That is, you can use either the type you specified or any type that is more derived. For more information about covariance and contravariance, see .
+
+
+ Gets the inner object.
+
+
+ Represents a performance tracing class to log method entry/exit and duration.
+
+
+ Initializes the class with a specified configuration.
+ The configuration.
+
+
+ Represents the trace writer.
+
+
+ Invokes the specified traceAction to allow setting values in a new if and only if tracing is permitted at the given category and level.
+ The current . It may be null but doing so will prevent subsequent trace analysis from correlating the trace to a particular request.
+ The logical category for the trace. Users can define their own.
+ The at which to write this trace.
+ The action to invoke if tracing is enabled. The caller is expected to fill in the fields of the given in this action.
+
+
+ Represents an extension methods for .
+
+
+ Provides a set of methods and properties that help debug your code with the specified writer, request, category and exception.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The error occurred during execution.
+
+
+ Provides a set of methods and properties that help debug your code with the specified writer, request, category, exception, message format and argument.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The error occurred during execution.
+ The format of the message.
+ The message argument.
+
+
+ Provides a set of methods and properties that help debug your code with the specified writer, request, category, exception, message format and argument.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The format of the message.
+ The message argument.
+
+
+ Displays an error message in the list with the specified writer, request, category and exception.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The error occurred during execution.
+
+
+ Displays an error message in the list with the specified writer, request, category, exception, message format and argument.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The exception.
+ The format of the message.
+ The argument in the message.
+
+
+ Displays an error message in the list with the specified writer, request, category, message format and argument.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The format of the message.
+ The argument in the message.
+
+
+ Displays an error message in the class with the specified writer, request, category and exception.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The exception that appears during execution.
+
+
+ Displays an error message in the class with the specified writer, request, category and exception, message format and argument.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The exception.
+ The format of the message.
+ The message argument.
+
+
+ Displays an error message in the class with the specified writer, request, category and message format and argument.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The format of the message.
+ The message argument.
+
+
+ Displays the details in the .
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The error occurred during execution.
+
+
+ Displays the details in the .
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The error occurred during execution.
+ The format of the message.
+ The message argument.
+
+
+ Displays the details in the .
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The format of the message.
+ The message argument.
+
+
+ Indicates the trace listeners in the Listeners collection.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The trace level.
+ The error occurred during execution.
+
+
+ Indicates the trace listeners in the Listeners collection.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The trace level.
+ The error occurred during execution.
+ The format of the message.
+ The message argument.
+
+
+ Indicates the trace listeners in the Listeners collection.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The of the trace.
+ The format of the message.
+ The message argument.
+
+
+ Traces both a begin and an end trace around a specified operation.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The of the trace.
+ The name of the object performing the operation. It may be null.
+ The name of the operation being performed. It may be null.
+ The to invoke prior to performing the operation, allowing the given to be filled in. It may be null.
+ An <see cref="T:System.Func`1" /> that returns the that will perform the operation.
+ The to invoke after successfully performing the operation, allowing the given to be filled in. It may be null.
+ The to invoke if an error was encountered performing the operation, allowing the given to be filled in. It may be null.
+
+
+ Traces both a begin and an end trace around a specified operation.
+ The returned by the operation.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The of the trace.
+ The name of the object performing the operation. It may be null.
+ The name of the operation being performed. It may be null.
+ The to invoke prior to performing the operation, allowing the given to be filled in. It may be null.
+ An <see cref="T:System.Func`1" /> that returns the that will perform the operation.
+ The to invoke after successfully performing the operation, allowing the given to be filled in. The result of the completed task will also be passed to this action. This action may be null.
+ The to invoke if an error was encountered performing the operation, allowing the given to be filled in. It may be null.
+ The type of result produced by the .
+
+
+ Traces both a begin and an end trace around a specified operation.
+ The returned by the operation.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The of the trace.
+ The name of the object performing the operation. It may be null.
+ The name of the operation being performed. It may be null.
+ The to invoke prior to performing the operation, allowing the given to be filled in. It may be null.
+ An <see cref="T:System.Func`1" /> that returns the that will perform the operation.
+ The to invoke after successfully performing the operation, allowing the given to be filled in. It may be null.
+ The to invoke if an error was encountered performing the operation, allowing the given to be filled in. It may be null.
+
+
+ Indicates the warning level of execution.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The error occurred during execution.
+
+
+ Indicates the warning level of execution.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The error occurred during execution.
+ The format of the message.
+ The message argument.
+
+
+ Indicates the warning level of execution.
+ The .
+ The with which to associate the trace. It may be null.
+ The logical category of the trace.
+ The format of the message.
+ The message argument.
+
+
+ Specifies an enumeration of tracing categories.
+
+
+ An action category.
+
+
+ The controllers category.
+
+
+ The filters category.
+
+
+ The formatting category.
+
+
+ The message handlers category.
+
+
+ The model binding category.
+
+
+ The request category.
+
+
+ The routing category.
+
+
+ Specifies the kind of tracing operation.
+
+
+ Trace marking the beginning of some operation.
+
+
+ Trace marking the end of some operation.
+
+
+ Single trace, not part of a Begin/End trace pair.
+
+
+ Specifies an enumeration of tracing level.
+
+
+ Trace level for debugging traces.
+
+
+ Trace level for error traces.
+
+
+ Trace level for fatal traces.
+
+
+ Trace level for informational traces.
+
+
+ Tracing is disabled.
+
+
+ Trace level for warning traces.
+
+
+ Represents a trace record.
+
+
+ Initializes a new instance of the class.
+ The message request.
+ The trace category.
+ The trace level.
+
+
+ Gets or sets the tracing category.
+ The tracing category.
+
+
+ Gets or sets the exception.
+ The exception.
+
+
+ Gets or sets the kind of trace.
+ The kind of trace.
+
+
+ Gets or sets the tracing level.
+ The tracing level.
+
+
+ Gets or sets the message.
+ The message.
+
+
+ Gets or sets the logical operation name being performed.
+ The logical operation name being performed.
+
+
+ Gets or sets the logical name of the object performing the operation.
+ The logical name of the object performing the operation.
+
+
+ Gets the optional user-defined properties.
+ The optional user-defined properties.
+
+
+ Gets the from the record.
+ The from the record.
+
+
+ Gets the correlation ID from the .
+ The correlation ID from the .
+
+
+ Gets or sets the associated with the .
+ The associated with the .
+
+
+ Gets the of this trace (via ).
+ The of this trace (via ).
+
+
+ Represents a class used to recursively validate an object.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether instances of a particular type should be validated.
+ true if the type should be validated; false otherwise.
+ The type to validate.
+
+
+ Determines whether the is valid and adds any validation errors to the 's .
+ true if model is valid, false otherwise.
+ The model to be validated.
+ The to use for validation.
+ The used to provide model metadata.
+ The within which the model is being validated.
+ The to append to the key for any validation errors.
+
+
+ Represents an interface for the validation of the models
+
+
+ Determines whether the model is valid and adds any validation errors to the actionContext's
+ trueif model is valid, false otherwise.
+ The model to be validated.
+ The to use for validation.
+ The used to provide the model metadata.
+ The within which the model is being validated.
+ The to append to the key for any validation errors.
+
+
+ This logs formatter errors to the provided .
+
+
+ Initializes a new instance of the class.
+ The model state.
+ The prefix.
+
+
+ Logs the specified model error.
+ The error path.
+ The error message.
+
+
+ Logs the specified model error.
+ The error path.
+ The error message.
+
+
+ Provides data for the event.
+
+
+ Initializes a new instance of the class.
+ The action context.
+ The parent node.
+
+
+ Gets or sets the context for an action.
+ The context for an action.
+
+
+ Gets or sets the parent of this node.
+ The parent of this node.
+
+
+ Provides data for the event.
+
+
+ Initializes a new instance of the class.
+ The action context.
+ The parent node.
+
+
+ Gets or sets the context for an action.
+ The context for an action.
+
+
+ Gets or sets the parent of this node.
+ The parent of this node.
+
+
+ Provides a container for model validation information.
+
+
+ Initializes a new instance of the class, using the model metadata and state key.
+ The model metadata.
+ The model state key.
+
+
+ Initializes a new instance of the class, using the model metadata, the model state key, and child model-validation nodes.
+ The model metadata.
+ The model state key.
+ The model child nodes.
+
+
+ Gets or sets the child nodes.
+ The child nodes.
+
+
+ Combines the current instance with a specified instance.
+ The model validation node to combine with the current instance.
+
+
+ Gets or sets the model metadata.
+ The model metadata.
+
+
+ Gets or sets the model state key.
+ The model state key.
+
+
+ Gets or sets a value that indicates whether validation should be suppressed.
+ true if validation should be suppressed; otherwise, false.
+
+
+ Validates the model using the specified execution context.
+ The action context.
+
+
+ Validates the model using the specified execution context and parent node.
+ The action context.
+ The parent node.
+
+
+ Gets or sets a value that indicates whether all properties of the model should be validated.
+ true if all properties of the model should be validated, or false if validation should be skipped.
+
+
+ Occurs when the model has been validated.
+
+
+ Occurs when the model is being validated.
+
+
+ Represents the selection of required members by checking for any required ModelValidators associated with the member.
+
+
+ Initializes a new instance of the class.
+ The metadata provider.
+ The validator providers.
+
+
+ Indicates whether the member is required for validation.
+ true if the member is required for validation; otherwise, false.
+ The member.
+
+
+ Provides a container for a validation result.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the name of the member.
+ The name of the member.
+
+
+ Gets or sets the validation result message.
+ The validation result message.
+
+
+ Provides a base class for implementing validation logic.
+
+
+ Initializes a new instance of the class.
+ The validator providers.
+
+
+ Returns a composite model validator for the model.
+ A composite model validator for the model.
+ An enumeration of validator providers.
+
+
+ Gets a value that indicates whether a model property is required.
+ true if the model property is required; otherwise, false.
+
+
+ Validates a specified object.
+ A list of validation results.
+ The metadata.
+ The container.
+
+
+ Gets or sets an enumeration of validator providers.
+ An enumeration of validator providers.
+
+
+ Provides a list of validators for a model.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a list of validators associated with this .
+ The list of validators.
+ The metadata.
+ The validator providers.
+
+
+ Provides an abstract class for classes that implement a validation provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a type descriptor for the specified type.
+ A type descriptor for the specified type.
+ The type of the validation provider.
+
+
+ Gets the validators for the model using the metadata and validator providers.
+ The validators for the model.
+ The metadata.
+ An enumeration of validator providers.
+
+
+ Gets the validators for the model using the metadata, the validator providers, and a list of attributes.
+ The validators for the model.
+ The metadata.
+ An enumeration of validator providers.
+ The list of attributes.
+
+
+ Represents the method that creates a instance.
+
+
+ Represents an implementation of which providers validators for attributes which derive from . It also provides a validator for types which implement . To support client side validation, you can either register adapters through the static methods on this class, or by having your validation attributes implement . The logic to support IClientValidatable is implemented in .
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the validators for the model using the specified metadata, validator provider and attributes.
+ The validators for the model.
+ The metadata.
+ The validator providers.
+ The attributes.
+
+
+ Registers an adapter to provide client-side validation.
+ The type of the validation attribute.
+ The type of the adapter.
+
+
+ Registers an adapter factory for the validation provider.
+ The type of the attribute.
+ The factory that will be used to create the object for the specified attribute.
+
+
+ Registers the default adapter.
+ The type of the adapter.
+
+
+ Registers the default adapter factory.
+ The factory that will be used to create the object for the default adapter.
+
+
+ Registers the default adapter type for objects which implement . The adapter type must derive from and it must contain a public constructor which takes two parameters of types and .
+ The type of the adapter.
+
+
+ Registers the default adapter factory for objects which implement .
+ The factory.
+
+
+ Registers an adapter type for the given modelType, which must implement . The adapter type must derive from and it must contain a public constructor which takes two parameters of types and .
+ The model type.
+ The type of the adapter.
+
+
+ Registers an adapter factory for the given modelType, which must implement .
+ The model type.
+ The factory.
+
+
+ Provides a factory for validators that are based on .
+
+
+ Represents a validator provider for data member model.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the validators for the model.
+ The validators for the model.
+ The metadata.
+ An enumerator of validator providers.
+ A list of attributes.
+
+
+ An implementation of which provides validators that throw exceptions when the model is invalid.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a list of validators associated with this .
+ The list of validators.
+ The metadata.
+ The validator providers.
+ The list of attributes.
+
+
+ Represents the provider for the required member model validator.
+
+
+ Initializes a new instance of the class.
+ The required member selector.
+
+
+ Gets the validator for the member model.
+ The validator for the member model.
+ The metadata.
+ The validator providers
+
+
+ Provides a model validator.
+
+
+ Initializes a new instance of the class.
+ The validator providers.
+ The validation attribute for the model.
+
+
+ Gets or sets the validation attribute for the model validator.
+ The validation attribute for the model validator.
+
+
+ Gets a value that indicates whether model validation is required.
+ true if model validation is required; otherwise, false.
+
+
+ Validates the model and returns the validation errors if any.
+ A list of validation error messages for the model, or an empty list if no errors have occurred.
+ The model metadata.
+ The container for the model.
+
+
+ A to represent an error. This validator will always throw an exception regardless of the actual model value.
+
+
+ Initializes a new instance of the class.
+ The list of model validator providers.
+ The error message for the exception.
+
+
+ Validates a specified object.
+ A list of validation results.
+ The metadata.
+ The container.
+
+
+ Represents the for required members.
+
+
+ Initializes a new instance of the class.
+ The validator providers.
+
+
+ Gets or sets a value that instructs the serialization engine that the member must be presents when validating.
+ true if the member is required; otherwise, false.
+
+
+ Validates the object.
+ A list of validation results.
+ The metadata.
+ The container.
+
+
+ Provides an object adapter that can be validated.
+
+
+ Initializes a new instance of the class.
+ The validation provider.
+
+
+ Validates the specified object.
+ A list of validation results.
+ The metadata.
+ The container.
+
+
+ Represents the base class for value providers whose values come from a collection that implements the interface.
+
+
+ Retrieves the keys from the specified .
+ The keys from the specified .
+ The prefix.
+
+
+ Represents an interface that is implemented by any that supports the creation of a to access the of an incoming .
+
+
+ Defines the methods that are required for a value provider in ASP.NET MVC.
+
+
+ Determines whether the collection contains the specified prefix.
+ true if the collection contains the specified prefix; otherwise, false.
+ The prefix to search for.
+
+
+ Retrieves a value object using the specified key.
+ The value object for the specified key, or null if the key is not found.
+ The key of the value object to retrieve.
+
+
+ This attribute is used to specify a custom .
+
+
+ Initializes a new instance of the .
+ The type of the model binder.
+
+
+ Initializes a new instance of the .
+ An array of model binder types.
+
+
+ Gets the value provider factories.
+ A collection of value provider factories.
+ A configuration object.
+
+
+ Gets the types of object returned by the value provider factory.
+ A collection of types.
+
+
+ Represents a factory for creating value-provider objects.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a value-provider object for the specified controller context.
+ A value-provider object.
+ An object that encapsulates information about the current HTTP request.
+
+
+ Represents the result of binding a value (such as from a form post or query string) to an action-method argument property, or to the argument itself.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The raw value.
+ The attempted value.
+ The culture.
+
+
+ Gets or sets the raw value that is converted to a string for display.
+ The raw value that is converted to a string for display.
+
+
+ Converts the value that is encapsulated by this result to the specified type.
+ The converted value.
+ The target type.
+
+
+ Converts the value that is encapsulated by this result to the specified type by using the specified culture information.
+ The converted value.
+ The target type.
+ The culture to use in the conversion.
+
+
+ Gets or sets the culture.
+ The culture.
+
+
+ Gets or set the raw value that is supplied by the value provider.
+ The raw value that is supplied by the value provider.
+
+
+ Represents a value provider whose values come from a list of value providers that implements the interface.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The list of value providers.
+
+
+ Determines whether the collection contains the specified .
+ true if the collection contains the specified ; otherwise, false.
+ The prefix to search for.
+
+
+ Retrieves the keys from the specified .
+ The keys from the specified .
+ The prefix from which keys are retrieved.
+
+
+ Retrieves a value object using the specified .
+ The value object for the specified .
+ The key of the value object to retrieve.
+
+
+ Inserts an element into the collection at the specified index.
+ The zero-based index at which should be inserted.
+ The object to insert.
+
+
+ Replaces the element at the specified index.
+ The zero-based index of the element to replace.
+ The new value for the element at the specified index.
+
+
+ Represents a factory for creating a list of value-provider objects.
+
+
+ Initializes a new instance of the class.
+ The collection of value-provider factories.
+
+
+ Retrieves a list of value-provider objects for the specified controller context.
+ The list of value-provider objects for the specified controller context.
+ An object that encapsulates information about the current HTTP request.
+
+
+ A value provider for name/value pairs.
+
+
+
+ Initializes a new instance of the class.
+ The name/value pairs for the provider.
+ The culture used for the name/value pairs.
+
+
+ Initializes a new instance of the class, using a function delegate to provide the name/value pairs.
+ A function delegate that returns a collection of name/value pairs.
+ The culture used for the name/value pairs.
+
+
+ Determines whether the collection contains the specified prefix.
+ true if the collection contains the specified prefix; otherwise, false.
+ The prefix to search for.
+
+
+ Gets the keys from a prefix.
+ The keys.
+ The prefix.
+
+
+ Retrieves a value object using the specified key.
+ The value object for the specified key.
+ The key of the value object to retrieve.
+
+
+ Represents a value provider for query strings that are contained in a object.
+
+
+ Initializes a new instance of the class.
+ An object that encapsulates information about the current HTTP request.
+ An object that contains information about the target culture.
+
+
+ Represents a class that is responsible for creating a new instance of a query-string value-provider object.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves a value-provider object for the specified controller context.
+ A query-string value-provider object.
+ An object that encapsulates information about the current HTTP request.
+
+
+ Represents a value provider for route data that is contained in an object that implements the IDictionary(Of TKey, TValue) interface.
+
+
+ Initializes a new instance of the class.
+ An object that contain information about the HTTP request.
+ An object that contains information about the target culture.
+
+
+ Represents a factory for creating route-data value provider objects.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves a value-provider object for the specified controller context.
+ A value-provider object.
+ An object that encapsulates information about the current HTTP request.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Mvc.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Mvc.dll
new file mode 100644
index 000000000..eb088f289
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Mvc.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Mvc.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Mvc.xml
new file mode 100644
index 000000000..b4b6df8a5
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Mvc.xml
@@ -0,0 +1,11485 @@
+
+
+
+ System.Web.Mvc
+
+
+
+ Represents an attribute that specifies which HTTP verbs an action method will respond to.
+
+
+ Initializes a new instance of the class by using a list of HTTP verbs that the action method will respond to.
+ The HTTP verbs that the action method will respond to.
+ The parameter is null or zero length.
+
+
+ Initializes a new instance of the class using the HTTP verbs that the action method will respond to.
+ The HTTP verbs that the action method will respond to.
+
+
+ Determines whether the specified method information is valid for the specified controller context.
+ true if the method information is valid; otherwise, false.
+ The controller context.
+ The method information.
+ The parameter is null.
+
+
+ Gets or sets the list of HTTP verbs that the action method will respond to.
+ The list of HTTP verbs that the action method will respond to.
+
+
+ Provides information about an action method, such as its name, controller, parameters, attributes, and filters.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the name of the action method.
+ The name of the action method.
+
+
+ Gets the controller descriptor.
+ The controller descriptor.
+
+
+ Executes the action method by using the specified parameters and controller context.
+ The result of executing the action method.
+ The controller context.
+ The parameters of the action method.
+
+
+ Returns an array of custom attributes that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Returns an array of custom attributes that are defined for this member, identified by type.
+ An array of custom attributes, or an empty array if no custom attributes of the specified type exist.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+ The parameter is null.
+
+
+ Gets the filter attributes.
+ The filter attributes.
+ true to use the cache, otherwise false.
+
+
+ Returns the filters that are associated with this action method.
+ The filters that are associated with this action method.
+
+
+ Returns the parameters of the action method.
+ The parameters of the action method.
+
+
+ Returns the action-method selectors.
+ The action-method selectors.
+
+
+ Determines whether one or more instances of the specified attribute type are defined for this member.
+ true if is defined for this member; otherwise, false.
+ The type of the custom attribute.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The parameter is null.
+
+
+ Gets the unique ID for the action descriptor using lazy initialization.
+ The unique ID.
+
+
+ Provides the context for the ActionExecuted method of the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The controller context.
+ The action method descriptor.
+ true if the action is canceled.
+ The exception object.
+ The parameter is null.
+
+
+ Gets or sets the action descriptor.
+ The action descriptor.
+
+
+ Gets or sets a value that indicates that this object is canceled.
+ true if the context canceled; otherwise, false.
+
+
+ Gets or sets the exception that occurred during the execution of the action method, if any.
+ The exception that occurred during the execution of the action method.
+
+
+ Gets or sets a value that indicates whether the exception is handled.
+ true if the exception is handled; otherwise, false.
+
+
+ Gets or sets the result returned by the action method.
+ The result returned by the action method.
+
+
+ Provides the context for the ActionExecuting method of the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified controller context, action descriptor, and action-method parameters.
+ The controller context.
+ The action descriptor.
+ The action-method parameters.
+ The or parameter is null.
+
+
+ Gets or sets the action descriptor.
+ The action descriptor.
+
+
+ Gets or sets the action-method parameters.
+ The action-method parameters.
+
+
+ Gets or sets the result that is returned by the action method.
+ The result that is returned by the action method.
+
+
+ Represents the base class for filter attributes.
+
+
+ Initializes a new instance of the class.
+
+
+ Called by the ASP.NET MVC framework after the action method executes.
+ The filter context.
+
+
+ Called by the ASP.NET MVC framework before the action method executes.
+ The filter context.
+
+
+ Called by the ASP.NET MVC framework after the action result executes.
+ The filter context.
+
+
+ Called by the ASP.NET MVC framework before the action result executes.
+ The filter context.
+
+
+ Represents an attribute that is used to influence the selection of an action method.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action method selection is valid for the specified controller context.
+ true if the action method selection is valid for the specified controller context; otherwise, false.
+ The controller context.
+ Information about the action method.
+
+
+ Represents an attribute that is used for the name of an action.
+
+
+ Initializes a new instance of the class.
+ Name of the action.
+ The parameter is null or empty.
+
+
+ Determines whether the action name is valid within the specified controller context.
+ true if the action name is valid within the specified controller context; otherwise, false.
+ The controller context.
+ The name of the action.
+ Information about the action method.
+
+
+ Gets or sets the name of the action.
+ The name of the action.
+
+
+ Represents an attribute that affects the selection of an action method.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action name is valid in the specified controller context.
+ true if the action name is valid in the specified controller context; otherwise, false.
+ The controller context.
+ The name of the action.
+ Information about the action method.
+
+
+ Represents the result of an action method.
+
+
+ Initializes a new instance of the class.
+
+
+ Enables processing of the result of an action method by a custom type that inherits from the class.
+ The context in which the result is executed. The context information includes the controller, HTTP content, request context, and route data.
+
+
+ Represents a delegate that contains the logic for selecting an action method.
+
+
+ Provides a class that implements the interface in order to support additional metadata.
+
+
+ Initializes a new instance of the class.
+ The name of the model metadata.
+ The value of the model metadata.
+
+
+ Gets the name of the additional metadata attribute.
+ The name of the of the additional metadata attribute.
+
+
+ Provides metadata to the model metadata creation process.
+ The meta data.
+
+
+ Gets the type of the of the additional metadata attribute.
+ The type of the of the additional metadata attribute.
+
+
+ Gets the value of the of the additional metadata attribute.
+ The value of the of the additional metadata attribute.
+
+
+ Represents support for rendering HTML in AJAX scenarios within a view.
+
+
+ Initializes a new instance of the class using the specified view context and view data container.
+ The view context.
+ The view data container.
+ One or both of the parameters is null.
+
+
+ Initializes a new instance of the class by using the specified view context, view data container, and route collection.
+ The view context.
+ The view data container.
+ The URL route collection.
+ One or more of the parameters is null.
+
+
+ Gets or sets the root path for the location to use for globalization script files.
+ The location of the folder where globalization script files are stored. The default location is "~/Scripts/Globalization".
+
+
+ Serializes the specified message and returns the resulting JSON-formatted string.
+ The serialized message as a JSON-formatted string.
+ The message to serialize.
+
+
+ Gets the collection of URL routes for the application.
+ The collection of routes for the application.
+
+
+ Gets the ViewBag.
+ The ViewBag.
+
+
+ Gets the context information about the view.
+ The context of the view.
+
+
+ Gets the current view data dictionary.
+ The view data dictionary.
+
+
+ Gets the view data container.
+ The view data container.
+
+
+ Represents support for rendering HTML in AJAX scenarios within a strongly typed view.
+ The type of the model.
+
+
+ Initializes a new instance of the class by using the specified view context and view data container.
+ The view context.
+ The view data container.
+
+
+ Initializes a new instance of the class by using the specified view context, view data container, and URL route collection.
+ The view context.
+ The view data container.
+ The URL route collection.
+
+
+ Gets the ViewBag.
+ The ViewBag.
+
+
+ Gets the strongly typed version of the view data dictionary.
+ The strongly typed data dictionary of the view.
+
+
+ Represents a class that extends the class by adding the ability to determine whether an HTTP request is an AJAX request.
+
+
+ Determines whether the specified HTTP request is an AJAX request.
+ true if the specified HTTP request is an AJAX request; otherwise, false.
+ The HTTP request.
+ The parameter is null (Nothing in Visual Basic).
+
+
+ Represents an attribute that marks controllers and actions to skip the during authorization.
+
+
+ Initializes a new instance of the class.
+
+
+ Allows a request to include HTML markup during model binding by skipping request validation for the property. (It is strongly recommended that your application explicitly check all models where you disable request validation in order to prevent script exploits.)
+
+
+ Initializes a new instance of the class.
+
+
+ This method supports the ASP.NET MVC validation infrastructure and is not intended to be used directly from your code.
+ The model metadata.
+
+
+ Controls interpretation of a controller name when constructing a .
+
+
+ Find the controller in the current area.
+
+
+ Find the controller in the root area.
+
+
+ Provides a way to register one or more areas in an ASP.NET MVC application.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the name of the area to register.
+ The name of the area to register.
+
+
+ Registers all areas in an ASP.NET MVC application.
+
+
+ Registers all areas in an ASP.NET MVC application by using the specified user-defined information.
+ An object that contains user-defined information to pass to the area.
+
+
+ Registers an area in an ASP.NET MVC application using the specified area's context information.
+ Encapsulates the information that is required in order to register the area.
+
+
+ Encapsulates the information that is required in order to register an area within an ASP.NET MVC application.
+
+
+ Initializes a new instance of the class using the specified area name and routes collection.
+ The name of the area to register.
+ The collection of routes for the application.
+
+
+ Initializes a new instance of the class using the specified area name, routes collection, and user-defined data.
+ The name of the area to register.
+ The collection of routes for the application.
+ An object that contains user-defined information to pass to the area.
+
+
+ Gets the name of the area to register.
+ The name of the area to register.
+
+
+ Maps the specified URL route and associates it with the area that is specified by the property.
+ A reference to the mapped route.
+ The name of the route.
+ The URL pattern for the route.
+ The parameter is null.
+
+
+ Maps the specified URL route and associates it with the area that is specified by the property, using the specified route default values.
+ A reference to the mapped route.
+ The name of the route.
+ The URL pattern for the route.
+ An object that contains default route values.
+ The parameter is null.
+
+
+ Maps the specified URL route and associates it with the area that is specified by the property, using the specified route default values and constraint.
+ A reference to the mapped route.
+ The name of the route.
+ The URL pattern for the route.
+ An object that contains default route values.
+ A set of expressions that specify valid values for a URL parameter.
+ The parameter is null.
+
+
+ Maps the specified URL route and associates it with the area that is specified by the property, using the specified route default values, constraints, and namespaces.
+ A reference to the mapped route.
+ The name of the route.
+ The URL pattern for the route.
+ An object that contains default route values.
+ A set of expressions that specify valid values for a URL parameter.
+ An enumerable set of namespaces for the application.
+ The parameter is null.
+
+
+ Maps the specified URL route and associates it with the area that is specified by the property, using the specified route default values and namespaces.
+ A reference to the mapped route.
+ The name of the route.
+ The URL pattern for the route.
+ An object that contains default route values.
+ An enumerable set of namespaces for the application.
+ The parameter is null.
+
+
+ Maps the specified URL route and associates it with the area that is specified by the property, using the specified namespaces.
+ A reference to the mapped route.
+ The name of the route.
+ The URL pattern for the route.
+ An enumerable set of namespaces for the application.
+ The parameter is null.
+
+
+ Gets the namespaces for the application.
+ An enumerable set of namespaces for the application.
+
+
+ Gets a collection of defined routes for the application.
+ A collection of defined routes for the application.
+
+
+ Gets an object that contains user-defined information to pass to the area.
+ An object that contains user-defined information to pass to the area.
+
+
+ Provides an abstract class to implement a metadata provider.
+
+
+ Called from constructors in a derived class to initialize the class.
+
+
+ When overridden in a derived class, creates the model metadata for the property.
+ The model metadata for the property.
+ The set of attributes.
+ The type of the container.
+ The model accessor.
+ The type of the model.
+ The name of the property.
+
+
+ Gets a list of attributes.
+ A list of attributes.
+ The type of the container.
+ The property descriptor.
+ The attribute container.
+
+
+ Returns a list of properties for the model.
+ A list of properties for the model.
+ The model container.
+ The type of the container.
+
+
+ Returns the metadata for the specified property using the container type and property descriptor.
+ The metadata for the specified property using the container type and property descriptor.
+ The model accessor.
+ The type of the container.
+ The property descriptor
+
+
+ Returns the metadata for the specified property using the container type and property name.
+ The metadata for the specified property using the container type and property name.
+ The model accessor.
+ The type of the container.
+ The name of the property.
+
+
+ Returns the metadata for the specified property using the type of the model.
+ The metadata for the specified property using the type of the model.
+ The model accessor.
+ The type of the model.
+
+
+ Returns the type descriptor from the specified type.
+ The type descriptor.
+ The type.
+
+
+ Provides an abstract class for classes that implement a validation provider.
+
+
+ Called from constructors in derived classes to initialize the class.
+
+
+ Gets a type descriptor for the specified type.
+ A type descriptor for the specified type.
+ The type of the validation provider.
+
+
+ Gets the validators for the model using the metadata and controller context.
+ The validators for the model.
+ The metadata.
+ The controller context.
+
+
+ Gets the validators for the model using the metadata, the controller context, and a list of attributes.
+ The validators for the model.
+ The metadata.
+ The controller context.
+ The list of attributes.
+
+
+ Provided for backward compatibility with ASP.NET MVC 3.
+
+
+ Initializes a new instance of the class.
+
+
+ Represents an attribute that is used to set the timeout value, in milliseconds, for an asynchronous method.
+
+
+ Initializes a new instance of the class.
+ The timeout value, in milliseconds.
+
+
+ Gets the timeout duration, in milliseconds.
+ The timeout duration, in milliseconds.
+
+
+ Called by ASP.NET before the asynchronous action method executes.
+ The filter context.
+
+
+ Encapsulates the information that is required for using an attribute.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified controller context.
+ The context within which the result is executed. The context information includes the controller, HTTP content, request context, and route data.
+
+
+ Initializes a new instance of the class using the specified controller context and action descriptor.
+ The context in which the result is executed. The context information includes the controller, HTTP content, request context, and route data.
+ An object that provides information about an action method, such as its name, controller, parameters, attributes, and filters.
+
+
+ Provides information about the action method that is marked by the attribute, such as its name, controller, parameters, attributes, and filters.
+ The action descriptor for the action method that is marked by the attribute.
+
+
+ Gets or sets the result that is returned by an action method.
+ The result that is returned by an action method.
+
+
+ Specifies that access to a controller or action method is restricted to users who meet the authorization requirement.
+
+
+ Initializes a new instance of the class.
+
+
+ When overridden, provides an entry point for custom authorization checks.
+ true if the user is authorized; otherwise, false.
+ The HTTP context, which encapsulates all HTTP-specific information about an individual HTTP request.
+ The parameter is null.
+
+
+ Processes HTTP requests that fail authorization.
+ Encapsulates the information for using . The object contains the controller, HTTP context, request context, action result, and route data.
+
+
+ Called when a process requests authorization.
+ The filter context, which encapsulates information for using .
+ The parameter is null.
+
+
+ Called when the caching module requests authorization.
+ A reference to the validation status.
+ The HTTP context, which encapsulates all HTTP-specific information about an individual HTTP request.
+ The parameter is null.
+
+
+ Gets or sets the user roles that are authorized to access the controller or action method.
+ The user roles that are authorized to access the controller or action method.
+
+
+ Gets the unique identifier for this attribute.
+ The unique identifier for this attribute.
+
+
+ Gets or sets the users that are authorized to access the controller or action method.
+ The users that are authorized to access the controller or action method.
+
+
+ Represents an attribute that is used to provide details about how model binding to a parameter should occur.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a comma-delimited list of property names for which binding is not allowed.
+ The exclude list.
+
+
+ Gets or sets a comma-delimited list of property names for which binding is allowed.
+ The include list.
+
+
+ Determines whether the specified property is allowed.
+ true if the specified property is allowed; otherwise, false.
+ The name of the property.
+
+
+ Gets or sets the prefix to use when markup is rendered for binding to an action argument or to a model property.
+ The prefix to use.
+
+
+ Represents the base class for views that are compiled by the BuildManager class before being rendered by a view engine.
+
+
+ Initializes a new instance of the class using the specified controller context and view path.
+ The controller context.
+ The view path.
+
+
+ Initializes a new instance of the class using the specified controller context, view path, and view page activator.
+ Context information for the current controller. This information includes the HTTP context, request context, route data, parent action view context, and more.
+ The path to the view that will be rendered.
+ The object responsible for dynamically constructing the view page at run time.
+ The parameter is null.
+ The parameter is null or empty.
+
+
+ Renders the specified view context by using the specified the writer object.
+ Information related to rendering a view, such as view data, temporary data, and form context.
+ The writer object.
+ The parameter is null.
+ An instance of the view type could not be created.
+
+
+ When overridden in a derived class, renders the specified view context by using the specified writer object and object instance.
+ Information related to rendering a view, such as view data, temporary data, and form context.
+ The writer object.
+ An object that contains additional information that can be used in the view.
+
+
+ Gets or sets the view path.
+ The view path.
+
+
+ Provides a base class for view engines.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified view page activator.
+ The view page activator.
+
+
+ Gets a value that indicates whether a file exists in the specified virtual file system (path).
+ true if the file exists in the virtual file system; otherwise, false.
+ The controller context.
+ The virtual path.
+
+
+
+ Gets the view page activator.
+ The view page activator.
+
+
+ Maps a browser request to a byte array.
+
+
+ Initializes a new instance of the class.
+
+
+ Binds the model by using the specified controller context and binding context.
+ The bound data object.Implements
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ The parameter is null.
+
+
+ Provides an abstract class to implement a cached metadata provider.
+
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the cache item policy.
+ The cache item policy.
+
+
+ Gets the cache key prefix.
+ The cache key prefix.
+
+
+ When overridden in a derived class, creates the cached model metadata for the property.
+ The cached model metadata for the property.
+ The attributes.
+ The container type.
+ The model accessor.
+ The model type.
+ The property name.
+
+
+ Creates prototype metadata by applying the prototype and model access to yield the final metadata.
+ The prototype metadata.
+ The prototype.
+ The model accessor.
+
+
+ Creates a metadata prototype.
+ A metadata prototype.
+ The attributes.
+ The container type.
+ The model type.
+ The property name.
+
+
+ Gets the metadata for the properties.
+ The metadata for the properties.
+ The container.
+ The container type.
+
+
+ Returns the metadata for the specified property.
+ The metadata for the specified property.
+ The model accessor.
+ The container type.
+ The property descriptor.
+
+
+ Returns the metadata for the specified property.
+ The metadata for the specified property.
+ The model accessor.
+ The container type.
+ The property name.
+
+
+ Returns the cached metadata for the specified property using the type of the model.
+ The cached metadata for the specified property using the type of the model.
+ The model accessor.
+ The type of the container.
+
+
+ Gets the prototype cache.
+ The prototype cache.
+
+
+ Provides a container to cache attributes.
+
+
+ Initializes a new instance of the class.
+ The attributes.
+
+
+ Gets the data type.
+ The data type.
+
+
+ Gets the display.
+ The display.
+
+
+ Gets the display column.
+ The display column.
+
+
+ Gets the display format.
+ The display format.
+
+
+ Gets the display name.
+ The display name.
+
+
+ Indicates whether a data field is editable.
+ true if the field is editable; otherwise, false.
+
+
+ Gets the hidden input.
+ The hidden input.
+
+
+ Indicates whether a data field is read only.
+ true if the field is read only; otherwise, false.
+
+
+ Indicates whether a data field is required.
+ true if the field is required; otherwise, false.
+
+
+ Indicates whether a data field is scaffold.
+ true if the field is scaffold; otherwise, false.
+
+
+ Gets the UI hint.
+ The UI hint.
+
+
+ Provides a container to cache .
+
+
+ Initializes a new instance of the class using the prototype and model accessor.
+ The prototype.
+ The model accessor.
+
+
+ Initializes a new instance of the class using the provider, container type, model type, property name and attributes.
+ The provider.
+ The container type.
+ The model type.
+ The property name.
+ The attributes.
+
+
+ Gets a value that indicates whether empty strings that are posted back in forms should be converted to Nothing.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A value that indicates whether empty strings that are posted back in forms should be converted to Nothing.
+
+
+ Gets meta information about the data type.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ Meta information about the data type.
+
+
+ Gets the description of the model.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ The description of the model.
+
+
+ Gets the display format string for the model.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ The display format string for the model.
+
+
+ Gets the display name of the model.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ The display name of the model.
+
+
+ Gets the edit format string of the model.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ The edit format string of the model.
+
+
+ Gets a value that indicates whether the model uses a non-default edit format.
+ A value that indicates whether non-default edit format is used.
+
+
+ Gets a value that indicates whether the model object should be rendered using associated HTML elements.Gets a value that indicates whether the model object should be rendered using associated HTML elements.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A value that indicates whether the model object should be rendered using associated HTML elements.
+
+
+ Gets a value that indicates whether the model is read-only.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A value that indicates whether the model is read-only.
+
+
+ Gets a value that indicates whether the model is required.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A value that indicates whether the model is required.
+
+
+ Gets the string to display for null values.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ The string to display for null values.
+
+
+ Gets a value that represents order of the current metadata.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A value that represents order of the current metadata.
+
+
+ Gets a short display name.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A short display name.
+
+
+ Gets a value that indicates whether the property should be displayed in read-only views such as list and detail views.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A value that indicates whether the property should be displayed in read-only views such as list and detail views.
+
+
+ Gets or sets a value that indicates whether the model should be displayed in editable views.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ Returns .
+
+
+ Gets the simple display string for the model.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ The simple display string for the model.
+
+
+ Gets a hint that suggests what template to use for this model.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A hint that suggests what template to use for this model.
+
+
+ Gets a value that can be used as a watermark.If the value is cached, the cashed value is returned; otherwise the value is retrieved from the model metadata and stored in the cache.
+ A value that can be used as a watermark.
+
+
+ Implements the default cached model metadata provider for ASP.NET MVC.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a container of real instances of the cached metadata class based on prototype and model accessor.
+ A container of real instances of the cached metadata class.
+ The prototype.
+ The model accessor.
+
+
+ Returns a container prototype instances of the metadata class.
+ a container prototype instances of the metadata class.
+ The attributes type.
+ The container type.
+ The model type.
+ The property name.
+
+
+ Provides a container for cached metadata.
+ he type of the container.
+
+
+ Constructor for creating real instances of the metadata class based on a prototype.
+ The provider.
+ The container type.
+ The model type.
+ The property name.
+ The prototype.
+
+
+ Constructor for creating the prototype instances of the metadata class.
+ The prototype.
+ The model accessor.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached value that indicates whether empty strings that are posted back in forms should be converted to null.
+ A cached value that indicates whether empty strings that are posted back in forms should be converted to null.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets meta information about the data type.
+ Meta information about the data type.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets the description of the model.
+ The description of the model.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets the display format string for the model.
+ The display format string for the model.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets the display name of the model.
+ The display name of the model.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets the edit format string of the model.
+ The edit format string of the model.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .
+ A value that indicates whether a non-default edit format is used.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached value that indicates whether the model object should be rendered using associated HTML elements.
+ A cached value that indicates whether the model object should be rendered using associated HTML elements.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached value that indicates whether the model is read-only.
+ A cached value that indicates whether the model is read-only.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached value that indicates whether the model is required.
+ A cached value that indicates whether the model is required.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets the cached string to display for null values.
+ The cached string to display for null values.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached value that represents order of the current metadata.
+ A cached value that represents order of the current metadata.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a short display name.
+ A short display name.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached value that indicates whether the property should be displayed in read-only views such as list and detail views.
+ A cached value that indicates whether the property should be displayed in read-only views such as list and detail views.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached value that indicates whether the model should be displayed in editable views.
+ A cached value that indicates whether the model should be displayed in editable views.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets the cached simple display string for the model.
+ The cached simple display string for the model.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached hint that suggests what template to use for this model.
+ A cached hint that suggests what template to use for this model.
+
+
+ This method is protected and therefore cannot be called directly. This method was designed to be overridden in a deriving class such as .Gets or sets a cached value that can be used as a watermark.
+ A cached value that can be used as a watermark.
+
+
+ Gets or sets a cached value that indicates whether empty strings that are posted back in forms should be converted to null.
+ A cached value that indicates whether empty strings that are posted back in forms should be converted to null.
+
+
+ Gets or sets meta information about the data type.
+ The meta information about the data type.
+
+
+ Gets or sets the description of the model.
+ The description of the model.
+
+
+ Gets or sets the display format string for the model.
+ The display format string for the model.
+
+
+ Gets or sets the display name of the model.
+ The display name of the model.
+
+
+ Gets or sets the edit format string of the model.
+ The edit format string of the model.
+
+
+ Gets or sets the simple display string for the model.
+ The simple display string for the model.
+
+
+ Gets or sets a value that indicates whether the model object should be rendered using associated HTML elements.
+ A value that indicates whether the model object should be rendered using associated HTML elements.
+
+
+ Gets or sets a value that indicates whether the model is read-only.
+ A value that indicates whether the model is read-only.
+
+
+ Gets or sets a value that indicates whether the model is required.
+ A value that indicates whether the model is required.
+
+
+ Gets or sets the string to display for null values.
+ The string to display for null values.
+
+
+ Gets or sets a value that represents order of the current metadata.
+ The order value of the current metadata.
+
+
+ Gets or sets the prototype cache.
+ The prototype cache.
+
+
+ Gets or sets a short display name.
+ The short display name.
+
+
+ Gets or sets a value that indicates whether the property should be displayed in read-only views such as list and detail views.
+ true if the model should be displayed in read-only views; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the model should be displayed in editable views.
+ true if the model should be displayed in editable views; otherwise, false.
+
+
+ Gets or sets the simple display string for the model.
+ The simple display string for the model.
+
+
+ Gets or sets a hint that suggests what template to use for this model.
+ A hint that suggests what template to use for this model.
+
+
+ Gets or sets a value that can be used as a watermark.
+ A value that can be used as a watermark.
+
+
+ Provides a mechanism to propagates notification that model binder operations should be canceled.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns the default cancellation token.
+ The default cancellation token.Implements
+ The controller context.
+ The binding context.
+
+
+ Represents an attribute that is used to indicate that an action method should be called only as a child action.
+
+
+ Initializes a new instance of the class.
+
+
+ Called when authorization is required.
+ An object that encapsulates the information that is required in order to authorize access to the child action.
+
+
+ Represents a value provider for values from child actions.
+
+
+ Initializes a new instance of the class.
+ The controller context.
+
+
+ Retrieves a value object using the specified key.
+ The value object for the specified key.
+ The key.
+
+
+ Represents a factory for creating value provider objects for child actions.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a object for the specified controller context.
+ A object.
+ The controller context.
+
+
+ Returns the client data-type model validators.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns the client data-type model validators.
+ The client data-type model validators.
+ The metadata.
+ The context.
+
+
+ Gets the resource class key.
+ The resource class key.
+
+
+ Provides an attribute that compares two properties of a model.
+
+
+ Initializes a new instance of the class.
+ The property to compare with the current property.
+
+
+ Applies formatting to an error message based on the data field where the compare error occurred.
+ The formatted error message.
+ The name of the field that caused the validation failure.
+
+
+ Formats the property for client validation by prepending an asterisk (*) and a dot.
+ The string "*." is prepended to the property.
+ The property.
+
+
+ Gets a list of compare-value client validation rules for the property using the specified model metadata and controller context.
+ A list of compare-value client validation rules.
+ The model metadata.
+ The controller context.
+
+
+ Determines whether the specified object is equal to the compared object.
+ null if the value of the compared property is equal to the value parameter; otherwise, a validation result that contains the error message that indicates that the comparison failed.
+ The value of the object to compare.
+ The validation context.
+
+
+ Gets the property to compare with the current property.
+ The property to compare with the current property.
+
+
+ Gets the other properties display name.
+ The other properties display name.
+
+
+ Represents a user-defined content type that is the result of an action method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the content.
+ The content.
+
+
+ Gets or sets the content encoding.
+ The content encoding.
+
+
+ Gets or sets the type of the content.
+ The type of the content.
+
+
+ Enables processing of the result of an action method by a custom type that inherits from the class.
+ The context within which the result is executed.
+ The parameter is null.
+
+
+ Provides methods that respond to HTTP requests that are made to an ASP.NET MVC Web site.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the action invoker for the controller.
+ The action invoker.
+
+
+ Provides asynchronous operations.
+ Returns .
+
+
+ Begins execution of the specified request context
+ Returns an IAsyncController instance.
+ The request context.
+ The asynchronous callback.
+ The state.
+
+
+ Begins to invoke the action in the current controller context.
+ Returns an IAsyncController instance.
+ The callback.
+ The state.
+
+
+ Gets or sets the binder.
+ The binder.
+
+
+ Creates a content result object by using a string.
+ The content result instance.
+ The content to write to the response.
+
+
+ Creates a content result object by using a string and the content type.
+ The content result instance.
+ The content to write to the response.
+ The content type (MIME type).
+
+
+ Creates a content result object by using a string, the content type, and content encoding.
+ The content result instance.
+ The content to write to the response.
+ The content type (MIME type).
+ The content encoding.
+
+
+ Creates an action invoker.
+ An action invoker.
+
+
+ Creates a temporary data provider.
+ A temporary data provider.
+
+
+ Gets whether to disable the asynchronous support for the controller.
+ true to disable the asynchronous support for the controller; otherwise, false.
+
+
+ Releases all resources that are used by the current instance of the class.
+
+
+ Releases unmanaged resources and optionally releases managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Ends the invocation of the action in the current controller context.
+ The asynchronous result.
+
+
+ Ends the execute core.
+ The asynchronous result.
+
+
+ Invokes the action in the current controller context.
+
+
+ Creates a FileContentResult object by using the file contents and file type.
+ The file-content result object.
+ The binary content to send to the response.
+ The content type (MIME type).
+
+
+ Creates a FileContentResult object by using the file contents, content type, and the destination file name.
+ The file-content result object.
+ The binary content to send to the response.
+ The content type (MIME type).
+ The file name to use in the file-download dialog box that is displayed in the browser.
+
+
+ Creates a FileStreamResult object by using the Stream object and content type.
+ The file-content result object.
+ The stream to send to the response.
+ The content type (MIME type).
+
+
+ Creates a FileStreamResult object using the Stream object, the content type, and the target file name.
+ The file-stream result object.
+ The stream to send to the response.
+ The content type (MIME type)
+ The file name to use in the file-download dialog box that is displayed in the browser.
+
+
+ Creates a FilePathResult object by using the file name and the content type.
+ The file-stream result object.
+ The path of the file to send to the response.
+ The content type (MIME type).
+
+
+ Creates a FilePathResult object by using the file name, the content type, and the file download name.
+ The file-stream result object.
+ The path of the file to send to the response.
+ The content type (MIME type).
+ The file name to use in the file-download dialog box that is displayed in the browser.
+
+
+ Called when a request matches this controller, but no method with the specified action name is found in the controller.
+ The name of the attempted action.
+
+
+ Gets HTTP-specific information about an individual HTTP request.
+ The HTTP context.
+
+
+ Returns an instance of the class.
+ An instance of the class.
+
+
+ Returns an instance of the class.
+ An instance of the class.
+ The status description.
+
+
+ Initializes data that might not be available when the constructor is called.
+ The HTTP context and route data.
+
+
+ Creates a object.
+ The object that writes the script to the response.
+ The JavaScript code to run on the client
+
+
+ Creates a object that serializes the specified object to JavaScript Object Notation (JSON).
+ The JSON result object that serializes the specified object to JSON format. The result object that is prepared by this method is written to the response by the ASP.NET MVC framework when the object is executed.
+ The JavaScript object graph to serialize.
+
+
+ Creates a object that serializes the specified object to JavaScript Object Notation (JSON) format.
+ The JSON result object that serializes the specified object to JSON format.
+ The JavaScript object graph to serialize.
+ The content type (MIME type).
+
+
+ Creates a object that serializes the specified object to JavaScript Object Notation (JSON) format.
+ The JSON result object that serializes the specified object to JSON format.
+ The JavaScript object graph to serialize.
+ The content type (MIME type).
+ The content encoding.
+
+
+ Creates a object that serializes the specified object to JavaScript Object Notation (JSON) format using the content type, content encoding, and the JSON request behavior.
+ The result object that serializes the specified object to JSON format.
+ The JavaScript object graph to serialize.
+ The content type (MIME type).
+ The content encoding.
+ The JSON request behavior
+
+
+ Creates a object that serializes the specified object to JavaScript Object Notation (JSON) format using the specified content type and JSON request behavior.
+ The result object that serializes the specified object to JSON format.
+ The JavaScript object graph to serialize.
+ The content type (MIME type).
+ The JSON request behavior
+
+
+ Creates a JsonResult object that serializes the specified object to JavaScript Object Notation (JSON) format using the specified JSON request behavior.
+ The result object that serializes the specified object to JSON format.
+ The JavaScript object graph to serialize.
+ The JSON request behavior.
+
+
+ Gets the model state dictionary object that contains the state of the model and of model-binding validation.
+ The model state dictionary.
+
+
+ Called after the action method is invoked.
+ Information about the current request and action.
+
+
+ Called before the action method is invoked.
+ Information about the current request and action.
+
+
+ Called when authorization occurs.
+ Information about the current request and action.
+
+
+ Called when authorization challenge occurs.
+ Information about the current request and action.
+
+
+ Called when authorization occurs.
+ Information about the current request and action.
+
+
+ Called when an unhandled exception occurs in the action.
+ Information about the current request and action.
+
+
+ Called after the action result that is returned by an action method is executed.
+ Information about the current request and action result.
+
+
+ Called before the action result that is returned by an action method is executed.
+ Information about the current request and action result.
+
+
+ Creates a object that renders a partial view.
+ A partial-view result object.
+
+
+ Creates a object that renders a partial view, by using the specified model.
+ A partial-view result object.
+ The model that is rendered by the partial view
+
+
+ Creates a object that renders a partial view, by using the specified view name.
+ A partial-view result object.
+ The name of the view that is rendered to the response.
+
+
+ Creates a object that renders a partial view, by using the specified view name and model.
+ A partial-view result object.
+ The name of the view that is rendered to the response.
+ The model that is rendered by the partial view
+
+
+ Gets the HTTP context profile.
+ The HTTP context profile.
+
+
+ Creates a object that redirects to the specified URL.
+ The redirect result object.
+ The URL to redirect to.
+
+
+ Returns an instance of the class with the Permanent property set to true.
+ An instance of the class with the Permanent property set to true.
+ The URL to redirect to.
+
+
+ Redirects to the specified action using the action name.
+ The redirect result object.
+ The name of the action.
+
+
+ Redirects to the specified action using the action name and route values.
+ The redirect result object.
+ The name of the action.
+ The parameters for a route.
+
+
+ Redirects to the specified action using the action name and controller name.
+ The redirect result object.
+ The name of the action.
+ The name of the controller.
+
+
+ Redirects to the specified action using the action name, controller name, and route dictionary.
+ The redirect result object.
+ The name of the action.
+ The name of the controller.
+ The parameters for a route.
+
+
+ Redirects to the specified action using the action name, controller name, and route values.
+ The redirect result object.
+ The name of the action.
+ The name of the controller.
+ The parameters for a route.
+
+
+ Redirects to the specified action using the action name and route dictionary.
+ The redirect result object.
+ The name of the action.
+ The parameters for a route.
+
+
+ Returns an instance of the class with the Permanent property set to true using the specified action name.
+ An instance of the class with the Permanent property set to true using the specified action name, controller name, and route values.
+ The action name.
+
+
+ Returns an instance of the class with the Permanent property set to true using the specified action name, and route values.
+ An instance of the class with the Permanent property set to true using the specified action name, and route values.
+ The action name.
+ The route values.
+
+
+ Returns an instance of the class with the Permanent property set to true using the specified action name, and controller name.
+ An instance of the class with the Permanent property set to true using the specified action name, and controller name.
+ The action name.
+ The controller name.
+
+
+ Returns an instance of the class with the Permanent property set to true using the specified action name, controller name, and route values.
+ An instance of the class with the Permanent property set to true using the specified action name, controller name, and route values.
+ The action name.
+ The controller name.
+ The route values.
+
+
+ Returns an instance of the class with the Permanent property set to true using the specified action name, controller name, and route values.
+ An instance of the class with the Permanent property set to true using the specified action name, controller name, and route values.
+ The action name.
+ The controller name.
+ The route values.
+
+
+ Returns an instance of the class with the Permanent property set to true using the specified action name, and route values.
+ An instance of the class with the Permanent property set to true using the specified action name, and route values.
+ The action name.
+ The route values.
+
+
+ Redirects to the specified route using the specified route values.
+ The redirect-to-route result object.
+ The parameters for a route.
+
+
+ Redirects to the specified route using the route name.
+ The redirect-to-route result object.
+ The name of the route.
+
+
+ Redirects to the specified route using the route name and route values.
+ The redirect-to-route result object.
+ The name of the route.
+ The parameters for a route.
+
+
+ Redirects to the specified route using the route name and route dictionary.
+ The redirect-to-route result object.
+ The name of the route.
+ The parameters for a route.
+
+
+ Redirects to the specified route using the route dictionary.
+ The redirect-to-route result object.
+ The parameters for a route.
+
+
+ Returns an instance of the RedirectResult class with the Permanent property set to true using the specified route values.
+ Returns an instance of the RedirectResult class with the Permanent property set to true.
+ The route name.
+
+
+ Returns an instance of the RedirectResult class with the Permanent property set to true using the specified route name.
+ Returns an instance of the RedirectResult class with the Permanent property set to true using the specified route name.
+ The route name.
+
+
+ Returns an instance of the RedirectResult class with the Permanent property set to true using the specified route name and route values.
+ An instance of the RedirectResult class with the Permanent property set to true using the specified route name and route values.
+ The route name.
+ The route values.
+
+
+ Returns an instance of the RedirectResult class with the Permanent property set to true using the specified route name and route values.
+ An instance of the RedirectResult class with the Permanent property set to true.
+ The route name.
+ The route values.
+
+
+ Returns an instance of the RedirectResult class with the Permanent property set to true using the specified route values.
+ An instance of the RedirectResult class with the Permanent property set to true using the specified route values.
+ The route values.
+
+
+ Gets the HttpRequestBase object for the current HTTP request.
+ The request object.
+
+
+ Represents a replaceable dependency resolver providing services. By default, it uses the .
+
+
+ Gets the HttpResponseBase object for the current HTTP response.
+ The HttpResponseBase object for the current HTTP response.
+
+
+ Gets the route data for the current request.
+ The route data.
+
+
+ Gets the HttpServerUtilityBase object that provides methods that are used during Web request processing.
+ The HTTP server object.
+
+
+ Gets the HttpSessionStateBase object for the current HTTP request.
+ The HTTP session-state object for the current HTTP request.
+
+
+ This method calls the BeginExecute method.
+ The result of the operation.
+ The request context.
+ The asynchronous callback.
+ The state of the object.
+
+
+ This method calls the EndExecute method.
+ The asynchronous result of the operation.
+
+
+ This method calls the OnAuthentication method.
+ The filter context.
+
+
+ This method calls the OnAuthenticationChallenge method.
+ The filter context.
+
+
+ This method calls the OnActionExecuted method.
+ The filter context.
+
+
+ This method calls the OnActionExecuting method.
+ The filter context.
+
+
+ This method calls the OnAuthorization method.
+ The filter context.
+
+
+ This method calls the OnException method.
+ The filter context.
+
+
+ This method calls the OnResultExecuted method.
+ The filter context.
+
+
+ This method calls the OnResultExecuting method.
+ The filter context.
+
+
+ Gets the temporary-data provider object that is used to store data for the next request.
+ The temporary-data provider.
+
+
+ Updates the specified model instance using values from the controller's current value provider.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ The type of the model object.
+ The parameter or the ValueProvider property is null.
+
+
+ Updates the specified model instance using values from the controller's current value provider and a prefix.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ The prefix to use when looking up values in the value provider.
+ The type of the model object.
+ The parameter or the ValueProvider property is null.
+
+
+ Updates the specified model instance using values from the controller's current value provider, a prefix, and included properties.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ The prefix to use when looking up values in the value provider.
+ A list of properties of the model to update.
+ The type of the model object.
+ The parameter or the ValueProvider property is null.
+
+
+ Updates the specified model instance using values from the controller's current value provider, a prefix, a list of properties to exclude, and a list of properties to include.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ The prefix to use when looking up values in the value provider.
+ A list of properties of the model to update.
+ A list of properties to explicitly exclude from the update. These are excluded even if they are listed in the includeProperties parameter list.
+ The type of the model object.
+ The parameter or the ValueProvider property is null.
+
+
+ Updates the specified model instance using values from the value provider, a prefix, a list of properties to exclude , and a list of properties to include.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ The prefix to use when looking up values in the value provider.
+ A list of properties of the model to update.
+ A list of properties to explicitly exclude from the update. These are excluded even if they are listed in the includeProperties parameter list.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider, a prefix, and included properties.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ The prefix to use when looking up values in the value provider.
+ A list of properties of the model to update.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider and a list of properties to include.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ A list of properties of the model to update.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the controller's current value provider and included properties.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ A list of properties of the model to update.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider and a list of properties to include.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ A list of properties of the model to update.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider.
+ true if the update is successful; otherwise, false.
+ The model instance to update.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Validates the specified model instance.
+ true if the model validation is successful; otherwise, false.
+ The model to validate.
+
+
+ Validates the specified model instance using an HTML prefix.
+ true if the model validation is successful; otherwise, false.
+ The model to validate.
+ The prefix to use when looking up values in the model provider.
+
+
+ Updates the specified model instance using values from the controller's current value provider.
+ The model instance to update.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the controller's current value provider and a prefix.
+ The model instance to update.
+ A prefix to use when looking up values in the value provider.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the controller's current value provider, a prefix, and included properties.
+ The model instance to update.
+ A prefix to use when looking up values in the value provider.
+ A list of properties of the model to update.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the controller's current value provider, a prefix, a list of properties to exclude, and a list of properties to include.
+ The model instance to update.
+ A prefix to use when looking up values in the value provider.
+ A list of properties of the model to update.
+ A list of properties to explicitly exclude from the update. These are excluded even if they are listed in the includeProperties list.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider, a prefix, a list of properties to exclude, and a list of properties to include.
+ The model instance to update.
+ The prefix to use when looking up values in the value provider.
+ A list of properties of the model to update.
+ A list of properties to explicitly exclude from the update. These are excluded even if they are listed in the includeProperties parameter list.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider, a prefix, and a list of properties to include.
+ The model instance to update.
+ The prefix to use when looking up values in the value provider.
+ A list of properties of the model to update.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider, a prefix, and a list of properties to include.
+ The model instance to update.
+ A list of properties of the model to update.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the controller object's current value provider.
+ The model instance to update.
+ A list of properties of the model to update.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider, a prefix, and a list of properties to include.
+ The model instance to update.
+ A list of properties of the model to update.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Updates the specified model instance using values from the value provider.
+ The model instance to update.
+ A dictionary of values that is used to update the model.
+ The type of the model object.
+
+
+ Gets the URL helper object that is used to generate URLs by using routing.
+ The URL helper object.
+
+
+ Gets the user security information for the current HTTP request.
+ The user security information for the current HTTP request.
+
+
+ Validates the specified model instance.
+ The model to validate.
+
+
+ Validates the specified model instance using an HTML prefix.
+ The model to validate.
+ The prefix to use when looking up values in the model provider.
+
+
+ Creates a object that renders a view to the response.
+ The result that renders a view to the response.
+
+
+ Creates a object by using the model that renders a view to the response.
+ The view result.
+ The model that is rendered by the view.
+
+
+ Creates a object by using the view name that renders a view.
+ The view result.
+ The name of the view that is rendered to the response.
+
+
+ Creates a object that renders the specified IView object.
+ The view result.
+ The view that is rendered to the response.
+ The model that is rendered by the view.
+
+
+ Creates a object using the view name and master-page name that renders a view to the response.
+ The view result.
+ The name of the view that is rendered to the response.
+ The name of the master page or template to use when the view is rendered.
+
+
+ Creates a object using the view name, master-page name, and model that renders a view.
+ The view result.
+ The name of the view that is rendered to the response.
+ The name of the master page or template to use when the view is rendered.
+ The model that is rendered by the view.
+
+
+ Creates a object that renders the specified IView object.
+ The view result.
+ The view that is rendered to the response.
+
+
+ Creates a object that renders the specified object.
+ The view result.
+ The view that is rendered to the response.
+ The model that is rendered by the view.
+
+
+ Gets the view engine collection.
+ The view engine collection.
+
+
+ Represents a class that is responsible for invoking the action methods of a controller.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the model binders that are associated with the action.
+ The model binders that are associated with the action.
+
+
+ Creates the action result.
+ The action result object.
+ The controller context.
+ The action descriptor.
+ The action return value.
+
+
+ Finds the information about the action method.
+ Information about the action method.
+ The controller context.
+ The controller descriptor.
+ The name of the action.
+
+
+ Retrieves information about the controller by using the specified controller context.
+ Information about the controller.
+ The controller context.
+
+
+ Retrieves information about the action filters.
+ Information about the action filters.
+ The controller context.
+ The action descriptor.
+
+
+ Gets the value of the specified action-method parameter.
+ The value of the action-method parameter.
+ The controller context.
+ The parameter descriptor.
+
+
+ Gets the values of the action-method parameters.
+ The values of the action-method parameters.
+ The controller context.
+ The action descriptor.
+
+
+ Invokes the specified action by using the specified controller context.
+ The result of executing the action.
+ The controller context.
+ The name of the action to invoke.
+ The parameter is null.
+ The parameter is null or empty.
+ The thread was aborted during invocation of the action.
+ An unspecified error occurred during invocation of the action.
+
+
+ Invokes the specified action method by using the specified parameters and the controller context.
+ The result of executing the action method.
+ The controller context.
+ The action descriptor.
+ The parameters.
+
+
+ Invokes the specified action method by using the specified parameters, controller context, and action filters.
+ The context for the ActionExecuted method of the class.
+ The controller context.
+ The action filters.
+ The action descriptor.
+ The parameters.
+
+
+ Invokes the specified action result by using the specified controller context.
+ The controller context.
+ The action result.
+
+
+ Invokes the specified action result by using the specified action filters and the controller context.
+ The context for the ResultExecuted method of the class.
+ The controller context.
+ The action filters.
+ The action result.
+
+
+
+
+ Invokes the specified authorization filters by using the specified action descriptor and controller context.
+ The context for the object.
+ The controller context.
+ The authorization filters.
+ The action descriptor.
+
+
+ Invokes the specified exception filters by using the specified exception and controller context.
+ The context for the object.
+ The controller context.
+ The exception filters.
+ The exception.
+
+
+ Represents the base class for all MVC controllers.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the controller context.
+ The controller context.
+
+
+ Executes the specified request context.
+ The request context.
+ The parameter is null.
+
+
+ Executes the request.
+
+
+ Initializes the specified request context.
+ The request context.
+
+
+ Executes the specified request context.
+ The request context.
+
+
+ Gets or sets the dictionary for temporary data.
+ The dictionary for temporary data.
+
+
+ Gets or sets a value that indicates whether request validation is enabled for this request.
+ true if request validation is enabled for this request; otherwise, false. The default is true.
+
+
+ Gets or sets the value provider for the controller.
+ The value provider for the controller.
+
+
+ Gets the dynamic view data dictionary.
+ The dynamic view data dictionary.
+
+
+ Gets or sets the dictionary for view data.
+ The dictionary for the view data.
+
+
+ Represents a class that is responsible for dynamically building a controller.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the current controller builder object.
+ The current controller builder.
+
+
+ Gets the default namespaces.
+ The default namespaces.
+
+
+ Gets the associated controller factory.
+ The controller factory.
+
+
+ Sets the controller factory by using the specified type.
+ The type of the controller factory.
+ The parameter is null.
+ The controller factory cannot be assigned from the type in the parameter.
+ An error occurred while the controller factory was being set.
+
+
+ Sets the specified controller factory.
+ The controller factory.
+ The parameter is null.
+
+
+ Encapsulates information about an HTTP request that matches specified and instances.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified HTTP context, URL route data, and controller.
+ The HTTP context.
+ The route data.
+ The controller.
+
+
+ Initializes a new instance of the class by using the specified controller context.
+ The controller context.
+ The parameter is null.
+
+
+ Initializes a new instance of the class by using the specified request context and controller.
+ The request context.
+ The controller.
+ One or both parameters are null.
+
+
+ Gets or sets the controller.
+ The controller.
+
+
+ Gets the display mode.
+ The display mode.
+
+
+ Gets or sets the HTTP context.
+ The HTTP context.
+
+
+ Gets a value that indicates whether the associated action method is a child action.
+ true if the associated action method is a child action; otherwise, false.
+
+
+ Gets an object that contains the view context information for the parent action method.
+ An object that contains the view context information for the parent action method.
+
+
+ Gets or sets the request context.
+ The request context.
+
+
+ Gets or sets the URL route data.
+ The URL route data.
+
+
+ Encapsulates information that describes a controller, such as its name, type, and actions.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the name of the controller.
+ The name of the controller.
+
+
+ Gets the type of the controller.
+ The type of the controller.
+
+
+ Finds an action method by using the specified name and controller context.
+ The information about the action method.
+ The controller context.
+ The name of the action.
+
+
+ Retrieves a list of action-method descriptors in the controller.
+ A list of action-method descriptors in the controller.
+
+
+ Retrieves custom attributes that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Retrieves custom attributes of a specified type that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+ The parameter is null (Nothing in Visual Basic).
+
+
+ Gets the filter attributes.
+ The filter attributes.
+ true if the cache should be used; otherwise, false.
+
+
+ Retrieves a value that indicates whether one or more instance of the specified custom attribute are defined for this member.
+ true if the is defined for this member; otherwise, false.
+ The type of the custom attribute.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The parameter is null (Nothing in Visual Basic).
+
+
+ When implemented in a derived class, gets the unique ID for the controller descriptor using lazy initialization.
+ The unique ID.
+
+
+ Adds the controller to the instance.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns the collection of controller instance filters.
+ The collection of controller instance filters.
+ The controller context.
+ The action descriptor.
+
+
+ Represents an attribute that invokes a custom model binder.
+
+
+ Initializes a new instance of the class.
+
+
+ Retrieves the associated model binder.
+ A reference to an object that implements the interface.
+
+
+ Provides a container for common metadata, for the class, and for the class for a data model.
+
+
+ Initializes a new instance of the class.
+ The data-annotations model metadata provider.
+ The type of the container.
+ The model accessor.
+ The type of the model.
+ The name of the property.
+ The display column attribute.
+
+
+ Returns simple text for the model data.
+ Simple text for the model data.
+
+
+ Implements the default model metadata provider for ASP.NET MVC.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the metadata for the specified property.
+ The metadata for the property.
+ The attributes.
+ The type of the container.
+ The model accessor.
+ The type of the model.
+ The name of the property.
+
+
+ Represents the method that creates a instance.
+
+
+ Provides a model validator.
+
+
+ Initializes a new instance of the class.
+ The metadata for the model.
+ The controller context for the model.
+ The validation attribute for the model.
+
+
+ Gets the validation attribute for the model validator.
+ The validation attribute for the model validator.
+
+
+ Gets the error message for the validation failure.
+ The error message for the validation failure.
+
+
+ Retrieves a collection of client validation rules.
+ A collection of client validation rules.
+
+
+ Gets a value that indicates whether model validation is required.
+ true if model validation is required; otherwise, false.
+
+
+ Returns a list of validation error messages for the model.
+ A list of validation error messages for the model, or an empty list if no errors have occurred.
+ The container for the model.
+
+
+ Provides a model validator for a specified validation type.
+
+
+
+ Initializes a new instance of the class.
+ The metadata for the model.
+ The controller context for the model.
+ The validation attribute for the model.
+
+
+ Gets the validation attribute from the model validator.
+ The validation attribute from the model validator.
+
+
+ Implements the default validation provider for ASP.NET MVC.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a value that indicates whether non-nullable value types are required.
+ true if non-nullable value types are required; otherwise, false.
+
+
+ Gets a list of validators.
+ A list of validators.
+ The metadata.
+ The context.
+ The list of validation attributes.
+
+
+ Registers an adapter to provide client-side validation.
+ The type of the validation attribute.
+ The type of the adapter.
+
+
+ Registers an adapter factory for the validation provider.
+ The type of the attribute.
+ The factory that will be used to create the object for the specified attribute.
+
+
+ Registers the default adapter.
+ The type of the adapter.
+
+
+ Registers the default adapter factory.
+ The factory that will be used to create the object for the default adapter.
+
+
+ Registers an adapter to provide default object validation.
+ The type of the adapter.
+
+
+ Registers an adapter factory for the default object validation provider.
+ The factory.
+
+
+ Registers an adapter to provide object validation.
+ The type of the model.
+ The type of the adapter.
+
+
+ Registers an adapter factory for the object validation provider.
+ The type of the model.
+ The factory.
+
+
+ Provides a factory for validators that are based on .
+
+
+ Provides a container for the error-information model validator.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets a list of error-information model validators.
+ A list of error-information model validators.
+ The model metadata.
+ The controller context.
+
+
+ Represents the controller factory that is registered by default.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using a controller activator.
+ An object that implements the controller activator interface.
+
+
+ Creates the specified controller by using the specified request context.
+ The controller.
+ The context of the HTTP request, which includes the HTTP context and route data.
+ The name of the controller.
+ The parameter is null.
+ The parameter is null or empty.
+
+
+ Retrieves the controller instance for the specified request context and controller type.
+ The controller instance.
+ The context of the HTTP request, which includes the HTTP context and route data.
+ The type of the controller.
+
+ is null.
+
+ cannot be assigned.
+ An instance of cannot be created.
+
+
+ Returns the controller's session behavior.
+ The controller's session behavior.
+ The request context.
+ The type of the controller.
+
+
+ Retrieves the controller type for the specified name and request context.
+ The controller type.
+ The context of the HTTP request, which includes the HTTP context and route data.
+ The name of the controller.
+
+
+ Releases the specified controller.
+ The controller to release.
+
+
+ This API supports the ASP.NET MVC infrastructure and is not intended to be used directly from your code. This method calls the method.
+ The controller's session behavior.
+ The request context.
+ The controller name.
+
+
+ Maps a browser request to a data object. This class provides a concrete implementation of a model binder.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the model binders for the application.
+ The model binders for the application.
+
+
+ Binds the model by using the specified controller context and binding context.
+ The bound object.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ The parameter is null.
+
+
+ Binds the specified property by using the specified controller context and binding context and the specified property descriptor.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ Describes a property to be bound. The descriptor provides information such as the component type, property type, and property value. It also provides methods to get or set the property value.
+
+
+ Creates the specified model type by using the specified controller context and binding context.
+ A data object of the specified type.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ The type of the model object to return.
+
+
+ Creates an index (a subindex) based on a category of components that make up a larger index, where the specified index value is an integer.
+ The name of the subindex.
+ The prefix for the subindex.
+ The index value.
+
+
+ Creates an index (a subindex) based on a category of components that make up a larger index, where the specified index value is a string.
+ The name of the subindex.
+ The prefix for the subindex.
+ The index value.
+
+
+ Creates the name of the subproperty by using the specified prefix and property name.
+ The name of the subproperty.
+ The prefix for the subproperty.
+ The name of the property.
+
+
+ Returns a set of properties that match the property filter restrictions that are established by the specified .
+ An enumerable set of property descriptors.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+
+
+ Returns the properties of the model by using the specified controller context and binding context.
+ A collection of property descriptors.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+
+
+ Returns the value of a property using the specified controller context, binding context, property descriptor, and property binder.
+ An object that represents the property value.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ The descriptor for the property to access. The descriptor provides information such as the component type, property type, and property value. It also provides methods to get or set the property value.
+ An object that provides a way to bind the property.
+
+
+ Returns the descriptor object for a type that is specified by its controller context and binding context.
+ A custom type descriptor object.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+
+
+ Determines whether a data model is valid for the specified binding context.
+ true if the model is valid; otherwise, false.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ The parameter is null.
+
+
+ Called when the model is updated.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+
+
+ Called when the model is updating.
+ true if the model is updating; otherwise, false.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+
+
+ Called when the specified property is validated.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ Describes a property to be validated. The descriptor provides information such as the component type, property type, and property value. It also provides methods to get or set the property value.
+ The value to set for the property.
+
+
+ Called when the specified property is validating.
+ true if the property is validating; otherwise, false.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ Describes a property being validated. The descriptor provides information such as component type, property type, and property value. It also provides methods to get or set the property value.
+ The value to set for the property.
+
+
+ Gets or sets the name of the resource file (class key) that contains localized string values.
+ The name of the resource file (class key).
+
+
+ Sets the specified property by using the specified controller context, binding context, and property value.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+ Describes a property to be set. The descriptor provides information such as the component type, property type, and property value. It also provides methods to get or set the property value.
+ The value to set for the property.
+
+
+ Represents a memory cache for view locations.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified cache time span.
+ The cache time span.
+ The Ticks attribute of the parameter is set to a negative number.
+
+
+ Retrieves the default view location by using the specified HTTP context and cache key.
+ The default view location.
+ The HTTP context.
+ The cache key
+ The parameter is null.
+
+
+ Inserts the view in the specified virtual path by using the specified HTTP context, cache key, and virtual path.
+ The HTTP context.
+ The cache key.
+ The virtual path
+ The parameter is null.
+
+
+ Creates an empty view location cache.
+
+
+ Gets or sets the cache time span.
+ The cache time span.
+
+
+ Provides a registration point for dependency resolvers that implement or the Common Service Locator IServiceLocator interface.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the implementation of the dependency resolver.
+ The implementation of the dependency resolver.
+
+
+ This API supports the ASP.NET MVC infrastructure and is not intended to be used directly from your code.
+ The implementation of the dependency resolver.
+
+
+ This API supports the ASP.NET MVC infrastructure and is not intended to be used directly from your code.
+ The function that provides the service.
+ The function that provides the services.
+
+
+ This API supports the ASP.NET MVC infrastructure and is not intended to be used directly from your code.
+ The common service locator.
+
+
+ This API supports the ASP.NET MVC infrastructure and is not intended to be used directly from your code.
+ The object that implements the dependency resolver.
+
+
+ Provides a registration point for dependency resolvers using the specified service delegate and specified service collection delegates.
+ The service delegate.
+ The services delegates.
+
+
+ Provides a registration point for dependency resolvers using the provided common service locator when using a service locator interface.
+ The common service locator.
+
+
+ Provides a registration point for dependency resolvers, using the specified dependency resolver interface.
+ The dependency resolver.
+
+
+ Provides a type-safe implementation of and .
+
+
+ Resolves singly registered services that support arbitrary object creation.
+ The requested service or object.
+ The dependency resolver instance that this method extends.
+ The type of the requested service or object.
+
+
+ Resolves multiply registered services.
+ The requested services.
+ The dependency resolver instance that this method extends.
+ The type of the requested services.
+
+
+ Represents the base class for value providers whose values come from a collection that implements the interface.
+ The type of the value.
+
+
+ Initializes a new instance of the class.
+ The name/value pairs that are used to initialize the value provider.
+ Information about a specific culture, such as the names of the culture, the writing system, and the calendar used.
+ The parameter is null.
+
+
+ Determines whether the collection contains the specified prefix.
+ true if the collection contains the specified prefix; otherwise, false.
+ The prefix to search for.
+ The parameter is null.
+
+
+ Gets the keys from the prefix.
+ The keys from the prefix.
+ the prefix.
+
+
+ Returns a value object using the specified key and controller context.
+ The value object for the specified key.
+ The key of the value object to retrieve.
+ The parameter is null.
+
+
+ Provides an empty metadata provider for data models that do not require metadata.
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a new instance of the class.
+ A new instance of the class.
+ The attributes.
+ The type of the container.
+ The model accessor.
+ The type of the model.
+ The name of the model.
+
+
+ Provides an empty validation provider for models that do not require a validator.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the empty model validator.
+ The empty model validator.
+ The metadata.
+ The context.
+
+
+ Represents a result that does nothing, such as a controller action method that returns nothing.
+
+
+ Initializes a new instance of the class.
+
+
+ Executes the specified result context.
+ The result context.
+
+
+ Provides the context for using the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class for the specified exception by using the specified controller context.
+ The controller context.
+ The exception.
+ The parameter is null.
+
+
+ Gets or sets the exception object.
+ The exception object.
+
+
+ Gets or sets a value that indicates whether the exception has been handled.
+ true if the exception has been handled; otherwise, false.
+
+
+ Gets or sets the action result.
+ The action result.
+
+
+ Provides a helper class to get the model name from an expression.
+
+
+ Gets the model name from a lambda expression.
+ The model name.
+ The expression.
+
+
+ Gets the model name from a string expression.
+ The model name.
+ The expression.
+
+
+ Provides a container for client-side field validation metadata.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the name of the data field.
+ The name of the data field.
+
+
+ Gets or sets a value that indicates whether the validation message contents should be replaced with the client validation error.
+ true if the validation message contents should be replaced with the client validation error; otherwise, false.
+
+
+ Gets or sets the validator message ID.
+ The validator message ID.
+
+
+ Gets the client validation rules.
+ The client validation rules.
+
+
+ Sends the contents of a binary file to the response.
+
+
+ Initializes a new instance of the class by using the specified file contents and content type.
+ The byte array to send to the response.
+ The content type to use for the response.
+ The parameter is null.
+
+
+ The binary content to send to the response.
+ The file contents.
+
+
+ Writes the file content to the response.
+ The response.
+
+
+ Sends the contents of a file to the response.
+
+
+ Initializes a new instance of the class by using the specified file name and content type.
+ The name of the file to send to the response.
+ The content type of the response.
+ The parameter is null or empty.
+
+
+ Gets or sets the path of the file that is sent to the response.
+ The path of the file that is sent to the response.
+
+
+ Writes the file to the response.
+ The response.
+
+
+ Represents a base class that is used to send binary file content to the response.
+
+
+ Initializes a new instance of the class.
+ The type of the content.
+ The parameter is null or empty.
+
+
+ Gets the content type to use for the response.
+ The type of the content.
+
+
+ Enables processing of the result of an action method by a custom type that inherits from the class.
+ The context within which the result is executed.
+ The parameter is null.
+
+
+ Gets or sets the content-disposition header so that a file-download dialog box is displayed in the browser with the specified file name.
+ The name of the file.
+
+
+ Writes the file to the response.
+ The response.
+
+
+ Sends binary content to the response by using a instance.
+
+
+ Initializes a new instance of the class.
+ The stream to send to the response.
+ The content type to use for the response.
+ The parameter is null.
+
+
+ Gets the stream that will be sent to the response.
+ The file stream.
+
+
+ Writes the file to the response.
+ The response.
+
+
+ Represents a metadata class that contains a reference to the implementation of one or more of the filter interfaces, the filter's order, and the filter's scope.
+
+
+ Initializes a new instance of the class.
+ The instance.
+ The scope.
+ The order.
+
+
+ Represents a constant that is used to specify the default ordering of filters.
+
+
+ Gets the instance of this class.
+ The instance of this class.
+
+
+ Gets the order in which the filter is applied.
+ The order in which the filter is applied.
+
+
+ Gets the scope ordering of the filter.
+ The scope ordering of the filter.
+
+
+ Represents the base class for action and result filter attributes.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a value that indicates whether more than one instance of the filter attribute can be specified.
+ true if more than one instance of the filter attribute can be specified; otherwise, false.
+
+
+ Gets or sets the order in which the action filters are executed.
+ The order in which the action filters are executed.
+
+
+ Defines a filter provider for filter attributes.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class and optionally caches attribute instances.
+ true to cache attribute instances; otherwise, false.
+
+
+ Gets a collection of custom action attributes.
+ A collection of custom action attributes.
+ The controller context.
+ The action descriptor.
+
+
+ Gets a collection of controller attributes.
+ A collection of controller attributes.
+ The controller context.
+ The action descriptor.
+
+
+ Aggregates the filters from all of the filter providers into one collection.
+ The collection filters from all of the filter providers.
+ The controller context.
+ The action descriptor.
+
+
+ Encapsulates information about the available action filters.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified filters collection.
+ The filters collection.
+
+
+ Gets all the action filters in the application.
+ The action filters.
+
+
+ Gets all the authentication filters in the application.
+ The list of authentication filters.
+
+
+ Gets all the authorization filters in the application.
+ The authorization filters.
+
+
+ Gets all the exception filters in the application.
+ The exception filters.
+
+
+ Gets all the result filters in the application.
+ The result filters.
+
+
+ Represents the collection of filter providers for the application.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class with specified list of filter provider.
+ The list of filter providers.
+
+
+ Removes all elements from the collection.
+
+
+ Returns the collection of filter providers.
+ The collection of filter providers.
+ The controller context.
+ The action descriptor.
+
+
+ Inserts an element into the collection at the specified index.
+ The zero-based index at which item should be inserted.
+ The object to insert. The value can be null for reference types.
+
+
+ Removes the element at the specified index of the collection
+ The zero-based index of the element to remove.
+
+
+ Replaces the element at the specified index.
+ The zero-based index of the element to replace.
+ The new value for the element at the specified index. The value can be null for reference types.
+
+
+ Provides a registration point for filters.
+
+
+ Provides a registration point for filters.
+ The collection of filters.
+
+
+ Defines values that specify the order in which ASP.NET MVC filters run within the same filter type and filter order.
+
+
+ Specifies an order before and after .
+
+
+ Specifies an order before and after .
+
+
+ Specifies first.
+
+
+ Specifies an order before and after .
+
+
+ Specifies last.
+
+
+ Contains the form value providers for the application.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The collection.
+ The parameter is null.
+
+
+ Gets the specified value provider.
+ The value provider.
+ The name of the value provider to get.
+ The parameter is null or empty.
+
+
+ Gets a value that indicates whether the value provider contains an entry that has the specified prefix.
+ true if the value provider contains an entry that has the specified prefix; otherwise, false.
+ The prefix to look for.
+
+
+ Gets a value from a value provider using the specified key.
+ A value from a value provider.
+ The key.
+
+
+ Returns a dictionary that contains the value providers.
+ A dictionary of value providers.
+
+
+ Encapsulates information that is required in order to validate and process the input data from an HTML form.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the field validators for the form.
+ A dictionary of field validators for the form.
+
+
+ Gets or sets the form identifier.
+ The form identifier.
+
+
+ Returns a serialized object that contains the form identifier and field-validation values for the form.
+ A serialized object that contains the form identifier and field-validation values for the form.
+
+
+ Returns the validation value for the specified input field.
+ The value to validate the field input with.
+ The name of the field to retrieve the validation value for.
+ The parameter is either null or empty.
+
+
+ Returns the validation value for the specified input field and a value that indicates what to do if the validation value is not found.
+ The value to validate the field input with.
+ The name of the field to retrieve the validation value for.
+ true to create a validation value if one is not found; otherwise, false.
+ The parameter is either null or empty.
+
+
+ Returns a value that indicates whether the specified field has been rendered in the form.
+ true if the field has been rendered; otherwise, false.
+ The field name.
+
+
+ Sets a value that indicates whether the specified field has been rendered in the form.
+ The field name.
+ true to specify that the field has been rendered in the form; otherwise, false.
+
+
+ Determines whether client validation errors should be dynamically added to the validation summary.
+ true if client validation errors should be added to the validation summary; otherwise, false.
+
+
+ Gets or sets the identifier for the validation summary.
+ The identifier for the validation summary.
+
+
+ Enumerates the HTTP request types for a form.
+
+
+ Specifies a GET request.
+
+
+ Specifies a POST request.
+
+
+ Represents a value provider for form values that are contained in a object.
+
+
+ Initializes a new instance of the class.
+ An object that encapsulates information about the current HTTP request.
+
+
+ Represents a class that is responsible for creating a new instance of a form-value provider object.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a form-value provider object for the specified controller context.
+ A form-value provider object.
+ An object that encapsulates information about the current HTTP request.
+ The parameter is null.
+
+
+ Represents a class that contains all the global filters.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds the specified filter to the global filter collection.
+ The filter.
+
+
+ Adds the specified filter to the global filter collection using the specified filter run order.
+ The filter.
+ The filter run order.
+
+
+ Removes all filters from the global filter collection.
+
+
+ Determines whether a filter is in the global filter collection.
+ true if is found in the global filter collection; otherwise, false.
+ The filter.
+
+
+ Gets the number of filters in the global filter collection.
+ The number of filters in the global filter collection.
+
+
+ Returns an enumerator that iterates through the global filter collection.
+ An enumerator that iterates through the global filter collection.
+
+
+ Removes all the filters that match the specified filter.
+ The filter to remove.
+
+
+ This API supports the ASP.NET MVC infrastructure and is not intended to be used directly from your code.
+ An enumerator that iterates through the global filter collection.
+
+
+ This API supports the ASP.NET MVC infrastructure and is not intended to be used directly from your code.
+ An enumerator that iterates through the global filter collection.
+ The controller context.
+ The action descriptor.
+
+
+ Represents the global filter collection.
+
+
+ Gets or sets the global filter collection.
+ The global filter collection.
+
+
+ Represents an attribute that is used to handle an exception that is thrown by an action method.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the type of the exception.
+ The type of the exception.
+
+
+ Gets or sets the master view for displaying exception information.
+ The master view.
+
+
+ Called when an exception occurs.
+ The action-filter context.
+ The parameter is null.
+
+
+ Gets the unique identifier for this attribute.
+ The unique identifier for this attribute.
+
+
+ Gets or sets the page view for displaying exception information.
+ The page view.
+
+
+ Encapsulates information for handling an error that was thrown by an action method.
+
+
+ Initializes a new instance of the class.
+ The exception.
+ The name of the controller.
+ The name of the action.
+ The parameter is null.
+ The or parameter is null or empty.
+
+
+ Gets or sets the name of the action that was executing when the exception was thrown.
+ The name of the action.
+
+
+ Gets or sets the name of the controller that contains the action method that threw the exception.
+ The name of the controller.
+
+
+ Gets or sets the exception object.
+ The exception object.
+
+
+ Represents an attribute that is used to indicate whether a property or field value should be rendered as a hidden input element.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a value that indicates whether to display the value of the hidden input element.
+ true if the value should be displayed; otherwise, false.
+
+
+ Enumerates the date rendering mode for HTML5.
+
+
+ The current culture formatting.
+
+
+ The RFC 3339 formatting.
+
+
+ Supports the rendering of HTML controls in a view.
+
+
+ Initializes a new instance of the class by using the specified view context and view data container.
+ The view context.
+ The view data container.
+ The or the viewDataContainer parameter is null.
+
+
+ Initializes a new instance of the class by using the specified view context, view data container, and route collection.
+ The view context.
+ The view data container.
+ The route collection.
+ One or more parameters is null.
+
+
+ Replaces underscore characters (_) with hyphens (-) in the specified HTML attributes.
+ The HTML attributes with underscore characters replaced by hyphens.
+ The HTML attributes.
+
+
+ Generates a hidden form field (anti-forgery token) that is validated when the form is submitted.
+ The generated form field (anti-forgery token).
+
+
+ Generates a hidden form field (anti-forgery token) that is validated when the form is submitted. The field value is generated using the specified salt value.
+ The generated form field (anti-forgery token).
+ The salt value, which can be any non-empty string.
+
+
+ Generates a hidden form field (anti-forgery token) that is validated when the form is submitted. The field value is generated using the specified salt value, domain, and path.
+ The generated form field (anti-forgery token).
+ The salt value, which can be any non-empty string.
+ The application domain.
+ The virtual path.
+
+
+ Converts the specified attribute value to an HTML-encoded string.
+ The HTML-encoded string. If the value parameter is null or empty, this method returns an empty string.
+ The object to encode.
+
+
+ Converts the specified attribute value to an HTML-encoded string.
+ The HTML-encoded string. If the value parameter is null or empty, this method returns an empty string.
+ The string to encode.
+
+
+ Gets or sets a value that indicates whether client validation is enabled.
+ true if enable client validation is enabled; otherwise, false.
+
+
+ Enables input validation that is performed by using client script in the browser.
+
+
+ Enables or disables client validation.
+ true to enable client validation; otherwise, false.
+
+
+ Enables or disables unobtrusive JavaScript.
+
+
+ Enables or disables unobtrusive JavaScript.
+ true to enable unobtrusive JavaScript; otherwise, false.
+
+
+ Converts the value of the specified object to an HTML-encoded string.
+ The HTML-encoded string.
+ The object to encode.
+
+
+ Converts the specified string to an HTML-encoded string.
+ The HTML-encoded string.
+ The string to encode.
+
+
+ Formats the value.
+ The formatted value.
+ The value.
+ The format string.
+
+
+ Creates an HTML element ID using the specified element name.
+ The ID of the HTML element.
+ The name of the HTML element.
+ The name parameter is null.
+
+
+ Creates an HTML element ID using the specified element name and a string that replaces dots in the name.
+ The ID of the HTML element.
+ The name of the HTML element.
+ The string that replaces dots (.) in the name parameter.
+ The name parameter or the idAttributeDotReplacement parameter is null.
+
+
+ Generates an HTML anchor element (a element) that links to the specified action method, and enables the user to specify the communication protocol, name of the host, and a URL fragment.
+ An HTML element that links to the specified action method.
+ The context of the HTTP request.
+ The collection of URL routes.
+ The text caption to display for the link.
+ The name of the route that is used to return a virtual path.
+ The name of the action method.
+ The name of the controller.
+ The communication protocol, such as HTTP or HTTPS. If this parameter is null, the protocol defaults to HTTP.
+ The name of the host.
+ The fragment identifier.
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes for the element.
+
+
+ Generates an HTML anchor element (a element) that links to the specified action method.
+ An HTML element that links to the specified action method.
+ The context of the HTTP request.
+ The collection of URL routes.
+ The text caption to display for the link.
+ The name of the route that is used to return a virtual path.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes for the element.
+
+
+ Generates an HTML anchor element (a element) that links to the specified URL route, and enables the user to specify the communication protocol, name of the host, and a URL fragment.
+ An HTML element that links to the specified URL route.
+ The context of the HTTP request.
+ The collection of URL routes.
+ The text caption to display for the link.
+ The name of the route that is used to return a virtual path.
+ The communication protocol, such as HTTP or HTTPS. If this parameter is null, the protocol defaults to HTTP.
+ The name of the host.
+ The fragment identifier.
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes for the element.
+
+
+ Generates an HTML anchor element (a element) that links to the specified URL route.
+ An HTML element that links to the specified URL route.
+ The context of the HTTP request.
+ The collection of URL routes.
+ The text caption to display for the link.
+ The name of the route that is used to return a virtual path.
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes for the element.
+
+
+ Returns the HTTP method that handles form input (GET or POST) as a string.
+ The form method string, either "get" or "post".
+ The HTTP method that handles the form.
+
+
+ Returns the HTML input control type as a string.
+ The input type string ("checkbox", "hidden", "password", "radio", or "text").
+ The enumerated input type.
+
+
+ Gets the collection of unobtrusive JavaScript validation attributes using the specified HTML name attribute.
+ The collection of unobtrusive JavaScript validation attributes.
+ The HTML name attribute.
+
+
+ Gets the collection of unobtrusive JavaScript validation attributes using the specified HTML name attribute and model metadata.
+ The collection of unobtrusive JavaScript validation attributes.
+ The HTML name attribute.
+ The model metadata.
+
+
+ Gets or sets the HTML5 date rendering mode.
+ The HTML5 date rendering mode.
+
+
+ Returns a hidden input element that identifies the override method for the specified HTTP data-transfer method that was used by the client.
+ The override method that uses the HTTP data-transfer method that was used by the client.
+ The HTTP data-transfer method that was used by the client (DELETE, HEAD, or PUT).
+ The httpVerb parameter is not "PUT", "DELETE", or "HEAD".
+
+
+ Returns a hidden input element that identifies the override method for the specified verb that represents the HTTP data-transfer method used by the client.
+ The override method that uses the verb that represents the HTTP data-transfer method used by the client.
+ The verb that represents the HTTP data-transfer method used by the client.
+ The httpVerb parameter is not "PUT", "DELETE", or "HEAD".
+
+
+ Gets or sets the character that replaces periods in the ID attribute of an element.
+ The character that replaces periods in the ID attribute of an element.
+
+
+ Creates a dictionary from an object, by adding each public instance property as a key with its associated value to the dictionary. It will expose public properties from derived types as well. This is typically used with objects of an anonymous type.
+ The created dictionary of property names and property values.
+ The object to be converted.
+
+
+ Returns markup that is not HTML encoded.
+ The HTML markup without encoding.
+ The HTML markup.
+
+
+ Returns markup that is not HTML encoded.
+ The HTML markup without encoding.
+ The HTML markup.
+
+
+ Gets or sets the collection of routes for the application.
+ The collection of routes for the application.
+
+
+ Set element name used to wrap the validation message generated by and other overloads.
+
+
+ Set element name used to wrap a top-level message in and other overloads.
+
+
+ Gets or sets a value that indicates whether unobtrusive JavaScript is enabled.
+ true if unobtrusive JavaScript is enabled; otherwise, false.
+
+
+ The name of the CSS class that is used to style an input field when a validation error occurs.
+
+
+ The name of the CSS class that is used to style an input field when the input is valid.
+
+
+ The name of the CSS class that is used to style the error message when a validation error occurs.
+
+
+ Element name used to wrap the validation message generated by and other overloads.
+
+
+ The name of the CSS class that is used to style the validation message when the input is valid.
+
+
+ The name of the CSS class that is used to style validation summary error messages.
+
+
+ Element name used to wrap a top-level message in and other overloads.
+
+
+ The name of the CSS class that is used to style the validation summary when the input is valid.
+
+
+ Gets the view bag.
+ The view bag.
+
+
+ Gets or sets the context information about the view.
+ The context of the view.
+
+
+ Gets the current view data dictionary.
+ The view data dictionary.
+
+
+ Gets or sets the view data container.
+ The view data container.
+
+
+ Represents support for rendering HTML controls in a strongly typed view.
+ The type of the model.
+
+
+ Initializes a new instance of the class by using the specified view context and view data container.
+ The view context.
+ The view data container.
+
+
+ Initializes a new instance of the class by using the specified view context, view data container, and route collection.
+ The view context.
+ The view data container.
+ The route collection.
+
+
+ Gets the view bag.
+ The view bag.
+
+
+ Gets the strongly typed view data dictionary.
+ The strongly typed view data dictionary.
+
+
+ Represents an attribute that is used to restrict an action method so that the method handles only HTTP DELETE requests.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action method delete request is valid for the specified controller context.
+ true if the action method request is valid for the specified controller context; otherwise, false.
+ The controller context.
+ Information about the action method.
+
+
+ Represents a value provider to use with values that come from a collection of HTTP files.
+
+
+ Initializes a new instance of the class.
+ An object that encapsulates information about the current HTTP request.
+
+
+ Represents a class that is responsible for creating a new instance of an HTTP file collection value provider object.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a value provider object for the specified controller context.
+ An HTTP file collection value provider.
+ An object that encapsulates information about the HTTP request.
+ The parameter is null.
+
+
+ Represents an attribute that is used to restrict an action method so that the method handles only HTTP GET requests.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action method get request is valid for the specified controller context.
+ true if the action method request is valid for the specified controller context; otherwise, false.
+ The controller context.
+ Information about the action method.
+
+
+ Specifies that the HTTP request must be the HTTP HEAD method.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action method request is valid for the specified controller context.
+ true if the action method request is valid for the specified controller context; otherwise, false.
+ The controller context.
+ Information about the action method.
+
+
+ Defines an object that is used to indicate that the requested resource was not found.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using a status description.
+ The status description.
+
+
+ Represents an attribute that is used to restrict an action method so that the method handles only HTTP OPTIONS requests.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action method request is valid for the specified controller context.
+ true if the action method request is valid for the specified controller context; otherwise, false.
+ The controller context.
+ Information about the action method.
+
+
+ Represents an attribute that is used to restrict an action method so that the method handles only HTTP PATCH requests.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action method request is valid for the specified controller context.
+ true if the action method request is valid for the specified controller context; otherwise, false.
+ The controller context.
+ Information about the action method.
+
+
+ Represents an attribute that is used to restrict an action method so that the method handles only HTTP POST requests.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action method post request is valid for the specified controller context.
+ true if the action method request is valid for the specified controller context; otherwise, false.
+ The controller context.
+ Information about the action method.
+
+
+ Binds a model to a posted file.
+
+
+ Initializes a new instance of the class.
+
+
+ Binds the model.
+ The bound value.Implements
+ The controller context.
+ The binding context.
+ One or both parameters are null.
+
+
+ Represents an attribute that is used to restrict an action method so that the method handles only HTTP PUT requests.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the action method put request is valid for the specified controller context.
+ true if the action method request is valid for the specified controller context; otherwise, false.
+ The controller context.
+ Information about the action method.
+
+
+ Extends the class that contains the HTTP values that were sent by a client during a Web request.
+
+
+ Retrieves the HTTP data-transfer method override that was used by the client.
+ The HTTP data-transfer method override that was used by the client.
+ An object that contains the HTTP values that were sent by a client during a Web request.
+ The parameter is null.
+ The HTTP data-transfer method override was not implemented.
+
+
+ Provides a way to return an action result with a specific HTTP response status code and description.
+
+
+ Initializes a new instance of the class using a status code.
+ The status code.
+
+
+ Initializes a new instance of the class using a status code and status description.
+ The status code.
+ The status description.
+
+
+ Initializes a new instance of the class using a status code.
+ The status code.
+
+
+ Initializes a new instance of the class using a status code and status description.
+ The status code.
+ The status description.
+
+
+ Enables processing of the result of an action method by a custom type that inherits from the class.
+ The context in which the result is executed. The context information includes the controller, HTTP content, request context, and route data.
+
+
+ Gets the HTTP status code.
+ The HTTP status code.
+
+
+ Gets the HTTP status description.
+ the HTTP status description.
+
+
+ Represents the result of an unauthorized HTTP request.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the status description.
+ The status description.
+
+
+ Enumerates the HTTP verbs.
+
+
+ Requests that a specified URI be deleted.
+
+
+ Retrieves the information or entity that is identified by the URI of the request.
+
+
+ Retrieves the message headers for the information or entity that is identified by the URI of the request.
+
+
+ Represents a request for information about the communication options available on the request/response chain identified by the Request-URI.
+
+
+ Requests that a set of changes described in the request entity be applied to the resource identified by the Request- URI.
+
+
+ Posts a new entity as an addition to a URI.
+
+
+ Replaces an entity that is identified by a URI.
+
+
+ Defines the methods that are used in an action filter.
+
+
+ Called after the action method executes.
+ The filter context.
+
+
+ Called before an action method executes.
+ The filter context.
+
+
+ Defines the contract for an action invoker, which is used to invoke an action in response to an HTTP request.
+
+
+ Invokes the specified action by using the specified controller context.
+ true if the action was found; otherwise, false.
+ The controller context.
+ The name of the action.
+
+
+ Used to create an instance for the current request.
+
+
+ Creates an instance of action invoker for the current request.
+ The created .
+
+
+ Defines the methods that are required for an authorization filter.
+
+
+ Called when authorization is required.
+ The filter context.
+
+
+ Provides a way for the ASP.NET MVC validation framework to discover at run time whether a validator has support for client validation.
+
+
+ When implemented in a class, returns client validation rules for that class.
+ The client validation rules for this validator.
+ The model metadata.
+ The controller context.
+
+
+ Defines the methods that are required for a controller.
+
+
+ Executes the specified request context.
+ The request context.
+
+
+ Provides fine-grained control over how controllers are instantiated using dependency injection.
+
+
+ When implemented in a class, creates a controller.
+ The created controller.
+ The request context.
+ The controller type.
+
+
+ Defines the methods that are required for a controller factory.
+
+
+ Creates the specified controller by using the specified request context.
+ The controller.
+ The request context.
+ The name of the controller.
+
+
+ Gets the controller's session behavior.
+ The controller's session behavior.
+ The request context.
+ The name of the controller whose session behavior you want to get.
+
+
+ Releases the specified controller.
+ The controller.
+
+
+ Defines the methods that simplify service location and dependency resolution.
+
+
+ Resolves singly registered services that support arbitrary object creation.
+ The requested service or object.
+ The type of the requested service or object.
+
+
+ Resolves multiply registered services.
+ The requested services.
+ The type of the requested services.
+
+
+ Represents a special that has the ability to be enumerable.
+
+
+ Gets the keys from the prefix.
+ The keys.
+ The prefix.
+
+
+ Defines the methods that are required for an exception filter.
+
+
+ Called when an exception occurs.
+ The filter context.
+
+
+ Provides an interface for finding filters.
+
+
+ Returns an enumerator that contains all the instances in the service locator.
+ The enumerator that contains all the instances in the service locator.
+ The controller context.
+ The action descriptor.
+
+
+ Provides an interface for exposing attributes to the class.
+
+
+ When implemented in a class, provides metadata to the model metadata creation process.
+ The model metadata.
+
+
+ An optional interface for types which provide a .
+
+
+ Gets the MethodInfo
+
+
+ Defines the methods that are required for a model binder.
+
+
+ Binds the model to a value by using the specified controller context and binding context.
+ The bound value.
+ The controller context.
+ The binding context.
+
+
+ Defines methods that enable dynamic implementations of model binding for classes that implement the interface.
+
+
+ Returns the model binder for the specified type.
+ The model binder for the specified type.
+ The type of the model.
+
+
+ Defines members that specify the order of filters and whether multiple filters are allowed.
+
+
+ When implemented in a class, gets or sets a value that indicates whether multiple filters are allowed.
+ true if multiple filters are allowed; otherwise, false.
+
+
+ When implemented in a class, gets the filter order.
+ The filter order.
+
+
+ Enumerates the types of input controls.
+
+
+ A check box.
+
+
+ A hidden field.
+
+
+ A password box.
+
+
+ A radio button.
+
+
+ A text box.
+
+
+ Defines the methods that are required for a result filter.
+
+
+ Called after an action result executes.
+ The filter context.
+
+
+ Called before an action result executes.
+ The filter context.
+
+
+ Associates a route with an area in an ASP.NET MVC application.
+
+
+ Gets the name of the area to associate the route with.
+ The name of the area to associate the route with.
+
+
+ Defines the contract for temporary-data providers that store data that is viewed on the next request.
+
+
+ Loads the temporary data.
+ The temporary data.
+ The controller context.
+
+
+ Saves the temporary data.
+ The controller context.
+ The values.
+
+
+ Used to create an instance for the controller.
+
+
+ Creates an instance of for the controller.
+ The created .
+
+
+ Represents an interface that can skip request validation.
+
+
+ Retrieves the value of the object that is associated with the specified key.
+ The value of the object for the specified key.
+ The key.
+ true if validation should be skipped; otherwise, false.
+
+
+ Defines the methods that are required for a value provider in ASP.NET MVC.
+
+
+ Determines whether the collection contains the specified prefix.
+ true if the collection contains the specified prefix; otherwise, false.
+ The prefix to search for.
+
+
+ Retrieves a value object using the specified key.
+ The value object for the specified key, or null if the key is not found.
+ The key of the value object to retrieve.
+
+
+ Defines the methods that are required for a view.
+
+
+ Renders the specified view context by using the specified the writer object.
+ The view context.
+ The writer object.
+
+
+ Defines the methods that are required for a view data dictionary.
+
+
+ Gets or sets the view data dictionary.
+ The view data dictionary.
+
+
+ Defines the methods that are required for a view engine.
+
+
+ Finds the specified partial view by using the specified controller context.
+ The partial view.
+ The controller context.
+ The name of the partial view.
+ true to specify that the view engine returns the cached view, if a cached view exists; otherwise, false.
+
+
+ Finds the specified view by using the specified controller context.
+ The page view.
+ The controller context.
+ The name of the view.
+ The name of the master.
+ true to specify that the view engine returns the cached view, if a cached view exists; otherwise, false.
+
+
+ Releases the specified view by using the specified controller context.
+ The controller context.
+ The view.
+
+
+ Defines the methods that are required in order to cache view locations in memory.
+
+
+ Gets the view location by using the specified HTTP context and the cache key.
+ The view location.
+ The HTTP context.
+ The cache key.
+
+
+ Inserts the specified view location into the cache by using the specified HTTP context and the cache key.
+ The HTTP context.
+ The cache key.
+ The virtual path.
+
+
+ Provides fine-grained control over how view pages are created using dependency injection.
+
+
+ Provides fine-grained control over how view pages are created using dependency injection.
+ The created view page.
+ The controller context.
+ The type of the controller.
+
+
+ Sends JavaScript content to the response.
+
+
+ Initializes a new instance of the class.
+
+
+ Enables processing of the result of an action method by a custom type that inherits from the class.
+ The context within which the result is executed.
+ The parameter is null.
+
+
+ Gets or sets the script.
+ The script.
+
+
+ The JQuery Form Value provider is used to handle JQuery formatted data in request Forms.
+
+
+ Constructs a new instance of the JQuery form ValueProvider
+ The context on which the ValueProvider operates.
+
+
+ Provides the necessary ValueProvider to handle JQuery Form data.
+
+
+ Constructs a new instance of the factory which provides JQuery form ValueProviders.
+
+
+ Returns the suitable ValueProvider.
+ The context on which the ValueProvider should operate.
+
+
+ Specifies whether HTTP GET requests from the client are allowed.
+
+
+ HTTP GET requests from the client are allowed.
+
+
+ HTTP GET requests from the client are not allowed.
+
+
+ Represents a class that is used to send JSON-formatted content to the response.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the content encoding.
+ The content encoding.
+
+
+ Gets or sets the type of the content.
+ The type of the content.
+
+
+ Gets or sets the data.
+ The data.
+
+
+ Enables processing of the result of an action method by a custom type that inherits from the class.
+ The context within which the result is executed.
+ The parameter is null.
+
+
+ Gets or sets a value that indicates whether HTTP GET requests from the client are allowed.
+ A value that indicates whether HTTP GET requests from the client are allowed.
+
+
+ Gets or sets the maximum length of data.
+ The maximum length of data.
+
+
+ Gets or sets the recursion limit.
+ The recursion limit.
+
+
+ Enables action methods to send and receive JSON-formatted text and to model-bind the JSON text to parameters of action methods.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a JSON value-provider object for the specified controller context.
+ A JSON value-provider object for the specified controller context.
+ The controller context.
+
+
+ Maps a browser request to a LINQ object.
+
+
+ Initializes a new instance of the class.
+
+
+ Binds the model by using the specified controller context and binding context.
+ The bound data object. If the model cannot be bound, this method returns null.Implements.
+ The context within which the controller operates. The context information includes the controller, HTTP content, request context, and route data.
+ The context within which the model is bound. The context includes information such as the model object, model name, model type, property filter, and value provider.
+
+
+ Provides an adapter for the MaxLengthAttribute attribute.
+
+
+ Initializes a new instance of the MaxLengthAttribute class.
+ The model metadata.
+ The controller context.
+ The MaxLength attribute.
+
+
+ Gets a list of client validation rules for a max length check.
+ A list of client validation rules for the check.
+
+
+ Provides an adapter for the MinLengthAttribute attribute.
+
+
+ Initializes a new instance of the MinLenghtAttribute class.
+ The model metadata.
+ The controller context.
+ The minimum length attribute.
+
+
+ Gets a list of client validation rules for the minimum length check.
+ A list of client validation rules for a check.
+
+
+ Represents an attribute that is used to associate a model type to a model-builder type.
+
+
+ Initializes a new instance of the class.
+ The type of the binder.
+ The parameter is null.
+
+
+ Gets or sets the type of the binder.
+ The type of the binder.
+
+
+ Retrieves an instance of the model binder.
+ A reference to an object that implements the interface.
+ An error occurred while an instance of the model binder was being created.
+
+
+ Represents a class that contains all model binders for the application, listed by binder type.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds the specified item to the model binder dictionary.
+ The object to add to the instance.
+ The object is read-only.
+
+
+ Adds the specified item to the model binder dictionary using the specified key.
+ The key of the element to add.
+ The value of the element to add.
+ The object is read-only.
+
+ is null.
+ An element that has the same key already exists in the object.
+
+
+ Removes all items from the model binder dictionary.
+ The object is read-only.
+
+
+ Determines whether the model binder dictionary contains a specified value.
+ true if is found in the model binder dictionary; otherwise, false.
+ The object to locate in the object.
+
+
+ Determines whether the model binder dictionary contains an element that has the specified key.
+ true if the model binder dictionary contains an element that has the specified key; otherwise, false.
+ The key to locate in the object.
+
+ is null.
+
+
+ Copies the elements of the model binder dictionary to an array, starting at a specified index.
+ The one-dimensional array that is the destination of the elements copied from . The array must have zero-based indexing.
+ The zero-based index in at which copying starts.
+
+ is null.
+
+ is less than 0.
+
+ is multidimensional.-or- is equal to or greater than the length of .-or- The number of elements in the source object is greater than the available space from to the end of the destination array. -or- Type cannot be cast automatically to the type of the destination array.
+
+
+ Gets the number of elements in the model binder dictionary.
+ The number of elements in the model binder dictionary.
+
+
+ Gets or sets the default model binder.
+ The default model binder.
+
+
+ Retrieves the model binder for the specified type.
+ The model binder.
+ The type of the model to retrieve.
+ The parameter is null.
+
+
+ Retrieves the model binder for the specified type or retrieves the default model binder.
+ The model binder.
+ The type of the model to retrieve.
+ true to retrieve the default model binder.
+ The parameter is null.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Gets a value that indicates whether the model binder dictionary is read-only.
+ true if the model binder dictionary is read-only; otherwise, false.
+
+
+ Gets or sets the specified key in an object that implements the interface.
+ The key for the specified item.
+
+
+ Gets a collection that contains the keys in the model binder dictionary.
+ A collection that contains the keys in the model binder dictionary.
+
+
+ Removes the first occurrence of the specified element from the model binder dictionary.
+ true if was successfully removed from the model binder dictionary; otherwise, false. This method also returns false if is not found in the model binder dictionary.
+ The object to remove from the object.
+ The object is read-only.
+
+
+ Removes the element that has the specified key from the model binder dictionary.
+ true if the element is successfully removed; otherwise, false. This method also returns false if was not found in the model binder dictionary.
+ The key of the element to remove.
+ The object is read-only.
+
+ is null.
+
+
+ Returns an enumerator that can be used to iterate through a collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Gets the value that is associated with the specified key.
+ true if the object that implements contains an element that has the specified key; otherwise, false.
+ The key of the value to get.
+ When this method returns, the value associated with the specified key, if the key is found; otherwise, the default value for the type of the parameter. This parameter is passed uninitialized.
+
+ is null.
+
+
+ Gets a collection that contains the values in the model binder dictionary.
+ A collection that contains the values in the model binder dictionary.
+
+
+ No content here will be updated; please do not add material here.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using a list of model binder providers.
+ A list of model binder providers.
+
+
+ Removes all elements from the collection.
+
+
+ Returns a model binder of the specified type.
+ A model binder of the specified type.
+ The type of the model binder.
+
+
+ Inserts a model binder provider into the ModelBinderProviderCollection at the specified index.
+ The index.
+ The model binder provider.
+
+
+ Removes the element at the specified index of the collection.
+ The zero-based index of the element to remove.
+
+
+ Replaces the model binder provider element at the specified index.
+ The index.
+ The model binder provider.
+
+
+ Provides a container for model binder providers.
+
+
+ Provides a registration point for model binder providers for applications that do not use dependency injection.
+ The model binder provider collection.
+
+
+ Provides global access to the model binders for the application.
+
+
+ Gets the model binders for the application.
+ The model binders for the application.
+
+
+ Provides the context in which a model binder functions.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the binding context.
+ The binding context.
+
+
+ Gets or sets a value that indicates whether the binder should use an empty prefix.
+ true if the binder should use an empty prefix; otherwise, false.
+
+
+ Gets or sets the model.
+ The model.
+
+
+ Gets or sets the model metadata.
+ The model metadata.
+
+
+ Gets or sets the name of the model.
+ The name of the model.
+
+
+ Gets or sets the state of the model.
+ The state of the model.
+
+
+ Gets or sets the type of the model.
+ The type of the model.
+
+
+ Gets or sets the property filter.
+ The property filter.
+
+
+ Gets the property metadata.
+ The property metadata.
+
+
+ Gets or sets the value provider.
+ The value provider.
+
+
+ Represents an error that occurs during model binding.
+
+
+ Initializes a new instance of the class by using the specified exception.
+ The exception.
+ The parameter is null.
+
+
+ Initializes a new instance of the class by using the specified exception and error message.
+ The exception.
+ The error message.
+ The parameter is null.
+
+
+ Initializes a new instance of the class by using the specified error message.
+ The error message.
+
+
+ Gets or sets the error message.
+ The error message.
+
+
+ Gets or sets the exception object.
+ The exception object.
+
+
+ A collection of instances.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds the specified object to the model-error collection.
+ The exception.
+
+
+ Adds the specified error message to the model-error collection.
+ The error message.
+
+
+ Provides a container for common metadata, for the class, and for the class for a data model.
+
+
+ Initializes a new instance of the class.
+ The provider.
+ The type of the container.
+ The model accessor.
+ The type of the model.
+ The name of the model.
+
+
+ Gets a dictionary that contains additional metadata about the model.
+ A dictionary that contains additional metadata about the model.
+
+
+ A reference to the model's container object. Will be non-null if the model represents a property.
+
+
+ Gets or sets the type of the container for the model.
+ The type of the container for the model.
+
+
+ Gets or sets a value that indicates whether empty strings that are posted back in forms should be converted to null.
+ true if empty strings that are posted back in forms should be converted to null; otherwise, false. The default value is true.
+
+
+ Gets or sets meta information about the data type.
+ Meta information about the data type.
+
+
+ The default order value, which is 10000.
+
+
+ Gets or sets the description of the model.
+ The description of the model. The default value is null.
+
+
+ Gets or sets the display format string for the model.
+ The display format string for the model.
+
+
+ Gets or sets the display name of the model.
+ The display name of the model.
+
+
+ Gets or sets the edit format string of the model.
+ The edit format string of the model.
+
+
+ Returns the metadata from the parameter for the model.
+ The metadata.
+ An expression that identifies the model.
+ The view data dictionary.
+ The type of the parameter.
+ The type of the value.
+
+
+ Gets the metadata from the expression parameter for the model.
+ The metadata for the model.
+ An expression that identifies the model.
+ The view data dictionary.
+
+
+ Gets the display name for the model.
+ The display name for the model.
+
+
+ Returns the simple description of the model.
+ The simple description of the model.
+
+
+ Gets a list of validators for the model.
+ A list of validators for the model.
+ The controller context.
+
+
+ Gets or sets a value that indicates whether the model object should be rendered using associated HTML elements.
+ true if the associated HTML elements that contains the model object should be included with the object; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the model is a complex type.
+ A value that indicates whether the model is considered a complex type by the MVC framework.
+
+
+ Gets a value that indicates whether the type is nullable.
+ true if the type is nullable; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the model is read-only.
+ true if the model is read-only; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the model is required.
+ true if the model is required; otherwise, false.
+
+
+ Gets the value of the model.
+ The value of the model. For more information about , see the entry ASP.NET MVC 2 Templates, Part 2: ModelMetadata on Brad Wilson's blog
+
+
+ Gets the type of the model.
+ The type of the model.
+
+
+ Gets or sets the string to display for null values.
+ The string to display for null values.
+
+
+ Gets or sets a value that represents order of the current metadata.
+ The order value of the current metadata.
+
+
+ Gets a collection of model metadata objects that describe the properties of the model.
+ A collection of model metadata objects that describe the properties of the model.
+
+
+ Gets the property name.
+ The property name.
+
+
+ Gets or sets the provider.
+ The provider.
+
+
+ Gets or sets a value that indicates whether request validation is enabled.
+ true if request validation is enabled; otherwise, false.
+
+
+ Gets or sets a short display name.
+ The short display name.
+
+
+ Gets or sets a value that indicates whether the property should be displayed in read-only views such as list and detail views.
+ true if the model should be displayed in read-only views; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the model should be displayed in editable views.
+ true if the model should be displayed in editable views; otherwise, false.
+
+
+ Gets or sets the simple display string for the model.
+ The simple display string for the model.
+
+
+ Gets or sets a hint that suggests what template to use for this model.
+ A hint that suggests what template to use for this model.
+
+
+ Gets or sets a value that can be used as a watermark.
+ The watermark.
+
+
+ Provides an abstract base class for a custom metadata provider.
+
+
+ When overridden in a derived class, initializes a new instance of the object that derives from the class.
+
+
+ Gets a object for each property of a model.
+ A object for each property of a model.
+ The container.
+ The type of the container.
+
+
+ Gets metadata for the specified property.
+ A object for the property.
+ The model accessor.
+ The type of the container.
+ The property to get the metadata model for.
+
+
+ Gets metadata for the specified model accessor and model type.
+ A object for the specified model accessor and model type.
+ The model accessor.
+ The type of the model.
+
+
+ Provides a container for the current instance.
+
+
+ Gets or sets the current object.
+ The current object.
+
+
+ Encapsulates the state of model binding to a property of an action-method argument, or to the argument itself.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a object that contains any errors that occurred during model binding.
+ The errors.
+
+
+ Returns a object that encapsulates the value that was being bound during model binding.
+ The value.
+
+
+ Represents the state of an attempt to bind a posted form to an action method, which includes validation information.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using values that are copied from the specified model-state dictionary.
+ The model-state dictionary.
+ The parameter is null.
+
+
+ Adds the specified item to the model-state dictionary.
+ The object to add to the model-state dictionary.
+ The model-state dictionary is read-only.
+
+
+ Adds an element that has the specified key and value to the model-state dictionary.
+ The key of the element to add.
+ The value of the element to add.
+ The model-state dictionary is read-only.
+
+ is null.
+ An element that has the specified key already occurs in the model-state dictionary.
+
+
+ Adds the specified model error to the errors collection for the model-state dictionary that is associated with the specified key.
+ The key.
+ The exception.
+
+
+ Adds the specified error message to the errors collection for the model-state dictionary that is associated with the specified key.
+ The key.
+ The error message.
+
+
+ Removes all items from the model-state dictionary.
+ The model-state dictionary is read-only.
+
+
+ Determines whether the model-state dictionary contains a specific value.
+ true if is found in the model-state dictionary; otherwise, false.
+ The object to locate in the model-state dictionary.
+
+
+ Determines whether the model-state dictionary contains the specified key.
+ true if the model-state dictionary contains the specified key; otherwise, false.
+ The key to locate in the model-state dictionary.
+
+
+ Copies the elements of the model-state dictionary to an array, starting at a specified index.
+ The one-dimensional array that is the destination of the elements copied from the object. The array must have zero-based indexing.
+ The zero-based index in at which copying starts.
+
+ is null.
+
+ is less than 0.
+
+ is multidimensional.-or- is equal to or greater than the length of .-or- The number of elements in the source collection is greater than the available space from to the end of the destination .-or- Type cannot be cast automatically to the type of the destination .
+
+
+ Gets the number of key/value pairs in the collection.
+ The number of key/value pairs in the collection.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Gets a value that indicates whether the collection is read-only.
+ true if the collection is read-only; otherwise, false.
+
+
+ Gets a value that indicates whether this instance of the model-state dictionary is valid.
+ true if this instance is valid; otherwise, false.
+
+
+ Determines whether there are any objects that are associated with or prefixed with the specified key.
+ true if the model-state dictionary contains a value that is associated with the specified key; otherwise, false.
+ The key.
+ The parameter is null.
+
+
+ Gets or sets the value that is associated with the specified key.
+ The model state item.
+
+
+ Gets a collection that contains the keys in the dictionary.
+ A collection that contains the keys of the model-state dictionary.
+
+
+ Copies the values from the specified object into this dictionary, overwriting existing values if keys are the same.
+ The dictionary.
+
+
+ Removes the first occurrence of the specified object from the model-state dictionary.
+ true if was successfully removed the model-state dictionary; otherwise, false. This method also returns false if is not found in the model-state dictionary.
+ The object to remove from the model-state dictionary.
+ The model-state dictionary is read-only.
+
+
+ Removes the element that has the specified key from the model-state dictionary.
+ true if the element is successfully removed; otherwise, false. This method also returns false if was not found in the model-state dictionary.
+ The key of the element to remove.
+ The model-state dictionary is read-only.
+
+ is null.
+
+
+ Sets the value for the specified key by using the specified value provider dictionary.
+ The key.
+ The value.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Attempts to gets the value that is associated with the specified key.
+ true if the object that implements contains an element that has the specified key; otherwise, false.
+ The key of the value to get.
+ When this method returns, the value associated with the specified key, if the key is found; otherwise, the default value for the type of the parameter. This parameter is passed uninitialized.
+
+ is null.
+
+
+ Gets a collection that contains the values in the dictionary.
+ A collection that contains the values of the model-state dictionary.
+
+
+ Provides a container for a validation result.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the name of the member.
+ The name of the member.
+
+
+ Gets or sets the validation result message.
+ The validation result message.
+
+
+ Provides a base class for implementing validation logic.
+
+
+ Called from constructors in derived classes to initialize the class.
+ The metadata.
+ The controller context.
+
+
+ Gets the controller context.
+ The controller context.
+
+
+ When implemented in a derived class, returns metadata for client validation.
+ The metadata for client validation.
+
+
+ Returns a composite model validator for the model.
+ A composite model validator for the model.
+ The metadata.
+ The controller context.
+
+
+ Gets or sets a value that indicates whether a model property is required.
+ true if the model property is required; otherwise, false.
+
+
+ Gets the metadata for the model validator.
+ The metadata for the model validator.
+
+
+ When implemented in a derived class, validates the object.
+ A list of validation results.
+ The container.
+
+
+ Provides a list of validators for a model.
+
+
+ When implemented in a derived class, initializes a new instance of the class.
+
+
+ Gets a list of validators.
+ A list of validators.
+ The metadata.
+ The context.
+
+
+ No content here will be updated; please do not add material here.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using a list of model-validation providers.
+ A list of model-validation providers.
+
+
+ Removes all elements from the collection.
+
+
+ Returns the list of model validators.
+ The list of model validators.
+ The model metadata.
+ The controller context.
+
+
+ Inserts a model-validator provider into the collection.
+ The zero-based index at which item should be inserted.
+ The model-validator provider object to insert.
+
+
+ Removes the element at the specified index of the collection.
+ The zero-based index of the element to remove.
+
+
+ Replaces the model-validator provider element at the specified index.
+ The zero-based index of the model-validator provider element to replace.
+ The new value for the model-validator provider element.
+
+
+ Provides a container for the current validation provider.
+
+
+ Gets the model validator provider collection.
+ The model validator provider collection.
+
+
+ Represents a list of items that users can select more than one item from.
+
+
+ Initializes a new instance of the class by using the specified items to include in the list.
+ The items.
+ The parameter is null.
+
+
+ Initializes a new instance of the class by using the specified items to include in the list and the selected values.
+ The items.
+ The selected values.
+ The parameter is null.
+
+
+ Initializes a new instance of the MultiSelectList class by using the items to include in the list, the selected values, the disabled values.
+ The items used to build each of the list.
+ The selected values field. Used to match the Selected property of the corresponding .
+ The disabled values. Used to match the Disabled property of the corresponding .
+
+
+ Initializes a new instance of the class by using the items to include in the list, the data value field, and the data text field.
+ The items.
+ The data value field.
+ The data text field.
+ The parameter is null.
+
+
+ Initializes a new instance of the class by using the items to include in the list, the data value field, the data text field, and the selected values.
+ The items.
+ The data value field.
+ The data text field.
+ The selected values.
+ The parameter is null.
+
+
+ Initializes a new instance of the MultiSelectList class by using the items to include in the list, the data value field, the data text field, the selected values, and the disabled values.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The selected values field. Used to match the Selected property of the corresponding .
+ The disabled values. Used to match the Disabled property of the corresponding .
+
+
+ Initializes a new instance of the MultiSelectList class by using the items to include in the list, the data value field, the data text field, and the data group field.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The data group field. Used to match the Group property of the corresponding .
+
+
+ Initializes a new instance of the MultiSelectList class by using the items to include in the list, the data value field, the data text field, the data group field, and the selected values.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The data group field. Used to match the Group property of the corresponding .
+ The selected values field. Used to match the Selected property of the corresponding .
+
+
+ Initializes a new instance of the MultiSelectList class by using the items to include in the list, the data value field, the data text field, the data group field, the selected values, and the disabled values.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The data group field. Used to match the Group property of the corresponding .
+ The selected values field. Used to match the Selected property of the corresponding .
+ The disabled values. Used to match the Disabled property of the corresponding .
+
+
+ Initializes a new instance of the MultiSelectList class by using the items to include in the list, the data value field, the data text field, the data group field, the selected values, the disabled values, and the disabled groups.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The data group field. Used to match the Group property of the corresponding .
+ The selected values field. Used to match the Selected property of the corresponding .
+ The disabled values. Used to match the Disabled property of the corresponding .
+ The disabled groups. Used to match the Disabled property of the corresponding .
+
+
+ Gets the data group field.
+
+
+ Gets or sets the data text field.
+ The data text field.
+
+
+ Gets or sets the data value field.
+ The data value field.
+
+
+ Gets the disabled groups.
+
+
+ Gets the disabled values.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Gets or sets the items in the list.
+ The items in the list.
+
+
+ Gets or sets the selected values.
+ The selected values.
+
+
+ Returns an enumerator can be used to iterate through a collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ When implemented in a derived class, provides a metadata class that contains a reference to the implementation of one or more of the filter interfaces, the filter's order, and the filter's scope.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class and specifies the order of filters and whether multiple filters are allowed.
+ true to specify that multiple filters of the same type are allowed; otherwise, false.
+ The filter order.
+
+
+ Gets a value that indicates whether more than one instance of the filter attribute can be specified.
+ true if more than one instance of the filter attribute is allowed; otherwise, false.Implements.
+
+
+ Gets a value that indicates the order in which a filter is applied.
+ A value that indicates the order in which a filter is applied.Implements.
+
+
+ Selects the controller that will handle an HTTP request.
+
+
+ Initializes a new instance of the class.
+ The request context.
+ The parameter is null.
+
+
+ Adds the version header by using the specified HTTP context.
+ The HTTP context.
+
+
+ Called by ASP.NET to begin asynchronous request processing.
+ The status of the asynchronous call.
+ The HTTP context.
+ The asynchronous callback method.
+ The state of the asynchronous object.
+
+
+ Called by ASP.NET to begin asynchronous request processing using the base HTTP context.
+ The status of the asynchronous call.
+ The HTTP context.
+ The asynchronous callback method.
+ The state of the asynchronous object.
+
+
+ Gets or sets a value that indicates whether the MVC response header is disabled.
+ true if the MVC response header is disabled; otherwise, false.
+
+
+ Called by ASP.NET when asynchronous request processing has ended.
+ The asynchronous result.
+
+
+ Gets a value that indicates whether another request can use the instance.
+ true if the instance is reusable; otherwise, false.
+
+
+ Contains the header name of the ASP.NET MVC version.
+
+
+ Processes the request by using the specified HTTP request context.
+ The HTTP context.
+
+
+ Processes the request by using the specified base HTTP request context.
+ The HTTP context.
+
+
+ Gets the request context.
+ The request context.
+
+
+ Called by ASP.NET to begin asynchronous request processing using the base HTTP context.
+ The status of the asynchronous call.
+ The HTTP context.
+ The asynchronous callback method.
+ The data.
+
+
+ Called by ASP.NET when asynchronous request processing has ended.
+ The asynchronous result.
+
+
+ Gets a value that indicates whether another request can use the instance.
+ true if the instance is reusable; otherwise, false.
+
+
+ Enables processing of HTTP Web requests by a custom HTTP handler that implements the interface.
+ An object that provides references to the intrinsic server objects (for example, Request, Response, Session, and Server) that are used to service HTTP requests.
+
+
+ Represents an HTML-encoded string that should not be encoded again.
+
+
+ Initializes a new instance of the class.
+ The string to create. If no value is assigned, the object is created using an empty-string value.
+
+
+ Creates an HTML-encoded string using the specified text value.
+ An HTML-encoded string.
+ The value of the string to create .
+
+
+ Contains an empty HTML string.
+
+
+ Determines whether the specified string contains content or is either null or empty.
+ true if the string is null or empty; otherwise, false.
+ The string.
+
+
+ Verifies and processes an HTTP request.
+
+
+ Initializes a new instance of the class.
+
+
+ Called by ASP.NET to begin asynchronous request processing.
+ The status of the asynchronous call.
+ The HTTP context.
+ The asynchronous callback method.
+ The state.
+
+
+ Called by ASP.NET to begin asynchronous request processing.
+ The status of the asynchronous call.
+ The base HTTP context.
+ The asynchronous callback method.
+ The state.
+
+
+ Called by ASP.NET when asynchronous request processing has ended.
+ The asynchronous result.
+
+
+ Called by ASP.NET to begin asynchronous request processing.
+ The status of the asynchronous call.
+ The context.
+ The asynchronous callback method.
+ An object that contains data.
+
+
+ Called by ASP.NET when asynchronous request processing has ended.
+ The status of the asynchronous operations.
+
+
+ Verifies and processes an HTTP request.
+ The HTTP handler.
+ The HTTP context.
+
+
+ Creates an object that implements the IHttpHandler interface and passes the request context to it.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified factory controller object.
+ The controller factory.
+
+
+ Returns the HTTP handler by using the specified HTTP context.
+ The HTTP handler.
+ The request context.
+
+
+ Returns the session behavior.
+ The session behavior.
+ The request context.
+
+
+ Returns the HTTP handler by using the specified request context.
+ The HTTP handler.
+ The request context.
+
+
+ Creates instances of files.
+
+
+ Initializes a new instance of the class.
+
+
+ Creates a Razor host.
+ A Razor host.
+ The virtual path to the target file.
+ The physical path to the target file.
+
+
+ Extends a NameValueCollection object so that the collection can be copied to a specified dictionary.
+
+
+ Copies the specified collection to the specified destination.
+ The collection.
+ The destination.
+
+
+ Copies the specified collection to the specified destination, and optionally replaces previous entries.
+ The collection.
+ The destination.
+ true to replace previous entries; otherwise, false.
+
+
+ Represents the base class for value providers whose values come from a object.
+
+
+ Initializes a new instance of the class using the specified unvalidated collection.
+ A collection that contains the values that are used to initialize the provider.
+ A collection that contains the values that are used to initialize the provider. This collection will not be validated.
+ An object that contains information about the target culture.
+
+
+ Initializes Name Value collection provider.
+ Key value collection from request.
+ Unvalidated key value collection from the request.
+ Culture with which the values are to be used.
+ jQuery POST when sending complex Javascript objects to server does not encode in the way understandable by MVC. This flag should be set if the request should be normalized to MVC form - https://aspnetwebstack.codeplex.com/workitem/1564.
+
+
+ Initializes a new instance of the class.
+ A collection that contains the values that are used to initialize the provider.
+ An object that contains information about the target culture.
+ The parameter is null.
+
+
+ Determines whether the collection contains the specified prefix.
+ true if the collection contains the specified prefix; otherwise, false.
+ The prefix to search for.
+ The parameter is null.
+
+
+ Gets the keys using the specified prefix.
+ They keys.
+ The prefix.
+
+
+ Returns a value object using the specified key.
+ The value object for the specified key.
+ The key of the value object to retrieve.
+ The parameter is null.
+
+
+ Returns a value object using the specified key and validation directive.
+ The value object for the specified key.
+ The key.
+ true if validation should be skipped; otherwise, false.
+
+
+ Provides a convenience wrapper for the attribute.
+
+
+ Initializes a new instance of the class.
+
+
+ Represents an attribute that is used to indicate that a controller method is not an action method.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether the attribute marks a method that is not an action method by using the specified controller context.
+ true if the attribute marks a valid non-action method; otherwise, false.
+ The controller context.
+ The method information.
+
+
+ Represents an attribute that is used to mark an action method whose output will be cached.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the cache profile name.
+ The cache profile name.
+
+
+ Gets or sets the child action cache.
+ The child action cache.
+
+
+ Gets or sets the cache duration, in seconds.
+ The cache duration.
+
+
+ Returns a value that indicates whether a child action cache is active.
+ true if the child action cache is active; otherwise, false.
+ The controller context.
+
+
+ Gets or sets the location.
+ The location.
+
+
+ Gets or sets a value that indicates whether to store the cache.
+ true if the cache should be stored; otherwise, false.
+
+
+ This method is an implementation of and supports the ASP.NET MVC infrastructure. It is not intended to be used directly from your code.
+ The filter context.
+
+
+ This method is an implementation of and supports the ASP.NET MVC infrastructure. It is not intended to be used directly from your code.
+ The filter context.
+
+
+ This method is an implementation of and supports the ASP.NET MVC infrastructure. It is not intended to be used directly from your code.
+ The filter context.
+
+
+ This method is an implementation of and supports the ASP.NET MVC infrastructure. It is not intended to be used directly from your code.
+ The filter context.
+
+
+ Called before the action result executes.
+ The filter context, which encapsulates information for using .
+ The parameter is null.
+
+
+ Gets or sets the SQL dependency.
+ The SQL dependency.
+
+
+ Gets or sets the vary-by-content encoding.
+ The vary-by-content encoding.
+
+
+ Gets or sets the vary-by-custom value.
+ The vary-by-custom value.
+
+
+ Gets or sets the vary-by-header value.
+ The vary-by-header value.
+
+
+ Gets or sets the vary-by-param value.
+ The vary-by-param value.
+
+
+ Represents the attributes associated with the override filter.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the filters to override for this instance.
+ The filters to override for this instance.
+
+
+ Represents the attributes associated with the authentication.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the filters to override for this instance.
+ The filters to override for this instance.
+
+
+ Represents the attributes associated with the authorization.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the filters to override for this instance.
+ The filters to override for this instance.
+
+
+ Represents the attributes associated with the exception filter.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the filters to override for this instance.
+ The filters to override for this instance.
+
+
+ Represents the attributes associated with the result filter.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the filters to override for this instance.
+ The filters to override for this instance.
+
+
+ Encapsulates information for binding action-method parameters to a data model.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the model binder.
+ The model binder.
+
+
+ Gets a comma-delimited list of property names for which binding is disabled.
+ The exclude list.
+
+
+ Gets a comma-delimited list of property names for which binding is enabled.
+ The include list.
+
+
+ Gets the prefix to use when the MVC framework binds a value to an action parameter or to a model property.
+ The prefix.
+
+
+ Contains information that describes a parameter.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the action descriptor.
+ The action descriptor.
+
+
+ Gets the binding information.
+ The binding information.
+
+
+ Gets the default value of the parameter.
+ The default value of the parameter.
+
+
+ Returns an array of custom attributes that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Returns an array of custom attributes that are defined for this member, identified by type.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+ The parameter is null.
+
+
+ Indicates whether one or more instances of a custom attribute type are defined for this member.
+ true if the custom attribute type is defined for this member; otherwise, false.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The parameter is null.
+
+
+ Gets the name of the parameter.
+ The name of the parameter.
+
+
+ Gets the type of the parameter.
+ The type of the parameter.
+
+
+ Represents a base class that is used to send a partial view to the response.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns the object that is used to render the view.
+ The view engine result.
+ The controller context.
+ An error occurred while the method was attempting to find the view.
+
+
+ Provides a registration point for ASP.NET Razor pre-application start code.
+
+
+ Registers Razor pre-application start code.
+
+
+ Represents a value provider for query strings that are contained in a object.
+
+
+ Initializes a new instance of the class.
+ An object that encapsulates information about the current HTTP request.
+
+
+ Represents a class that is responsible for creating a new instance of a query-string value-provider object.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a value-provider object for the specified controller context.
+ A query-string value-provider object.
+ An object that encapsulates information about the current HTTP request.
+ The parameter is null.
+
+
+ Provides an adapter for the attribute.
+
+
+ Initializes a new instance of the class.
+ The model metadata.
+ The controller context.
+ The range attribute.
+
+
+ Gets a list of client validation rules for a range check.
+ A list of client validation rules for a range check.
+
+
+ Represents the class used to create views that have Razor syntax.
+
+
+ Initializes a new instance of the class.
+ The controller context.
+ The view path.
+ The layout or master page.
+ A value that indicates whether view start files should be executed before the view.
+ The set of extensions that will be used when looking up view start files.
+
+
+ Initializes a new instance of the class using the view page activator.
+ The controller context.
+ The view path.
+ The layout or master page.
+ A value that indicates whether view start files should be executed before the view.
+ The set of extensions that will be used when looking up view start files.
+ The view page activator.
+
+
+ Gets the layout or master page.
+ The layout or master page.
+
+
+ Renders the specified view context by using the specified writer and instance.
+ The view context.
+ The writer that is used to render the view to the response.
+ The instance.
+
+
+ Gets a value that indicates whether view start files should be executed before the view.
+ A value that indicates whether view start files should be executed before the view.
+
+
+ Gets or sets the set of file extensions that will be used when looking up view start files.
+ The set of file extensions that will be used when looking up view start files.
+
+
+ Represents a view engine that is used to render a Web page that uses the ASP.NET Razor syntax.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the view page activator.
+ The view page activator.
+
+
+ Creates a partial view using the specified controller context and partial path.
+ The partial view.
+ The controller context.
+ The path to the partial view.
+
+
+ Creates a view by using the specified controller context and the paths of the view and master view.
+ The view.
+ The controller context.
+ The path to the view.
+ The path to the master view.
+
+
+ Controls the processing of application actions by redirecting to a specified URI.
+
+
+ Initializes a new instance of the class.
+ The target URL.
+ The parameter is null.
+
+
+ Initializes a new instance of the class using the specified URL and permanent-redirection flag.
+ The URL.
+ A value that indicates whether the redirection should be permanent.
+
+
+ Enables processing of the result of an action method by a custom type that inherits from the class.
+ The context within which the result is executed.
+ The parameter is null.
+
+
+ Gets a value that indicates whether the redirection should be permanent.
+ true if the redirection should be permanent; otherwise, false.
+
+
+ Gets or sets the target URL.
+ The target URL.
+
+
+ Represents a result that performs a redirection by using the specified route values dictionary.
+
+
+ Initializes a new instance of the class by using the specified route name and route values.
+ The name of the route.
+ The route values.
+
+
+ Initializes a new instance of the class by using the specified route name, route values, and permanent-redirection flag.
+ The name of the route.
+ The route values.
+ A value that indicates whether the redirection should be permanent.
+
+
+ Initializes a new instance of the class by using the specified route values.
+ The route values.
+
+
+ Enables processing of the result of an action method by a custom type that inherits from the class.
+ The context within which the result is executed.
+ The parameter is null.
+
+
+ Gets a value that indicates whether the redirection should be permanent.
+ true if the redirection should be permanent; otherwise, false.
+
+
+ Gets or sets the name of the route.
+ The name of the route.
+
+
+ Gets or sets the route values.
+ The route values.
+
+
+ Contains information that describes a reflected action method.
+
+
+ Initializes a new instance of the class.
+ The action-method information.
+ The name of the action.
+ The controller descriptor.
+ Either the or parameter is null.
+ The parameter is null or empty.
+
+
+ Gets the name of the action.
+ The name of the action.
+
+
+ Gets the controller descriptor.
+ The controller descriptor.
+
+
+ Executes the specified controller context by using the specified action-method parameters.
+ The action return value.
+ The controller context.
+ The parameters.
+ The or parameter is null.
+
+
+ Returns an array of custom attributes defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Returns an array of custom attributes defined for this member, identified by type.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Gets the filter attributes.
+ The filter attributes.
+ true to use the cache, otherwise false.
+
+
+ Retrieves the parameters of the action method.
+ The parameters of the action method.
+
+
+ Retrieves the action selectors.
+ The action selectors.
+
+
+ Indicates whether one or more instances of a custom attribute type are defined for this member.
+ true if the custom attribute type is defined for this member; otherwise, false.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Gets or sets the action-method information.
+ The action-method information.
+
+
+ Gets the unique ID for the reflected action descriptor using lazy initialization.
+ The unique ID.
+
+
+ Contains information that describes a reflected controller.
+
+
+ Initializes a new instance of the class.
+ The type of the controller.
+ The parameter is null.
+
+
+ Gets the type of the controller.
+ The type of the controller.
+
+
+ Finds the specified action for the specified controller context.
+ The information about the action.
+ The controller context.
+ The name of the action.
+ The parameter is null.
+ The parameter is null or empty.
+
+
+ Returns the list of actions for the controller.
+ A list of action descriptors for the controller.
+
+
+ Returns an array of custom attributes that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Returns an array of custom attributes that are defined for this member, identified by type.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Gets the filter attributes.
+ The filter attributes.
+ true to use the cache, otherwise false.
+
+
+ Returns a value that indicates whether one or more instances of a custom attribute type are defined for this member.
+ true if the custom attribute type is defined for this member; otherwise, false.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Contains information that describes a reflected action-method parameter.
+
+
+ Initializes a new instance of the class.
+ The parameter information.
+ The action descriptor.
+ The or parameter is null.
+
+
+ Gets the action descriptor.
+ The action descriptor.
+
+
+ Gets the binding information.
+ The binding information.
+
+
+ Gets the default value of the reflected parameter.
+ The default value of the reflected parameter.
+
+
+ Returns an array of custom attributes that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Returns an array of custom attributes that are defined for this member, identified by type.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+ The custom attribute type cannot be loaded.
+ There is more than one attribute of type defined for this member.
+
+
+ Returns a value that indicates whether one or more instances of a custom attribute type are defined for this member.
+ true if the custom attribute type is defined for this member; otherwise, false.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Gets or sets the parameter information.
+ The parameter information.
+
+
+ Gets the name of the parameter.
+ The name of the parameter.
+
+
+ Gets the type of the parameter.
+ The type of the parameter.
+
+
+ Provides an adapter for the attribute.
+
+
+ Initializes a new instance of the class.
+ The model metadata.
+ The controller context.
+ The regular expression attribute.
+
+
+ Gets a list of regular-expression client validation rules.
+ A list of regular-expression client validation rules.
+
+
+ Provides an attribute that uses the jQuery validation plug-in remote validator.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified route name.
+ The route name.
+
+
+ Initializes a new instance of the class using the specified action-method name and controller name.
+ The name of the action method.
+ The name of the controller.
+
+
+ Initializes a new instance of the class using the specified action-method name, controller name, and area name.
+ The name of the action method.
+ The name of the controller.
+ The name of the area.
+
+
+ Initializes a new instance of the class.
+ The route name.
+ The name of the controller.
+ Find the controller in the root if . Otherwise look in the current area.
+
+
+ Gets or sets the additional fields that are required for validation.
+ The additional fields that are required for validation.
+
+
+ Returns a comma-delimited string of validation field names.
+ A comma-delimited string of validation field names.
+ The name of the validation property.
+
+
+ Formats the error message that is displayed when validation fails.
+ A formatted error message.
+ A name to display with the error message.
+
+
+ Formats the property for client validation by prepending an asterisk (*) and a dot.
+ The string "*." Is prepended to the property.
+ The property.
+
+
+ Gets a list of client validation rules for the property.
+ A list of remote client validation rules for the property.
+ The model metadata.
+ The controller context.
+
+
+ Gets the URL for the remote validation call.
+ The URL for the remote validation call.
+ The controller context.
+
+
+ Gets or sets the HTTP method used for remote validation.
+ The HTTP method used for remote validation. The default value is "Get".
+
+
+ This method always returns true.
+ true
+ The validation target.
+
+
+ Gets the route data dictionary.
+ The route data dictionary.
+
+
+ Gets or sets the route name.
+ The route name.
+
+
+ Gets the route collection from the route table.
+ The route collection from the route table.
+
+
+ Provides an adapter for the attribute.
+
+
+ Initializes a new instance of the class.
+ The model metadata.
+ The controller context.
+ The required attribute.
+
+
+ Gets a list of required-value client validation rules.
+ A list of required-value client validation rules.
+
+
+ Represents an attribute that forces an unsecured HTTP request to be re-sent over HTTPS.
+
+
+ Initializes a new instance of the class.
+
+
+ Handles unsecured HTTP requests that are sent to the action method.
+ An object that encapsulates information that is required in order to use the attribute.
+ The HTTP request contains an invalid transfer method override. All GET requests are considered invalid.
+
+
+ Determines whether a request is secured (HTTPS) and, if it is not, calls the method.
+ An object that encapsulates information that is required in order to use the attribute.
+ The parameter is null.
+
+
+ Provides the context for the method of the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The controller context.
+ The result object.
+ true to cancel execution; otherwise, false.
+ The exception object.
+ The parameter is null.
+
+
+ Gets or sets a value that indicates whether this instance is canceled.
+ true if the instance is canceled; otherwise, false.
+
+
+ Gets or sets the exception object.
+ The exception object.
+
+
+ Gets or sets a value that indicates whether the exception has been handled.
+ true if the exception has been handled; otherwise, false.
+
+
+ Gets or sets the action result.
+ The action result.
+
+
+ Provides the context for the method of the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified controller context and action result.
+ The controller context.
+ The action result.
+ The parameter is null.
+
+
+ Gets or sets a value that indicates whether this value is "cancel".
+ true if the value is "cancel"; otherwise, false.
+
+
+ Gets or sets the action result.
+ The action result.
+
+
+ Defines the area to set for all the routes defined in this controller.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The name of the area. If the value is null, an attempt will be made to infer the area name from the target controller's namespace.
+
+
+ Gets the area name to set for all the routes defined in the controller. If the value is null, an attempt will be made to infer the area name from the target controller's namespace.
+ The area name to set for all the routes defined in the controller.
+
+
+ Gets the URL prefix to apply to the routes of this area. Defaults to the area's name.
+ The URL prefix to apply to the routes of this area.
+
+
+ Place on a controller or action to expose it directly via a route. When placed on a controller, it applies to actions that do not have any System.Web.Mvc.RouteAttribute’s on them.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class with the specified template.
+ The pattern of the route to match.
+
+
+ Gets or sets the name of the route.
+ The name of the route
+
+
+ Gets the order the route is applied.
+ The order the route is applied.
+
+
+ Creates a direct route entry.
+ The direct route entry.
+ The context to use to create the route.
+
+
+ Gets the pattern for the route to match.
+ The pattern to match.
+
+
+ Provides routing extensions for route collection attribute.
+
+
+ Maps the attribute-defined routes for the application.
+ A collection of routes.
+
+
+ Maps the attribute-defined routes for the application.
+ The to use for mapping routes.
+
+
+ Maps the attribute-defined routes for the application.
+ A collection of routes.
+ The to use for resolving inline constraints in route templates.
+
+
+ Maps the attribute-defined routes for the application.
+ The to use for resolving inline constraints in route templates.
+ The to use for mapping routes.
+
+
+ Extends a object for MVC routing.
+
+
+ Returns an object that contains information about the route and virtual path that are the result of generating a URL in the current area.
+ An object that contains information about the route and virtual path that are the result of generating a URL in the current area.
+ An object that contains the routes for the applications.
+ An object that encapsulates information about the requested route.
+ The name of the route to use when information about the URL path is retrieved.
+ An object that contains the parameters for a route.
+
+
+ Returns an object that contains information about the route and virtual path that are the result of generating a URL in the current area.
+ An object that contains information about the route and virtual path that are the result of generating a URL in the current area.
+ An object that contains the routes for the applications.
+ An object that encapsulates information about the requested route.
+ An object that contains the parameters for a route.
+
+
+ Ignores the specified URL route for the given list of available routes.
+ A collection of routes for the application.
+ The URL pattern for the route to ignore.
+ The or parameter is null.
+
+
+ Ignores the specified URL route for the given list of the available routes and a list of constraints.
+ A collection of routes for the application.
+ The URL pattern for the route to ignore.
+ A set of expressions that specify values for the parameter.
+ The or parameter is null.
+
+
+ Maps the specified URL route.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The URL pattern for the route.
+ The or parameter is null.
+
+
+ Maps the specified URL route and sets default route values.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The URL pattern for the route.
+ An object that contains default route values.
+ The or parameter is null.
+
+
+ Maps the specified URL route and sets default route values and constraints.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The URL pattern for the route.
+ An object that contains default route values.
+ A set of expressions that specify values for the parameter.
+ The or parameter is null.
+
+
+ Maps the specified URL route and sets default route values, constraints, and namespaces.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The URL pattern for the route.
+ An object that contains default route values.
+ A set of expressions that specify values for the parameter.
+ A set of namespaces for the application.
+ The or parameter is null.
+
+
+ Maps the specified URL route and sets default route values and namespaces.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The URL pattern for the route.
+ An object that contains default route values.
+ A set of namespaces for the application.
+ The or parameter is null.
+
+
+ Maps the specified URL route and sets the namespaces.
+ A reference to the mapped route.
+ A collection of routes for the application.
+ The name of the route to map.
+ The URL pattern for the route.
+ A set of namespaces for the application.
+ The or parameter is null.
+
+
+ Represents a value provider for route data that is contained in an object that implements the interface.
+
+
+ Initializes a new instance of the class.
+ An object that contain information about the HTTP request.
+
+
+ Represents a factory for creating route-data value provider objects.
+
+
+ Initialized a new instance of the class.
+
+
+ Returns a value-provider object for the specified controller context.
+ A value-provider object.
+ An object that encapsulates information about the current HTTP request.
+ The parameter is null.
+
+
+ Annotates a controller with a route prefix that applies to all actions within the controller.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class with the specified prefix.
+ The route prefix for the controller.
+
+
+ Gets the route prefix.
+ The route prefix.
+
+
+ Represents a list that lets users select one item.
+
+
+ Initializes a new instance of the class by using the specified items for the list.
+ The items.
+
+
+ Initializes a new instance of the class by using the specified items for the list and a selected value.
+ The items.
+ The selected value.
+
+
+ Initializes a new instance of the SelectList class by using the specified items for the list, the selected value, and the disabled values.
+ The items used to build each of the list.
+ The selected value. Used to match the Selected property of the corresponding .
+ The disabled values. Used to match the Disabled property of the corresponding .
+
+
+ Initializes a new instance of the class by using the specified items for the list, the data value field, and the data text field.
+ The items.
+ The data value field.
+ The data text field.
+
+
+ Initializes a new instance of the class by using the specified items for the list, the data value field, the data text field, and a selected value.
+ The items.
+ The data value field.
+ The data text field.
+ The selected value.
+
+
+ Initializes a new instance of the SelectList class by using the specified items for the list, the data value field, the data text field, the selected value, and the disabled values.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The selected value. Used to match the Selected property of the corresponding .
+ The disabled values. Used to match the Disabled property of the corresponding .
+
+
+ Initializes a new instance of the SelectList class by using the specified items for the list, the data value field, the data text field, the data group field, and the selected value.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The data group field. Used to match the Group property of the corresponding .
+ The selected value. Used to match the Selected property of the corresponding .
+
+
+ Initializes a new instance of the SelectList class by using the specified items for the list, the data value field, the data text field, the data group field, the selected value, and the disabled values.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The data group field. Used to match the Group property of the corresponding .
+ The selected value. Used to match the Selected property of the corresponding .
+ The disabled values. Used to match the Disabled property of the corresponding .
+
+
+ Initializes a new instance of the SelectList class by using the specified items for the list, the data value field, the data text field, the data group field. the selected value, the disabled values, and the disabled groups.
+ The items used to build each of the list.
+ The data value field. Used to match the Value property of the corresponding .
+ The data text field. Used to match the Text property of the corresponding .
+ The data group field. Used to match the Group property of the corresponding .
+ The selected value. Used to match the Selected property of the corresponding .
+ The disabled values. Used to match the Disabled property of the corresponding .
+ The disabled groups. Used to match the Disabled property of the corresponding .
+
+
+ Gets the list value that was selected by the user.
+ The selected value.
+
+
+ Represents the optgroup HTML element and its attributes. In a select list, multiple groups with the same name are supported. They are compared with reference equality.
+
+
+
+ Gets or sets a value that indicates whether this is disabled.
+
+
+ Represents the value of the optgroup's label.
+
+
+ Represents the selected item in an instance of the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a value that indicates whether this is disabled.
+
+
+ Represents the optgroup HTML element this item is wrapped into. In a select list, multiple groups with the same name are supported. They are compared with reference equality.
+
+
+ Gets or sets a value that indicates whether this is selected.
+ true if the item is selected; otherwise, false.
+
+
+ Gets or sets the text of the selected item.
+ The text.
+
+
+ Gets or sets the value of the selected item.
+ The value.
+
+
+ Specifies the session state of the controller.
+
+
+ Initializes a new instance of the class
+ The type of the session state.
+
+
+ Get the session state behavior for the controller.
+ The session state behavior for the controller.
+
+
+ Provides session-state data to the current object.
+
+
+ Initializes a new instance of the class.
+
+
+ Loads the temporary data by using the specified controller context.
+ The temporary data.
+ The controller context.
+ An error occurred when the session context was being retrieved.
+
+
+ Saves the specified values in the temporary data dictionary by using the specified controller context.
+ The controller context.
+ The values.
+ An error occurred the session context was being retrieved.
+
+
+ Provides an adapter for the attribute.
+
+
+ Initializes a new instance of the class.
+ The model metadata.
+ The controller context.
+ The string-length attribute.
+
+
+ Gets a list of string-length client validation rules.
+ A list of string-length client validation rules.
+
+
+ Represents a set of data that persists only from one request to the next.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds an element that has the specified key and value to the object.
+ The key of the element to add.
+ The value of the element to add.
+ The object is read-only.
+
+ is null.
+ An element that has the same key already exists in the object.
+
+
+ Removes all items from the instance.
+ The object is read-only.
+
+
+ Determines whether the instance contains an element that has the specified key.
+ true if the instance contains an element that has the specified key; otherwise, false.
+ The key to locate in the instance.
+
+ is null.
+
+
+ Determines whether the dictionary contains the specified value.
+ true if the dictionary contains the specified value; otherwise, false.
+ The value.
+
+
+ Gets the number of elements in the object.
+ The number of elements in the object.
+
+
+ Gets the enumerator.
+ The enumerator.
+
+
+ Gets or sets the object that has the specified key.
+ The object that has the specified key.
+
+
+ Marks all keys in the dictionary for retention.
+
+
+ Marks the specified key in the dictionary for retention.
+ The key to retain in the dictionary.
+
+
+ Gets an object that contains the keys of elements in the object.
+ The keys of the elements in the object.
+
+
+ Loads the specified controller context by using the specified data provider.
+ The controller context.
+ The temporary data provider.
+
+
+ Returns an object that contains the element that is associated with the specified key, without marking the key for deletion.
+ An object that contains the element that is associated with the specified key.
+ The key of the element to return.
+
+
+ Removes the element that has the specified key from the object.
+ true if the element was removed successfully; otherwise, false. This method also returns false if was not found in the . instance.
+ The key of the element to remove.
+ The object is read-only.
+
+ is null.
+
+
+ Saves the specified controller context by using the specified data provider.
+ The controller context.
+ The temporary data provider.
+
+
+ Adds the specified key/value pair to the dictionary.
+ The key/value pair.
+
+
+ Determines whether a sequence contains a specified element by using the default equality comparer.
+ true if the dictionary contains the specified key/value pair; otherwise, false.
+ The key/value pair to search for.
+
+
+ Copies a key/value pair to the specified array at the specified index.
+ The target array.
+ The index.
+
+
+ Gets a value that indicates whether the dictionary is read-only.
+ true if the dictionary is read-only; otherwise, false.
+
+
+ Deletes the specified key/value pair from the dictionary.
+ true if the key/value pair was removed successfully; otherwise, false.
+ The key/value pair.
+
+
+ Returns an enumerator that can be used to iterate through a collection.
+ An object that can be used to iterate through the collection.
+
+
+ Gets the value of the element that has the specified key.
+ true if the object that implements contains an element that has the specified key; otherwise, false.
+ The key of the value to get.
+ When this method returns, the value that is associated with the specified key, if the key is found; otherwise, the default value for the type of the parameter. This parameter is passed uninitialized.
+
+ is null.
+
+
+ Gets the object that contains the values in the object.
+ The values of the elements in the object that implements .
+
+
+ Encapsulates information about the current template context.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the formatted model value.
+ The formatted model value.
+
+
+ Retrieves the full DOM ID of a field using the specified HTML name attribute.
+ The full DOM ID.
+ The value of the HTML name attribute.
+
+
+ Retrieves the fully qualified name (including a prefix) for a field using the specified HTML name attribute.
+ The prefixed name of the field.
+ The value of the HTML name attribute.
+
+
+ Gets or sets the HTML field prefix.
+ The HTML field prefix.
+
+
+ Contains the number of objects that were visited by the user.
+ The number of objects.
+
+
+ Determines whether the template has been visited by the user.
+ true if the template has been visited by the user; otherwise, false.
+ An object that encapsulates information that describes the model.
+
+
+ Contains methods to build URLs for ASP.NET MVC within an application.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified request context.
+ An object that contains information about the current request and about the route that it matched.
+
+
+ Initializes a new instance of the class using the specified request context and route collection.
+ An object that contains information about the current request and about the route that it matched.
+ A collection of routes.
+ The or the parameter is null.
+
+
+ Generates a string to a fully qualified URL to an action method.
+ A string to a fully qualified URL to an action method.
+
+
+ Generates a fully qualified URL to an action method by using the specified action name.
+ The fully qualified URL to an action method.
+ The name of the action method.
+
+
+ Generates a fully qualified URL to an action method by using the specified action name and route values.
+ The fully qualified URL to an action method.
+ The name of the action method.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+
+
+ Generates a fully qualified URL to an action method by using the specified action name and controller name.
+ The fully qualified URL to an action method.
+ The name of the action method.
+ The name of the controller.
+
+
+ Generates a fully qualified URL to an action method by using the specified action name, controller name, and route values.
+ The fully qualified URL to an action method.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+
+
+ Generates a fully qualified URL to an action method by using the specified action name, controller name, route values, and protocol to use.
+ The fully qualified URL to an action method.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ The protocol for the URL, such as "http" or "https".
+
+
+ Generates a fully qualified URL to an action method by using the specified action name, controller name, and route values.
+ The fully qualified URL to an action method.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+
+
+ Generates a fully qualified URL for an action method by using the specified action name, controller name, route values, and protocol to use.
+ The fully qualified URL to an action method.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ The protocol for the URL, such as "http" or "https".
+
+
+ Generates a fully qualified URL for an action method by using the specified action name, controller name, route values, protocol to use and host name.
+ The fully qualified URL to an action method.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+
+
+ Generates a fully qualified URL to an action method for the specified action name and route values.
+ The fully qualified URL to an action method.
+ The name of the action method.
+ An object that contains the parameters for a route.
+
+
+ Converts a virtual (relative) path to an application absolute path.
+ The application absolute path.
+ The virtual path of the content.
+
+
+ Encodes special characters in a URL string into character-entity equivalents.
+ An encoded URL string.
+ The text to encode.
+
+
+ Returns a string that contains a content URL.
+ A string that contains a content URL.
+ The content path.
+ The http context.
+
+
+ Returns a string that contains a URL.
+ A string that contains a URL.
+ The route name.
+ The action name.
+ The controller name.
+ The HTTP protocol.
+ The host name.
+ The fragment.
+ The route values.
+ The route collection.
+ The request context.
+ true to include implicit MVC values; otherwise false.
+
+
+ Returns a string that contains a URL.
+ A string that contains a URL.
+ The route name.
+ The action name.
+ The controller name.
+ The route values.
+ The route collection.
+ The request context.
+ true to include implicit MVC values; otherwise false.
+
+
+ Generates a fully qualified URL for the specified route values.
+ A fully qualified URL for the specified route values.
+ The route name.
+ The route values.
+
+
+ Generates a fully qualified URL for the specified route values.
+ A fully qualified URL for the specified route values.
+ The route name.
+ The route values.
+
+
+ Returns a value that indicates whether the URL is local.
+ true if the URL is local; otherwise, false.
+ The URL.
+
+
+ Gets information about an HTTP request that matches a defined route.
+ The request context.
+
+
+ Gets a collection that contains the routes that are registered for the application.
+ The route collection.
+
+
+ Generates a fully qualified URL for the specified route values.
+ The fully qualified URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+
+
+ Generates a fully qualified URL for the specified route name.
+ The fully qualified URL.
+ The name of the route that is used to generate URL.
+
+
+ Generates a fully qualified URL for the specified route values by using a route name.
+ The fully qualified URL.
+ The name of the route that is used to generate URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+
+
+ Generates a fully qualified URL for the specified route values by using a route name and the protocol to use.
+ The fully qualified URL.
+ The name of the route that is used to generate the URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ The protocol for the URL, such as "http" or "https".
+
+
+ Generates a fully qualified URL for the specified route values by using a route name.
+ The fully qualified URL.
+ The name of the route that is used to generate URL.
+ An object that contains the parameters for a route.
+
+
+ Generates a fully qualified URL for the specified route values by using the specified route name, protocol to use, and host name.
+ The fully qualified URL.
+ The name of the route that is used to generate URL.
+ An object that contains the parameters for a route.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+
+
+ Generates a fully qualified URL for the specified route values.
+ The fully qualified URL.
+ An object that contains the parameters for a route.
+
+
+ Represents an optional parameter that is used by the class during routing.
+
+
+ Contains the read-only value for the optional parameter.
+
+
+ Returns an empty string. This method supports the ASP.NET MVC infrastructure and is not intended to be used directly from your code.
+ An empty string.
+
+
+ Provides an object adapter that can be validated.
+
+
+ Initializes a new instance of the class.
+ The model metadata.
+ The controller context.
+
+
+ Validates the specified object.
+ A list of validation results.
+ The container.
+
+
+ Represents an attribute that is used to prevent forgery of a request.
+
+
+ Initializes a new instance of the class.
+
+
+ Called when authorization is required.
+ The filter context.
+ The parameter is null.
+
+
+ Gets or sets the salt string.
+ The salt string.
+
+
+ Represents an attribute that is used to mark action methods whose input must be validated.
+
+
+ Initializes a new instance of the class.
+ true to enable validation.
+
+
+ Gets or sets a value that indicates whether to enable validation.
+ true if validation is enabled; otherwise, false.
+
+
+ Called when authorization is required.
+ The filter context.
+ The parameter is null.
+
+
+ Represents the collection of value-provider objects for the application.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class and registers the specified value providers.
+ The list of value providers to register.
+
+
+ Determines whether the collection contains the specified prefix.
+ true if the collection contains the specified prefix; otherwise, false.
+ The prefix to search for.
+
+
+ Gets the keys using the specified prefix.
+ They keys.
+ The prefix.
+
+
+ Returns a value object using the specified key.
+ The value object for the specified key.
+ The key of the value object to retrieve.
+
+
+ Returns a value object using the specified key and skip-validation parameter.
+ The value object for the specified key.
+ The key of the value object to retrieve.
+ true to specify that validation should be skipped; otherwise, false.
+
+
+ Inserts the specified value-provider object into the collection at the specified index location.
+ The zero-based index location at which to insert the value provider into the collection.
+ The value-provider object to insert.
+ The parameter is null.
+
+
+ Replaces the value provider at the specified index location with a new value provider.
+ The zero-based index of the element to replace.
+ The new value for the element at the specified index.
+ The parameter is null.
+
+
+ Note: This API is now obsolete.Represents a dictionary of value providers for the application.
+
+
+ Initializes a new instance of the class.
+ The controller context.
+
+
+ Adds the specified item to the collection of value providers.
+ The object to add to the object.
+ The object is read-only.
+
+
+ Adds an element that has the specified key and value to the collection of value providers.
+ The key of the element to add.
+ The value of the element to add.
+ The object is read-only.
+
+ is null.
+ An element that has the specified key already exists in the object.
+
+
+ Adds an element that has the specified key and value to the collection of value providers.
+ The key of the element to add.
+ The value of the element to add.
+ The object is read-only.
+
+ is null.
+ An element that has the specified key already exists in the object.
+
+
+ Removes all items from the collection of value providers.
+ The object is read-only.
+
+
+ Determines whether the collection of value providers contains the specified item.
+ true if is found in the collection of value providers; otherwise, false.
+ The object to locate in the instance.
+
+
+ Determines whether the collection of value providers contains an element that has the specified key.
+ true if the collection of value providers contains an element that has the key; otherwise, false.
+ The key of the element to find in the instance.
+
+ is null.
+
+
+ Gets or sets the controller context.
+ The controller context.
+
+
+ Copies the elements of the collection to an array, starting at the specified index.
+ The one-dimensional array that is the destination of the elements copied from the object. The array must have zero-based indexing.
+ The zero-based index in at which copying starts.
+
+ is null.
+
+ is less than 0.
+
+ is multidimensional.-or- is equal to or greater than the length of .-or-The number of elements in the source collection is greater than the available space from to the end of the destination .-or-Type cannot be cast automatically to the type of the destination array.
+
+
+ Gets the number of elements in the collection.
+ The number of elements in the collection.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Gets a value that indicates whether the collection is read-only.
+ true if the collection is read-only; otherwise, false.
+
+
+ Gets or sets the object that has the specified key.
+ The object.
+
+
+ Gets a collection that contains the keys of the instance.
+ A collection that contains the keys of the object that implements the interface.
+
+
+ Removes the first occurrence of the specified item from the collection of value providers.
+ true if was successfully removed from the collection; otherwise, false. This method also returns false if is not found in the collection.
+ The object to remove from the instance.
+ The object is read-only.
+
+
+ Removes the element that has the specified key from the collection of value providers.
+ true if the element was successfully removed; otherwise, false. This method also returns false if was not found in the collection.
+ The key of the element to remove.
+ The object is read-only.
+
+ is null.
+
+
+ Returns an enumerator that can be used to iterate through a collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Determines whether the collection contains the specified prefix.
+ true if the collection contains the specified prefix; otherwise, false.
+ The prefix to search for.
+
+
+ Returns a value object using the specified key.
+ The value object for the specified key.
+ The key of the value object to return.
+
+
+ Gets the value of the element that has the specified key.
+ true if the object that implements contains an element that has the specified key; otherwise, false.
+ The key of the element to get.
+ When this method returns, the value that is associated with the specified key, if the key is found; otherwise, the default value for the type of the parameter. This parameter is passed uninitialized.
+
+ is null.
+
+
+ Gets a collection that contains the values in the object.
+ A collection of the values in the object that implements the interface.
+
+
+ Represents a container for value-provider factory objects.
+
+
+ Gets the collection of value-provider factories for the application.
+ The collection of value-provider factory objects.
+
+
+ Represents a factory for creating value-provider objects.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a value-provider object for the specified controller context.
+ A value-provider object.
+ An object that encapsulates information about the current HTTP request.
+
+
+ Represents the collection of value-provider factories for the application.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified list of value-provider factories.
+ A list of value-provider factories to initialize the collection with.
+
+
+ Removes all elements from the collection.
+
+
+ Returns the value-provider factory for the specified controller context.
+ The value-provider factory object for the specified controller context.
+ An object that encapsulates information about the current HTTP request.
+
+
+ Inserts the specified value-provider factory object at the specified index location.
+ The zero-based index location at which to insert the value provider into the collection.
+ The value-provider factory object to insert.
+ The parameter is null.
+
+
+ Removes the element at the specified index of the .
+ The zero-based index of the element to remove.
+
+ is less than zero.-or- is equal to or greater than
+
+
+ Sets the specified value-provider factory object at the given index location.
+ The zero-based index location at which to insert the value provider into the collection.
+ The value-provider factory object to set.
+ The parameter is null.
+
+
+ Represents the result of binding a value (such as from a form post or query string) to an action-method argument property, or to the argument itself.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified raw value, attempted value, and culture information.
+ The raw value.
+ The attempted value.
+ The culture.
+
+
+ Gets or sets the raw value that is converted to a string for display.
+ The raw value.
+
+
+ Converts the value that is encapsulated by this result to the specified type.
+ The converted value.
+ The target type.
+ The parameter is null.
+
+
+ Converts the value that is encapsulated by this result to the specified type by using the specified culture information.
+ The converted value.
+ The target type.
+ The culture to use in the conversion.
+ The parameter is null.
+
+
+ Gets or sets the culture.
+ The culture.
+
+
+ Gets or set the raw value that is supplied by the value provider.
+ The raw value.
+
+
+ Encapsulates information that is related to rendering a view.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified controller context, view, view data dictionary, temporary data dictionary, and text writer.
+ Encapsulates information about the HTTP request.
+ The view to render.
+ The dictionary that contains the data that is required in order to render the view.
+ The dictionary that contains temporary data for the view.
+ The text writer object that is used to write HTML output.
+ One of the parameters is null.
+
+
+ Gets or sets a value that indicates whether client-side validation is enabled.
+ true if client-side validation is enabled; otherwise, false.
+
+
+ Gets or sets an object that encapsulates information that is required in order to validate and process the input data from an HTML form.
+ An object that encapsulates information that is required in order to validate and process the input data from an HTML form.
+
+
+ Writes the client validation information to the HTTP response.
+
+
+ Gets data that is associated with this request and that is available for only one request.
+ The temporary data.
+
+
+ Gets or sets a value that indicates whether unobtrusive JavaScript is enabled.
+ true if unobtrusive JavaScript is enabled; otherwise, false.
+
+
+ Element name used to wrap a top-level message generated by and other overloads.
+
+
+ Element name used to wrap a top-level message generated by and other overloads.
+
+
+ Gets an object that implements the interface to render in the browser.
+ The view.
+
+
+ Gets the dynamic view data dictionary.
+ The dynamic view data dictionary.
+
+
+ Gets the view data that is passed to the view.
+ The view data.
+
+
+ Gets or sets the text writer object that is used to write HTML output.
+ The object that is used to write the HTML output.
+
+
+ Represents a container that is used to pass data between a controller and a view.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified model.
+ The model.
+
+
+ Initializes a new instance of the class by using the specified dictionary.
+ The dictionary.
+ The parameter is null.
+
+
+ Adds the specified item to the collection.
+ The object to add to the collection.
+ The collection is read-only.
+
+
+ Adds an element to the collection using the specified key and value .
+ The key of the element to add.
+ The value of the element to add.
+ The object is read-only.
+
+ is null.
+ An element with the same key already exists in the object.
+
+
+ Removes all items from the collection.
+ The object is read-only.
+
+
+ Determines whether the collection contains the specified item.
+ true if is found in the collection; otherwise, false.
+ The object to locate in the collection.
+
+
+ Determines whether the collection contains an element that has the specified key.
+ true if the collection contains an element that has the specified key; otherwise, false.
+ The key of the element to locate in the collection.
+
+ is null.
+
+
+ Copies the elements of the collection to an array, starting at a particular index.
+ The one-dimensional array that is the destination of the elements copied from the collection. The array must have zero-based indexing.
+ The zero-based index in at which copying begins.
+
+ is null.
+
+ is less than 0.
+
+ is multidimensional.-or- is equal to or greater than the length of .-or- The number of elements in the source collection is greater than the available space from to the end of the destination .-or- Type cannot be cast automatically to the type of the destination .
+
+
+ Gets the number of elements in the collection.
+ The number of elements in the collection.
+
+
+ Evaluates the specified expression.
+ The results of the evaluation.
+ The expression.
+ The parameter is null or empty.
+
+
+ Evaluates the specified expression by using the specified format.
+ The results of the evaluation.
+ The expression.
+ The format.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Returns information about the view data as defined by the parameter.
+ An object that contains the view data information that is defined by the parameter.
+ A set of key/value pairs that define the view-data information to return.
+ The parameter is either null or empty.
+
+
+ Gets a value that indicates whether the collection is read-only.
+ true if the collection is read-only; otherwise, false.
+
+
+ Gets or sets the item that is associated with the specified key.
+ The value of the selected item.
+
+
+ Gets a collection that contains the keys of this dictionary.
+ A collection that contains the keys of the object that implements .
+
+
+ Gets or sets the model that is associated with the view data.
+ The model that is associated with the view data.
+
+
+ Gets or sets information about the model.
+ Information about the model.
+
+
+ Gets the state of the model.
+ The state of the model.
+
+
+ Removes the first occurrence of a specified object from the collection.
+ true if was successfully removed from the collection; otherwise, false. This method also returns false if is not found in the collection.
+ The object to remove from the collection.
+ The collection is read-only.
+
+
+ Removes the element from the collection using the specified key.
+ true if the element is successfully removed; otherwise, false. This method also returns false if was not found in the original collection.
+ The key of the element to remove.
+ The collection is read-only.
+
+ is null.
+
+
+ Sets the data model to use for the view.
+ The data model to use for the view.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Gets or sets an object that encapsulates information about the current template context.
+ An object that contains information about the current template.
+
+
+ Attempts to retrieve the value that is associated with the specified key.
+ true if the collection contains an element with the specified key; otherwise, false.
+ The key of the value to get.
+ When this method returns, the value that is associated with the specified key, if the key is found; otherwise, the default value for the type of the parameter. This parameter is passed uninitialized.
+
+ is null.
+
+
+ Gets a collection that contains the values in this dictionary.
+ A collection that contains the values of the object that implements .
+
+
+ Represents a container that is used to pass strongly typed data between a controller and a view.
+ The type of the model.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified view data dictionary.
+ An existing view data dictionary to copy into this instance.
+
+
+ Initializes a new instance of the class by using the specified model.
+ The data model to use for the view.
+
+
+ Gets or sets the model.
+ A reference to the data model.
+
+
+ Gets or sets information about the model.
+ Information about the model.
+
+
+ Sets the data model to use for the view.
+ The data model to use for the view.
+ An error occurred while the model was being set.
+
+
+ Encapsulates information about the current template content that is used to develop templates and about HTML helpers that interact with templates.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the T:System.Web.Mvc.ViewDataInfo class and associates a delegate for accessing the view data information.
+ A delegate that defines how the view data information is accessed.
+
+
+ Gets or sets the object that contains the values to be displayed by the template.
+ The object that contains the values to be displayed by the template.
+
+
+ Gets or sets the description of the property to be displayed by the template.
+ The description of the property to be displayed by the template.
+
+
+ Gets or sets the current value to be displayed by the template.
+ The current value to be displayed by the template.
+
+
+ Represents a collection of view engines that are available to the application.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified list of view engines.
+ The list that is wrapped by the new collection.
+
+ is null.
+
+
+ Removes all elements from the .
+
+
+ Finds the specified partial view by using the specified controller context.
+ The partial view.
+ The controller context.
+ The name of the partial view.
+ The parameter is null.
+ The parameter is null or empty.
+
+
+ Finds the specified view by using the specified controller context and master view.
+ The view.
+ The controller context.
+ The name of the view.
+ The name of the master view.
+ The parameter is null.
+ The parameter is null or empty.
+
+
+ Inserts an element into the collection at the specified index.
+ The zero-based index at which item should be inserted.
+ The object to insert.
+
+ is less than zero.-or- is greater than the number of items in the collection.
+ The parameter is null.
+
+
+ Removes the element at the specified index of the .
+ The zero-based index of the element to remove.
+
+ is less than zero.-or- is equal to or greater than
+
+
+ Replaces the element at the specified index.
+ The zero-based index of the element to replace.
+ The new value for the element at the specified index.
+
+ is less than zero.-or- is greater than the number of items in the collection.
+ The parameter is null.
+
+
+ Represents the result of locating a view engine.
+
+
+ Initializes a new instance of the class by using the specified searched locations.
+ The searched locations.
+ The parameter is null.
+
+
+ Initializes a new instance of the class by using the specified view and view engine.
+ The view.
+ The view engine.
+ The or parameter is null.
+
+
+ Gets or sets the searched locations.
+ The searched locations.
+
+
+ Gets or sets the view.
+ The view.
+
+
+ Gets or sets the view engine.
+ The view engine.
+
+
+ Represents a collection of view engines that are available to the application.
+
+
+ Gets the view engines.
+ The view engines.
+
+
+ Represents the information that is needed to build a master view page.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the AJAX script for the master page.
+ The AJAX script for the master page.
+
+
+ Gets the HTML for the master page.
+ The HTML for the master page.
+
+
+ Gets the model.
+ The model.
+
+
+ Gets the temporary data.
+ The temporary data.
+
+
+ Gets the URL.
+ The URL.
+
+
+ Gets the dynamic view-bag dictionary.
+ The dynamic view-bag dictionary.
+
+
+ Gets the view context.
+ The view context.
+
+
+ Gets the view data.
+ The view data.
+
+
+ Gets the writer that is used to render the master page.
+ The writer that is used to render the master page.
+
+
+ Represents the information that is required in order to build a strongly typed master view page.
+ The type of the model.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the AJAX script for the master page.
+ The AJAX script for the master page.
+
+
+ Gets the HTML for the master page.
+ The HTML for the master page.
+
+
+ Gets the model.
+ A reference to the data model.
+
+
+ Gets the view data.
+ The view data.
+
+
+ Represents the properties and methods that are needed to render a view as a Web Forms page.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the object that is used to render HTML in Ajax scenarios.
+ The Ajax helper object that is associated with the view.
+
+
+ Gets or sets the object that is used to render HTML elements.
+ The HTML helper object that is associated with the view.
+
+
+ Initializes the , , and properties.
+
+
+ Gets or sets the path of the master view.
+ The path of the master view.
+
+
+ Gets the Model property of the associated object.
+ The Model property of the associated object.
+
+
+ Raises the event at the beginning of page initialization.
+ The event data.
+
+
+ Enables processing of the specified HTTP request by the ASP.NET MVC framework.
+ An object that encapsulates HTTP-specific information about the current HTTP request.
+
+
+ Initializes the object that receives the page content to be rendered.
+ The object that receives the page content.
+
+
+ Renders the view page to the response using the specified view context.
+ An object that encapsulates the information that is required in order to render the view, which includes the controller context, form context, the temporary data, and the view data for the associated view.
+
+
+ Note: This API is now obsolete.Sets the text writer that is used to render the view to the response.
+ The writer that is used to render the view to the response.
+
+
+ Sets the view data dictionary for the associated view.
+ A dictionary of data to pass to the view.
+
+
+ Gets the temporary data to pass to the view.
+ The temporary data to pass to the view.
+
+
+ Gets or sets the URL of the rendered page.
+ The URL of the rendered page.
+
+
+ Gets the view bag.
+ The view bag.
+
+
+ Gets or sets the information that is used to render the view.
+ The information that is used to render the view, which includes the form context, the temporary data, and the view data of the associated view.
+
+
+ Gets or sets a dictionary that contains data to pass between the controller and the view.
+ A dictionary that contains data to pass between the controller and the view.
+
+
+ Gets the text writer that is used to render the view to the response.
+ The text writer that is used to render the view to the response.
+
+
+ Represents the information that is required in order to render a strongly typed view as a Web Forms page.
+ The type of the model.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the object that supports rendering HTML in Ajax scenarios.
+ The Ajax helper object that is associated with the view.
+
+
+ Gets or sets the object that provides support for rendering elements.
+ The HTML helper object that is associated with the view.
+
+
+ Instantiates and initializes the and properties.
+
+
+ Gets the property of the associated object.
+ A reference to the data model.
+
+
+ Sets the view data dictionary for the associated view.
+ A dictionary of data to pass to the view.
+
+
+ Gets or sets a dictionary that contains data to pass between the controller and the view.
+ A dictionary that contains data to pass between the controller and the view.
+
+
+ Represents a class that is used to render a view by using an instance that is returned by an object.
+
+
+ Initializes a new instance of the class.
+
+
+ Searches the registered view engines and returns the object that is used to render the view.
+ The object that is used to render the view.
+ The controller context.
+ An error occurred while the method was searching for the view.
+
+
+ Gets the name of the master view (such as a master page or template) to use when the view is rendered.
+ The name of the master view.
+
+
+ Represents a base class that is used to provide the model to the view and then render the view to the response.
+
+
+ Initializes a new instance of the class.
+
+
+ When called by the action invoker, renders the view to the response.
+ The context that the result is executed in.
+ The parameter is null.
+
+
+ Returns the object that is used to render the view.
+ The view engine.
+ The context.
+
+
+ Gets the view data model.
+ The view data model.
+
+
+ Gets or sets the object for this result.
+ The temporary data.
+
+
+ Gets or sets the object that is rendered to the response.
+ The view.
+
+
+ Gets the view bag.
+ The view bag.
+
+
+ Gets or sets the view data object for this result.
+ The view data.
+
+
+ Gets or sets the collection of view engines that are associated with this result.
+ The collection of view engines.
+
+
+ Gets or sets the name of the view to render.
+ The name of the view.
+
+
+ Provides an abstract class that can be used to implement a view start (master) page.
+
+
+ When implemented in a derived class, initializes a new instance of the class.
+
+
+ When implemented in a derived class, gets the HTML markup for the view start page.
+ The HTML markup for the view start page.
+
+
+ When implemented in a derived class, gets the URL for the view start page.
+ The URL for the view start page.
+
+
+ When implemented in a derived class, gets the view context for the view start page.
+ The view context for the view start page.
+
+
+ Provides a container for objects.
+
+
+ Initializes a new instance of the class.
+
+
+ Provides a container for objects.
+ The type of the model.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the formatted value.
+ The formatted value.
+
+
+ Represents the type of a view.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the name of the type.
+ The name of the type.
+
+
+ Represents the information that is needed to build a user control.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the AJAX script for the view.
+ The AJAX script for the view.
+
+
+ Ensures that view data is added to the object of the user control if the view data exists.
+
+
+ Gets the HTML for the view.
+ The HTML for the view.
+
+
+ Gets the model.
+ The model.
+
+
+ Renders the view by using the specified view context.
+ The view context.
+
+
+ Sets the text writer that is used to render the view to the response.
+ The writer that is used to render the view to the response.
+
+
+ Sets the view-data dictionary by using the specified view data.
+ The view data.
+
+
+ Gets the temporary-data dictionary.
+ The temporary-data dictionary.
+
+
+ Gets the URL for the view.
+ The URL for the view.
+
+
+ Gets the view bag.
+ The view bag.
+
+
+ Gets or sets the view context.
+ The view context.
+
+
+ Gets or sets the view-data dictionary.
+ The view-data dictionary.
+
+
+ Gets or sets the view-data key.
+ The view-data key.
+
+
+ Gets the writer that is used to render the view to the response.
+ The writer that is used to render the view to the response.
+
+
+ Represents the information that is required in order to build a strongly typed user control.
+ The type of the model.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the AJAX script for the view.
+ The AJAX script for the view.
+
+
+ Gets the HTML for the view.
+ The HTML for the view.
+
+
+ Gets the model.
+ A reference to the data model.
+
+
+ Sets the view data for the view.
+ The view data.
+
+
+ Gets or sets the view data.
+ The view data.
+
+
+ Represents an abstract base-class implementation of the interface.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the area-enabled master location formats.
+ The area-enabled master location formats.
+
+
+ Gets or sets the area-enabled partial-view location formats.
+ The area-enabled partial-view location formats.
+
+
+ Gets or sets the area-enabled view location formats.
+ The area-enabled view location formats.
+
+
+ Creates the specified partial view by using the specified controller context.
+ A reference to the partial view.
+ The controller context.
+ The partial path for the new partial view.
+
+
+ Creates the specified view by using the controller context, path of the view, and path of the master view.
+ A reference to the view.
+ The controller context.
+ The path of the view.
+ The path of the master view.
+
+
+ Gets or sets the display mode provider.
+ The display mode provider.
+
+
+ Returns a value that indicates whether the file is in the specified path by using the specified controller context.
+ true if the file is in the specified path; otherwise, false.
+ The controller context.
+ The virtual path.
+
+
+ Gets or sets the file-name extensions that are used to locate a view.
+ The file-name extensions that are used to locate a view.
+
+
+ Finds the specified partial view by using the specified controller context.
+ The partial view.
+ The controller context.
+ The name of the partial view.
+ true to use the cached partial view.
+ The parameter is null (Nothing in Visual Basic).
+ The parameter is null or empty.
+
+
+ Finds the specified view by using the specified controller context and master view name.
+ The page view.
+ The controller context.
+ The name of the view.
+ The name of the master view.
+ true to use the cached view.
+ The parameter is null (Nothing in Visual Basic).
+ The parameter is null or empty.
+
+
+ Gets or sets the master location formats.
+ The master location formats.
+
+
+ Gets or sets the partial-view location formats.
+ The partial-view location formats.
+
+
+ Releases the specified view by using the specified controller context.
+ The controller context.
+ The view to release.
+
+
+ Gets or sets the view location cache.
+ The view location cache.
+
+
+ Gets or sets the view location formats.
+ The view location formats.
+
+
+ Gets or sets the virtual path provider.
+ The virtual path provider.
+
+
+ Represents the information that is needed to build a Web Forms page in ASP.NET MVC.
+
+
+ Initializes a new instance of the class using the controller context and view path.
+ The controller context.
+ The view path.
+
+
+ Initializes a new instance of the class using the controller context, view path, and the path to the master page.
+ The controller context.
+ The view path.
+ The path to the master page.
+
+
+ Initializes a new instance of the class using the controller context, view path, the path to the master page, and a instance.
+ The controller context.
+ The view path.
+ The path to the master page.
+ An instance of the view page activator interface.
+
+
+ Gets or sets the master path.
+ The master path.
+
+
+ Renders the view to the response.
+ An object that encapsulates the information that is required in order to render the view, which includes the controller context, form context, the temporary data, and the view data for the associated view.
+ The text writer object that is used to write HTML output.
+ The view page instance.
+
+
+ Represents a view engine that is used to render a Web Forms page to the response.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified view page activator.
+ An instance of a class that implements the interface.
+
+
+ Creates the specified partial view by using the specified controller context.
+ The partial view.
+ The controller context.
+ The partial path.
+
+
+ Creates the specified view by using the specified controller context and the paths of the view and master view.
+ The view.
+ The controller context.
+ The view path.
+ The master-view path.
+
+
+ Represents the properties and methods that are needed in order to render a view that uses ASP.NET Razor syntax.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the object that is used to render HTML using Ajax.
+ The object that is used to render HTML using Ajax.
+
+
+ Sets the view context and view data for the page.
+ The parent page.
+
+
+ Gets the object that is associated with the page.
+ The object that is associated with the page.
+
+
+ Runs the page hierarchy for the ASP.NET Razor execution pipeline.
+
+
+ Gets or sets the object that is used to render HTML elements.
+ The object that is used to render HTML elements.
+
+
+ Initializes the , , and classes.
+
+
+ Gets the Model property of the associated object.
+ The Model property of the associated object.
+
+
+ Sets the view data.
+ The view data.
+
+
+ Gets the temporary data to pass to the view.
+ The temporary data to pass to the view.
+
+
+ Gets or sets the URL of the rendered page.
+ The URL of the rendered page.
+
+
+ Gets the view bag.
+ The view bag.
+
+
+ Gets or sets the information that is used to render the view.
+ The information that is used to render the view, which includes the form context, the temporary data, and the view data of the associated view.
+
+
+ Gets or sets a dictionary that contains data to pass between the controller and the view.
+ A dictionary that contains data to pass between the controller and the view.
+
+
+ Represents the properties and methods that are needed in order to render a view that uses ASP.NET Razor syntax.
+ The type of the view data model.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the object that is used to render HTML markup using Ajax.
+ The object that is used to render HTML markup using Ajax.
+
+
+ Gets or sets the object that is used to render HTML elements.
+ The object that is used to render HTML elements.
+
+
+ Initializes the , , and classes.
+
+
+ Gets the Model property of the associated object.
+ The Model property of the associated object.
+
+
+ Sets the view data.
+ The view data.
+
+
+ Gets or sets a dictionary that contains data to pass between the controller and the view.
+ A dictionary that contains data to pass between the controller and the view.
+
+
+ Represents support for ASP.NET AJAX within an ASP.NET MVC application.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ The name of the controller.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+ The URL fragment name (the anchor name).
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ The name of the controller.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+ The URL fragment name (the anchor name).
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ The name of the controller.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the URL to the specified action method; when the action link is clicked, the action method is invoked asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the action method.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ The name of the controller.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the action method that will handle the request.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element..
+
+
+ Writes an opening <form> tag to the response.
+ An opening <form> tag.
+ The AJAX helper.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response using the specified routing information.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the route to use to obtain the form post URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response using the specified routing information.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the route to use to obtain the form post URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response using the specified routing information.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the route to use to obtain the form post URL.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response using the specified routing information.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the route to use to obtain the form post URL.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+
+
+ Writes an opening <form> tag to the response using the specified routing information.
+ An opening <form> tag.
+ The AJAX helper.
+ The name of the route to use to obtain the form post URL.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML script element that contains a reference to a globalization script that defines the culture information.
+ A script element whose src attribute is set to the globalization script, as in the following example: <script type="text/javascript" src="/MvcApplication1/Scripts/Globalization/en-US.js"></script>
+ The AJAX helper object that this method extends.
+
+
+ Returns an HTML script element that contains a reference to a globalization script that defines the specified culture information.
+ An HTML script element whose src attribute is set to the globalization script, as in the following example:<script type="text/javascript" src="/MvcApplication1/Scripts/Globalization/en-US.js"></script>
+ The AJAX helper object that this method extends.
+ Encapsulates information about the target culture, such as date formats.
+ The parameter is null.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the route to use to obtain the form post URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the route to use to obtain the form post URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the route to use to obtain the form post URL.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+ The URL fragment name (the anchor name).
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the route to use to obtain the form post URL.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the route to use to obtain the form post URL.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the route to use to obtain the form post URL.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the route to use to obtain the form post URL.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ The name of the route to use to obtain the form post URL.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ The parameter is null or empty.
+
+
+ Returns an anchor element that contains the virtual path for the specified route values; when the link is clicked, a request is made to the virtual path asynchronously by using JavaScript.
+ An anchor element.
+ The AJAX helper.
+ The inner text of the anchor element.
+ An object that contains the parameters for a route.
+ An object that provides options for the asynchronous request.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Represents option settings for running Ajax scripts in an ASP.NET MVC application.
+
+
+ Initializes a new instance of the class.
+
+
+
+ Gets or sets the message to display in a confirmation window before a request is submitted.
+ The message to display in a confirmation window.
+
+
+ Gets or sets the HTTP request method ("Get" or "Post").
+ The HTTP request method. The default value is "Post".
+
+
+ Gets or sets the mode that specifies how to insert the response into the target DOM element.
+ The insertion mode ("InsertAfter", "InsertBefore", or "Replace"). The default value is "Replace".
+
+
+ Gets or sets a value, in milliseconds, that controls the duration of the animation when showing or hiding the loading element.
+ A value, in milliseconds, that controls the duration of the animation when showing or hiding the loading element.
+
+
+ Gets or sets the id attribute of an HTML element that is displayed while the Ajax function is loading.
+ The ID of the element that is displayed while the Ajax function is loading.
+
+
+ Gets or sets the name of the JavaScript function to call immediately before the page is updated.
+ The name of the JavaScript function to call before the page is updated.
+
+
+ Gets or sets the JavaScript function to call when response data has been instantiated but before the page is updated.
+ The JavaScript function to call when the response data has been instantiated.
+
+
+ Gets or sets the JavaScript function to call if the page update fails.
+ The JavaScript function to call if the page update fails.
+
+
+ Gets or sets the JavaScript function to call after the page is successfully updated.
+ The JavaScript function to call after the page is successfully updated.
+
+
+ Returns the Ajax options as a collection of HTML attributes to support unobtrusive JavaScript.
+ The Ajax options as a collection of HTML attributes to support unobtrusive JavaScript.
+
+
+ Gets or sets the ID of the DOM element to update by using the response from the server.
+ The ID of the DOM element to update.
+
+
+ Gets or sets the URL to make the request to.
+ The URL to make the request to.
+
+
+ Enumerates the AJAX script insertion modes.
+
+
+ Insert after the element.
+
+
+ Insert before the element.
+
+
+ Replace the element.
+
+
+ Replace the entire element.
+
+
+ Provides information about an asynchronous action method, such as its name, controller, parameters, attributes, and filters.
+
+
+ Initializes a new instance of the class.
+
+
+ Invokes the asynchronous action method by using the specified parameters and controller context.
+ An object that contains the result of an asynchronous call.
+ The controller context.
+ The parameters of the action method.
+ The callback method.
+ An object that contains information to be used by the callback method. This parameter can be null.
+
+
+ Returns the result of an asynchronous operation.
+ The result of an asynchronous operation.
+ An object that represents the status of an asynchronous operation.
+
+
+ Executes the asynchronous action method by using the specified parameters and controller context.
+ The result of executing the asynchronous action method.
+ The controller context.
+ The parameters of the action method.
+
+
+ Represents a class that is responsible for invoking the action methods of an asynchronous controller.
+
+
+ Initializes a new instance of the class.
+
+
+ Invokes the asynchronous action method by using the specified controller context, action name, callback method, and state.
+ An object that contains the result of an asynchronous operation.Implements
+ The controller context.
+ The name of the action.
+ The callback method.
+ An object that contains information to be used by the callback method. This parameter can be null.
+
+
+ Invokes the asynchronous action method by using the specified controller context, action descriptor, parameters, callback method, and state.
+ An object that contains the result of an asynchronous operation.
+ The controller context.
+ The action descriptor.
+ The parameters for the asynchronous action method.
+ The callback method.
+ An object that contains information to be used by the callback method. This parameter can be null.
+
+
+ Invokes the asynchronous action method by using the specified controller context, filters, action descriptor, parameters, callback method, and state.
+ An object that contains the result of an asynchronous operation.
+ The controller context.
+ The filters.
+ The action descriptor.
+ The parameters for the asynchronous action method.
+ The callback method.
+ An object that contains information to be used by the callback method. This parameter can be null.
+
+
+ Cancels the action.
+ true if the action was canceled; otherwise, false.
+ The user-defined object that qualifies or contains information about an asynchronous operation.
+
+
+ Cancels the action.
+ true if the action was canceled; otherwise, false.
+ The user-defined object that qualifies or contains information about an asynchronous operation.
+
+
+ Cancels the action.
+ true if the action was canceled; otherwise, false.
+ The user-defined object that qualifies or contains information about an asynchronous operation.
+
+
+ Returns the controller descriptor.
+ The controller descriptor.
+ The controller context.
+
+
+ Provides asynchronous operations for the class.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the synchronization context.
+ The synchronization context.
+
+
+ Notifies ASP.NET that all asynchronous operations are complete.
+
+
+ Occurs when the method is called.
+
+
+ Gets the number of outstanding operations.
+ The number of outstanding operations.
+
+
+ Gets the parameters that were passed to the asynchronous completion method.
+ The parameters that were passed to the asynchronous completion method.
+
+
+ Executes a callback in the current synchronization context.
+ The asynchronous action.
+
+
+ Gets or sets the asynchronous timeout value, in milliseconds.
+ The asynchronous timeout value, in milliseconds.
+
+
+ Defines the interface for an action invoker, which is used to invoke an asynchronous action in response to an HTTP request.
+
+
+ Invokes the specified action.
+ The status of the asynchronous result.
+ The controller context.
+ The name of the asynchronous action.
+ The callback method.
+ The state.
+
+
+ Cancels the asynchronous action.
+ true if the asynchronous method could be canceled; otherwise, false.
+ The asynchronous result.
+
+
+ Used to create an instance for the current request.
+
+
+ Creates an instance of async action invoker for the current request.
+ The created .
+
+
+ Defines the methods that are required for an asynchronous controller.
+
+
+ Executes the specified request context.
+ The status of the asynchronous operation.
+ The request context.
+ The asynchronous callback method.
+ The state.
+
+
+ Ends the asynchronous operation.
+ The asynchronous result.
+
+
+ Provides a container for the asynchronous manager object.
+
+
+ Gets the asynchronous manager object.
+ The asynchronous manager object.
+
+
+ Provides a container that maintains a count of pending asynchronous operations.
+
+
+ Initializes a new instance of the class.
+
+
+ Occurs when an asynchronous method completes.
+
+
+ Gets the operation count.
+ The operation count.
+
+
+ Reduces the operation count by 1.
+ The updated operation count.
+
+
+ Reduces the operation count by the specified value.
+ The updated operation count.
+ The number of operations to reduce the count by.
+
+
+ Increments the operation count by one.
+ The updated operation count.
+
+
+ Increments the operation count by the specified value.
+ The updated operation count.
+ The number of operations to increment the count by.
+
+
+ Provides information about an asynchronous action method, such as its name, controller, parameters, attributes, and filters.
+
+
+ Initializes a new instance of the class.
+ An object that contains information about the method that begins the asynchronous operation (the method whose name ends with "Asynch").
+ An object that contains information about the completion method (method whose name ends with "Completed").
+ The name of the action.
+ The controller descriptor.
+
+
+ Gets the name of the action method.
+ The name of the action method.
+
+
+ Gets the method information for the asynchronous action method.
+ The method information for the asynchronous action method.
+
+
+ Begins running the asynchronous action method by using the specified parameters and controller context.
+ An object that contains the result of an asynchronous call.
+ The controller context.
+ The parameters of the action method.
+ The callback method.
+ An object that contains information to be used by the callback method. This parameter can be null.
+
+
+ Gets the method information for the asynchronous completion method.
+ The method information for the asynchronous completion method.
+
+
+ Gets the controller descriptor for the asynchronous action method.
+ The controller descriptor for the asynchronous action method.
+
+
+ Returns the result of an asynchronous operation.
+ The result of an asynchronous operation.
+ An object that represents the status of an asynchronous operation.
+
+
+ Returns an array of custom attributes that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Returns an array of custom attributes that are defined for this member, identified by type.
+ An array of custom attributes, or an empty array if no custom attributes of the specified type exist.
+ The type of the custom attributes to return.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Gets the filter attributes.
+ The filter attributes.
+ Use cache flag.
+
+
+ Returns the parameters of the action method.
+ The parameters of the action method.
+
+
+ Returns the action-method selectors.
+ The action-method selectors.
+
+
+ Determines whether one or more instances of the specified attribute type are defined for the action member.
+ true if an attribute of type that is represented by is defined for this member; otherwise, false.
+ The type of the custom attribute.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+
+ Gets the lazy initialized unique ID of the instance of this class.
+ The lazy initialized unique ID of the instance of this class.
+
+
+ Encapsulates information that describes an asynchronous controller, such as its name, type, and actions.
+
+
+ Initializes a new instance of the class.
+ The type of the controller.
+
+
+ Gets the type of the controller.
+ The type of the controller.
+
+
+ Finds an action method by using the specified name and controller context.
+ The information about the action method.
+ The controller context.
+ The name of the action.
+
+
+ Returns a list of action method descriptors in the controller.
+ A list of action method descriptors in the controller.
+
+
+ Returns custom attributes that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Returns custom attributes of a specified type that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Gets the filter attributes.
+ The filter attributes.
+ true to use the cache, otherwise false.
+
+
+ Returns a value that indicates whether one or more instances of the specified custom attribute are defined for this member.
+ true if an attribute of the type represented by is defined for this member; otherwise, false.
+ The type of the custom attribute.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Represents an exception that occurred during the synchronous processing of an HTTP request in an ASP.NET MVC application.
+
+
+ Initializes a new instance of the class using a system-supplied message.
+
+
+ Initializes a new instance of the class using the specified message.
+ The message that describes the exception. The caller of this constructor must make sure that this string has been localized for the current system culture.
+
+
+ Initializes a new instance of the class using a specified error message and a reference to the inner exception that is the cause of this exception.
+ The message that describes the exception. The caller of this constructor must make sure that this string has been localized for the current system culture.
+ The exception that is the cause of the current exception. If the parameter is not null, the current exception is raised in a catch block that handles the inner exception.
+
+
+ When an action method returns either Task or Task<T> the provides information about the action.
+
+
+ Initializes a new instance of the class.
+ The task method information.
+ The action name.
+ The controller descriptor.
+
+
+ Gets the name of the action method.
+ The name of the action method.
+
+
+ Invokes the asynchronous action method using the specified parameters, controller context callback and state.
+ An object that contains the result of an asynchronous call.
+ The controller context.
+ The parameters of the action method.
+ The optional callback method.
+ An object that contains information to be used by the callback method. This parameter can be null.
+
+
+ Gets the controller descriptor.
+ The controller descriptor.
+
+
+ Ends the asynchronous operation.
+ The result of an asynchronous operation.
+ An object that represents the status of an asynchronous operation.
+
+
+ Executes the asynchronous action method
+ The result of executing the asynchronous action method.
+ The controller context.
+ The parameters of the action method.
+
+
+ Returns an array of custom attributes that are defined for this member, excluding named attributes.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Returns an array of custom attributes that are defined for this member, identified by type.
+ An array of custom attributes, or an empty array if no custom attributes exist.
+ The type of the custom attributes.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+ Returns an array of all custom attributes applied to this member.
+ An array that contains all the custom attributes applied to this member, or an array with zero elements if no attributes are defined.
+ true to search this member's inheritance chain to find the attributes; otherwise, false.
+
+
+ Returns the parameters of the asynchronous action method.
+ The parameters of the asynchronous action method.
+
+
+ Returns the asynchronous action-method selectors.
+ The asynchronous action-method selectors.
+
+
+ Returns a value that indicates whether one or more instance of the specified custom attribute are defined for this member.
+ A value that indicates whether one or more instance of the specified custom attribute are defined for this member.
+ The type of the custom attribute.
+ true to look up the hierarchy chain for the inherited custom attribute; otherwise, false.
+
+
+
+ Gets information for the asynchronous task.
+ Information for the asynchronous task.
+
+
+ Gets the unique ID for the task.
+ The unique ID for the task.
+
+
+ Represents an authentication challenge context containing information for executing an authentication challenge.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The controller context.
+ The action methods associated with the challenge.
+ The challenge response.
+
+
+ Gets or sets the action descriptor.
+ The action descriptor associated with the challenge.
+
+
+ Gets or sets the action result to execute.
+ The challenge response.
+
+
+ Represents an authentication context containing information for performing authentication.
+
+
+ Initializes a new instance of the class.
+
+
+
+ Gets or sets the action descriptor.
+ The action methods associated with the authentication
+
+
+ Gets or sets the currently authenticated principal.
+ The security credentials for the authentication.
+
+
+ Gets or sets the error result, which indicates that authentication was attempted and failed.
+ The authentication result.
+
+
+ Defines a filter that performs authentication.
+
+
+ Authenticates the request.
+ The context to use for authentication.
+
+
+ Adds an authentication challenge to the current .
+ The context to use for the authentication challenge.
+
+
+ Defines a filter that overrides other filters.
+
+
+ Gets the type of filters to override.
+ The filter to override.
+
+
+ Represents support for calling child action methods and rendering the result inline in a parent view.
+
+
+ Invokes the specified child action method and returns the result as an HTML string.
+ The child action result as an HTML string.
+ The HTML helper instance that this method extends.
+ The name of the action method to invoke.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method with the specified parameters and returns the result as an HTML string.
+ The child action result as an HTML string.
+ The HTML helper instance that this method extends.
+ The name of the action method to invoke.
+ An object that contains the parameters for a route. You can use to provide the parameters that are bound to the action method parameters. The parameter is merged with the original route values and overrides them.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified controller name and returns the result as an HTML string.
+ The child action result as an HTML string.
+ The HTML helper instance that this method extends.
+ The name of the action method to invoke.
+ The name of the controller that contains the action method.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified parameters and controller name and returns the result as an HTML string.
+ The child action result as an HTML string.
+ The HTML helper instance that this method extends.
+ The name of the action method to invoke.
+ The name of the controller that contains the action method.
+ An object that contains the parameters for a route. You can use to provide the parameters that are bound to the action method parameters. The parameter is merged with the original route values and overrides them.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified parameters and controller name and returns the result as an HTML string.
+ The child action result as an HTML string.
+ The HTML helper instance that this method extends.
+ The name of the action method to invoke.
+ The name of the controller that contains the action method.
+ A dictionary that contains the parameters for a route. You can use to provide the parameters that are bound to the action method parameters. The parameter is merged with the original route values and overrides them.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified parameters and returns the result as an HTML string.
+ The child action result as an HTML string.
+ The HTML helper instance that this method extends.
+ The name of the action method to invoke.
+ A dictionary that contains the parameters for a route. You can use to provide the parameters that are bound to the action method parameters. The parameter is merged with the original route values and overrides them.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method and renders the result inline in the parent view.
+ The HTML helper instance that this method extends.
+ The name of the child action method to invoke.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified parameters and renders the result inline in the parent view.
+ The HTML helper instance that this method extends.
+ The name of the child action method to invoke.
+ An object that contains the parameters for a route. You can use to provide the parameters that are bound to the action method parameters. The parameter is merged with the original route values and overrides them.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified controller name and renders the result inline in the parent view.
+ The HTML helper instance that this method extends.
+ The name of the child action method to invoke.
+ The name of the controller that contains the action method.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified parameters and controller name and renders the result inline in the parent view.
+ The HTML helper instance that this method extends.
+ The name of the child action method to invoke.
+ The name of the controller that contains the action method.
+ An object that contains the parameters for a route. You can use to provide the parameters that are bound to the action method parameters. The parameter is merged with the original route values and overrides them.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified parameters and controller name and renders the result inline in the parent view.
+ The HTML helper instance that this method extends.
+ The name of the child action method to invoke.
+ The name of the controller that contains the action method.
+ A dictionary that contains the parameters for a route. You can use to provide the parameters that are bound to the action method parameters. The parameter is merged with the original route values and overrides them.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Invokes the specified child action method using the specified parameters and renders the result inline in the parent view.
+ The HTML helper instance that this method extends.
+ The name of the child action method to invoke.
+ A dictionary that contains the parameters for a route. You can use to provide the parameters that are bound to the action method parameters. The parameter is merged with the original route values and overrides them.
+ The parameter is null.
+ The parameter is null or empty.
+ The required virtual path data cannot be found.
+
+
+ Represents support for rendering object values as HTML.
+
+
+ Returns HTML markup for each property in the object that is represented by a string expression.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+
+
+ Returns HTML markup for each property in the object that is represented by a string expression, using additional view data.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns HTML markup for each property in the object that is represented by the expression, using the specified template.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template that is used to render the object.
+
+
+ Returns HTML markup for each property in the object that is represented by the expression, using the specified template and additional view data.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template that is used to render the object.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns HTML markup for each property in the object that is represented by the expression, using the specified template and an HTML field ID.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template that is used to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+
+
+ Returns HTML markup for each property in the object that is represented by the expression, using the specified template, HTML field ID, and additional view data.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template that is used to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns HTML markup for each property in the object that is represented by the expression.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The type of the model.
+ The type of the value.
+
+
+ Returns a string that contains each property value in the object that is represented by the specified expression, using additional view data.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+ The type of the model.
+ The type of the value.
+
+
+ Returns a string that contains each property value in the object that is represented by the , using the specified template.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template that is used to render the object.
+ The type of the model.
+ The type of the value.
+
+
+ Returns a string that contains each property value in the object that is represented by the specified expression, using the specified template and additional view data.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template that is used to render the object.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+ The type of the model.
+ The type of the value.
+
+
+ Returns HTML markup for each property in the object that is represented by the , using the specified template and an HTML field ID.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template that is used to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+ The type of the model.
+ The type of the value.
+
+
+ Returns HTML markup for each property in the object that is represented by the specified expression, using the template, an HTML field ID, and additional view data.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template that is used to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+ The type of the model.
+ The type of the value.
+
+
+ Returns HTML markup for each property in the model.
+ The HTML markup for each property in the model.
+ The HTML helper instance that this method extends.
+
+
+ Returns HTML markup for each property in the model, using additional view data.
+ The HTML markup for each property in the model.
+ The HTML helper instance that this method extends.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns HTML markup for each property in the model using the specified template.
+ The HTML markup for each property in the model.
+ The HTML helper instance that this method extends.
+ The name of the template that is used to render the object.
+
+
+ Returns HTML markup for each property in the model, using the specified template and additional view data.
+ The HTML markup for each property in the model.
+ The HTML helper instance that this method extends.
+ The name of the template that is used to render the object.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns HTML markup for each property in the model using the specified template and HTML field ID.
+ The HTML markup for each property in the model.
+ The HTML helper instance that this method extends.
+ The name of the template that is used to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+
+
+ Returns HTML markup for each property in the model, using the specified template, an HTML field ID, and additional view data.
+ The HTML markup for each property in the model.
+ The HTML helper instance that this method extends.
+ The name of the template that is used to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Provides a mechanism to get display names.
+
+
+ Gets the display name.
+ The display name.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the display name.
+
+
+ Gets the display name for the model.
+ The display name for the model.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the display name.
+ The type of the model.
+ The type of the value.
+
+
+ Gets the display name for the model.
+ The display name for the model.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the display name.
+ The type of the model.
+ The type of the value.
+
+
+ Gets the display name for the model.
+ The display name for the model.
+ The HTML helper instance that this method extends.
+
+
+ Provides a way to render object values as HTML.
+
+
+ Returns HTML markup for each property in the object that is represented by the specified expression.
+ The HTML markup for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+
+
+ Returns HTML markup for each property in the object that is represented by the specified expression.
+ The HTML markup for each property.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The type of the model.
+ The type of the result.
+
+
+ Represents support for the HTML input element in an application.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using additional view data.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using the specified template.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template to use to render the object.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using the specified template and additional view data.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template to use to render the object.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using the specified template and HTML field name.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template to use to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using the specified template, HTML field name, and additional view data.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template to use to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using additional view data.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using the specified template.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template to use to render the object.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using the specified template and additional view data.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template to use to render the object.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using the specified template and HTML field name.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template to use to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML input element for each property in the object that is represented by the expression, using the specified template, HTML field name, and additional view data.
+ An HTML input element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ The name of the template to use to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML input element for each property in the model.
+ An HTML input element for each property in the model.
+ The HTML helper instance that this method extends.
+
+
+ Returns an HTML input element for each property in the model, using additional view data.
+ An HTML input element for each property in the model.
+ The HTML helper instance that this method extends.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns an HTML input element for each property in the model, using the specified template.
+ An HTML input element for each property in the model and in the specified template.
+ The HTML helper instance that this method extends.
+ The name of the template to use to render the object.
+
+
+ Returns an HTML input element for each property in the model, using the specified template and additional view data.
+ An HTML input element for each property in the model.
+ The HTML helper instance that this method extends.
+ The name of the template to use to render the object.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Returns an HTML input element for each property in the model, using the specified template name and HTML field name.
+ An HTML input element for each property in the model and in the named template.
+ The HTML helper instance that this method extends.
+ The name of the template to use to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+
+
+ Returns an HTML input element for each property in the model, using the template name, HTML field name, and additional view data.
+ An HTML input element for each property in the model.
+ The HTML helper instance that this method extends.
+ The name of the template to use to render the object.
+ A string that is used to disambiguate the names of HTML input elements that are rendered for properties that have the same name.
+ An anonymous object that can contain additional view data that will be merged into the instance that is created for the template.
+
+
+ Provides methods for working with enumeration values and select lists.
+
+
+ Gets a list of objects corresponding to enum constants defined in the given type.
+ A list for the given .
+ The type to evaluate.
+
+
+ Gets a list of objects corresponding to enum constants defined in the given type. Also ensures the will round-trip even if it does not match a defined constant and sets the Selected property to true for one element in the returned list -- matching the .
+ A list for the given , possibly extended to include an unrecognized .
+ The type to evaluate.
+ The value from type to select.
+
+
+ Gets a list of objects corresponding to enum constants defined in the given metadata.
+ A list for the given metadata.
+ The model metadata to evaluate.
+
+
+ Gets a list of objects corresponding to enum constants defined in the given metadata. Also ensures the value will round-trip even if it does not match a defined constant and sets the Selected property to true for one element in the returned list -- matching the value.
+ A list for the given , possibly extended to include an unrecognized .
+ The metadata to evaluate.
+ Value from the type of metadata to select.
+
+
+ Gets a value indicating whether the given type or an expression of this type is suitable for use in and calls.
+ true if will not throw when passed the given type and will not throw when passed an expression of this type; otherwise, false.
+ The type to check.
+
+
+ Gets a value indicating whether the given metadata or associated expression is suitable for use in and calls.
+ true if will return not throw when passed given and will not throw when passed associated expression; otherwise, false.
+ The metadata to check.
+
+
+ Represents support for HTML in an application.
+
+
+ Writes an opening <form> tag to the response. The form uses the POST method, and the request is processed by the action method for the view.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+
+
+ Writes an opening <form> tag to the response and includes the route values in the action attribute. The form uses the POST method, and the request is processed by the action method for the view.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+
+
+ Writes an opening <form> tag to the response and sets the action tag to the specified controller and action. The form uses the POST method.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+
+
+ Writes an opening <form> tag to the response, and sets the action tag to the specified controller, action, and route values. The form uses the POST method.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+
+
+ Writes an opening <form> tag to the response and sets the action tag to the specified controller, action, and route values. The form uses the specified HTTP method.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ The HTTP method for processing the form, either GET or POST.
+
+
+ Writes an opening <form> tag to the response and sets the action tag to the specified controller, action, and route values. The form uses the specified HTTP method and includes the HTML attributes.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ The HTTP method for processing the form, either GET or POST.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response and sets the action tag to the specified controller and action. The form uses the specified HTTP method.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ The HTTP method for processing the form, either GET or POST.
+
+
+ Writes an opening <form> tag to the response and sets the action tag to the specified controller and action. The form uses the specified HTTP method and includes the HTML attributes from a dictionary.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ The HTTP method for processing the form, either GET or POST.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response and sets the action tag to the specified controller and action. The form uses the specified HTTP method and includes the HTML attributes.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ The HTTP method for processing the form, either GET or POST.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response, and sets the action tag to the specified controller, action, and route values from the route value dictionary. The form uses the POST method.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+
+
+ Writes an opening <form> tag to the response, and sets the action tag to the specified controller, action, and route values from the route value dictionary. The form uses the specified HTTP method.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ The HTTP method for processing the form, either GET or POST.
+
+
+ Writes an opening <form> tag to the response, and sets the action tag to the specified controller, action, and route values from the route value dictionary. The form uses the specified HTTP method, and includes the HTML attributes from the dictionary.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the action method.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ The HTTP method for processing the form, either GET or POST.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response and includes the route values from the route value dictionary in the action attribute. The form uses the POST method, and the request is processed by the action method for the view.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ An object that contains the parameters for a route.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ The HTTP method for processing the form, either GET or POST.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. This object is typically created by using object initializer syntax.
+ The HTTP method for processing the form, either GET or POST.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ The HTTP method for processing the form, either GET or POST.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ The HTTP method for processing the form, either GET or POST.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ The HTTP method for processing the form, either GET or POST.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ An object that contains the parameters for a route
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ An object that contains the parameters for a route
+ The HTTP method for processing the form, either GET or POST.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ The name of the route to use to obtain the form-post URL.
+ An object that contains the parameters for a route
+ The HTTP method for processing the form, either GET or POST.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Writes an opening <form> tag to the response. When the user submits the form, the request will be processed by the route target.
+ An opening <form> tag.
+ The HTML helper instance that this method extends.
+ An object that contains the parameters for a route
+
+
+ Renders the closing </form> tag to the response.
+ The HTML helper instance that this method extends.
+
+
+ Represents support for HTML input controls in an application.
+
+
+ Returns a check box input element by using the specified HTML helper and the name of the form field.
+ An input element whose type attribute is set to "checkbox".
+ The HTML helper instance that this method extends.
+ The name of the form field.
+
+
+ Returns a check box input element by using the specified HTML helper, the name of the form field, and a value to indicate whether the check box is selected.
+ An input element whose type attribute is set to "checkbox".
+ The HTML helper instance that this method extends.
+ The name of the form field.
+ true to select the check box; otherwise, false. The value of the check box is retrieved in this order - the object, the value of this parameter, the object, and lastly, a checked attribute in the html attributes.
+
+
+ Returns a check box input element by using the specified HTML helper, the name of the form field, a value to indicate whether the check box is selected, and the HTML attributes.
+ An input element whose type attribute is set to "checkbox".
+ The HTML helper instance that this method extends.
+ The name of the form field.
+ true to select the check box; otherwise, false. The value of the check box is retrieved in this order - the object, the value of this parameter, the object, and lastly, a checked attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a check box input element by using the specified HTML helper, the name of the form field, a value that indicates whether the check box is selected, and the HTML attributes.
+ An input element whose type attribute is set to "checkbox".
+ The HTML helper instance that this method extends.
+ The name of the form field.
+ true to select the check box; otherwise, false. The value of the check box is retrieved in this order - the object, the value of this parameter, the object, and lastly, a checked attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a check box input element by using the specified HTML helper, the name of the form field, and the HTML attributes.
+ An input element whose type attribute is set to "checkbox".
+ The HTML helper instance that this method extends.
+ The name of the form field.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a check box input element by using the specified HTML helper, the name of the form field, and the HTML attributes.
+ An input element whose type attribute is set to "checkbox".
+ The HTML helper instance that this method extends.
+ The name of the form field.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a check box input element for each property in the object that is represented by the specified expression.
+ An HTML input element whose type attribute is set to "checkbox" for each property in the object that is represented by the specified expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The type of the model.
+ The parameter is null.
+
+
+ Returns a check box input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An HTML input element whose type attribute is set to "checkbox" for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ A dictionary that contains the HTML attributes to set for the element.
+ The type of the model.
+ The parameter is null.
+
+
+ Returns a check box input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An HTML input element whose type attribute is set to "checkbox" for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The parameter is null.
+
+
+ Returns a hidden input element by using the specified HTML helper and the name of the form field.
+ An input element whose type attribute is set to "hidden".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+
+
+ Returns a hidden input element by using the specified HTML helper, the name of the form field, and the value.
+ An input element whose type attribute is set to "hidden".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the hidden input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+
+
+ Returns a hidden input element by using the specified HTML helper, the name of the form field, the value, and the HTML attributes.
+ An input element whose type attribute is set to "hidden".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the hidden input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a hidden input element by using the specified HTML helper, the name of the form field, the value, and the HTML attributes.
+ An input element whose type attribute is set to "hidden".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the hidden input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML hidden input element for each property in the object that is represented by the specified expression.
+ An input element whose type attribute is set to "hidden" for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The type of the model.
+ The type of the property.
+
+
+ Returns an HTML hidden input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An input element whose type attribute is set to "hidden" for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the property.
+
+
+ Returns an HTML hidden input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An input element whose type attribute is set to "hidden" for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the property.
+
+
+ Returns a password input element by using the specified HTML helper and the name of the form field.
+ An input element whose type attribute is set to "password".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+
+
+ Returns a password input element by using the specified HTML helper, the name of the form field, and the value.
+ An input element whose type attribute is set to "password".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the password input element. If a value for this parameter is not provided, the value attribute in the html attributes is used to retrieve the value.
+
+
+ Returns a password input element by using the specified HTML helper, the name of the form field, the value, and the HTML attributes.
+ An input element whose type attribute is set to "password".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the password input element. If a value for this parameter is not provided, the value attribute in the html attributes is used to retrieve the value.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a password input element by using the specified HTML helper, the name of the form field, the value, and the HTML attributes.
+ An input element whose type attribute is set to "password".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the password input element. If a value for this parameter is not provided, the value attribute in the html attributes is used to retrieve the value.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a password input element for each property in the object that is represented by the specified expression.
+ An HTML input element whose type attribute is set to "password" for each property in the object that is represented by the specified expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns a password input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An HTML input element whose type attribute is set to "password" for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ A dictionary that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns a password input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An HTML input element whose type attribute is set to "password" for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns a radio button input element that is used to present mutually exclusive options.
+ An input element whose type attribute is set to "radio".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ The parameter is null or empty.
+ The parameter is null.
+
+
+ Returns a radio button input element that is used to present mutually exclusive options.
+ An input element whose type attribute is set to "radio".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ true to select the radio button; otherwise, false.
+ The parameter is null or empty.
+ The parameter is null.
+
+
+ Returns a radio button input element that is used to present mutually exclusive options.
+ An input element whose type attribute is set to "radio".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ true to select the radio button; otherwise, false.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+ The parameter is null.
+
+
+ Returns a radio button input element that is used to present mutually exclusive options.
+ An input element whose type attribute is set to "radio".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ true to select the radio button; otherwise, false.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+ The parameter is null.
+
+
+ Returns a radio button input element that is used to present mutually exclusive options.
+ An input element whose type attribute is set to "radio".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+ The parameter is null.
+
+
+ Returns a radio button input element that is used to present mutually exclusive options.
+ An input element whose type attribute is set to "radio".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+ The parameter is null.
+
+
+ Returns a radio button input element for each property in the object that is represented by the specified expression.
+ An HTML input element whose type attribute is set to "radio" for each property in the object that is represented by the specified expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns a radio button input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An HTML input element whose type attribute is set to "radio" for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ A dictionary that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns a radio button input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An HTML input element whose type attribute is set to "radio" for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The value of the selected radio button. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns a text input element by using the specified HTML helper and the name of the form field.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+
+
+ Returns a text input element by using the specified HTML helper, the name of the form field, and the value.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the text input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+
+
+ Returns a text input element by using the specified HTML helper, the name of the form field, the value, and the HTML attributes.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the text input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a text input element by using the specified HTML helper, the name of the form field, the value, and the HTML attributes.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the text input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a text input element.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ The name of the form field.
+ The value of the text input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ A string that is used to format the input.
+
+
+ Returns a text input element.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the text input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ A string that is used to format the input.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a text input element.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ The name of the form field and the key that is used to look up the value.
+ The value of the text input element. The value is retrieved in this order - the object, the value of this parameter, the object, and lastly, a value attribute in the html attributes.
+ A string that is used to format the input.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns a text input element for each property in the object that is represented by the specified expression.
+ An HTML input element whose type attribute is set to "text" for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The type of the model.
+ The type of the value.
+ The parameter is null or empty.
+
+
+ Returns a text input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An HTML input element type attribute is set to "text" for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ A dictionary that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null or empty.
+
+
+ Returns a text input element for each property in the object that is represented by the specified expression, using the specified HTML attributes.
+ An HTML input element whose type attribute is set to "text" for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null or empty.
+
+
+ Returns a text input element.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A string that is used to format the input.
+ The type of the model.
+ The type of the value.
+
+
+ Returns a text input element.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A string that is used to format the input.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+
+
+ Returns a text input element.
+ An input element whose type attribute is set to "text".
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A string that is used to format the input.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+
+
+ Represents support for the HTML label element in an ASP.NET MVC view.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression using the label text.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ The label text to display.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ The label text.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ The label text.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The value.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression using the label text.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ The label text to display.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ The label text to display.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the property to display.
+ The label text.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The Value.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the model.
+ An HTML label element and the property name of the property that is represented by the model.
+ The HTML helper instance that this method extends.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression using the label text.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ The label text to display.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ The label Text.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML label element and the property name of the property that is represented by the specified expression.
+ An HTML label element and the property name of the property that is represented by the expression.
+ The HTML helper instance that this method extends.
+ The label text.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Represents support for HTML links in an application.
+
+
+ Returns an anchor element (a element) for the specified link text and action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, and route values.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, route values, and HTML attributes.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ An object that contains the HTML attributes for the element. The attributes are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, and controller.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ The name of the controller.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, controller, route values, and HTML attributes.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ The name of the controller.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, controller, protocol, host name, URL fragment, route values, and HTML attributes.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ The name of the controller.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+ The URL fragment name (the anchor name).
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, controller, protocol, host name, URL fragment, route values as a route value dictionary, and HTML attributes as a dictionary.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ The name of the controller.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+ The URL fragment name (the anchor name).
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, controller, route values as a route value dictionary, and HTML attributes as a dictionary.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ The name of the controller.
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, and route values as a route value dictionary.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ An object that contains the parameters for a route.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) for the specified link text, action, route values as a route value dictionary, and HTML attributes as a dictionary.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the action.
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the route that is used to return a virtual path.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the route that is used to return a virtual path.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the route that is used to return a virtual path.
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the route that is used to return a virtual path.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+ The URL fragment name (the anchor name).
+ An object that contains the parameters for a route. The parameters are retrieved through reflection by examining the properties of the object. The object is typically created by using object initializer syntax.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the route that is used to return a virtual path.
+ The protocol for the URL, such as "http" or "https".
+ The host name for the URL.
+ The URL fragment name (the anchor name).
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the route that is used to return a virtual path.
+ An object that contains the parameters for a route.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ The name of the route that is used to return a virtual path.
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ An object that contains the parameters for a route.
+ The parameter is null or empty.
+
+
+ Returns an anchor element (a element) that contains the virtual path of the specified action.
+ An anchor element (a element).
+ The HTML helper instance that this method extends.
+ The inner text of the anchor element.
+ An object that contains the parameters for a route.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Represents an HTML form element in an MVC view.
+
+
+ Initializes a new instance of the class using the specified HTTP response object.
+ The HTTP response object.
+ The parameter is null.
+
+
+ Initializes a new instance of the class using the specified view context.
+ An object that encapsulates the information that is required in order to render a view.
+ The parameter is null.
+
+
+ Releases all resources that are used by the current instance of the class.
+
+
+ Releases unmanaged and, optionally, managed resources used by the current instance of the class.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ Ends the form and disposes of all form resources.
+
+
+ Gets the HTML ID and name attributes of the string.
+
+
+ Gets the ID of the string.
+ The HTML ID attribute value for the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the ID.
+
+
+ Gets the ID of the string
+ The HTML ID attribute value for the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the ID.
+ The type of the model.
+ The type of the property.
+
+
+ Gets the ID of the string.
+ The HTML ID attribute value for the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+
+
+ Gets the full HTML field name for the object that is represented by the expression.
+ The full HTML field name for the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the name.
+
+
+ Gets the full HTML field name for the object that is represented by the expression.
+ The full HTML field name for the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the name.
+ The type of the model.
+ The type of the property.
+
+
+ Gets the full HTML field name for the object that is represented by the expression.
+ The full HTML field name for the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+
+
+ Represents the functionality to render a partial view as an HTML-encoded string.
+
+
+ Renders the specified partial view as an HTML-encoded string.
+ The partial view that is rendered as an HTML-encoded string.
+ The HTML helper instance that this method extends.
+ The name of the partial view to render.
+
+
+ Renders the specified partial view as an HTML-encoded string.
+ The partial view that is rendered as an HTML-encoded string.
+ The HTML helper instance that this method extends.
+ The name of the partial view to render.
+ The model for the partial view.
+
+
+ Renders the specified partial view as an HTML-encoded string.
+ The partial view that is rendered as an HTML-encoded string.
+ The HTML helper instance that this method extends.
+ The name of the partial view.
+ The model for the partial view.
+ The view data dictionary for the partial view.
+
+
+ Renders the specified partial view as an HTML-encoded string.
+ The partial view that is rendered as an HTML-encoded string.
+ The HTML helper instance that this method extends.
+ The name of the partial view to render.
+ The view data dictionary for the partial view.
+
+
+ Provides support for rendering a partial view.
+
+
+ Renders the specified partial view by using the specified HTML helper.
+ The HTML helper.
+ The name of the partial view
+
+
+ Renders the specified partial view, passing it a copy of the current object, but with the Model property set to the specified model.
+ The HTML helper.
+ The name of the partial view.
+ The model.
+
+
+ Renders the specified partial view, replacing the partial view's ViewData property with the specified object and setting the Model property of the view data to the specified model.
+ The HTML helper.
+ The name of the partial view.
+ The model for the partial view.
+ The view data for the partial view.
+
+
+ Renders the specified partial view, replacing its ViewData property with the specified object.
+ The HTML helper.
+ The name of the partial view.
+ The view data.
+
+
+ Represents support for making selections in a list.
+
+
+ Returns a single-selection select element using the specified HTML helper and the name of the form field.
+ An HTML select element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ The parameter is null or empty.
+
+
+ Returns a single-selection select element using the specified HTML helper, the name of the form field, and the specified list items.
+ An HTML select element with an option subelement for each item in the list.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ The parameter is null or empty.
+
+
+ Returns a single-selection select element using the specified HTML helper, the name of the form field, the specified list items, and the specified HTML attributes.
+ An HTML select element with an option subelement for each item in the list.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns a single-selection select element using the specified HTML helper, the name of the form field, the specified list items, and the specified HTML attributes.
+ An HTML select element with an option subelement for each item in the list.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns a single-selection select element using the specified HTML helper, the name of the form field, the specified list items, and an option label.
+ An HTML select element with an option subelement for each item in the list.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ The text for a default empty item. This parameter can be null.
+ The parameter is null or empty.
+
+
+ Returns a single-selection select element using the specified HTML helper, the name of the form field, the specified list items, an option label, and the specified HTML attributes.
+ An HTML select element with an option subelement for each item in the list.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ The text for a default empty item. This parameter can be null.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns a single-selection select element using the specified HTML helper, the name of the form field, the specified list items, an option label, and the specified HTML attributes.
+ An HTML select element with an option subelement for each item in the list.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ The text for a default empty item. This parameter can be null.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns a single-selection select element using the specified HTML helper, the name of the form field, and an option label.
+ An HTML select element with an option subelement for each item in the list.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ The text for a default empty item. This parameter can be null.
+ The parameter is null or empty.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression using the specified list items.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression using the specified list items and HTML attributes.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression using the specified list items and HTML attributes.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression using the specified list items and option label.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ The text for a default empty item. This parameter can be null.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression using the specified list items, option label, and HTML attributes.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ The text for a default empty item. This parameter can be null.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression using the specified list items, option label, and HTML attributes.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ The text for a default empty item. This parameter can be null.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+ The parameter is null.
+
+
+ Returns an HTML select element for each value in the enumeration that is represented by the specified expression.
+ An HTML select element for each value in the enumeration that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the values to display.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML select element for each value in the enumeration that is represented by the specified expression.
+ An HTML select element for each value in the enumeration that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the values to display.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML select element for each value in the enumeration that is represented by the specified expression.
+ An HTML select element for each value in the enumeration that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the values to display.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML select element for each value in the enumeration that is represented by the specified expression.
+ An HTML select element for each value in the enumeration that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the values to display.
+ The text for a default empty item. This parameter can be null.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML select element for each value in the enumeration that is represented by the specified expression.
+ An HTML select element for each value in the enumeration that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the values to display.
+ The text for a default empty item. This parameter can be null.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+
+
+ Returns an HTML select element for each value in the enumeration that is represented by the specified expression.
+ An HTML select element for each value in the enumeration that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the values to display.
+ The text for a default empty item. This parameter can be null.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the value.
+
+
+ Returns a multi-select select element using the specified HTML helper and the name of the form field.
+ An HTML select element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ The parameter is null or empty.
+
+
+ Returns a multi-select select element using the specified HTML helper, the name of the form field, and the specified list items.
+ An HTML select element with an option subelement for each item in the list.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ The parameter is null or empty.
+
+
+ Returns a multi-select select element using the specified HTML helper, the name of the form field, the specified list items, and the specified HMTL attributes.
+ An HTML select element with an option subelement for each item in the list..
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns a multi-select select element using the specified HTML helper, the name of the form field, and the specified list items.
+ An HTML select element with an option subelement for each item in the list..
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ A collection of objects that are used to populate the drop-down list.
+ An object that contains the HTML attributes to set for the element.
+ The parameter is null or empty.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression and using the specified list items.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ The type of the model.
+ The type of the property.
+ The parameter is null.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression using the specified list items and HTML attributes.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the property.
+ The parameter is null.
+
+
+ Returns an HTML select element for each property in the object that is represented by the specified expression using the specified list items and HTML attributes.
+ An HTML select element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to display.
+ A collection of objects that are used to populate the drop-down list.
+ An object that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the property.
+ The parameter is null.
+
+
+ Represents support for HTML textarea controls.
+
+
+ Returns the specified textarea element by using the specified HTML helper and the name of the form field.
+ The textarea element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+
+
+ Returns the specified textarea element by using the specified HTML helper, the name of the form field, and the specified HTML attributes.
+ The textarea element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns the specified textarea element by using the specified HTML helper and HTML attributes.
+ The textarea element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns the specified textarea element by using the specified HTML helper, the name of the form field, and the text content.
+ The textarea element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ The text content.
+
+
+ Returns the specified textarea element by using the specified HTML helper, the name of the form field, the text content, and the specified HTML attributes.
+ The textarea element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ The text content.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns the specified textarea element by using the specified HTML helper, the name of the form field, the text content, the number of rows and columns, and the specified HTML attributes.
+ The textarea element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ The text content.
+ The number of rows.
+ The number of columns.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns the specified textarea element by using the specified HTML helper, the name of the form field, the text content, the number of rows and columns, and the specified HTML attributes.
+ The textarea element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ The text content.
+ The number of rows.
+ The number of columns.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns the specified textarea element by using the specified HTML helper, the name of the form field, the text content, and the specified HTML attributes.
+ The textarea element.
+ The HTML helper instance that this method extends.
+ The name of the form field to return.
+ The text content.
+ An object that contains the HTML attributes to set for the element.
+
+
+ Returns an HTML textarea element for each property in the object that is represented by the specified expression.
+ An HTML textarea element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The type of the model.
+ The type of the property.
+ The parameter is null.
+
+
+ Returns an HTML textarea element for each property in the object that is represented by the specified expression using the specified HTML attributes.
+ An HTML textarea element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ A dictionary that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the property.
+ The parameter is null.
+
+
+ Returns an HTML textarea element for each property in the object that is represented by the specified expression using the specified HTML attributes and the number of rows and columns.
+ An HTML textarea element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The number of rows.
+ The number of columns.
+ A dictionary that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the property.
+ The parameter is null.
+
+
+ Returns an HTML textarea element for each property in the object that is represented by the specified expression using the specified HTML attributes and the number of rows and columns.
+ An HTML textarea element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The number of rows.
+ The number of columns.
+ A dictionary that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the property.
+ The parameter is null.
+
+
+ Returns an HTML textarea element for each property in the object that is represented by the specified expression using the specified HTML attributes.
+ An HTML textarea element for each property in the object that is represented by the expression.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ A dictionary that contains the HTML attributes to set for the element.
+ The type of the model.
+ The type of the property.
+ The parameter is null.
+
+
+ Provides support for validating the input from an HTML form.
+
+
+ Gets or sets the name of the resource file (class key) that contains localized string values.
+ The name of the resource file (class key).
+
+
+ Retrieves the validation metadata for the specified model and applies each rule to the data field.
+ The HTML helper instance that this method extends.
+ The name of the property or model object that is being validated.
+ The parameter is null.
+
+
+ Retrieves the validation metadata for the specified model and applies each rule to the data field.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The type of the model.
+ The type of the property.
+
+
+ Displays a validation message if an error exists for the specified field in the object.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ The name of the property or model object that is being validated.
+
+
+ Displays a validation message if an error exists for the specified field in the object.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ The name of the property or model object that is being validated.
+ An object that contains the HTML attributes for the element.
+
+
+ Displays a validation message if an error exists for the specified entry in the object.
+ null if the entry is valid and client-side validation is disabled. Otherwise, a element that contains an error message.
+ The HTML helper instance that this method operates on.
+ The name of the entry being validated.
+ An that contains the HTML attributes for the element.
+ The tag to be set for the wrapping HTML element of the validation message.
+
+
+ Displays a validation message if an error exists for the specified field in the object.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ The name of the property or model object that is being validated.
+ An object that contains the HTML attributes for the element.
+
+
+ Displays a validation message if an error exists for the specified entry in the object.
+ null if the entry is valid and client-side validation is disabled. Otherwise, a element that contains an error message.
+ The HTML helper instance that this method operates on.
+ The name of the entry being validated.
+ An object that contains the HTML attributes for the element.
+ The tag to be set for the wrapping HTML element of the validation message.
+
+
+ Displays a validation message if an error exists for the specified field in the object.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ The name of the property or model object that is being validated.
+ The message to display if the specified field contains an error.
+
+
+ Displays a validation message if an error exists for the specified field in the object.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ The name of the property or model object that is being validated.
+ The message to display if the specified field contains an error.
+ An object that contains the HTML attributes for the element.
+
+
+ Displays a validation message if an error exists for the specified entry in the object.
+ null if the model object is valid and client-side validation is disabled. Otherwise, a element that contains an error message.
+ The HTML helper instance that this method operates on.
+ The name of the model object being validated.
+ The message to display if the specified entry contains an error.
+ An that contains the HTML attributes for the element.
+ The tag to be set for the wrapping HTML element of the validation message.
+
+
+ Displays a validation message if an error exists for the specified field in the object.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ The name of the property or model object that is being validated.
+ The message to display if the specified field contains an error.
+ An object that contains the HTML attributes for the element.
+
+
+ Displays a validation message if an error exists for the specified entry in the object.
+ null if the entry is valid and client-side validation is disabled. Otherwise, a element that contains an error message.
+ The HTML helper instance that this method operates on.
+ The name of the entry being validated.
+ The message to display if the specified entry contains an error.
+ An object that contains the HTML attributes for the element.
+ The tag to be set for the wrapping HTML element of the validation message.
+
+
+ Displays a validation message if an error exists for the specified entry in the object.
+ null if the entry is valid and client-side validation is disabled. Otherwise, a element that contains an error message.
+ The HTML helper instance that this method operates on.
+ The name of the entry being validated.
+ The message to display if the specified entry contains an error.
+ The tag to be set for the wrapping HTML element of the validation message.
+
+
+ Returns the HTML markup for a validation-error message for each data field that is represented by the specified expression.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The type of the model.
+ The type of the property.
+
+
+ Returns the HTML markup for a validation-error message for each data field that is represented by the specified expression, using the specified message.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The message to display if the specified field contains an error.
+ The type of the model.
+ The type of the property.
+
+
+ Returns the HTML markup for a validation-error message for each data field that is represented by the specified expression, using the specified message and HTML attributes.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The message to display if the specified field contains an error.
+ An object that contains the HTML attributes for the element.
+ The type of the model.
+ The type of the property.
+
+
+ Returns the HTML markup for a validation-error message for the specified expression.
+ null if the model object is valid and client-side validation is disabled. Otherwise, a element that contains an error message.
+ The HTML helper instance that this method operates on.
+ An expression that identifies the object that contains the properties to render.
+ The message to display if a validation error occurs.
+ An that contains the HTML attributes for the element.
+ The tag to be set for the wrapping HTML element of the validation message.
+ The type of the model.
+ The type of the property.
+
+
+ Returns the HTML markup for a validation-error message for each data field that is represented by the specified expression, using the specified message and HTML attributes.
+ If the property or object is valid, an empty string; otherwise, a span element that contains an error message.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to render.
+ The message to display if the specified field contains an error.
+ An object that contains the HTML attributes for the element.
+ The type of the model.
+ The type of the property.
+
+
+ Returns the HTML markup for a validation-error message for the specified expression.
+ null if the model object is valid and client-side validation is disabled. Otherwise, a element that contains an error message.
+ The HTML helper instance that this method operates on.
+ An expression that identifies the object that contains the properties to render.
+ The message to display if a validation error occurs.
+ An object that contains the HTML attributes for the element.
+ The tag to be set for the wrapping HTML element of the validation message.
+ The type of the model.
+ The type of the property.
+
+
+ Returns the HTML markup for a validation-error message for the specified expression.
+ null if the model object is valid and client-side validation is disabled. Otherwise, a element that contains an error message.
+ The HTML helper instance that this method operates on.
+ An expression that identifies the object that contains the properties to render.
+ The message to display if a validation error occurs.
+ The tag to be set for the wrapping HTML element of the validation message.
+ The type of the model.
+ The type of the property.
+
+
+ Returns an unordered list (ul element) of validation messages that are in the object.
+ A string that contains an unordered list (ul element) of validation messages.
+ The HTML helper instance that this method extends.
+
+
+ Returns an unordered list (ul element) of validation messages that are in the object and optionally displays only model-level errors.
+ A string that contains an unordered list (ul element) of validation messages.
+ The HTML helper instance that this method extends.
+ true to have the summary display model-level errors only, or false to have the summary display all errors.
+
+
+ Returns an unordered list (ul element) of validation messages that are in the object and optionally displays only model-level errors.
+ A string that contains an unordered list (ul element) of validation messages.
+ The HTML helper instance that this method extends.
+ true to have the summary display model-level errors only, or false to have the summary display all errors.
+ The message to display with the validation summary.
+
+
+ Returns an unordered list (ul element) of validation messages that are in the object and optionally displays only model-level errors.
+ A string that contains an unordered list (ul element) of validation messages.
+ The HTML helper instance that this method extends.
+ true to have the summary display model-level errors only, or false to have the summary display all errors.
+ The message to display with the validation summary.
+ A dictionary that contains the HTML attributes for the element.
+
+
+
+ Returns an unordered list (ul element) of validation messages that are in the object and optionally displays only model-level errors.
+ A string that contains an unordered list (ul element) of validation messages.
+ The HTML helper instance that this method extends.
+ true to have the summary display model-level errors only, or false to have the summary display all errors.
+ The message to display with the validation summary.
+ An object that contains the HTML attributes for the element.
+
+
+
+
+ Returns an unordered list (ul element) of validation messages that are in the object.
+ A string that contains an unordered list (ul element) of validation messages.
+ The HMTL helper instance that this method extends.
+ The message to display if the specified field contains an error.
+
+
+ Returns an unordered list (ul element) of validation messages that are in the object.
+ A string that contains an unordered list (ul element) of validation messages.
+ The HTML helper instance that this method extends.
+ The message to display if the specified field contains an error.
+ A dictionary that contains the HTML attributes for the element.
+
+
+
+ Returns an unordered list (ul element) of validation messages in the object.
+ A string that contains an unordered list (ul element) of validation messages.
+ The HTML helper instance that this method extends.
+ The message to display if the specified field contains an error.
+ An object that contains the HTML attributes for the element.
+
+
+
+
+ Provides a mechanism to create custom HTML markup compatible with the ASP.NET MVC model binders and templates.
+
+
+ Provides a mechanism to create custom HTML markup compatible with the ASP.NET MVC model binders and templates.
+ The HTML markup for the value.
+ The HTML helper instance that this method extends.
+ The name of the model.
+
+
+ Provides a mechanism to create custom HTML markup compatible with the ASP.NET MVC model binders and templates.
+ The HTML markup for the value.
+ The HTML helper instance that this method extends.
+ The name of the model.
+ The format string.
+
+
+ Provides a mechanism to create custom HTML markup compatible with the ASP.NET MVC model binders and templates.
+ The HTML markup for the value.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to expose.
+ The model.
+ The property.
+
+
+ Provides a mechanism to create custom HTML markup compatible with the ASP.NET MVC model binders and templates.
+ The HTML markup for the value.
+ The HTML helper instance that this method extends.
+ An expression that identifies the object that contains the properties to expose.
+ The format string.
+ The model.
+ The property.
+
+
+ Provides a mechanism to create custom HTML markup compatible with the ASP.NET MVC model binders and templates.
+ The HTML markup for the value.
+ The HTML helper instance that this method extends.
+
+
+ Provides a mechanism to create custom HTML markup compatible with the ASP.NET MVC model binders and templates.
+ The HTML markup for the value.
+ The HTML helper instance that this method extends.
+ The format string.
+
+
+ Compiles ASP.NET Razor views into classes.
+
+
+ Initializes a new instance of the class.
+
+
+ The inherits directive.
+
+
+ The model directive.
+
+
+ Extends the VBCodeParser class by adding support for the @model keyword.
+
+
+ Initializes a new instance of the class.
+
+
+ Sets a value that indicates whether the current code block and model should be inherited.
+ true if the code block and model is inherited; otherwise, false.
+
+
+ The Model Type Directive.
+ Returns void.
+
+
+ Configures the ASP.NET Razor parser and code generator for a specified file.
+
+
+ Initializes a new instance of the class.
+ The virtual path of the ASP.NET Razor file.
+ The physical path of the ASP.NET Razor file.
+
+
+ Returns the ASP.NET MVC language-specific Razor code generator.
+ The ASP.NET MVC language-specific Razor code generator.
+ The C# or Visual Basic code generator.
+
+
+ Returns the ASP.NET MVC language-specific Razor code parser using the specified language parser.
+ The ASP.NET MVC language-specific Razor code parser.
+ The C# or Visual Basic code parser.
+
+
+
+
+ Creates instances based on the provided factories and action. The route entries provide direct routing to the provided action.
+ A set of route entries.
+ The action descriptor.
+ The direct route factories.
+ The constraint resolver.
+
+
+ Gets a set of route factories for the given action descriptor.
+ A set of route factories.
+ The action descriptor.
+
+
+ Gets the area prefix from the provided controller.
+ The area prefix or null.
+ The controller descriptor.
+
+
+ Creates instances based on the provided factories, controller and actions. The route entries provided direct routing to the provided controller and can reach the set of provided actions.
+ A set of route entries.
+ The controller descriptor.
+ The action descriptors.
+ The direct route factories.
+ The constraint resolver.
+
+
+ Gets route factories for the given controller descriptor.
+ A set of route factories.
+ The controller descriptor.
+
+
+ Gets direct routes for the given controller descriptor and action descriptors based on attributes.
+ A set of route entries.
+ The controller descriptor.
+ The action descriptors for all actions.
+ The constraint resolver.
+
+
+ Gets the route prefix from the provided controller.
+ The route prefix or null.
+ The controller descriptor.
+
+
+ The default implementation of . Resolves constraints by parsing a constraint key and constraint arguments, using a map to resolve the constraint type, and calling an appropriate constructor for the constraint type.
+
+
+
+ Gets the mutable dictionary that maps constraint keys to a particular constraint type.
+
+
+
+ Represents a context that supports creating a direct route.
+
+
+ Initializes a new instance of the class.
+ The route prefix, if any, defined by the area.
+ The route prefix, if any, defined by the controller.
+ The action descriptors to which to create a route.
+ The inline constraint resolver.
+ A value indicating whether the route is configured at the action or controller level.
+
+
+ Gets the action descriptors to which to create a route.
+ The action descriptors to which to create a route.
+
+
+ Gets the route prefix, if any, defined by the area.
+ The route prefix, if any, defined by the area.
+
+
+ Gets the route prefix, if any, defined by the controller.
+ The route prefix, if any, defined by the controller.
+
+
+ Creates a route builder that can build a route matching this context.
+ A route builder that can build a route matching this context.
+ The route template.
+
+
+ Creates a route builder that can build a route matching this context.
+ A route builder that can build a route matching this context.
+ The route template.
+ The inline constraint resolver to use, if any; otherwise, null.
+
+
+ Gets the inline constraint resolver.
+ The inline constraint resolver.
+
+
+ Gets a value indicating whether the route is configured at the action or controller level.
+ true when the route is configured at the action level; otherwise false if the route is configured at the controller level.
+
+
+ Defines a builder that creates direct routes to actions (attribute routes).
+
+
+ Gets the action descriptors to which to create a route.
+ The action descriptors to which to create a route.
+
+
+ Creates a route entry based on the current property values.
+ The route entry created.
+
+
+ Gets or sets the route constraints.
+ The route constraints.
+
+
+ Gets or sets the route data tokens.
+ The route data tokens.
+
+
+ Gets or sets the route defaults.
+ The route defaults.
+
+
+ Gets or sets the route name.
+ The route name, or null if no name supplied.
+
+
+ Gets or sets the route order.
+ The route order.
+
+
+ Gets or sets the route precedence.
+ The route precedence.
+
+
+ Gets a value indicating whether the route is configured at the action or controller level.
+ true when the route is configured at the action level; otherwise, false if the route is configured at the controller level.
+
+
+ Gets or sets the route template.
+ The route template.
+
+
+ Defines a factory that creates a route directly to a set of action descriptors (an attribute route).
+
+
+ Creates a direct route entry.
+ The direct route entry.
+ The context to use to create the route.
+
+
+ Defines a provider for routes that directly target action descriptors (attribute routes).
+
+
+ Gets the direct routes for a controller.
+ A set of route entries for the controller.
+ The controller descriptor.
+ The action descriptors.
+ The inline constraint resolver.
+
+
+ Defines an abstraction for resolving inline constraints as instances of .
+
+
+ Resolves the inline constraint.
+ The the inline constraint was resolved to.
+ The inline constraint to resolve.
+
+
+ Provides information for building a System.Web.Routing.Route.
+
+
+ Gets the route template describing the URI pattern to match against.
+ The route template describing the URI pattern to match against.
+
+
+ Gets the name of the route to generate.
+ The name of the route to generate.
+
+
+ Defines a route prefix.
+
+
+ Gets the route prefix.
+ The route prefix.
+
+
+ Builds instances based on route information.
+
+
+ Initializes a new instance of the class using the default inline constraint resolver.
+
+
+ Initializes a new instance of the class.
+ The to use for resolving inline constraints.
+
+
+ Builds an for a particular action.
+ The generated .
+ The tokenized route template for the route.
+ The HTTP methods supported by the route. A null value specify that all possible methods are supported.
+ The name of the associated controller.
+ The name of the associated action.
+ The method that the route attribute has been applied on.
+
+
+ Builds an for a particular action.
+ The generated route.
+ The tokenized route template for the route.
+ The controller the route attribute has been applied on.
+
+
+ Builds an .
+ The generated .
+ The route defaults.
+ The route constraints.
+ The detokenized route template.
+ The method that the route attribute has been applied on.
+
+
+ Gets the resolver for resolving inline constraints.
+ The resolver for resolving inline constraints.
+
+
+ Represents a named route.
+
+
+ Initializes a new instance of the class.
+ The route name.
+ The route.
+
+
+ Gets the route name.
+ The route name, if any; otherwise, null.
+
+
+ Gets the route.
+ The route.
+
+
+ Represents an attribute route that may contain custom constraints.
+
+
+ Initializes a new instance of the class.
+ The route template.
+
+
+ Gets the route constraints.
+ The route constraints, if any; otherwise null.
+
+
+ Creates a direct route entry.
+ The direct route entry.
+ The context to use to create the route.
+
+
+ Gets the route data tokens.
+ The route data tokens, if any; otherwise null.
+
+
+ Gets the route defaults.
+ The route defaults, if any; otherwise null.
+
+
+ Gets or sets the route name.
+ The route name, if any; otherwise null.
+
+
+ Gets or sets the route order.
+ The route order.
+
+
+ Gets the route template.
+ The route template.
+
+
+ Constrains a route parameter to contain only lowercase or uppercase letters A through Z in the English alphabet.
+
+
+ Initializes a new instance of the class.
+
+
+ Constrains a route parameter to represent only Boolean values.
+
+
+
+
+ Constrains a route by several child constraints.
+
+
+ Initializes a new instance of the class.
+ The child constraints that must match for this constraint to match.
+
+
+ Gets the child constraints that must match for this constraint to match.
+ The child constraints that must match for this constraint to match.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to represent only values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to represent only decimal values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to represent only 64-bit floating-point values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to represent only 32-bit floating-point values.
+
+
+
+
+ Constrains a route parameter to represent only values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to represent only 32-bit integer values.
+
+
+
+
+ Constrains a route parameter to be a string of a given length or within a given range of lengths.
+
+
+
+ Initializes a new instance of the class that constrains a route parameter to be a string of a given length.
+ The minimum length of the route parameter.
+ The maximum length of the route parameter.
+
+
+ Gets the length of the route parameter, if one is set.
+
+
+
+ Gets the maximum length of the route parameter, if one is set.
+
+
+ Gets the minimum length of the route parameter, if one is set.
+
+
+ Constrains a route parameter to represent only 64-bit integer values.
+
+
+ Initializes a new instance of the class.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Constrains a route parameter to be a string with a maximum length.
+
+
+
+
+ Gets the maximum length of the route parameter.
+
+
+ Constrains a route parameter to be an integer with a maximum value.
+
+
+ Initializes a new instance of the class.
+ The maximum value.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the maximum value of the route parameter.
+ The maximum value of the route parameter.
+
+
+ Constrains a route parameter to be a string with a maximum length.
+
+
+ Initializes a new instance of the class.
+ The minimum length.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the compare.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the minimum length of the route parameter.
+ The minimum length of the route parameter.
+
+
+ Constrains a route parameter to be a long with a minimum value.
+
+
+ Initializes a new instance of the class.
+ The minimum value.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the minimum value of the route parameter.
+ The minimum value of the route parameter.
+
+
+ Constrains a route by an inner constraint that doesn't fail when an optional parameter is set to its default value.
+
+
+ Initializes a new instance of the class.
+ The inner constraint to match if the parameter is not an optional parameter without a value
+
+
+ Gets the inner constraint to match if the parameter is not an optional parameter without a value.
+
+
+
+ Constraints a route parameter to be an integer within a given range of values.
+
+
+ Initializes a new instance of the class.
+ The minimum value.
+ The maximum value.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the maximum value of the route parameter.
+ The maximum value of the route parameter.
+
+
+ Gets the minimum value of the route parameter.
+ The minimum value of the route parameter.
+
+
+ Constrains a route parameter to match a regular expression.
+
+
+ Initializes a new instance of the class with the specified pattern.
+ The pattern to match.
+
+
+ Determines whether this instance equals a specified route.
+ true if this instance equals a specified route; otherwise, false.
+ The HTTP context.
+ The route to compare.
+ The name of the parameter.
+ A list of parameter values.
+ The route direction.
+
+
+ Gets the regular expression pattern to match.
+ The regular expression pattern to match.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Optimization.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Optimization.dll
new file mode 100644
index 000000000..393d41655
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Optimization.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Optimization.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Optimization.xml
new file mode 100644
index 000000000..1bfd64c86
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Optimization.xml
@@ -0,0 +1,666 @@
+
+
+
+ System.Web.Optimization
+
+
+
+ Represents a list of file references to be bundled together as a single resource.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class.
+ The virtual path used to reference the from within a view or Web page.
+
+
+ Initializes a new instance of the class.
+ The virtual path used to reference the from within a view or Web page.
+ An alternate url for the bundle when it is stored in a content delivery network.
+
+
+ Initializes a new instance of the class.
+ The virtual path used to reference the from within a view or Web page.
+ An alternate url for the bundle when it is stored in a content delivery network.
+ A list of objects which process the contents of the bundle in the order which they are added.
+
+
+ Initializes a new instance of the class.
+ The virtual path used to reference the from within a view or Web page.
+ A list of objects which process the contents of the bundle in the order which they are added.
+
+
+
+ Builds the bundle content from the individual files included in the object.
+ The object used to build the bundle content.
+
+
+ Overrides this to implement own caching logic.
+ A bundle response.
+ The bundle context.
+
+
+ Script expression rendered by the helper class to reference the local bundle file if the CDN is unavailable.
+ The script expression rendered by the helper class to reference the local bundle file if the CDN is unavailable.
+
+
+ Gets or sets an alternate url for the bundle when it is stored in a content delivery network.
+ An alternate url for the bundle when it is stored in a content delivery network.
+
+
+ The token inserted between bundled files to ensure that the final bundle content is valid.
+ By default, if is not specified, the Web optimization framework inserts a new line.
+
+
+ Specifies whether to use the .
+ true if the is used; otherwise, false.
+
+
+ Generates an enumeration of objects that represent the contents of the bundle.
+ An enumeration of objects that represent the contents of the bundle.
+ The object that contains state for both the framework configuration and the HTTP request.
+
+
+ Processes the bundle request to generate the response.
+ A object containing the processed bundle contents.
+ The object that contains state for both the framework configuration and the HTTP request.
+
+
+
+
+ Specifies a set of files to be included in the .
+ The object itself for use in subsequent method chaining.
+ The virtual path of the file or file pattern to be included in the bundle.
+
+
+ Includes all files in a directory that match a search pattern.
+ The object itself for use in subsequent method chaining.
+ The virtual path to the directory from which to search for files.
+ The search pattern to use in selecting files to add to the bundle.
+
+
+ Includes all files in a directory that match a search pattern.
+ The object itself for use in subsequent method chaining.
+ The virtual path to the directory from which to search for files.
+ The search pattern to use in selecting files to add to the bundle.
+ Specifies whether to recursively search subdirectories of .
+
+
+ Determines the order of files in a bundle.
+ The order of files in a bundle.
+
+
+ Virtual path used to reference the from within a view or Web page.
+ The virtual path.
+
+
+ Transforms the contents of a bundle.
+ The list of transforms for the bundle.
+
+
+
+ Contains and manages the set of registered objects in an ASP.NET application.
+
+
+ Initializes a new instance of the class.
+
+
+ Adds a bundle to the collection.
+ The bundle to add.
+
+
+ Adds the default file extension replacements for common conventions.
+ The list to populate with default values.
+
+
+ Adds default file order specifications to use with bundles in the collection.
+ The list to populate with default values.
+
+
+ Adds the default file ignore patterns.
+ The ignore list to populate with default values.
+
+
+ Removes all bundles from the collection.
+
+
+ Gets the count of registered bundles in the collection.
+ The number of bundles.
+
+
+ Gets a list of file patterns which are ignored when including files using wildcards or substitution tokens.
+ A list of file patterns.
+
+
+ Gets the file extension replacement list.
+ The file extension replacement list.
+
+
+ Gets a list that specifies default file orderings to use for files in the registered bundles.
+ The list of file orderings.
+
+
+ Returns a bundle in the collection using the specified virtual path.
+ The bundle for the virtual path or null if no bundle exists at the path.
+ The virtual path of the bundle to return.
+
+
+ Returns the bundle enumerator.
+ The bundle enumerator.
+
+
+ Returns the collection of all registered bundles.
+ The collection of registered bundles.
+
+
+ Gets the list of files to ignore.
+ The list of files to ignore.
+
+
+ Removes a bundle from the collection.
+ true if the bundle was removed; otherwise, false.
+ The bundle to remove.
+
+
+ Clears the bundles and resets all the defaults.
+
+
+ Returns the bundle URL for the specified virtual path.
+ The bundle URL or null if the bundle cannot be found.
+ The bundle virtual path.
+
+
+ Returns the bundle URL for the specified virtual path, including a content hash if requested.
+ The bundle URL or null if the bundle cannot be found.
+ The virtual path of the bundle.
+ true to include a hash code for the content; otherwise, false. The default is true.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An that can be used to iterate through the collection.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An that can be used to iterate through the collection.
+
+
+ Gets or sets whether the collection will try to use if specified.
+ true if the collection will try to use Bundle.CdnPath if specified; Otherwise, false.
+
+
+ Encapsulates the info needed to process a bundle request
+
+
+ Initializes a new instance of the class.
+ The context.
+ The collection of bundles.
+ The virtual path of the bundles.
+
+
+ Gets or sets the collection of bundles.
+ The collection of bundles.
+
+
+ Gets or sets the virtual path for the bundle request
+ The virtual path for the bundle request.
+
+
+ Gets or sets whether the instrumentation output is requested.
+ true if instrumentation output is requested; otherwise, false.
+
+
+ Gets or sets whether optimizations are enabled via .
+ true if optimizations are enabled via ; otherwise, false.
+
+
+ Gets or sets the HTTP context associated with the bundle context.
+ The HTTP context associated with the bundle context.
+
+
+ Gets or sets whether the bindle context will store the bundle response in the HttpContext.Cache.
+ true if the bindle context will store the bundle response in the cache; Otherwise, false.
+
+
+ Represents a bundle definition as specified by the bundle manifest.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the CDN fallback expression for the bundle.
+ The CDN fallback expression for the bundle.
+
+
+ Gets or sets the CDN path for the bundle.
+ The CDN path for the bundle.
+
+
+ Gets the files included in the bundle.
+ The files included in the bundle.
+
+
+ Gets or sets the virtual path for the bundle.
+ The virtual path for the bundle.
+
+
+
+
+
+
+
+
+
+ Encapsulates a named set of files with relative orderings, for example jquery or modernizer.
+
+
+ Initializes a new instance of the class.
+ The name used to help identify the file ordering.
+
+
+ Gets or sets the ordered list of file name patterns (allows one prefix/suffix wildcard '*') that determines the relative ordering of these files in the bundle. For example, ["z.js", "b*", "*a", "a.js"].
+ The ordered list of file name patterns that determines the relative ordering of these files in the bundle.
+
+
+ Gets or sets the name used to help identify the file ordering, for example, jquery.
+ The name used to help identify the file ordering.
+
+
+ Represents the XML configuration to configure the bundle collection.
+
+
+ Gets or sets the path to the bundle manifest file that sets up the .
+ The path to the bundle manifest file that sets up the .
+
+
+ Reads the bundle manifest using the default bundle configuration.
+ The bundle manifest.
+
+
+ Reads the bundle manifest from a given stream.
+ The bundle manifest.
+ The bundle stream to read from.
+
+
+ Gets the objects specified by the manifest file.
+ The objects specified by the manifest file.
+
+
+ Gets or sets the registered style bundles.
+ The registered style bundles.
+
+
+ Represents a module that enables bundling to intercept requests to bundle URLs.
+
+
+ Initializes a new instance of the class.
+
+
+ Disposes any resources used by the class.
+
+
+ Hooks the OnApplicationPostResolveRequestCache event to remap to the bundle handler.
+ The application that will receive the registration of the event.
+
+
+ Calls the Dispose() method.
+
+
+ Calls the Init method.
+ The application that will receive the registration of the event.
+
+
+ Represents a class that determine if a script reference is a bundle, and what it contains to prevent duplicate script references.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class with the specified bundle.
+ The bundles of objects.
+
+
+ Initializes a new instance of the class with the specified bundle and context.
+ The bundles of object.
+ The HttpContextBase.
+
+
+ Gets or sets the ScriptManager that reflects against .
+ The ScriptManager that reflects against .
+
+
+ Returns an enumeration of actual file paths to the contents of the bundle.
+ The actual file paths to the contents of the bundle.
+ The virtual file path.
+
+
+ Gets the versioned url for the bundle or returns the virtualPath unchanged if it does not point to a bundle.
+ The versioned url for the bundle.
+ The virtual file path.
+
+
+ Determines if the virtualPath is to a bundle.
+ The virtualPath.
+ The virtual file path.
+
+
+ Encapsulates the response data that will be sent for a bundle request.
+
+
+ Initializes a new instance of the class.
+
+
+
+ Gets or sets a value that is used to set the Cache-Control HTTP header.
+ A value that is used to set the Cache-Control HTTP header.
+
+
+ Gets or sets the content of the bundle which is sent as the response body.
+ The content of the bundle.
+
+
+ Gets or sets the media type that is sent in the HTTP content/type header.
+ The media type that is sent in the HTTP content/type header.
+
+
+ Gets or sets the list of files in the bundle.
+ The list of files in the bundle.
+
+
+ Static holder class for the default bundle collection.
+
+
+ Gets the default bundle collection.
+ The default bundle collection.
+
+
+ Gets or sets whether bundling and minification of bundle references is enabled.
+ true if bundling and minification of bundle references is enabled; otherwise, false.
+
+
+ Gets or sets the provider to be used in resolving bundle files.
+ The provider to be used in resolving bundle files.
+
+
+ Represents a that does CSS minification.
+
+
+ Initializes a new instance of the class.
+
+
+ Transforms the bundle contents by applying CSS minification.
+ The bundle context.
+ The bundle response object
+
+
+
+
+
+ Represents the default logic which combines files in the bundle.
+
+
+ Initializes a new instance of the class.
+
+
+
+ Default which orders files in a bundled using .
+
+
+ Initializes a new instance of the class.
+
+
+
+ Represents a object that ASP.NET creates from a folder that contains files of the same type.
+
+
+ Initializes a new instance of the class.
+ The path suffix.
+ The search pattern.
+
+
+ Initializes a new instance of the class.
+ The path suffix.
+ The search pattern.
+ The search subdirectories.
+
+
+ Initializes a new instance of the class.
+ The path suffix.
+ The search pattern.
+ The search subdirectories.
+ The transform parameter.
+
+
+ Initializes a new instance of the class.
+ The path suffix.
+ The search pattern.
+ The transform parameter.
+
+
+ Gets or set the path of a Content Delivery Network (CDN) that contains the folder bundle.
+ The path of a Content Delivery Network (CDN)
+
+
+ Returns all the base methods files and any dynamic files found in the requested directory.
+ All the base methods files and any dynamic files found in the requested directory.
+ The bundle context.
+
+
+ Gets or sets the search pattern for the folder bundle.
+ The search pattern for the folder bundle.
+
+
+ Gets or sets whether the search pattern is applied to subdirectories.
+ true if the search pattern is applied to subdirectories; otherwise, false.
+
+
+ A set of file extensions that will be used to select different files based on the .
+
+
+ Initializes a new instance of the class.
+
+
+ Adds a file extension which will be applied regardless of .
+ File extension string.
+
+
+ Add a file extension for a specified .
+ File extension string.
+
+ in which to apply the file extension replacement.
+
+
+ Clears file extension replacements.
+
+
+
+ Specifies the building of the bundle from the individual file contents.
+
+
+
+ Defines methods for ordering files within a .
+
+
+
+ Represents an interface used to query the BundleCollection for metadata.
+
+
+ Returns a list of all the virtualPaths of the contents of the bundle.
+ The list of virtual path.
+ The virtual path for the bundle.
+
+
+ Returns the versioned URL of the bundle.
+ The versioned URL of the bundle.
+ The virtual path.
+
+
+ Specifies whether the virtual path is to a bundle.
+ true if the virtual path is to a bundle; Otherwise, false.
+ The virtual path.
+
+
+ Defines a method that transforms the files in a object.
+
+
+ Transforms the content in the object.
+ The bundle context.
+ The bundle response.
+
+
+ A list of filename patterns to be ignored and thereby excluded from bundles.
+
+
+ Initializes a new instance of the class.
+
+
+ Clears entire ignore list.
+
+
+
+ Ignores the specified pattern regardless of the value set in .
+ The ignore pattern.
+
+
+ Ignores the specified pattern when in the appropriate .
+ The ignore pattern.
+ The in which to apply the ignore pattern.
+
+
+ Determines whether a file should be ignored based on the ignore list.
+ true if the filename matches a pattern in the ; otherwise, false.
+ The object that contains state for both the framework configuration and the HTTP request.
+ The name of the file to compare with the ignore list.
+
+
+
+
+ Represents a BundleTransform that does CSS Minification.
+
+
+ Initializes a new instance of the class.
+
+
+ Transforms the bundle contents by applying javascript minification.
+ The context associated with the bundle.
+ The .
+
+
+ OptimizationMode used by IgnoreList and FileExtensionReplacement.
+
+
+ Always: Always ignore
+
+
+ WhenDisabled: Only when BundleTable.EnableOptimization = false
+
+
+ WhenEnabled: Only when BundleTable.EnableOptimization = true
+
+
+ Configuration settings used by the class to generate bundle responses outside of ASP.NET applications.
+
+
+ Initializes a new instance of the class.
+
+
+ The physical file path to resolve the ‘~’ token in virtual paths.
+ The physical file path.
+
+
+ The path to the bundle manifest file that sets up the .
+ The path to the bundle manifest file that sets up the .
+
+
+ Gets or sets a callback function which is invoked after the bundle manifest is loaded to allow further customization of the bundle collection.
+ A callback function which is invoked after the bundle manifest is loaded to allow further customization of the bundle collection.
+
+
+
+ Represents a standalone class for generating bundle responses outside of ASP.NET
+
+
+
+ Builds a object from the declarations found in a bundle manifest file.
+ The bundle response for specified .
+ The path to the bundle being requested.
+ An object containing configuration settings for optimization.
+
+
+ Hooks up the BundleModule
+
+
+ Hooks up the BundleModule
+
+
+ Represents a bundle that does Js Minification.
+
+
+ Initializes a new instance of the class that takes a virtual path for the bundle.
+ The virtual path for the bundle.
+
+
+ Initializes a new instance of the class that takes virtual path and cdnPath for the bundle.
+ The virtual path for the bundle.
+ The path of a Content Delivery Network (CDN).
+
+
+ Represents a type that allows queuing and rendering script elements.
+
+
+ Gets or sets the default format string for defining how script tags are rendered.
+ The default format string for defining how script tags are rendered.
+
+
+ Renders script tags for the following paths.
+ The HTML string containing the script tag or tags for the bundle.
+ Set of virtual paths for which to generate script tags.
+
+
+ Renders script tags for a set of paths based on a format string.
+ The HTML string containing the script tag or tags for the bundle.
+ The format string for defining the rendered script tags.
+ Set of virtual paths for which to generate script tags.
+
+
+ Returns a fingerprinted URL if the is to a bundle, otherwise returns the resolve URL.
+ A that represents the URL.
+ The virtual path.
+
+
+ Represents a bundle that does CSS minification.
+
+
+ Initializes a new instance of the class with a virtual path for the bundle.
+ A virtual path for the bundle.
+
+
+ Initializes a new instance of the class with virtual path and CDN path for the bundle.
+ A virtual path for the bundle.
+ A CDN path for the bundle.
+
+
+ Represents a helper class for rendering link elements.
+
+
+ Gets or sets the default format string for defining how link tags are rendered.
+ The default format string for defining how link tags are rendered.
+
+
+ Renders link tags for a set of paths.
+ A HTML string containing the link tag or tags for the bundle.
+ Set of virtual paths for which to generate link tags.
+
+
+ Renders link tags for a set of paths based on a format string.
+ A HTML string containing the link tag or tags for the bundle.
+ Format string for defining the rendered link tags.
+ Set of virtual paths for which to generate link tags.
+
+
+ Generates a version-stamped URL for a bundle.
+ A fingerprinted URL.
+ The virtual file path.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Razor.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Razor.dll
new file mode 100644
index 000000000..6089cb334
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Razor.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Razor.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Razor.xml
new file mode 100644
index 000000000..c88ee1318
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.Razor.xml
@@ -0,0 +1,5742 @@
+
+
+
+ System.Web.Razor
+
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a Razor code language that is based on C# syntax.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the type of the code provider.
+ The type of the code provider.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates a new Razor code generator based on C# code language.
+ The newly created Razor code generator based on C# code language.
+ The class name for the generated code.
+ The name of the root namespace for the generated code.
+ The name of the source code file.
+ The Razor engine host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates a new code parser for C# code language.
+ The newly created code parser for C# code language.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the name of the C# code language.
+ The name of the C# code language. Value is ‘csharp’.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents results from code generation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ true if the code generation is a success; otherwise, false.
+ The document.
+ The parser errors.
+ The generated code.
+ The dictionary of design-time generated code mappings.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The document.
+ The parser errors.
+ The generated code.
+ The dictionary of design-time generated code mappings.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The parser results.
+ The generated code.
+ The dictionary of design-time generated code mappings.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the dictionary of design-time generated code mappings.
+ The dictionary of design-time generated code mappings.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the generated code.
+ The generated code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the results of parsing a Razor document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ true if parsing was successful; otherwise, false.
+ The root node in the document’s syntax tree.
+ The list of errors which occurred during parsing.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The root node in the document’s syntax tree.
+ The list of errors which occurred during parsing.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the root node in the document’s syntax tree.
+ The root node in the document’s syntax tree.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the list of errors which occurred during parsing.
+ The list of errors which occurred during parsing.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value indicating whether parsing was successful.
+ true if parsing was successful; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ Represents the base for all Razor code language.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ Initializes a new instance of the class.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ Gets the type of the CodeDOM provider.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The type of the CodeDOM provider.
+
+
+ Creates the code generator for the Razor code language.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The code generator for the Razor code language.
+ The class name.
+ The name of the root namespace.
+ The source file name.
+ The Razor engine host.
+
+
+ Creates the code parser for the Razor code language.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The code parser for the Razor code language.
+
+
+ Gets the language of the Razor code using the specified file extension.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The language of the Razor code.
+ The file extension.
+
+
+ Gets the language name of the current Razor code, that is “csharp” or “vb”.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The language name of the current Razor code.
+
+
+ Gets the list of language supported by the Razor code.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The list of language supported by the Razor code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents an attribute for the Razor directive.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The name of the attribute.
+ The value of the attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether this instance is equal to a specified object.
+ true if the object is equal to the this instance; otherwise, false.
+ The object to compare with this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the name of the attribute.
+ The name of the attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the unique type ID of the attribute.
+ The unique type ID of the attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the value of the attribute.
+ The value of the attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parser used by editors to avoid reparsing the entire document on each text change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Constructs the editor parser.
+ The which defines the environment in which the generated code will live.
+ The physical path to use in line pragmas.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines if a change will cause a structural change to the document and if not, applies it to the existing tree. If a structural change would occur, automatically starts a reparse.
+ A value indicating the result of the incremental parse.
+ The change to apply to the parse tree.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the current parse tree.
+ The current parse tree.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Releases all resources used by the current instance of the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Releases the unmanaged resources used by the class and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Event fired when a full reparse of the document completes.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the filename of the document to parse.
+ The filename of the document to parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Retrieves the auto complete string.
+ The auto complete string.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the host for the parse.
+ The host for the parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value indicating whether the last result of the parse was provisionally accepted for next partial parse.
+ true if the last result of the parse was provisionally accepted for next partial parse; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the generated code for the razor engine host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The specified code language.
+
+
+ Initializes a new instance of the class.
+ The specified code language.
+ The markup parser factory.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the languages supported by the code generator.
+ The languages supported that by the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a markup parser using the specified language parser for the .
+ A markup parser to create using the specified language parser for the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the methods as language-specific Razor code generator.
+ The methods as language-specific Razor code generator.
+ The C# or Visual Basic code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the methods as language-specific Razor code parser using the specified language parser.
+ The methods as language-specific Razor code parser using the specified language parser.
+ The C# or Visual Basic code parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the method to decorate markup parser using the specified language parser.
+ The method to decorate markup parser using the specified language parser.
+ The C# or Visual Basic code parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the default base class for the host.
+ The default base class for the host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the default class name for the host.
+ The default class name for the host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the default namespace for the host.
+ The default namespace for the host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value that indicates whether the mode designs a time for the host.
+ true if the mode designs a time for the host; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the host that enables the instrumentation.
+ The host that enables the instrumentation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the generated class context for the host.
+ The generated class context for the host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the instrumented source file path for the host.
+ The instrumented source file path for the host.
+
+
+ Gets or sets whether the design time editor is using tabs or spaces for indentation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the namespace imports for the host.
+ The namespace imports for the host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns this method to post all the processed generated code for the host.
+ The code compile unit.
+ The generated namespace.
+ The generated class.
+ The execute method.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns this method to post all the processed generated code for the host.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the static helpers for the host.
+ The static helpers for the host.
+
+
+ Tab size used by the hosting editor, when indenting with tabs.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents an entry-point to the Razor Template Engine.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a code generator.
+ The created .
+ The name of the generated class.
+ The namespace in which the generated class will reside.
+ The file name to use in line pragmas.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a .
+ The created .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the default class name of the template.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the default namespace for the template.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer, generates code for it, and returns the constructed CodeDOM tree.
+ The resulting parse tree AND generated Code DOM tree.
+ The input text to parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer, generates code for it, and returns the constructed CodeDOM tree.
+ The resulting parse tree AND generated Code DOM tree.
+ The input text to parse.
+ A token used to cancel the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer, generates code for it, and returns the constructed CodeDOM tree.
+ The resulting parse tree AND generated Code DOM tree.
+ The input text to parse.
+ The name of the generated class, overriding whatever is specified in the host.
+ The namespace in which the generated class will reside.
+ The file name to use in line pragmas.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer, generates code for it, and returns the constructed CodeDOM tree.
+ The resulting parse tree AND generated Code DOM tree.
+ The input text to parse.
+ The name of the generated class, overriding whatever is specified in the host.
+ The namespace in which the generated class will reside.
+ The file name to use in line pragmas.
+ A token used to cancel the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer, generates code for it, and returns the constructed CodeDOM tree.
+ The resulting parse tree AND generated Code DOM tree.
+ The input text to parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer, generates code for it, and returns the constructed CodeDOM tree.
+ The resulting parse tree AND generated Code DOM tree.
+ The input text to parse.
+ A token used to cancel the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer, generates code for it, and returns the constructed CodeDOM tree.
+ The resulting parse tree AND generated Code DOM tree.
+ The input text to parse.
+ The name of the generated class, overriding whatever is specified in the host.
+ The namespace in which the generated class will reside.
+ The file name to use in line pragmas.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer, generates code for it, and returns the constructed CodeDOM tree.
+ The resulting parse tree AND generated Code DOM tree.
+ The input text to parse.
+ The name of the generated class, overriding whatever is specified in the host.
+ The namespace in which the generated class will reside.
+ The file name to use in line pragmas.
+ A token used to cancel the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates a code core.
+ The results of the generated core.
+ The input text to parse.
+ The name of the generated class, overriding whatever is specified in the host.
+ The namespace in which the generated class will reside.
+ The file name to use in line pragmas.
+ A token used to cancel the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the which defines the environment in which the generated template code will live.
+ The which defines the environment in which the generated template code will live.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer and returns its result.
+ The resulting parse tree.
+ The input text to parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer and returns its result.
+ The resulting parse tree.
+ The input text to parse.
+ A token used to cancel the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer and returns its result.
+ The resulting parse tree.
+ The input text to parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template specified by the TextBuffer and returns its result.
+ The resulting parse tree.
+ The input text to parse.
+ A token used to cancel the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the template core.
+ The resulting parse tree.
+ The input text to parse.
+ A token used to cancel the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the state of the machine.
+ The generic type Return.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the current state of the machine.
+ The current state of the machine.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the starting state of the machine.
+ The starting state of the machine.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Stays into the machine during the transition.
+ Transition of the state machine.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Stays into the machine during the transition with the specified output.
+ The output of the transition.
+ The output.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Disables the machine upon transition.
+ The machine to stop.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the new transition of the state.
+ The new transition of the state.
+ The new state.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the new transition of the state with the specified output.
+ The new transition of the state with the specified output.
+ The output.
+ The new state.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Describes the turning process of the state.
+ The turning process of the state.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the state result.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The next output.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The output.
+ The next state.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value indicating whether the state has output.
+ true if the state has output; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the next state in the machine.
+ The next state in the machine.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the output.
+ The representing the output.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a language generator and provider of the VB razor code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the type of CodeDomProvider.
+ The type of CodeDomProvider.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates the code language generator.
+ The code language generator.
+ The name of the class.
+ The root namespace name.
+ The source File name.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a code parser in a .
+ A code parser in a .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the language name.
+ The language name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the editing result of the Editor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The partial parse result.
+ The edited span builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the edited span of the .
+ The edited span of the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the partial parse result.
+ The partial parse result.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Provides edit handler for implicit expression.
+
+
+ Initializes a new instance of the class.
+ The tokenizer.
+ The keywords.
+ true to accept trailing dot; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value indicating whether the expression accepts trailing dot.
+ true if the expression accepts trailing dot; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the parse that can accept change.
+ The partial parse result.
+ The target.
+ The normalized change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates whether the specified object is equal to the current object.
+ true if the specified object is equal to the current objet; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Retrieves the hash code for this current instance.
+ The hash code for this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the keywords associated with the expression.
+ The keywords associated with the expression.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of this current instance.
+ A string representation of this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the handler editor for this webpages.
+
+
+ Initializes a new instance of the class.
+ The tokenizer symbols.
+
+
+ Initializes a new instance of the class.
+ The tokenizer symbols.
+ The accepted characters.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Provides methods for handling the span edits.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The method used to parse string into tokens.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The method used to parse string into tokens.
+ One of the values of the enumeration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets a value that specifies the accepted characters.
+ One of the values of the enumeration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Applies the text change to the span.
+ The result of the apply operation.
+ The span to apply changes to.
+ The change to apply.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Applies the text change to the span.
+ The result of the apply operation.
+ The span to apply changes to.
+ The change to apply.
+ true to accept partial result; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the span can accept the specified change.
+ true if the span can accept the specified change; otherwise, false.
+ The span to check.
+ The change to apply.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates a new default span edit handler.
+ A newly created default span edit handler.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates a new default span edit handler.
+ A newly created default span edit handler.
+ The method used to parse string into tokens.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the editor hints.
+ The editor hints.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether this instance is equal to a specified object.
+ true if the object is equal to the this instance; otherwise, false.
+ The object to compare with this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the old text from the span content.
+ The old text from the span content.
+ The span to get old text from.
+ The text change which contains the location of the old text.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified change is at the end of first line of the span content.
+ true if the specified change is at the end of first line of the span content; otherwise, false.
+ The span to check.
+ The change to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified change is at the end of the span.
+ true if the specified change is at the end of the span; otherwise, false.
+ The span to check.
+ The change to chek.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified change is at the end the span content and for deletion.
+ true if the specified change is at the end the span content and for deletion; otherwise, false.
+ The span to check.
+ The change to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified change is at the end the span content and for insertion.
+ true if the specified change is at the end the span content and for insertion; otherwise, false.
+ The span to check.
+ The change to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified change is at the end the span content and for replacement.
+ true if the specified change is at the end the span content and for replacement; otherwise, false.
+ The span to check.
+ The change to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the span owns the specified change.
+ true if the span owns the specified change; otherwise, false.
+ The span to check.
+ The change to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the method used to parse string into tokens.
+ The method used to parse string into tokens.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the string representation of the span edit handler.
+ The string representation of the span edit handler.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Updates the span using the normalized change.
+ The new span builder for the specified target.
+ The span to update.
+ The normalized change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the added import code generator for the razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The string namespace.
+ The length of the keyword namespace.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether two object instances are equal.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare with the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code with the specified parameters using the added import code generator.
+ The target span.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the string namespace of the generator to add import code generator.
+ The string namespace of the generator to add import code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the length of keyword namespace for the code generator.
+ The length of keyword namespace for the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string that represents the current object.
+ A string that represents the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the attributes of the block code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The name.
+ The prefix string.
+ The suffix string.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare with the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code to end the block using the specified parameters.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code to start the block using the specified parameters.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this code generator.
+ The hash code for this code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the string name of the .
+ The string name of the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the prefix of the code generator.
+ The prefix of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the suffix for the code generator.
+ The suffix for the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string that represents the current object.
+ A string that represents the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represent the block code generator for this razor syntax.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare with the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the end of the block code generator for this razor syntax.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the start of the block code generator for this razor syntax.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a hash code for the block code generator.
+ A hash code for the block code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a null value for the block code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the completion of event arguments for the code generation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The virtual path string.
+ The physical path string.
+ The generated code compile unit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the generated code to complete the event argument.
+ The generated code to complete the event argument.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the physical path for the code generation.
+ The physical path for the code generation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the virtual path of the code generation.
+ The virtual path of the code generation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents the context of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds a new generated code mapping to the collection.
+ The collection index of the newly added code mapping.
+ The source location of the generated code mapping.
+ The code start of the generated code mapping.
+ The length of the generated code mapping.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds a code statement for a context call on the specified method.
+ The content span.
+ The name of the method to invoke a context call.
+ true to specify that the method parameter is literal; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds a code statement that inserts the Razor design time helpers method in the specified code statement.
+ The code statement that receives the code insertion.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds the specified code statement to the body of the target method.
+ The code statement to add the target method.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds the specified code statement to the body of the target method.
+ The code statement to add the target method.
+ The line pragma.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Appends the specified fragment to the current buffered statement.
+ The fragment to add.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Appends the specified fragment to the current buffered statement.
+ The fragment to add.
+ The source span for the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Appends the content of the span to the current buffered statement.
+ The source span whose content is to be added.
+
+
+ Assigns a new statement collector and returns a disposable action that restores the old statement collector.
+ A disposable action that restores the old statement collector.
+ The new statement collector.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the dictionary collection of generated code mapping.
+ The dictionary collection of generated code mapping.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the code compile unit that will hold the program graph.
+ The code compile unit that will hold the program graph.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates a new instance of the class.
+ The newly created instance of the code generator context.
+ The Razor engine host.
+ The class name for the generated class type declaration.
+ The name for the generated namespace declaration.
+ The source file.
+ true to enable the generation of line pragmas; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the current buffered statement.
+ The current buffered statement.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds the expression helper variable to the generated class if not yet added,
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Flushes the current buffered statement.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the generated class type declaration.
+ The generated class type declaration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the line pragma for the specified source.
+ The line pragma for the specified source.
+ The source span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the line pragma for the source.
+ The line pragma for the specified source.
+ The source span.
+ The start index of code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the line pragma for the source.
+ The line pragma for the specified source.
+ The source span.
+ The start index of code.
+ The length of code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the line pragma for the source.
+ The line pragma for the specified source.
+ The source location.
+ The start index of code.
+ The length of code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the Razor engine host.
+ The Razor engine host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Marks the end of generated code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Marks the start of generated code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the generated namespace declaration.
+ The generated namespace declaration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the source file.
+ The source file.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the generated member method.
+ The generated member method.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the name of text writer.
+ The name of text writer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a Razor code generator for C# language.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The class name for the generated class type declaration.
+ The name for the generated namespace declaration.
+ The source file.
+ The Razor engine host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes the context for this code generator.
+ The context for this code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the dynamic attributes of the block code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instances of the class.
+ The prefix.
+ The offset values.
+ The line values.
+ The col.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instances of the class.
+ The string prefix.
+ The value start.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare with the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code to end the block using the specified parameters.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code to start the block using the specified parameters.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the namespace prefix of the code generator.
+ The namespace prefix of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string that represents the current object.
+ A string that represents the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the value start for the dynamic attribute block code generator.
+ The value start for the dynamic attribute block code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a code generator for expression.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates whether this instance and a specified object are equal.
+ true if and this instance are the same type and represent the same value; otherwise, false.
+ The object to compare with the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code for the expression.
+ The source span whose content represents an expression.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the end code for the block.
+ The target block for the end code generation.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the start code for the block.
+ The target block the start code generation.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the string representation of this instance.
+ The string representation of this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a generated class context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The execute method name.
+ The write method name.
+ Write literal method name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ Execute method name.
+ Write method name.
+ Write literal method name.
+ Write to method name.
+ Write literal to method name.
+ Template type name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ Execute method name.
+ Write method name.
+ Write literal method name.
+ Write to method name.
+ Write literal to method name.
+ Template type name.
+ Define section method name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ Execute method name.
+ Write method name.
+ Write literal method name.
+ Write to method name.
+ Write literal to method name.
+ Template type name.
+ Define section method name.
+ Begin context method name.
+ End context method name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value indicating whether the context allows sections.
+ true if the context allows sections; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value indicating whether the context allows templates.
+ true if the context allows templates; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method before the generated context.
+ The name of the method before the generated context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Defines the default generated context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Defines the default name of the execute method.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Defines the default name of the layout property.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Defines the default name of the write attribute method.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Defines the default name of the write to attribute to method.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Specifies the default name of the write literal method.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Specifies the default name of the write method.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method that defines the section of the context.
+ The name of the method that defines the section of the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method after the generated context.
+ The name of the method after the generated context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method that will be invoked on the context.
+ The name of the method that will be invoked on the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this current instance.
+ The hash code for this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the property name for the layout.
+ The property name for the layout.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two object are equal.
+ true if the two object are equal; otherwise, false.
+ The first object to compare.
+ The second object to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two object are not equal.
+ true if the two object are not equal; otherwise, false.
+ The first object to compare.
+ The second object to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method that resolves a Url for the context.
+ The name of the method that resolves a Url for the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value indicating whether the generated class supports instrumentation.
+ true if the generated class supports instrumentation; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the type name for the template.
+ The type name for the template.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method that writes an attribute.
+ The name of the method that writes an attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method where to write an attribute.
+ The name of the method where to write an attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method where to write literal for the context.
+ The name of the method where to write literal for the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method where to write literal for the context.
+ The name of the method where to write literal for the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method that will write on the context.
+ The name of the method that will write on the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the method that will write on the context.
+ The name of the method that will write on the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the generated code mapping objects.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The starting line.
+ The starting column.
+ The start generated column.
+ The code length.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The start offset.
+ The starting line.
+ The starting column.
+ The start generated column.
+ The code length.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the length of the generated map codes.
+ The length of the generated map codes.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current generated code mapping object.
+ true if the specified object is equal to the current generated code mapping object; otherwise, false.
+ The object to compare with the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for the generated code mapping object.
+ The hash code for the generated code mapping object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two specified generated code mapping objects have the same value.
+ true if the two specified generated code mapping objects have the same value; otherwise, false.
+ The left generated code mapping objects.
+ The right generated code mapping objects.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two specified generated code mapping objects have different values.
+ true the two specified generated code mapping objects have different values; otherwise, false.
+ The right generated code mapping objects.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the starting column of the generated code maps.
+ The starting column of the generated code maps.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the starting column of a generated code maps in the generated source file.
+ The starting column of a generated code maps in the generated source file.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the starting line of the generated code maps.
+ The starting line of the generated code maps.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the starting offset of the generated code maps.
+ The starting offset of the generated code maps.
+
+
+ Returns a string that represents the current object.
+ A string that represents the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a helper code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The signature.
+ true to complete the header; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the footer for this code.
+ The footer for this code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates a block after the code.
+ The block to generate.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates a block before the code.
+ The block to generate.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the hash code for the current instance.
+ The hash code for the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value indicating whether the header for this code is complete.
+ true if the header for this code is complete; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the signature for this code.
+ The signature for this code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of the current instance.
+ A string representation of the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a hybrid code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code for the data model from switches identified by parameters.
+ The target object.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates an end block code.
+ The target object.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the start block code.
+ The target object.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the for the webpages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the end block code for the razor.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the start block code for the razor.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a phase of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code for the data model with the specified target and context.
+ The target object.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a code generator for literal attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. . Initializes a new instance of the class.
+ The prefix of the literal attribute.
+ The value of the literal attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. . Initializes a new instance of the class.
+ The prefix of the literal attribute.
+ The value generator for the literal attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified object is equal to this instance.
+ true if the specified object is equal to this instance; otherwise, false.
+ The object to compare to this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the code for the literal attribute.
+ The source span whose content represents the literal attribute.
+ The context of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the hash code for the current instance.
+ The hash code for the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the prefix of the literal attribute.
+ The prefix of the literal attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the string representation of this instance.
+ The string representation of this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the value of the literal attribute.
+ The value of the literal attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the value generator for the literal attribute.
+ The value generator for the literal attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a code generator for markup.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified object is equal to this instance.
+ true if the specified object is equal to this instance; otherwise, false.
+ The object to compare to this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the code for the markup.
+ The source span whose content represents the markup.
+ The context of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the string representation for this instance.
+ The string representation for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a Razor code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The class name.
+ The root namespace name.
+ The source file name.
+ The host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the class name for this code.
+ The class name for this code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the context of this code generator.
+ The context of this code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value indicating whether the code generator is in design-time mode.
+ true if the code generator is in design-time mode; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value indicating whether the generator should generate line pragmas in the Razor code.
+ true if the generator should generate line pragmas in the Razor code; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the razor engine host.
+ The razor engine host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes the current instance.
+ The context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Raises the Complete event.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the root namespace.
+ The name of the root namespace.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the source file.
+ The name of the source file.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Visits the end block.
+ The block to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Visits the span.
+ The span to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Visits the start block.
+ The block to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the razor comment code generator for the webpages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the start block code with the specified parameters.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a code generator for Razor directive attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The name of the directive attribute.
+ The value of the directive attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified object is equal to this instance.
+ true if the specified object is equal to this instance; otherwise, false.
+ The object to compare to this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the code for the directive attribute.
+ The source span whose content represents the directive attribute to generate.
+ The context of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the name of the directive attribute.
+ The name of the directive attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the string representation for this instance.
+ The string representation for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the value of the directive attribute.
+ The value of the directive attribute.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the resolve Url code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates whether this instance and a specified object are equal.
+ true if and this instance are the same type and represent the same value; otherwise, false.
+ The object to compare with the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code for the Url.
+ The target object.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the fully qualified type name of this instance.
+ The fully qualified type name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a section code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The name of the section code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates a block after the section code.
+ The target to generate.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates a block before the section code.
+ The target to generate.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Retrieves the hash code for this current instance.
+ The hash code for this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the section.
+ The name of the section.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of this current instance.
+ A string representation of this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a code generator for set base type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The set base type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the set base type.
+ The set base type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified object is equal to this instance.
+ true if the specified object is equal to this instance; otherwise, false.
+ The object to compare to this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the code for this set base type.
+ The source span that contains the set base type to generate code.
+ The context of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the hash code for this current instance.
+ The hash code for this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Resolves the given set base type.
+ The resolved set base type.
+ The context of the code generator.
+ The set base type to resolve.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the string representation for this instance.
+ The string representation for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a code generator that sets layout for the web Razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The layout path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates a layout code.
+ The target where to generate the code.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Retrieves a hash code for this current instance.
+ A hash code for this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the path of the layout code.
+ The path of the layout code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of this current instance.
+ A string representation of this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the conversion of the SetVBOptionCodeGenerator of the value.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The option name.
+ true if the object has a value; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Converts the explicitly to the on and off value.
+ The explicitly converts to the on and off value.
+ true if the converts to on and off value; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the explicit code Dom option name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code for the specified parameters.
+ The target.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the option name for the code generator.
+ The option name for the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Strictly converts the to the on and off value.
+ The strictly converts to the on and off value.
+ true if the strictly converts to the on and off value; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the strict code Dom option name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a String that represents the current Object.
+ A String that represents the current Object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether the has a value.
+ true if the has a value; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the span code generator for the razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare with the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates a code for the specified target and context parameters.
+ The target span.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a hash code for the span code generator.
+ A hash code for the span code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a null value for the span code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a code generator for the statement.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified object is equal to this instance.
+ true if the specified object is equal to this instance; otherwise, false.
+ The object to compare to this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Generates the code for the statement.
+ The span source whose content contains the statement to generate.
+ The context of the code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the hash code for this current instance.
+ The hash code for this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the string representation for this instance.
+ The string representation for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the template block code generator of the razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code to end the block of the template block code generator.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code to start the block for the template block code generator.
+ The target block.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a type member code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates code with a given target and context.
+ The target where to generate the code.
+ The code generator context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Retrieves the hash code for this current instance.
+ The hash code for this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of this code.
+ A string representation of this code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the razor code generator for VB.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The name of the class.
+ The root namespace.
+ The file name of the asset source.
+ The host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a visitor that executes a callback upon the completion of a visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The delegate for the span visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The delegate for the span visit.
+ The delegate for the error visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The delegate for the span visit.
+ The delegate for the error visit.
+ The delegate for the start block visit.
+ The delegate for the end block visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The delegate for the span visit.
+ The delegate for the error visit.
+ The delegate for the start block visit.
+ The delegate for the end block visit.
+ The delegate to execute for the complete event.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the synchronization context for this callback visitor.
+ The synchronization context for this callback visitor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Executes the visitor callback to visit the end block.
+ The end block to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Executes the visitor callback to visit the error.
+ The Razor error to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Executes the visitor callback to visit the span.
+ The span to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Executes the visitor callback to visit the start block.
+ The start block to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a C sharp code parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the parser accepts the ‘IF’ keyword.
+ true if the parser accepts the ‘IF’ keyword; otherwise, false.
+ The keyword to accept.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Asserts a directive code.
+ The directive code to assert.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code contains ‘AT’ keyword.
+ true if the code contains ‘AT’ keyword; otherwise, false.
+ The keyword.
+
+
+ Indicates the base type directive.
+ The no type name error.
+ The create code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the functions directive.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the code that handles embedded transition.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a helper directive.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates which class the application will derive the view from, and can therefore ensure proper type checking.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Inherits a directive core.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code is at embedded transition.
+ true if the code is at embedded transition; otherwise, false.
+ true to allow templates and comments; otherwise, false.
+ true to allow transitions; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value that indicates whether the code is nested.
+ true if the code is nested; otherwise, false.
+
+
+ Indicates whether the lines and comments is spacing token.
+ The function that indicates the spacing token.
+ true to include new lines; otherwise, false.
+ true to include comments; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the C sharp language keywords.
+ The C sharp language keywords.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the specific language for parsing.
+ The specific language for parsing.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the layout directive.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Maps the given directives.
+ The handler.
+ The directives.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the other parser used for the code.
+ The other parser used for the code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Spans the output of the parsing before the comment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Blocks the parsing.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the reserved directive.
+ Determines whether the directive is a top level.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a section directive.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a session state directive.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the session state directive core.
+
+
+ Indicates the directive for session state type.
+ The no value error.
+ The create code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a directive handler.
+ true if successful; otherwise, false.
+ The directive.
+ The handler.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the value of the session state is valid.
+ true if the value of the session state is valid; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the block for this CSharpCode parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The string name.
+ The start of the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The CSharp symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the string name for the block.
+ The string name for the block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the source location to start the block.
+ The source location to start the block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the different language characteristics in a CSharp language.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a marker symbol in the code.
+ A marker symbol in the code.
+ The source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a symbol in the code.
+ A symbol in the code.
+ The source location.
+ The content value.
+ The html symbol type.
+ List of errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a language tokenizer.
+ A language tokenizer.
+ The source of the text document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Flips the bracket symbol in the code.
+ The bracket symbol in the code.
+ The symbol bracket.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the keyword in the code.
+ The keyword in the code.
+ The keyword.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the in the code.
+ The in the code.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a sample symbol in the code.
+ A sample symbol in the code.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a sample symbol in the code.
+ A sample symbol in the code.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the instance for the class.
+ The instance for the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the different language characteristics in an html.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a marker symbol in the Html.
+ A marker symbol in the Html.
+ The source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a symbol in the Html.
+ A symbol in the Html.
+ The source location.
+ The content value.
+ The html symbol type.
+ List of errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates an html tokenizer.
+ An html tokenizer.
+ The source of the text document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Flips the bracket symbol in the html.
+ The bracket symbol in the html.
+ The symbol bracket.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the in the html.
+ The in the html.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a sample symbol in the html.
+ A sample symbol in the html.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the instance for the class.
+ The instance for the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a parser specifically for parsing HTML markup.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Builds the span for the given content using the specified span builder.
+ The span builder used to build the span.
+ The start location.
+ The span content.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the function delegate used to determine the token used for HTML spacing.
+ The function delegate used to determine the token used for HTML spacing.
+ true to indicate that new lines are considered as spacing token; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the instance that defines the characteristics of HTML language.
+ The instance that defines the characteristics of HTML language.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the other parser for parsing HTML markup.
+ The other parser for parsing HTML markup.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Builds the span before the Razor comment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Parses the next HTML block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Parses the HTML document.
+
+
+ Parses a section with markups given by the nesting sequences.
+ A tuple that specifies the markup nesting sequences.
+ true to indicate case-sensitive parsing; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Skips the parse until the specified condition is meet.
+ A function delegate that defines the condition.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Skips the parse until the specified HTML symbol type is encountered.
+ The HTML symbol type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the HTML tags that are considered as void.
+ The HTML tags that are considered as void.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Provides methods that define the behavior of a Razor code language.
+ The type of the code tokenizer for the Razor language.
+ The type for the language symbol.
+ The enumeration type for the language symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates a code language symbol with the specified source location as the start marker.
+ The symbol for the code language.
+ The source location as the start marker.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates a code language symbol with the specified source location with the specified source location as the start marker.
+ The symbol for the code language.
+ The source location as the start marker.
+ The content.
+ The enumeration type for the language symbol.
+ The collection of error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates a Razor code language tokenizer for the specified source document.
+ A Razor code language tokenizer for the specified source document.
+ The source document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the opposite bracket symbol for the specified bracket symbol.
+ The opposite bracket symbol for the specified bracket symbol.
+ The bracket symbol to flip.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the specific language symbol type for the given symbol type.
+ The specific language symbol type for the given symbol type.
+ The symbol type to get.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the actual symbol for the given language symbol type.
+ The actual symbol for the given language symbol type.
+ The language symbol type to get.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is a comment body type.
+ true if the symbol is a comment body type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is a comment star type.
+ true if the symbol is a comment star type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is a comment start type.
+ true if the symbol is a comment start type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is an identifier type.
+ true if the symbol is an identifier type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is a keyword type.
+ true if the symbol is a keyword type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol type is a known symbol type.
+ true if the symbol type is a known symbol type; otherwise, false.
+ The symbol whose type is to be checked.
+ The known type of the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is a new line type.
+ true if the symbol is a new line type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is a transition type.
+ true if the symbol is a transition type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is an unknown type.
+ true if the symbol is an unknown type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is a whitespace type.
+ true if the symbol is a whitespace type; otherwise, false.
+ The symbol to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the symbol is an unknown type.
+ true if the symbol is an unknown type; otherwise, false.
+ The known type of the symbol.
+
+
+ Splits the content of the code language symbol at the specified index.
+ A tuple of code language symbol.
+ The symbol whose content is to be splitted.
+ The index where the split occurs.
+ The enumeration type for the language symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Splits the specified string into tokens.
+ The collection of token.
+ The string to tokenize.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Splits the specified string into tokens.
+ The collection of token.
+ The source location as the start marker for the tokenizer.
+ The string to tokenize.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the parser base class for the razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Builds a span for the parser base.
+ The span builder.
+ The beginning of the source location.
+ The content.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the .
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether the parser is a markup parser.
+ true if the parser is a markup parser; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the other parser .
+ The other parser .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Blocks the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates documentation for the parse.
+
+
+ Parses the section in ordered list of the elements.
+ The pair of nesting sequences.
+ true if the case is sensitive; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a parser whose context can be switched to either a code or a markup.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The source document.
+ The code parser for the context.
+ The markup parser for the context.
+ The active parser for the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the active parser for the context.
+ The active parser for the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds the specified span at the end of the block builder stack.
+ The span to add.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the code parser for the context.
+ The code parser for the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Parses the last span and returns the parse results that contain the newly built block.
+ The parse results that contain the newly built block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the current block builder.
+ The current block builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the current character available from the source.
+ The current character available from the source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets a value that indicates whether the parser is in design mode.
+ true if the parser is in design mode; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Creates an end block from the last item of the block builder stack.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets a value that indicates whether the source status is end of file.
+ true if the source status is end of file; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the list of errors during parsing.
+ The list of errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified block type exists in the block builder list.
+ true if the specified block type exists in the block builder list; otherwise, false.
+ The block type to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the last accepted characters.
+ One of the values of the enumeration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the last span.
+ The last span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the markup parser for the context.
+ The markup parser for the context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Occurs when parse encountered error.
+ The source location.
+ The error message.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Occurs when parse encountered an error.
+ The source location.
+ The error message.
+ The other information about the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the text reader for the source document.
+ The text reader for the source document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds a new block builder at the end of the block builder stack and returns a disposable action that returns an end block.
+ A disposable action that returns an end block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Adds a new block builder at the end of the block builder stack and returns a disposable action that returns an end block.
+ A disposable action that returns an end block.
+ The type for the new block builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Alternately switches the code parser or markup parser as the active parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets a value that indicates whether white space is significant to ancestor block.
+ true is white space is significant to ancestor block; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Provides helper methods for the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a spacing combining mark or a non-spacing mark.
+ true if the specified character value is a spacing combining mark or a non-spacing mark; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a connector punctuation.
+ true if the specified character value is a connector punctuation; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a decimal digit number.
+ true if the specified character value is a decimal digit number; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is valid for use in email address.
+ true if the specified character value is valid for use in email address; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is used for formatting text layout or formatting text operation.
+ true if the specified character value is used for formatting text layout or formatting text operation.; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a hexadecimal digit number.
+ true if the specified character is a hexadecimal digit number; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified string value is an identifier.
+ true if the specified string value is an identifier; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified string value is an identifier.
+ true if the specified string value is an identifier; otherwise, false.
+ The value to check.
+ true to require that the identifier starts with a letter or underscore (_); otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is valid for use in identifier.
+ true if the specified character is valid for use in identifier; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is valid for use as start character of an identifier.
+ true if the specified character value is valid for use as start character of an identifier; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a letter.
+ true if the specified character is a letter; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a letter or a decimal digit number.
+ true if the specified character is a letter or a decimal digit number; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified value is a newline.
+ true if the specified character is a newline; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified value is a newline.
+ true if the specified character is a newline; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a terminating character token.
+ true if the specified character value is a terminating character token; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a terminating quoted string.
+ true if the specified character value is a terminating quoted string; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a whitespace.
+ true if the specified character value is a whitespace; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified character value is a whitespace or newline.
+ true if the specified character value is a whitespace or newline; otherwise, false.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Sanitizes the specified input name to conform as a valid value for class name.
+ The sanitized class name.
+ The value to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a parser visitor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the cancellation token.
+ The cancellation token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates that a visitor method has completed execution.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Visits the specified block.
+ The block to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Visits the specified black after parsing.
+ The block to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Visits the given razor error.
+ The error to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Visits the specified span.
+ The span to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Visits the specified block before parsing.
+ The block to visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Provides extension methods for parser visitor.
+
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a Razor parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The code parser.
+ The markup parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a task that parses a specified object.
+ The created .
+ The object to parse.
+ The span callback.
+ The error callback.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a task that parses a specified object.
+ The created .
+ The object to parse.
+ The span callback.
+ The error callback.
+ The cancellation token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a task that parses a specified object.
+ The created .
+ The object to parse.
+ The span callback.
+ The error callback.
+ The context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a task that parses a specified object.
+ The created .
+ The object to parse.
+ The span callback.
+ The error callback.
+ The context.
+ The cancellation token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a task that parses a specified object.
+ The created .
+ The object to parse.
+ The consumer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the design time mode.
+ The design time mode.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the specified object.
+ The parser result.
+ The object to parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the specified object.
+ The object to parse.
+ The visitor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the specified object.
+ The parser result.
+ The object to parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the specified object.
+ The parser result.
+ The object to parse.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the specified object.
+ The object to parse.
+ The visitor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a tokenizer backed parser.
+ The type of tokenizer.
+ The type of symbol.
+ The type of SymbolType.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the list of symbols
+ The list of symbols.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the specified symbol.
+ The symbol to accept.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the parser accepts all types of tokenizer.
+ true of the parser accepts all types of tokenizer; otherwise, false.
+ The types.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the parser accepts and moves to the next tokenizer.
+ true if the parser accepts and moves to the next tokenizer; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the parser accepts single whitespace character.
+ true if the parser accepts single whitespace character; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts token until a token of the given type is found.
+ The type of the token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts token until a token of the given type is found and it will backup so that the next token is of the given type.
+ The type of the first token.
+ The type of the second token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the given tokens until a token of the given type is found.
+ The type of the first token.
+ The type of the second token.
+ The type of the third token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts token until a token of the given types is found.
+ The types of the token.
+
+
+ Accepts token while the condition has been reached.
+ The condition.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the token while a token of the given type is not found.
+ The type of the token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts token while the token of the given type has been reached.
+ The type of the first token.
+ The type of the second token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts token while the token of the given type has been reached.
+ The type of the first token.
+ The type of the second token.
+ The type of the third token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts token while the token of the given types has been reached.
+ The types.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the parser accepts whitespace in lines.
+ true if the parser accepts whitespace in lines; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Adds a marker symbol if necessary.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Adds a marker symbol if necessary.
+ The location where to add the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the token is at the specified type.
+ true if the token is at the specified type; otherwise, false.
+ The type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the token is at the specified identifier.
+ true if the token is at the specified identifier; otherwise, false.
+ true to allow keywords; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the parsing is balance.
+ true if the parsing is balance; otherwise, false.
+ The balancing mode.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the parsing is balance.
+ true if the parsing is balance; otherwise, false.
+ The balancing mode.
+ The left parse.
+ The right parse.
+ The start of the mode.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Builds a specified span.
+ The span to build.
+ The start location to build the span.
+ The content of the span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Configures the span.
+ The configuration.
+
+
+ Configures the span.
+ The configuration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the current location of the current instance.
+ The current location of the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the current symbol of this instance.
+ The current symbol of this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value indicating whether the tokenizer is in the end of file.
+ true if the tokenizer is in the end of file; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether to ensure the current parser.
+ true if to ensure the current parser; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the expected token with the given type.
+ The type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the expected token with the given types.
+ The types.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Handles the embedded transition.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a specified span.
+ The span to initialize.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether this instance is at embedded transition.
+ true if this instance is at embedded transition; otherwise, false.
+ true to allow templates and comments; otherwise, false.
+ true to allow transitions; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the language used for parsing.
+ The language used for parsing.
+
+
+ Determines whether the token with the given condition would pass.
+ true if the token with the given condition would pass; otherwise, false.
+ The condition.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the token with the given type would pass.
+ true if the token with the give type would pass; otherwise, false.
+ The type of the token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the token with the given types would pass.
+ true if the token with the given types would pass; otherwise, false.
+ The types.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the parser advances to the next token.
+ true if the parser advances to the next token; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether parsing a token with the given type is optional.
+ true if parsing a token with the given type is optional; otherwise, false.
+ The type of the token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether parsing a token with the given type is optional.
+ true if parsing a token with the given type is optional; otherwise, false.
+ The type of the token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Outputs a token with accepted characters.
+ The accepted characters.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Outputs a token with span kind.
+ The span kind.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Outputs a token with a given span kind and accepted characters.
+ The span kind.
+ The accepted characters.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Outputs a span before the razor comment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code..Gets the previous symbol of this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Pushes the span configuration.
+ An that shuts down the configuration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Pushes the span configuration.
+ An that shuts down the configuration.
+ The new configuration.
+
+
+ Pushes the span configuration.
+ An that shuts down the configuration.
+ The new configuration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Puts the transition back.
+ The symbols.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Puts the transition back.
+ The symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Puts the current transition back.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Displays the razor comment.
+
+
+ Reads a token while the condition is not reached.
+ The token to read.
+ The condition.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the expected token is required.
+ true if the expected token is required; otherwise, false.
+ The expected token.
+ true to display an error if not found; otherwise, false.
+ The error base.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the associated with this instance.
+ The associated with this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the span configuration.
+ The span configuration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the tokenizer.
+ The tokenizer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the token with the given type was parsed.
+ true if the token with the given type was parsed; otherwise, false.
+ The type of the token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a Visual Basic code parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts spaces in the VB code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Checks for a condition and displays a keyword in the code.
+ The keyword.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Asserts the given directive.
+ The directive to assert.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the directive is ‘AT’ directive.
+ true if the directive is an ‘AT’ directive; otherwise, false.
+ The directive.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the given keyword is ‘AT’.
+ true if the given keyword is ‘AT’; otherwise, false.
+ The keyword.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Ends a terminated directive.
+ The function that ends the terminated directive.
+ The directive.
+ The block type.
+ The code generator.
+ true to allow markup; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the termination of directive body is ended.
+ true if the termination of directive body is ended; otherwise, false.
+ The directive.
+ The block start.
+ true to allow all transitions; otherwise, false.
+
+
+ Ends a termination of statement.
+ The function that ends the termination.
+ The keyword.
+ true if the termination supports exit; otherwise, false.
+ true if the termination supports continue; otherwise, false.
+
+
+ Ends a termination of statement.
+ The function that ends the termination.
+ The keyword.
+ true if the termination supports exit; otherwise, false.
+ true if the termination supports continue; otherwise, false.
+ The block name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Handles the embedded transition.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Handles the embedded transition.
+ The last white space.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the code that handles the Exit or Continue keyword.
+ The keyword.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a code that handles a transition.
+ The last white space.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates whether the code is a helper directive.
+ true if the code is a helper directive; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code imports a statement.
+ true if the code imports a statement; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code inherits a statement.
+ true if the code inherits a statement; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code is at embedded transition.
+ true if the code is at embedded transition; otherwise, false.
+ true to allow templates and comments; otherwise, false.
+ true to allow transitions; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code is directive defined.
+ true if the code is directive defined; otherwise, false.
+ The directive.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the keywords associated with the code.
+ The keywords associated with the code.
+
+
+ Indicates a keyword that terminates a statement.
+ The function that terminates the statement.
+ The start.
+ The terminator.
+ true if the termination supports exit; otherwise, false.
+ true if the termination supports continue; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the language for the parser.
+ The language for the parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code is a layout directive.
+ true if the code is a layout directive; otherwise, false.
+
+
+ Maps a given directive.
+ The directive.
+ The action whether to map a given directive.
+
+
+ Maps a given keyword.
+ The keyword.
+ The action whether to map a given keyword.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a nested block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the keyword from the code is optional.
+ true if the keyword from the code is optional; otherwise, false.
+ The keyword.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code is an option statement.
+ true if the code is an option statement; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the other parser.
+ The other parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the parser block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the parser block.
+ The start sequence.
+ The end sequence.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Spans the output before Razor comment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Blocks the parsing.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Reads a list of Visual Basic spaces.
+ A list of Visual Basic spaces.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the expected symbol is required.
+ true if the expected symbol is required; otherwise, false.
+ The expected symbol.
+ The error base.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code is a reserved word.
+ true if the code is a reserved word; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code is a section directive.
+ true if the code is a section directive; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the code has a session state directive.
+ true if the code has a session state directive; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the characteristics of the Visual Basic language.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a Visual Basic marker symbol.
+ The created Visual Basic marker symbol.
+ The location to create the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a Visual Basic symbol.
+ The created .
+ The location to create the symbol.
+ The content.
+ The type of the symbol.
+ The errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a Visual Basic tokenizer.
+ The created .
+ The source where to create the tokenizer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Flips the given bracket.
+ The type of the Visual Basic symbol.
+ The bracket to flip.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Retrieves the type of the known symbol.
+ The type of the known symbol.
+ The type to retrieve.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a sample symbol with the given type.
+ A sample symbol with the given type.
+ The type of the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets an instance of this .
+ An instance of .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the auto-complete editing handler class.
+
+
+ Initializes a new instance of the class.
+ The tokenizer.
+
+
+ Initializes a new instance of the class.
+ The tokenizer.
+ The accepted characters.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value that indicates whether the auto-complete function is at the end of this span.
+ true if the auto-complete function is at the end of this span; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a string value to auto-complete.
+ A string value to auto-complete.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a parse result that can accept changes.
+ The phase of the target.
+ The normalized .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates whether this instance and a specified object are equal.
+ true if and this instance are the same type and represent the same value; otherwise, false.
+ The object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this instance.
+ A 32-bit signed integer that is the hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the fully qualified type name of this instance.
+ A String containing a fully qualified type name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the block for creating webpages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The source for the block builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the parser visitor of the block.
+ The parser visitor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a collection of SyntaxTreeNode to view the children of the block.
+ A collection of SyntaxTreeNode to view the children of the block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the IBlockCodeGenerator to generate codes for the elements.
+ The IBlockCodeGenerator to generate codes for the elements.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current block.
+ true if the specified object is equal to the current block; otherwise, false.
+ The object to compare with the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a value indicating whether the block is equivalent to the same element.
+ true if the block is equivalent to the same element; otherwise, false.
+ The syntax tree node.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Finds the first descendent span of the block.
+ The first descendent span of the block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Finds the last descendent span of the block.
+ The last descendent span of the block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Flattens a collection of a specified type for the block.
+ A collection of a specified type for the block to flatten.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether the object is a block-level object.
+ true if the object is a block-level object; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the length value of the block.
+ The length value of the block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Locates the owner of the block.
+ The owner of the block to locate.
+ The text change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the string name of the block.
+ The string name of the block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the start to identify the specific location of the block.
+ The start to identify the specific location of the block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string that represents the current object.
+ A string that represents the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the type of code block.
+ The type of code block.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the block builder for the webpages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The original block builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Builds a block for this instance.
+ A block builds for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the collection of child elements of the block builder.
+ The collection of child elements of the block builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the code generator for the block builder.
+ The code generator for the block builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the string name for the block builder.
+ The string name for the block builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Resets the block builder to its original position.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a block type that can be assigned null.
+ A block type that can be assigned null.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a parsing error in Razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The error message.
+ The absolute index of the source location.
+ The line index of the source location.
+ The column index of the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The error message.
+ The absolute index of the source location.
+ The line index of the source location.
+ The column index of the source location.
+ The length for the error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The error message.
+ The source location of the error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The error message.
+ The source location of the error.
+ The length for the error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified object is equal to this instance.
+ true if the specified object is equal to this instance; otherwise, false.
+ The object to compare to this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified object is equal to this instance.
+ true if the specified object is equal to this instance; otherwise, false.
+ The object to compare to this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the hash code for the current instance.
+ The hash code for the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the length for the error.
+ The length for the error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the source location of the error.
+ The source location of the error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the error message.
+ The error message.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the string representation of this error instance.
+ The string representation of this error instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Represents a Razor parse tree node that contains the all the content of a block node.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The builder to use for this span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Accepts visit from the specified visitor.
+ The object that performs the visit.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Changes the span builder for this span.
+ A delegate that will be executed along with this change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Sets the start character location of this span.
+ The new start location to set for this span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the code generator for the span.
+ The code generator for the span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the content of the span.
+ The content of the span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the handler for span edits.
+ The handler for span edits.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified object is equal to this span.
+ true if the specified object is equal to this span; otherwise, false.
+ The object to compare to this span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Determines whether the specified node is equivalent to this span.
+ true if the specified node is equal to this span; otherwise, false.
+ The node to compare with this span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the hash code for this current span.
+ The hash code for this current span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets a value that indicates whether this node is a block node.
+ false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the kind for this span.
+ One of the values of the enumeration.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the length of the span content.
+ The length of the span content.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the next span in the tree node.
+ The next span in the tree node.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the previous span in the tree node.
+ The previous span in the tree node.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Replaces the span builder for this span with the specified span builder.
+ The new builder to use for this span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the start character location of the span.
+ The start character location of the span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the symbols used to generate the code for the span.
+ The symbols used to generate the code for the span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the string representation of this current span.
+ The string representation of this current span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the span builder for the syntax tree.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The original span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the given symbol for the span builder.
+ The symbol builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Builds a span builder for this instance.
+ A span builder for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Clears the symbols of the span builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the span code generator.
+ The span code generator.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the span edit handler of the builder.
+ The span edit handler of the builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the span kind of the span builder.
+ The span kind of the span builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Resets the span builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the source location of the span builder.
+ The source location of the span builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the symbols for a generic read-only collection.
+ The symbols for a generic read-only collection.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the node for the syntax tree.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the visitor of the tree node.
+ The parser visitor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates whether the syntax tree node is equivalent to given node.
+ true the syntax tree node is equivalent to given node; false.
+ The given node.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether the syntax tree node is a block-level object.
+ true if the syntax tree node is a block-level object; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the length of the syntax tree node.
+ The length of the syntax tree node.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the parent tree node of the current tree node.
+ The parent tree node of the current tree node.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the specific source location for the syntax tree node.
+ The specific source location for the syntax tree node.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Provides a lookahead buffer for the text reader.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The text reader for the buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Begins the lookahead buffering operation for this .
+ A disposable action that ends the lookahead buffering.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Discards the backtrack context associated the lookahead buffering operation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets the current character in the buffer.
+ The current character in the buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Gets or sets the current location of the character in the buffer.
+ The current location of the character in the buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Releases the unmanaged resources used by the current instance of this class, and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Reads the next character from the text reader and appends it to the lookahead buffer.
+ true if a character was read from the text reader; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Advances the buffer position to the next character.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the current character in the buffer.
+ The current character in the buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Returns the current character from the buffer and advances the buffer position to the next character.
+ The current character from the buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a location tagged.
+ The type of the location tagged.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The value of the source.
+ The offset.
+ The line.
+ The column location of the source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The value of the source.
+ The location of the source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for the current instance.
+ The hash code for the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the location of the source.
+ The location of the source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two object are equal.
+ true if the two object are equal; otherwise, false.
+ The first object to compare.
+ The second object to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Converts the specified value to a object.
+ true if successfully converted; otherwise, false.
+ The value to convert.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two object are not equal.
+ true if the two object are not equal; otherwise, false.
+ The first object to compare.
+ The second objet to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of the current instance.
+ The string that represents the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of the current instance.
+ A string that represents the current instance.
+ The format.
+ The format provider.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the value of the source.
+ The value of the source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the token to look for the razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The action to cancel.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the token.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Releases the resources used by the current instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Releases the unmanaged resources used by the and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a reader
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The source reader.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The string content.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The text buffering.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the length of the text to read.
+ The length of the text to read.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the source of location for the text reader.
+ The source of location for the text reader.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Reads the next character without changing the state of the reader or the character source.
+ An integer representing the next character to be read.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the position to seek the text reader.
+ The position to seek the text reader.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Reads the next character from the text reader and advances the character position by one character.
+ The next character from the text reader, or -1 if no more characters are available.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The absolute index.
+ The line index.
+ The character index.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the absolute index for the source location.
+ The absolute index for the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Adds the two object.
+ The sum of the two object.
+ The first object to add.
+ The second object to add.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Advances the specified object to the given location.
+ The source location.
+ The location where to advance the object.
+ The text that advances to the given location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the character index for the source location.
+ The character index for the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Compares current object to the other object.
+ The value of the objects compared.
+ The object to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the current object is equal to the other object.
+ true if the current object is equal to the other object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this instance.
+ The hash code for this instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the line index for the source location.
+ The line index for the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Adds the two object.
+ The that is the sum of the two object.
+ The object to add.
+ The object to add.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two objects are equal.
+ true if the two objects are equal; otherwise, false.
+ The first object to compare.
+ The second object to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the first object is greater than the second object.
+ true if the first object is greater than the second object; otherwise, false.
+ The first object.
+ The second object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two object are not equal.
+ true if the two objects are not equal; otherwise, false.
+ The object to compare.
+ The object to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the first object is less than the second object.
+ true if the first object is greater than the second object; otherwise, false.
+ The first object.
+ The second object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ Returns .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Subtracts the first object to the second object.
+ The difference of the two objects.
+ The first object.
+ The second object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of the source location.
+ A string representation of the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Provides a source location tracker.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The current location of the source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Calculates the new location of the source.
+ The new source location.
+ The last position.
+ The new content.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the current location of the source.
+ The current location of the source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Updates the source location.
+ The character to read.
+ The character to update.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Updates the location of the source.
+ The object.
+ The content of the source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Provides a reader for text buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The text buffer to read.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Begins reading the current text buffer.
+ An instance that stops the text buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Cancels backtrack.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the current location of the text buffer.
+ The current location of the text buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Releases the unmanaged resources used by the class and optionally releases the managed resources.
+ true to release both managed and unmanaged resources; false to release only unmanaged resources.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the next text buffer to read.
+ The next text buffer to read.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Reads the current text buffer.
+ The current text buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Describes a text change operation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The position of the text change in the snapshot immediately before the change.
+ The length of the old text.
+ An old text buffer.
+ The position of the text change in the snapshot immediately after the change.
+ The length of the new text.
+ A new text buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Applies the specified text change.
+ A string that contains the value of the text.
+ The content of the text.
+ The change offset.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Applies the specified text change.
+ A string that contains the value of the text.
+ The span of the text change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the hash code for this text change.
+ The hash code for this text change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether this text change is a delete.
+ true if this text change is a delete; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether this text change is an insert.
+ true if this text change is an insert; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether this text change is a replace.
+ true if this text change is a replace; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a new text buffer.
+ A new text buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the length of the new text.
+ The length of the new text.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the position of the text change in the snapshot immediately after the change.
+ The position of the text change in the snapshot immediately after the change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the text that replaced the old text.
+ The text that replaced the old text.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a normalized value of this text change.
+ A normalized value of this text change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets an old text buffer.
+ An old text buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the length of the old text.
+ The length of the old text.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the position of the text change in the snapshot immediately before the change.
+ The position of the text change in the snapshot immediately before the change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the text that was replaced.
+ The text that was replaced.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two text change are equal.
+ true if the two text change are equal; otherwise, false.
+ The left text change.
+ The right text change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two text change are not equal.
+ true if the two text change are not equal; otherwise, false.
+ The left text change.
+ The right text change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of the text change.
+ A string representation of the text change.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Provides reader for text document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The source to read.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the length of the document.
+ The length of the document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the location of the document.
+ The location of the document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the next text document to read.
+ The next text document to read.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the position of the text document.
+ The position of the text document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Reads a specified text document.
+ The text document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Provides helper functions for the CSharp tokenizer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified character can be used for identifier.
+ true if the specified character can be used for identifier; otherwise, false.
+ The character to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified character can be used as an identifier start character.
+ true if the specified character can be used as an identifier start character; otherwise, false.
+ The character to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified character is a literal suffix for real numbers.
+ true if the specified character is a literal suffix for real numbers; otherwise, false.
+ The character to check.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a CSharp tokenizer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a CSharp tokenizer symbol.
+ A CSharp tokenizer symbol.
+ The beginning of the source location.
+ The contents.
+ The CSharp symbol type.
+ A collection of razor errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the star type of the .
+ The star type of the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the razor comment transition type for the .
+ The razor comment transition type for the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the razor comment type for the .
+ The razor comment type for the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the state of the machine.
+ The state of the machine.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the html tokenizer of the razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The source for the text document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a symbol for the specified parameters of the html tokenizer.
+ A symbol to create for the specified parameters of the html tokenizer.
+ The source location.
+ The content string.
+ The type of html symbol.
+ The razor errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the html symbols for the razor comment star type.
+ The html symbols for the razor comment star type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the html symbols for the razor comment transition type.
+ The html symbols for the razor comment transition type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the html symbols for the razor comment type.
+ The html symbols for the razor comment type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the start of the state machine for the html.
+ The start of the state machine for the html.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The type for the language symbol.
+ The enumeration type for the language symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a result after the razor comment transition.
+ The result.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the lookahead buffer contains the expected string.
+ true if the lookahead buffer contains the expected string; otherwise, false.
+ The string to check.
+ true to indicate comparison is case sensitive; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the buffer for the tokenizer.
+ The buffer for the tokenizer.
+
+
+ Returns a function delegate, that accepts a character parameter and returns a value that indicates whether the character parameter is equal to specified character or white space.
+ A function delegate.
+ The character used to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a language symbol type for the tokenizer with the specified content.
+ A language symbol type for the tokenizer.
+ The start of the source location.
+ The content value.
+ The symbol type.
+ The razor error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the current character in the tokenizer.
+ The current character.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a list of the current razor errors.
+ A list of the current errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the current source location.
+ The current source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the current start of the source location.
+ The current start of the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value whether the tokenizer current location is at the end of the file.
+ true if the tokenizer current location is at the end of the file; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the language end symbol type used by the tokenizer.
+ The language end symbol type.
+ The start of the source location.
+ The enumeration type for the language symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the language end symbol type used by the tokenizer.
+ The language end symbol type.
+ The enumeration type for the language symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value whether the tokenizer have content.
+ true if the tokenizer have content; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Reads to the next character from the code reader.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Shows the next symbol to be used.
+ The next symbol to be used.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Reads the next symbol in the code.
+ The next symbol to read.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Parses the Razor comment body.
+ The object that represent the state of the result.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the star type for the razor comment.
+ The star type for the razor comment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the transition type for the razor comment.
+ The transition type for the razor comment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the type of razor comment.
+ The type of razor comment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Sets the tokenizer status to its initial state.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Resumes using the previous language symbol type.
+ The previous language symbol type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Uses a single type of symbol.
+ A single type of symbol.
+ The type of symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the source of the text document.
+ The source of the source document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the start symbol used in this class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the next language symbol type.
+ The next language symbol type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Takes the string if found in the lookahead buffer into the tokenizer buffer.
+ true if the lookahead buffer contains the expected string; otherwise, false.
+ The string to match.
+ true to indicate comparison is case sensitive; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the current character into the buffer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Accepts the given input string into the buffer.
+ true if the whole input string was accepted; false, if only a substring was accepted.
+ The input string.
+ true to indicate comparison is case sensitive; otherwise, false.
+
+
+ Parses the source document until the condition specified by predicate is met or end file is reached.
+ true if the predicate condition is met; false if end of file is reached.
+ The predicate that specifies the processing condition.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the specified parameters for the tokenizer view.
+ The type tokenizer.
+ The type symbol.
+ The token symbol type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The tokenizer view.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the current view of the TSymbol.
+ The current view of the TSymbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether the view can reach the end of a file.
+ true if the view can reach the end of a file; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the tokenizer moves to the next view.
+ true if the tokenizer moves to the next view; false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Puts a specified symbol into the tokenizer view.
+ The symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the source of the text document for the tokenizer view.
+ The source of the text document for the tokenizer view.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the tokenizer to view the symbols for the razor.
+ The tokenizer to view the symbols for the razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a set of characters as helpers in VB.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a value whether a specified character is enclosed in double quotation marks (").
+ true if the character is enclosed in double quotation marks ("); otherwise, false.
+ The character.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a value whether a character is in octal digit.
+ true if a character is in octal digit; otherwise, false.
+ The character.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a value whether a specified character is enclosed in a single quotation mark (').
+ true if the character is enclosed in a single quotation mark ('); otherwise, false.
+ The character.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Allows an application to break a VB symbol into tokens.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The source of text.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a domain of symbols.
+ A domain of symbols.
+ The source location.
+ The content value.
+ The .
+ The razor error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the VB symbol type.
+ The VB symbol type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the transition style of the VB symbol.
+ The transition style of the VB symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the razor type comment of the .
+ The razor type comment of the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the start state of the machine.
+ The start state of the machine.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a C sharp symbol for the razor tokenizer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The symbol’s offset.
+ The line.
+ The column
+ The content of the symbol.
+ The type of the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The symbol’s offset.
+ The line.
+ The column
+ The content of the symbol.
+ The type of the symbol.
+ A list of errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The location to start the symbol.
+ The content of the symbol.
+ The type of the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The location to start the symbol.
+ The content of the symbol.
+ The type of the symbol.
+ A list of errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value that indicates whether the symbol has an escaped identifier.
+ true if the symbol has an escaped identifier; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this current instance.
+ The hash code for this current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the language keyword.
+ The language keyword.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the Html symbols.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The location of the symbol.
+ The exact line the symbol is found.
+ The column number the symbol is found.
+ The content value.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The location of the symbol.
+ The exact line the symbol is found.
+ The column number the symbol is found.
+ The content value.
+ The .
+ The razor error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The start of the source location.
+ The content value.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The start of the source location.
+ The content value.
+ The .
+ The razor error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents an interface for the web razor symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Changes the location of the symbol.
+ The new location of the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the content of the symbol.
+ The content of the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the starting offset of the symbol.
+ The location where to start the document.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the location of the symbol.
+ The location of the symbol.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a new instance of symbols.
+ The generic type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The source location.
+ The content value.
+ The type.
+ The razor error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Changes the start of the machine.
+ The new start.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the content of a .
+ The content of a .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified Object is equal to the current Object.
+ true if the specified Object is equal to the current Object; otherwise, false.
+ The object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the razor error.
+ The razor error.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Retrieves a hash code based on the current object.
+ A hash of the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Starts the time’s offset for the source location.
+ The document start.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the starting point of the source location.
+ The starting point of the source location.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates a string representation of the current object.
+ A string representation of the current object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a Type that inherits from the base Type.
+ A Type that inherits from the base Type.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the symbol extensions for the web tokenizer.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the content of this class.
+ The content of this class.
+ The symbols to provide.
+ The starting index of the span.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the content of this class.
+ The content of this class.
+ The intersection with the given span.
+
+
+ Gets the content of this class.
+ The content of this class.
+ The intersection with the given span.
+ A list of chosen symbols.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the content of this class.
+ The content of this class.
+ The provided symbols.
+
+
+ Enumerates the list of Visual Basic keywords.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the VB symbol components.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The offset value.
+ The line value.
+ The column value.
+ The content String value.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The offset value.
+ The line value.
+ The column value.
+ The content String value.
+ The .
+ List of razor errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The start of the source location.
+ The content String value.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The start of the source location.
+ The content String value.
+ The .
+ List of razor errors.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a value whether the current object is equal to the new object.
+ true if the current object is equal to the new object; otherwise, false.
+ The object to compare.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the hash code for this instance.
+ The hash code to return.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the specified data sample from the object.
+ The specified data sample from the object.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the keyword used in the VB.
+ The keyword used.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Deployment.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Deployment.dll
new file mode 100644
index 000000000..d904d0f13
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Deployment.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Deployment.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Deployment.xml
new file mode 100644
index 000000000..7dc960bc0
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Deployment.xml
@@ -0,0 +1,60 @@
+
+
+
+ System.Web.WebPages.Deployment
+
+
+
+ Provides a registration point for pre-application start code for Web Pages deployment.
+
+
+ Registers pre-application start code for Web Pages deployment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Provides methods that are used to get deployment information about the Web application.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the assembly path for the Web Pages deployment.
+ The assembly path for the Web Pages deployment.
+ The Web Pages version.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the Web Pages version from the given binary path.
+ The Web Pages version.
+ The binary path for the Web Pages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the assembly references from the given path regardless of the Web Pages version.
+ The dictionary containing the assembly references of the Web Pages and its version.
+ The path to the Web Pages application.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the maximum version of the Web Pages loaded assemblies.
+ The maximum version of the Web Pages loaded assemblies.
+
+
+ Gets the Web Pages version from the given path.
+ The Web Pages version.
+ The path of the root directory for the application.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the Web Pages version using the configuration settings with the specified path.
+ The Web Pages version.
+ The path to the application settings.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the assemblies for this Web Pages deployment.
+ A list containing the assemblies for this Web Pages deployment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates whether the Web Pages deployment is enabled.
+ true if the Web Pages deployment is enabled; otherwise, false.
+ The path to the Web Pages deployment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates whether the Web Pages deployment is explicitly disabled.
+ true if the Web Pages deployment is explicitly disabled; otherwise, false.
+ The path to the Web Pages deployment.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Razor.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Razor.dll
new file mode 100644
index 000000000..711c6ff61
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Razor.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Razor.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Razor.xml
new file mode 100644
index 000000000..bf6455588
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.Razor.xml
@@ -0,0 +1,292 @@
+
+
+
+ System.Web.WebPages.Razor
+
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the base class for the compiling path that contains event data.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The string of virtual path.
+ The host for the webpage razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the host for the webpage razor.
+ The host for the webpage razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the virtual path for the webpage.
+ The virtual path for the webpage.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a build provider for Razor.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Adds a virtual path dependency to the collection.
+ A virtual path dependency to add.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the assembly builder for Razor environment.
+ The assembly builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the compiler settings for Razor environment.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Occurs when code generation is completed.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Occurs when code generation is started.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Occurs when compiling with a new virtual path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a Razor engine host instance base on web configuration.
+ A Razor engine host instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Generates the code using the provided assembly builder.
+ The assembly builder.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the type of the generated code.
+ The type of the generated code.
+ The results of the code compilation.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates the Razor engine host instance based on the web configuration.
+ The Razor engine host instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Opens an internal text reader.
+ An internal text reader.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Raises the CompilingPath event.
+ The data provided for the CompilingPath event.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the virtual path of the source code.
+ The virtual path of the source code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the collection of virtual path for the dependencies.
+ The collection of virtual path for the dependencies.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a web code razor host for the web pages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The virtual path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The virtual path.
+ The physical path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns the class name of this instance.
+ The class name of this instance.
+ The virtual path.
+
+
+ Generates a post process code for the web code razor host.
+ The generator code context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the razor hosts in a webpage.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class with the specified virtual file path.
+ The virtual file path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class with the specified virtual and physical file path.
+ The virtual file path.
+ The physical file path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Adds a global import on the webpage.
+ The notification service name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the .
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a markup parser.
+ A markup parser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value for the DefaultBaseClass.
+ A value for the DefaultBaseClass.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the name of the default class.
+ The name of the default class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value that indicates whether the debug compilation is set to default.
+ true if the debug compilation is set to default; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the base class of the default page.
+ The base class of the default page.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Retrieves the name of the class to which the specified webpage belongs.
+ The name of the class to which the specified webpage belongs.
+ The virtual file path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the code language specified in the webpage.
+ The code language specified in the webpage.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the global imports for the webpage.
+ The global imports for the webpage.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the file path of the instrumental source.
+ The file path of the instrumental source.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value that indicates whether the webpage is a special page.
+ true if the webpage is a special page; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the physical file system path of the razor host.
+ They physical file system path of the razor host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the generated code after the process.
+ The .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Registers the special file with the specified file name and base type name.
+ The file name.
+ The base type name.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Registers the special file with the specified file name and base type.
+ The file name.
+ The type of base file.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the virtual file path.
+ The virtual file path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates instances of the host files.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Loads the service description information from the configuration file and applies it to the host.
+ The configuration.
+ The webpage razor host.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a default host with the specified virtual path.
+ A default host.
+ The virtual path of the file.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a default host with the specified virtual and physical path.
+ A default host.
+ The virtual path of the file.
+ The physical file system path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a Razor host.
+ A razor host.
+ The virtual path to the target file.
+ The physical path to the target file.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a host from the configuration.
+ A host from the configuration.
+ The virtual path to the target file.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a host from the configuration.
+ A host from the configuration.
+ The virtual path of the file.
+ The physical file system path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a host from the configuration.
+ A host from the configuration.
+ The configuration.
+ The virtual path of the file.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Creates a host from the configuration.
+ A host from the configuration.
+ The configuration.
+ The virtual path of the file.
+ The physical file system path.
+
+
+ Provides configuration system support for the host configuration section.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the host factory.
+ The host factory.
+
+
+ Represents the name of the configuration section for a Razor host environment.
+
+
+ Provides configuration system support for the pages configuration section.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the collection of namespaces to add to Web Pages pages in the current application.
+ The collection of namespaces.
+
+
+ Gets or sets the name of the page base type class.
+ The name of the page base type class.
+
+
+ Represents the name of the configuration section for Razor pages.
+
+
+ Provides configuration system support for the system.web.webPages.razor configuration section.
+
+
+ Initializes a new instance of the class.
+
+
+ Represents the name of the configuration section for Razor Web section. Contains the static, read-only string "system.web.webPages.razor".
+
+
+ Gets or sets the host value for system.web.webPages.razor section group.
+ The host value.
+
+
+ Gets or sets the value of the pages element for the system.web.webPages.razor section.
+ The pages element value.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.dll b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.dll
new file mode 100644
index 000000000..cdb61e362
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.xml b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.xml
new file mode 100644
index 000000000..84699ef2e
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/System.Web.WebPages.xml
@@ -0,0 +1,2706 @@
+
+
+
+ System.Web.WebPages
+
+
+
+ Helps prevent malicious scripts from submitting forged page requests.
+
+
+ Adds an authenticating token to a form to help protect against request forgery.
+ Returns a string that contains the encrypted token value in a hidden HTML field.
+ The current object is null.
+
+
+ Adds an authenticating token to a form to help protect against request forgery and lets callers specify authentication details.
+ Returns the encrypted token value in a hidden HTML field.
+ The HTTP context data for a request.
+ An optional string of random characters (such as Z*7g1&p4) that is used to add complexity to the encryption for extra safety. The default is null.
+ The domain of a web application that a request is submitted from.
+ The virtual root path of a web application that a request is submitted from.
+
+ is null.
+
+
+ Gets the search tokens.
+ The previous cookie token.
+ The new cookie token.
+ The form of the token.
+
+
+ Validates that input data from an HTML form field comes from the user who submitted the data.
+ The current value is null.
+ The HTTP cookie token that accompanies a valid request is missing-or-The form token is missing.-or-The form token value does not match the cookie token value.-or-The form token value does not match the cookie token value.
+
+
+ Validates that input data from an HTML form field comes from the user who submitted the data.
+ The cookie token value.
+ The token form.
+
+
+ Validates that input data from an HTML form field comes from the user who submitted the data and lets callers specify additional validation details.
+ The HTTP context data for a request.
+ An optional string of random characters (such as Z*7g1&p4) that is used to decrypt an authentication token created by the class. The default is null.
+ The current value is null.
+ The HTTP cookie token that accompanies a valid request is missing.-or-The form token is missing.-or-The form token value does not match the cookie token value.-or-The form token value does not match the cookie token value.-or-The value supplied does not match the value that was used to create the form token.
+
+
+ Provides programmatic configuration for the anti-forgery token system.
+
+
+ Gets a data provider that can provide additional data to put into all generated tokens and that can validate additional data in incoming tokens.
+ The data provider.
+
+
+ Gets or sets the name of the cookie that is used by the anti-forgery system.
+ The cookie name.
+
+
+ Gets or sets a value that indicates whether the anti-forgery cookie requires SSL in order to be returned to the server.
+ true if SSL is required to return the anti-forgery cookie to the server; otherwise, false.
+
+
+ Gets or sets a value that indicates whether the anti-forgery system should skip checking for conditions that might indicate misuse of the system.
+ true if the anti-forgery system should not check for possible misuse; otherwise, false.
+
+
+ Specifies whether to suppress the generation of X-Frame-Options header which is used to prevent ClickJacking. By default, the X-Frame-Options header is generated with the value SAMEORIGIN. If this setting is 'true', the X-Frame-Options header will not be generated for the response.
+
+
+ If claims-based authorization is in use, gets or sets the claim type from the identity that is used to uniquely identify the user.
+ The claim type.
+
+
+ Provides a way to include or validate custom data for anti-forgery tokens.
+
+
+ Provides additional data to store for the anti-forgery tokens that are generated during this request.
+ The supplemental data to embed in the anti-forgery token.
+ Information about the current request.
+
+
+ Validates additional data that was embedded inside an incoming anti-forgery token.
+ true if the data is valid, or false if the data is invalid.
+ Information about the current request.
+ The supplemental data that was embedded in the token.
+
+
+ Provides access to unvalidated form values in the object.
+
+
+ Gets a collection of unvalidated form values that were posted from the browser.
+ An unvalidated collection of form values.
+
+
+ Gets the specified unvalidated object from the collection of posted values in the object.
+ The specified member, or null if the specified item is not found.
+
+
+ Gets a collection of unvalidated query-string values.
+ A collection of unvalidated query-string values.
+
+
+ Excludes fields of the Request object from being checked for potentially unsafe HTML markup and client script.
+
+
+ Returns a version of form values, cookies, and query-string variables without checking them first for HTML markup and client script.
+ An object that contains unvalidated versions of the form and query-string values.
+ The object that contains values to exclude from request validation.
+
+
+ Returns a value from the specified form field, cookie, or query-string variable without checking it first for HTML markup and client script.
+ A string that contains unvalidated text from the specified field, cookie, or query-string value.
+ The object that contains values to exclude from validation.
+ The name of the field to exclude from validation. can refer to a form field, to a cookie, or to the query-string variable.
+
+
+ Returns all values from the Request object (including form fields, cookies, and the query string) without checking them first for HTML markup and client script.
+ An object that contains unvalidated versions of the form, cookie, and query-string values.
+ The object that contains values to exclude from validation.
+
+
+ Returns the specified value from the Request object without checking it first for HTML markup and client script.
+ A string that contains unvalidated text from the specified field, cookie, or query-string value.
+ The object that contains values to exclude from validation.
+ The name of the field to exclude from validation. can refer to a form field, to a cookie, or to the query-string variable.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The containing message.
+
+
+ This member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The message.
+ The inner exception.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The error message.
+ The other.
+
+
+
+
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The error message.
+ The minimum value.
+ The maximum value.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code. Initializes a new instance of the class.
+ The exception message.
+ The pattern.
+
+
+ Represents the remote rule for the validation of the model client.
+
+
+ Initializes a new instance of the class.
+ The error message.
+ The URL of the rule.
+ The HTTP method.
+ The additional fields used.
+
+
+ Represents the required rule for the validation of the model client.
+
+
+ Initializes a new instance of the class.
+ The error message
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a length of the validation rule of the model client.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The error message.
+ The minimum length of the validation rule.
+ The maximum length of the validation rule.
+
+
+ Contains classes and properties that are used to create HTML elements. This class is used to write helpers, such as those found in the namespace.
+
+
+ Creates a new tag that has the specified tag name.
+ The tag name without the "<", "/", or ">" delimiters.
+
+ is null or empty.
+
+
+ Adds a CSS class to the list of CSS classes in the tag.
+ The CSS class to add.
+
+
+ Gets the collection of attributes.
+ The collection of attributes.
+
+
+ Replaces each invalid character in the tag ID with a valid HTML character.
+ The sanitized tag ID, or null if is null or empty, or if does not begin with a letter.
+ The ID that might contain characters to replace.
+
+
+ Replaces each invalid character in the tag ID with the specified replacement string.
+ The sanitized tag ID, or null if is null or empty, or if does not begin with a letter.
+ The ID that might contain characters to replace.
+ The replacement string.
+
+ is null.
+
+
+ Generates a sanitized ID attribute for the tag by using the specified name.
+ The name to use to generate an ID attribute.
+
+
+ Gets or sets a string that can be used to replace invalid HTML characters.
+ The string to use to replace invalid HTML characters.
+
+
+ Gets or sets the inner HTML value for the element.
+ The inner HTML value for the element.
+
+
+ Adds a new attribute to the tag.
+ The key for the attribute.
+ The value of the attribute.
+
+
+ Adds a new attribute or optionally replaces an existing attribute in the opening tag.
+ The key for the attribute.
+ The value of the attribute.
+ true to replace an existing attribute if an attribute exists that has the specified value, or false to leave the original attribute unchanged.
+
+
+ Adds new attributes to the tag.
+ The collection of attributes to add.
+ The type of the key object.
+ The type of the value object.
+
+
+ Adds new attributes or optionally replaces existing attributes in the tag.
+ The collection of attributes to add or replace.
+ For each attribute in , true to replace the attribute if an attribute already exists that has the same key, or false to leave the original attribute unchanged.
+ The type of the key object.
+ The type of the value object.
+
+
+ Sets the property of the element to an HTML-encoded version of the specified string.
+ The string to HTML-encode.
+
+
+ Gets the tag name for this tag.
+ The name.
+
+
+ Renders the element as a element.
+
+
+ Renders the HTML tag by using the specified render mode.
+ The rendered HTML tag.
+ The render mode.
+
+
+ Enumerates the modes that are available for rendering HTML tags.
+
+
+ Represents the mode for rendering a closing tag (for example, </tag>).
+
+
+ Represents the mode for rendering normal text.
+
+
+ Represents the mode for rendering a self-closing tag (for example, <tag />).
+
+
+ Represents the mode for rendering an opening tag (for example, <tag>).
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the validation attributes from the structure or content of .
+ The to be implemented.
+ The result of the validation.
+
+
+ Contains methods to register assemblies as application parts.
+
+
+ Initializes a new instance of the class by using the specified assembly and root virtual path.
+ The assembly.
+ The root virtual path.
+
+ is null or empty.
+
+
+ Resolves a path to the specified assembly or resource within an assembly by using the specified base virtual path and specified virtual path.
+ The path of the assembly or resource.
+ The assembly.
+ The base virtual path.
+ The virtual path.
+
+ is not registered.
+
+
+ Adds an assembly and all web pages within the assembly to the list of available application parts.
+ The application part.
+
+ is already registered.
+
+
+ Provides objects and methods that are used to execute and render ASP.NET Web Pages application start pages (_AppStart.cshtml or _AppStart.vbhtml files).
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the HTTP application object that references this application startup page.
+ The HTTP application object that references this application startup page.
+
+
+ The prefix that is applied to all keys that are added to the cache by the application start page.
+
+
+ Gets the object that represents context data that is associated with this page.
+ The current context data.
+
+
+ Returns the text writer instance that is used to render the page.
+ The text writer.
+
+
+ Gets the output from the application start page as an HTML-encoded string.
+ The output from the application start page as an HTML-encoded string.
+
+
+ Gets the text writer for the page.
+ The text writer for the page.
+
+
+ The path to the application start page.
+
+
+ Gets or sets the virtual path of the page.
+ The virtual path.
+
+
+ Writes the string representation of the specified object as an HTML-encoded string.
+ The object to encode and write.
+
+
+ Writes the specified object as an HTML-encoded string.
+ The helper result to encode and write.
+
+
+ Writes the specified object without HTML encoding.
+ The object to write.
+
+
+ Stores the value for an attribute.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ Initializes a new instance of the class.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The namespace prefix for the attribute.
+ The value for the attribute.
+ true to indicate that the value is a literal value; otherwise, false.
+
+
+ Creates an attribute value from the specified tuple object.
+ The created attribute value.
+ The tuple object from which to create from.
+
+
+ Creates an attribute value from the specified tuple object.
+ The created attribute value.
+ The tuple object from which to create from.
+
+
+ Gets or sets a value that indicates whether the value is a literal value.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ true if the value is a literal value; otherwise, false.
+
+
+ Creates an attribute value from the specified tuple object.
+ The created attribute value.
+ The tuple object from which to create from.
+
+
+ Creates an attribute value from the specified tuple object.
+ The created attribute value.
+ The tuple object from which to create from.
+
+
+ Gets or sets the namespace prefix for the attribute.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The namespace prefix for the attribute.
+
+
+ Gets or set the value for the attribute.This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The value for the attribute.
+
+
+ Provides a way to specify custom browser (user agent) information.
+
+
+ Removes any overridden user agent for the current request.
+ The current context.
+
+
+ Returns the browser capabilities object for the overridden browser capabilities or for the actual browser if no override has been specified.
+ The browser capabilities.
+ The current context.
+
+
+ Returns the overridden user agent value or the actual user agent string if no override has been specified.
+ The user agent string
+ The current context.
+
+
+ Gets a string that varies based on the type of the browser.
+ A string that identifies the browser.
+ The current context.
+
+
+ Gets a string that varies based on the type of the browser.
+ A string that identifies the browser.
+ The current context base.
+
+
+ Overrides the request's actual user agent value using the specified user agent.
+ The current context.
+ The user agent to use.
+
+
+ Overrides the request's actual user agent value using the specified browser override information.
+ The current context.
+ One of the enumeration values that represents the browser override information to use.
+
+
+ Specifies browser types that can be defined for the method.
+
+
+ Specifies a desktop browser.
+
+
+ Specifies a mobile browser.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.The current BrowserOverrideStore is used to get and set the user agent of a request.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Looks for a user agent by searching for the browser override cookie.
+ The user agent.
+ The HTTP context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Adds a browser override cookie with the set user agent to the response of the current request.
+ The HTTP context.
+ The user agent.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets overridden user agent for a request from a cookie. Creates a cookie to set the overridden user agent.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The days to expire.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Looks for a user agent by searching for the browser override cookie.
+ The user agent.
+ The HTTP context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Adds a browser override cookie with the set user agent to the response of the current request.
+ The HTTP context.
+ The user agent.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the default display mode of the web pages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The suffix.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a value whether the can handle context.
+ true if the can handle context; otherwise, false.
+ The specified http context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value that indicates whether the context condition displays a default mode.
+ true if the context condition displays a default mode; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the display mode identifier of the web pages.
+ The display mode identifier of the web pages.
+
+
+ Retrieves the display information about an item in the result pane.
+ The display information about an item in the result pane.
+ The http context.
+ The virtual path.
+ true if the virtual path exists; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Transforms the path of the display mode.
+ The path of the display mode to transform.
+ The virtual path.
+ The suffix.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a property’s display information.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The virtual path.
+ The active display mode.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the active display mode for a Web page.
+ The active display mode for a Web page.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the virtual path of the current Web page.
+ The virtual path of the current Web page.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the modes of display for the provider.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Defines the default display mode identifier.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a list of the available display modes for the context base.
+ A list of the available display modes for the context base.
+ The http context base.
+ The current display mode.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the for the virtual path.
+ The for the virtual path.
+ The virtual path.
+ The http context base.
+ true if the virtual path exists; otherwise, false.
+ The current display mode.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the instance of the .
+ The instance of the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Defines the mobile display mode identifier.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a list of modes of the .
+ A list of modes of the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets a value that indicates whether the Web page requires consistent display mode.
+ true if the Web page requires consistent display mode; otherwise, false.
+
+
+ Represents a base class for pages that is used when ASP.NET compiles a .cshtml or .vbhtml file and that exposes page-level and application-level properties and methods.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ Gets the application-state data as a object that callers can use to create and access custom application-scoped properties.
+ The application-state data.
+
+
+ Gets a reference to global application-state data that can be shared across sessions and requests in an ASP.NET application.
+ The application-state data.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Puts all the helper statements into the context of the helper page.
+ The text writer.
+ The helper virtual path.
+ The starting position.
+ The length of the context.
+ true of the context has a literal attribute; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Puts all the helper statements into the context of the helper page.
+ The helper virtual path.
+ The starting position.
+ The length of the context.
+ true of the context has a literal attribute; otherwise, false.
+
+
+ Gets the cache object for the current application domain.
+ The cache object.
+
+
+ Gets the object that is associated with a page.
+ The current context data.
+
+
+ Gets the current page for this helper page.
+ The current page.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the end of context block.
+ The text writer.
+ The helper virtual path.
+ The starting position.
+ The length of the context.
+ true of the context has a literal attribute; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates the end of context block.
+ The helper virtual path.
+ The starting position.
+ The length of the context.
+ true of the context has a literal attribute; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the path of the helper page.
+ The path of the helper page.
+
+
+ Builds an absolute URL from an application-relative URL by using the specified parameters.
+ The absolute URL.
+ The initial path to use in the URL.
+ Additional path information, such as folders and subfolders.
+
+
+ Gets the object that is associated with a page.
+ An object that supports rendering HTML form controls in a page.
+
+
+ Gets a value that indicates whether Ajax is being used during the request of the web page.
+ true if Ajax is being used during the request; otherwise, false.
+
+
+ Gets a value that indicates whether the current request is a post (submitted using the HTTP POST verb).
+ true if the HTTP verb is POST; otherwise, false.
+
+
+ Gets the model that is associated with a page.
+ An object that represents a model that is associated with the view data for a page.
+
+
+ Gets the state data for the model that is associated with a page.
+ The state of the model.
+
+
+ Gets property-like access to page data that is shared between pages, layout pages, and partial pages.
+ An object that contains page data.
+
+
+ Gets and sets the HTTP context for the web page.
+ The HTTP context for the web page.
+
+
+ Gets array-like access to page data that is shared between pages, layout pages, and partial pages.
+ An object that provides array-like access to page data.
+
+
+ Gets the object for the current HTTP request.
+ An object that contains the HTTP values that were sent by a client during a web request.
+
+
+ Gets the object for the current HTTP response.
+ An object that contains the HTTP-response information from an ASP.NET operation.
+
+
+ Gets the object that provides methods that can be used as part of web-page processing.
+ The object.
+
+
+ Gets the object for the current HTTP request.
+ The object for the current HTTP request.
+
+
+ Gets data related to the URL path.
+ Data related to the URL path.
+
+
+ Gets a user value based on the HTTP context.
+ A user value based on the HTTP context.
+
+
+ Gets the virtual path of the page.
+ The virtual path.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Writes an attribute associated with the helper.
+ The text writer.
+ The name of the attribute.
+ The prefix.
+ The suffix.
+ The attribute value.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Writes a literal object to the helper.
+ The text writer.
+ The value of the object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Writes a helper result object to the helper.
+ The text writer
+ The helper result.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Writes an object to the helper.
+ The text writer.
+ The object value.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Writes a helper result object to the helper.
+ The text writer.
+ The helper result value.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code..
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents the display mode interface for the web pages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Indicates a value whether the web pages can handle HTTP context.
+ true if the web pages can handle HTTP context; otherwise, false.
+ The HTTP context.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the display mode id for the web pages.
+ The display mode id for the web pages.
+
+
+ Returns this method to display all the information for the web pages.
+ The method to display all the information for the web pages.
+ The HTTP context.
+ The virtual path.
+ true if the virtual path exists; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Defines the properties and methods that objects that participate in webpages.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a container for client validation for the required field.
+ A container for client validation for the required field.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Evaluates the condition it checks and updates the validation context.
+ The condition it checks and updates the validation context.
+ The validation context.
+
+
+ Defines methods that are implemented by virtual path handler factories.
+
+
+ Creates a handler factory for the specified virtual path.
+ A handler factory for the specified virtual path.
+ The virtual path.
+
+
+ Determines whether the specified virtual path is associated with a handler factory.
+ true if a handler factory exists for the specified virtual path; otherwise, false.
+ The virtual path.
+
+
+ Defines methods to implement an executor class that can execute the code on a web page.
+
+
+ Executes the code on the specified web page.
+ true if the executor took over execution of the web page; otherwise, false.
+ The web page.
+
+
+ Represents a path attribute for a web page class.
+
+
+ Initializes a new instance of the class by using the specified virtual path.
+ The virtual path.
+
+
+ Gets the virtual path of the current web page.
+ The virtual path.
+
+
+ Provides a registration point for pre-application start code for web pages.
+
+
+ Registers pre-application start code for web pages.
+
+
+ Defines extension methods for the class.
+
+
+ Determines whether the specified URL references the local computer.
+ true if the specified URL references the local computer; otherwise, false.
+ The HTTP request object.
+ The URL to test.
+
+
+ Serves as the abstract base class for the validation helper classes.
+
+
+ Initializes a new instance of the derived class and specifies the name of the HTML element that is being validated.
+ The name (value of the name attribute) of the user input element to validate.
+
+
+ Initializes a new instance of the derived class, registers the specified string as the error message to display if no value is supplied, and specifies whether the method can use unvalidated data.
+ The error message.
+ true to use unvalidated user input; false to reject unvalidated data. This parameter is set to true by calling methods in circumstances when the actual value of the user input is not important, such as for required fields.
+
+
+ When implemented in a derived class, gets a container for client validation for the required field.
+ The container.
+
+
+ Returns the HTTP context of the current request.
+ The context.
+ The validation context.
+
+
+ Returns the value to validate.
+ The value to validate.
+ The current request.
+ The name of the field from the current request to validate.
+
+
+ Returns a value that indicates whether the specified value is valid.
+ true if the value is valid; otherwise, false.
+ The current context.
+ The value to validate.
+
+
+ Performs the validation test.
+ The result of the validation test.
+ The context.
+
+
+ Defines extension methods for the base class.
+
+
+ Configures the cache policy of an HTTP response instance.
+ The HTTP response instance.
+ The length of time, in seconds, before items expire from the cache.
+ true to indicate that items expire from the cache on a sliding basis; false to indicate that items expire when they reach the predefined expiration time.
+ The list of all parameters that can be received by a GET or POST operation that affect caching.
+ The list of all HTTP headers that affect caching.
+ The list of all Content-Encoding headers that affect caching.
+ One of the enumeration values that specifies how items are cached.
+
+
+ Sets the HTTP status code of an HTTP response using the specified integer value.
+ The HTTP response instance.
+ The HTTP status code.
+
+
+ Sets the HTTP status code of an HTTP response using the specified HTTP status code enumeration value.
+ The HTTP response instance.
+ The HTTP status code
+
+
+ Writes a sequence of bytes that represent binary content of an unspecified type to the output stream of an HTTP response.
+ The HTTP response instance.
+ An array that contains the bytes to write.
+
+
+ Writes a sequence of bytes that represent binary content of the specified MIME type to the output stream of an HTTP response.
+ The receiving HTTP response instance.
+ An array that contains the bytes to write.
+ The MIME type of the binary content.
+
+
+ Provides a delegate that represents one or more methods that are called when a content section is written.
+
+
+ Provides methods and properties that are used to render start pages that use the Razor view engine.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets the child page of the current start page.
+ The child page of the current start page.
+
+
+ Gets or sets the context of the page.
+ The context of the page.
+
+
+ Calls the methods that are used to execute the developer-written code in the _PageStart start page and in the page.
+
+
+ Returns the text writer instance that is used to render the page.
+ The text writer.
+
+
+ Returns the initialization page for the specified page.
+ The _AppStart page if the _AppStart page exists. If the _AppStart page cannot be found, returns the _PageStart page if a _PageStart page exists. If the _AppStart and _PageStart pages cannot be found, returns .
+ The page.
+ The file name of the page.
+ The collection of file-name extensions that can contain ASP.NET Razor syntax, such as "cshtml" and "vbhtml".
+ Either or are null.
+
+ is null or empty.
+
+
+ Gets or sets the path of the layout page for the page.
+ The path of the layout page for the page.
+
+
+ Gets property-like access to page data that is shared between pages, layout pages, and partial pages.
+ An object that contains page data.
+
+
+ Gets array-like access to page data that is shared between pages, layout pages, and partial pages.
+ An object that provides array-like access to page data.
+
+
+ Renders the page.
+ The HTML markup that represents the web page.
+ The path of the page to render.
+ Additional data that is used to render the page.
+
+
+ Executes the developer-written code in the page.
+
+
+ Writes the string representation of the specified object as an HTML-encoded string.
+ The object to encode and write.
+
+
+ Writes the string representation of the specified object as an HTML-encoded string.
+ The helper result to encode and write.
+
+
+ Writes the string representation of the specified object without HTML encoding.
+ The object to write.
+
+
+ Provides utility methods for converting string values to other data types.
+
+
+ Converts a string to a strongly typed value of the specified data type.
+ The converted value.
+ The value to convert.
+ The data type to convert to.
+
+
+ Converts a string to the specified data type and specifies a default value.
+ The converted value.
+ The value to convert.
+ The value to return if is null.
+ The data type to convert to.
+
+
+ Converts a string to a Boolean (true/false) value.
+ The converted value.
+ The value to convert.
+
+
+ Converts a string to a Boolean (true/false) value and specifies a default value.
+ The converted value.
+ The value to convert.
+ The value to return if is null or is an invalid value.
+
+
+ Converts a string to a value.
+ The converted value.
+ The value to convert.
+
+
+ Converts a string to a value and specifies a default value.
+ The converted value.
+ The value to convert.
+ The value to return if is null or is an invalid value. The default is the minimum time value on the system.
+
+
+ Converts a string to a number.
+ The converted value.
+ The value to convert.
+
+
+ Converts a string to a number and specifies a default value.
+ The converted value.
+ The value to convert.
+ The value to return if is null or invalid.
+
+
+ Converts a string to a number.
+ The converted value.
+ The value to convert.
+
+
+ Converts a string to a number and specifies a default value.
+ The converted value.
+ The value to convert.
+ The value to return if is null.
+
+
+ Converts a string to an integer.
+ The converted value.
+ The value to convert.
+
+
+ Converts a string to an integer and specifies a default value.
+ The converted value.
+ The value to convert.
+ The value to return if is null or is an invalid value.
+
+
+ Checks whether a string can be converted to the specified data type.
+ true if can be converted to the specified type; otherwise, false.
+ The value to test.
+ The data type to convert to.
+
+
+ Checks whether a string can be converted to the Boolean (true/false) type.
+ true if can be converted to the specified type; otherwise, false.
+ The string value to test.
+
+
+ Checks whether a string can be converted to the type.
+ true if can be converted to the specified type; otherwise, false.
+ The string value to test.
+
+
+ Checks whether a string can be converted to the type.
+ true if can be converted to the specified type; otherwise, false.
+ The string value to test.
+
+
+ Checks whether a string value is null or empty.
+ true if is null or is a zero-length string (""); otherwise, false.
+ The string value to test.
+
+
+ Checks whether a string can be converted to the type.
+ true if can be converted to the specified type; otherwise, false.
+ The string value to test.
+
+
+ Checks whether a string can be converted to an integer.
+ true if can be converted to the specified type; otherwise, false.
+ The string value to test.
+
+
+ Contains methods and properties that describe a file information template.
+
+
+ Initializes a new instance of the class by using the specified virtual path.
+ The virtual path.
+
+
+ Gets the virtual path of the web page.
+ The virtual path.
+
+
+ Represents a last-in-first-out (LIFO) collection of template files.
+
+
+ Returns the current template file from the specified HTTP context.
+ The template file, removed from the top of the stack.
+ The HTTP context that contains the stack that stores the template files.
+
+
+ Removes and returns the template file that is at the top of the stack in the specified HTTP context.
+ The template file, removed from the top of the stack.
+ The HTTP context that contains the stack that stores the template files.
+
+ is null.
+
+
+ Inserts a template file at the top of the stack in the specified HTTP context.
+ The HTTP context that contains the stack that stores the template files.
+ The template file to push onto the specified stack.
+
+ or are null.
+
+
+ Implements validation for user input.
+
+
+ Registers a list of user input elements for validation.
+ The names (value of the name attribute) of the user input elements to validate.
+ The type of validation to register for each user input element specified in .
+
+
+ Registers a user input element for validation.
+ The name (value of the name attribute) of the user input element to validate.
+ A list of one or more types of validation to register.
+
+
+ Adds an error message.
+ The error message.
+
+
+ Renders an attribute that references the CSS style definition to use when validation messages for the user input element are rendered.
+ The attribute.
+ The name (value of the name attribute) of the user input element to validate.
+
+
+ Renders attributes that enable client-side validation for an individual user input element.
+ The attributes to render.
+ The name (value of the name attribute) of the user input element to validate.
+
+
+ Gets the name of the current form. This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The name.
+
+
+ Returns a list of current validation errors, and optionally lets you specify a list of fields to check.
+ The list of errors.
+ Optional. The names (value of the name attribute) of the user input elements to get error information for. You can specify any number of element names, separated by commas. If you do not specify a list of fields, the method returns errors for all fields.
+
+
+ Gets the name of the class that is used to specify the appearance of error-message display when errors have occurred. This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The name.
+
+
+ Determines whether the contents of the user input fields pass validation checks, and optionally lets you specify a list of fields to check.
+ true if all specified field or fields pass validation checks; false if any field contains a validation error.
+ Optional. The names (value of the name attribute) of the user input elements to check for validation errors. You can specify any number of element names, separated by commas. If you do not specify a list of fields, the method checks all elements that are registered for validation.
+
+
+ Registers the specified field as one that requires user entry.
+ The name (value of the name attribute) of the user input element to validate.
+
+
+ Registers the specified field as one that requires user entry and registers the specified string as the error message to display if no value is supplied.
+ The name (value of the name attribute) of the user input element to validate.
+ The error message.
+
+
+ Registers the specified fields as ones that require user entry.
+ The names (value of the name attribute) of the user input elements to validate. You can specify any number of element names, separated by commas.
+
+
+ Performs validation on elements registered for validation, and optionally lets you specify a list of fields to check.
+ The list of errors for the specified fields, if any validation errors occurred.
+ Optional. The names (value of the name attribute) of the user input elements to validate. You can specify any number of element names, separated by commas. If you do not specify a list, the method validates all registered elements.
+
+
+ Gets the name of the class that is used to specify the appearance of error-message display when errors have occurred. This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+ The name.
+
+
+ Defines validation tests that can be registered using the method.
+
+
+ Initializes a new instance of the class.
+
+
+ Defines a validation test that tests whether a value can be treated as a date/time value.
+ The validation test.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests whether a value can be treated as a decimal number.
+ The validation test.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that test user input against the value of another field.
+ The validation test.
+ The other field to compare.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests whether a value can be treated as a floating-point number.
+ The validation test.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests whether a value can be treated as an integer.
+ The validation test.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests whether a decimal number falls within a specific range.
+ The validation test.
+ The minimum value. The default is 0.
+ The maximum value.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests whether an integer value falls within a specific range.
+ The validation test.
+ The minimum value. The default is 0.
+ The maximum value.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests a value against a pattern specified as a regular expression.
+ The validation test.
+ The regular expression to use to test the user input.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests whether a value has been provided.
+ The validation test.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests the length of a string.
+ The validation test.
+ The maximum length of the string.
+ The minimum length of the string. The default is 0.
+ The error message to display if validation fails.
+
+
+ Defines a validation test that tests whether a value is a well-formed URL.
+ The validation test.
+ The error message to display if validation fails.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.
+
+
+ Represents an ASP.NET Razor page.
+
+
+ Called from a derived class to create a new instance that is based on the class.
+
+
+ Gets or sets the object that is associated with a page.
+ The current context data.
+
+
+ Executes the code in a set of dependent pages.
+
+
+ Gets the object that is associated with a page.
+ An object that can render HTML form controls in a page.
+
+
+ Initializes an object that inherits from the class.
+
+
+ Gets the model that is associated with a page.
+ An object that represents a model that is associated with the view data for a page.
+
+
+ Gets the state of the model that is associated with a page.
+ The state of the model.
+
+
+ Adds a class to a list of classes that handle page execution and that implement custom features for pages.
+ The class to add.
+
+
+ Renders a content page.
+ An object that can write the output of the page.
+ The path of the page to render.
+ Data to pass to the page.
+
+
+ Gets the validation helper for the current page context.
+ The validation helper.
+
+
+ Serves as the base class for classes that represent an ASP.NET Razor page.
+
+
+ Initializes the class for use by an inherited class instance. This constructor can only be called by an inherited class.
+
+
+ When overridden in a derived class, configures the current web page based on the configuration of the parent web page.
+ The parent page from which to read configuration information.
+
+
+ Creates a new instance of the class by using the specified virtual path.
+ The new object.
+ The virtual path to use to create the instance.
+
+
+ Attempts to create a WebPageBase instance from a virtualPath and wraps complex compiler exceptions with simpler messages
+
+
+ Called by content pages to create named content sections.
+ The name of the section to create.
+ The type of action to take with the new section.
+
+
+ Executes the code in a set of dependent web pages.
+
+
+ Executes the code in a set of dependent web pages by using the specified parameters.
+ The context data for the page.
+ The writer to use to write the executed HTML.
+
+
+ Executes the code in a set of dependent web pages by using the specified context, writer, and start page.
+ The context data for the page.
+ The writer to use to write the executed HTML.
+ The page to start execution in the page hierarchy.
+
+
+ Returns the text writer instance that is used to render the page.
+ The text writer.
+
+
+ Initializes the current page.
+
+
+ Returns a value that indicates whether the specified section is defined in the page.
+ true if the specified section is defined in the page; otherwise, false.
+ The name of the section to search for.
+
+
+ Gets or sets the path of a layout page.
+ The path of the layout page.
+
+
+ Gets the current object for the page.
+ The object.
+
+
+ Gets the stack of objects for the current page context.
+ The objects.
+
+
+ Provides property-like access to page data that is shared between pages, layout pages, and partial pages.
+ An object that contains page data.
+
+
+ Provides array-like access to page data that is shared between pages, layout pages, and partial pages.
+ A dictionary that contains page data.
+
+
+ Returns and removes the context from the top of the instance.
+
+
+ Inserts the specified context at the top of the instance.
+ The page context to push onto the instance.
+ The writer for the page context.
+
+
+ In layout pages, renders the portion of a content page that is not within a named section.
+ The HTML content to render.
+
+
+ Renders the content of one page within another page.
+ The HTML content to render.
+ The path of the page to render.
+ (Optional) An array of data to pass to the page being rendered. In the rendered page, these parameters can be accessed by using the property.
+
+
+ In layout pages, renders the content of a named section.
+ The HTML content to render.
+ The section to render.
+ The section was already rendered.-or-The section was marked as required but was not found.
+
+
+ In layout pages, renders the content of a named section and specifies whether the section is required.
+ The HTML content to render.
+ The section to render.
+ true to specify that the section is required; otherwise, false.
+
+
+ Writes the specified object as an HTML-encoded string.
+ The object to encode and write.
+
+
+ Writes the specified object as an HTML-encoded string.
+ The helper result to encode and write.
+
+
+ Writes the specified object without HTML-encoding it first.
+ The object to write.
+
+
+ Contains data that is used by a object to reference details about the web application, the current HTTP request, the current execution context, and page-rendering data.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using the specified context, page, and model.
+ The HTTP request context data to associate with the page context.
+ The page data to share between pages, layout pages, and partial pages.
+ The model to associate with the view data.
+
+
+ Gets a reference to the current object that is associated with a page.
+ The current page context object.
+
+
+ Gets the model that is associated with a page.
+ An object that represents a model that is associated with the view data for a page.
+
+
+ Gets the object that is associated with a page.
+ The object that renders the page.
+
+
+ Gets the page data that is shared between pages, layout pages, and partial pages.
+ A dictionary that contains page data.
+
+
+ Provides objects and methods that are used to execute and render ASP.NET pages that include Razor syntax.
+
+
+ Initializes a new instance of the class. This constructor can only be called by an inherited class.
+
+
+
+
+
+
+
+
+ When overridden in a derived class, gets or sets the object that is associated with a page.
+ The current context data.
+
+
+
+
+
+
+
+ Returns the text writer instance that is used to render the page.
+ The text writer.
+
+
+
+
+
+
+
+ Writes the string representation of the specified object as an HTML-encoded string.
+ The object to encode and write.
+
+
+ Writes the specified object as an HTML-encoded string.
+ The helper result to encode and write.
+
+
+
+
+
+ Writes the specified object without HTML encoding.
+ The object to write.
+
+
+ Writes the specified object to the specified instance without HTML encoding.
+ The text writer.
+ The object to write.
+
+
+ Writes the specified object as an HTML-encoded string to the specified text writer.
+ The text writer.
+ The object to encode and write.
+
+
+ Writes the specified object as an HTML-encoded string to the specified text writer.
+ The text writer.
+ The helper result to encode and write.
+
+
+ Provides methods and properties that are used to process specific URL extensions.
+
+
+ Initializes a new instance of the class by using the specified web page.
+ The web page to process.
+
+ is null.
+
+
+ Creates a new handler object from the specified virtual path.
+ A object for the specified virtual path.
+ The virtual path to use to create the handler.
+
+
+ Gets or sets a value that indicates whether web page response headers are disabled.
+ true if web page response headers are disabled; otherwise, false.
+
+
+ Returns a list of file name extensions that the current instance can process.
+ A read-only list of file name extensions that are processed by the current instance.
+
+
+ Gets a value that indicates whether another request can use the instance.
+ true if the instance is reusable; otherwise, false.
+
+
+ Processes the web page by using the specified context.
+ The context to use when processing the web page.
+
+
+ Adds a file name extension to the list of extensions that are processed by the current instance.
+ The extension to add, without a leading period.
+
+
+ The HTML tag name (X-AspNetWebPages-Version) for the version of the ASP.NET Web Pages specification that is used by this web page.
+
+
+ Provides methods and properties that are used to render pages that use the Razor view engine.
+
+
+ Initializes a new instance of the class.
+
+
+
+
+
+ When overridden in a derived class, calls the methods that are used to initialize the page.
+
+
+
+
+ When overridden in a derived class, gets or sets the path of a layout page.
+ The path of a layout page.
+
+
+ When overridden in a derived class, provides property-like access to page data that is shared between pages, layout pages, and partial pages.
+ An object that contains page data.
+
+
+
+ When overridden in a derived class, provides array-like access to page data that is shared between pages, layout pages, and partial pages.
+ An object that provides array-like access to page data.
+
+
+
+ When overridden in a derived class, renders a web page.
+ The markup that represents the web page.
+ The path of the page to render.
+ Additional data that is used to render the page.
+
+
+
+
+
+
+
+
+
+
+ Provides support for rendering HTML form controls and performing form validation in a web page.
+
+
+ Creates a dictionary of HTML attributes from the input object, translating underscores to dashes.
+ A dictionary that represents HTML attributes.
+ Anonymous object describing HTML attributes.
+
+
+ Returns an HTML-encoded string that represents the specified object by using a minimal encoding that is suitable only for HTML attributes that are enclosed in quotation marks.
+ An HTML-encoded string that represents the object.
+ The object to encode.
+
+
+ Returns an HTML-encoded string that represents the specified string by using a minimal encoding that is suitable only for HTML attributes that are enclosed in quotation marks.
+ An HTML-encoded string that represents the original string.
+ The string to encode.
+
+
+ Returns an HTML check box control that has the specified name.
+ The HTML markup that represents the check box control.
+ The value to assign to the name attribute of the HTML control element.
+
+ is null or empty.
+
+
+ Returns an HTML check box control that has the specified name and default checked status.
+ The HTML markup that represents the check box control.
+ The value to assign to the name attribute of the HTML control element.
+ true to indicate that the checked attribute is set to checked; otherwise, false.
+
+ is null or empty.
+
+
+ Returns an HTML check box control that has the specified name, default checked status, and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the check box control.
+ The value to assign to the name attribute of the HTML control element.
+ true to indicate that the checked attribute is set to checked; otherwise, false.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML check box control that has the specified name, default checked status, and custom attributes defined by an attribute object.
+ The HTML markup that represents the check box control.
+ The value to assign to the name attribute of the HTML control element.
+ true to indicate that the checked attribute is set to checked; otherwise, false.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML check box control that has the specified name and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the check box control.
+ The value to assign to the name attribute of the HTML control element.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML check box control that has the specified name and custom attributes defined by an attribute object.
+ The HTML markup that represents the check box control.
+ The value to assign to the name attribute of the HTML control element.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML drop-down list control that has the specified name and that contains the specified list items.
+ The HTML markup that represents the drop-down list control.
+ The value to assign to the name attribute of the HTML select element.
+ A list of instances that are used to populate the list.
+
+ is null or empty.
+
+
+ Returns an HTML drop-down list control that has the specified name and custom attributes defined by an attribute dictionary, and that contains the specified list items.
+ The HTML markup that represents the drop-down list control.
+ The value to assign to the name attribute of the HTML select element.
+ A list of instances that are used to populate the list.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML drop-down list control that has the specified name and custom attributes defined by an attribute object, and that contains the specified list items.
+ The HTML markup that represents the drop-down list control.
+ The value to assign to the name attribute of the HTML select element.
+ A list of instances that are used to populate the list.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML drop-down list control that has the specified name, and that contains the specified list items and default item.
+ The HTML markup that represents the drop-down list control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+
+ is null or empty.
+
+
+ Returns an HTML drop-down list control that has the specified name and custom attributes defined by an attribute dictionary, and that contains the specified list items and default item.
+ The HTML markup that represents the drop-down list control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML drop-down list control that has the specified name and custom attributes defined by an attribute object, and that contains the specified list items and default item.
+ The HTML markup that represents the drop-down list control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML drop-down list control that has the specified name, custom attributes defined by an attribute dictionary, and default selection, and that contains the specified list items and default item.
+ The HTML markup that represents the drop-down list control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ The value that specifies the item in the list that is selected by default. The selected item is the first item in the list whose value matches the parameter (or whose text matches, if there is no value.)
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML drop-down list control that has the specified name, custom attributes defined by an attribute object, and default selection, and that contains the specified list items and default item.
+ The HTML markup that represents the drop-down list control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ The value that specifies the item in the list that is selected by default. The item that is selected is the first item in the list that has a matching value, or that matches the items displayed text if the item has no value.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML-encoded string that represents the specified object by using a full encoding that is suitable for arbitrary HTML.
+ An HTML-encoded string that represents the object.
+ The object to encode.
+
+
+ Returns an HTML-encoded string that represents the specified string by using a full encoding that is suitable for arbitrary HTML.
+ An HTML-encoded string that represents the original string.
+ The string to encode.
+
+
+ Returns an HTML hidden control that has the specified name.
+ The HTML markup that represents the hidden control.
+ The value to assign to the name attribute of the HTML control element.
+
+ is null or empty.
+
+
+ Returns an HTML hidden control that has the specified name and value.
+ The HTML markup that represents the hidden control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+
+ is null or empty.
+
+
+ Returns an HTML hidden control that has the specified name, value, and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the hidden control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML hidden control that has the specified name, value, and custom attributes defined by an attribute object.
+ The HTML markup that represents the hidden control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Gets or sets the character that is used to replace the dot (.) in the id attribute of rendered form controls.
+ The character that is used to replace the dot in the id attribute of rendered form controls. The default is an underscore (_).
+
+
+ Returns an HTML label that displays the specified text.
+ The HTML markup that represents the label.
+ The text to display.
+
+ is null or empty.
+
+
+ Returns an HTML label that displays the specified text and that has the specified custom attributes.
+ The HTML markup that represents the label.
+ The text to display.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML label that displays the specified text and that has the specified for attribute.
+ The HTML markup that represents the label.
+ The text to display.
+ The value to assign to the for attribute of the HTML control element.
+
+ is null or empty.
+
+
+ Returns an HTML label that displays the specified text, and that has the specified for attribute and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the label.
+ The text to display.
+ The value to assign to the for attribute of the HTML control element.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML label that displays the specified text, and that has the specified for attribute and custom attributes defined by an attribute object.
+ The HTML markup that represents the label.
+ The text to display.
+ The value to assign to the for attribute of the HTML control element.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name and that contains the specified list items.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ A list of instances that are used to populate the list.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name and custom attributes defined by an attribute dictionary, and that contains the specified list items.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ A list of instances that are used to populate the list.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name and custom attributes defined by an attribute object, and that contains the specified list items.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ A list of instances that are used to populate the list.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name, size, list items, and default selections, and that specifies whether multiple selections are enabled.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ A list of instances that are used to populate the list.
+ An object that specifies the items in the list that are selected by default. The selections are retrieved through reflection by examining the properties of the object.
+ The value to assign to the size attribute of the element.
+ true to indicate that the multiple selections are enabled; otherwise, false.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name, and that contains the specified list items and default item.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list box.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name and custom attributes defined by an attribute dictionary, and that contains the specified list items and default item.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name and custom attributes defined by an attribute object, and that contains the specified list items and default item.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list box.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name and custom attributes defined by an attribute dictionary, and that contains the specified list items, default item, and selections.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ An object that specifies the items in the list that are selected by default. The selections are retrieved through reflection by examining the properties of the object.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name, size, items, default item, and selections, and that specifies whether multiple selections are enabled.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ An object that specifies the items in the list that are selected by default. The selections are retrieved through reflection by examining the properties of the object.
+ The value to assign to the size attribute of the element.
+ true to indicate that multiple selections are enabled; otherwise, false.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name, size, custom attributes defined by an attribute dictionary, items, default item, and selections, and that specifies whether multiple selections are enabled.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ An object that specifies the items in the list that are selected by default. The selections are retrieved through reflection by examining the properties of the object.
+ The value to assign to the size attribute of the element.
+ true to indicate that multiple selections are enabled; otherwise, false.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name, size, custom attributes defined by an attribute object, items, default item, and selections, and that specifies whether multiple selections are enabled.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ An object that specifies the items in the list that are selected by default. The selections are retrieved through reflection by examining the properties of the object.
+ The value to assign to the size attribute of the element.
+ true to indicate that multiple selections are enabled; otherwise, false.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML list box control that has the specified name, items, default item, and custom attributes defined by an attribute object, and selections.
+ The HTML markup that represents the list box control.
+ The value to assign to the name attribute of the HTML select element.
+ The text to display for the default option in the list.
+ A list of instances that are used to populate the list.
+ An object that specifies the items in the list that are selected by default. The selections are retrieved through reflection by examining the properties of the object.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Creates a dictionary from an object, by adding each public instance property as a key with its associated value to the dictionary. It will expose public properties from derived types as well. This is typically used with objects of an anonymous type.
+ The created dictionary of property names and property values.
+ The object to be converted.
+
+
+ Returns an HTML password control that has the specified name.
+ The HTML markup that represents the password control.
+ The value to assign to the name attribute of the HTML control element.
+
+ is null or empty.
+
+
+ Returns an HTML password control that has the specified name and value.
+ The HTML markup that represents the password control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+
+ is null or empty.
+
+
+ Returns an HTML password control that has the specified name, value, and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the password control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML password control that has the specified name, value, and custom attributes defined by an attribute object.
+ The HTML markup that represents the password control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML radio button control that has the specified name and value.
+ The HTML markup that represents the radio button control.
+ The value to assign to the name attribute of the HTML control element. The name attribute defines the group that the radio button belongs to.
+ The value to assign to the value attribute of the element.
+
+ is null or empty.
+
+
+ Returns an HTML radio button control that has the specified name, value, and default selected status.
+ The HTML markup that represents the radio button control.
+ The value to assign to the name attribute of the HTML control element. The name attribute defines the group that the radio button belongs to.
+ The value to assign to the value attribute of the element.
+ true to indicate that the control is selected; otherwise, false.
+
+ is null or empty.
+
+
+ Returns an HTML radio button control that has the specified name, value, default selected status, and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the radio button control.
+ The value to assign to the name attribute of the HTML control element. The name attribute defines the group that the radio button belongs to.
+ The value to assign to the value attribute of the element.
+ true to indicate that the control is selected; otherwise, false.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML radio button control that has the specified name, value, default selected status, and custom attributes defined by an attribute object.
+ The HTML markup that represents the radio button control.
+ The value to assign to the name attribute of the HTML control element. The name attribute defines the group that the radio button belongs to.
+ The value to assign to the value attribute of the element.
+ true to indicate that the control is selected; otherwise, false.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML radio button control that has the specified name, value, and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the radio button control.
+ The value to assign to the name attribute of the HTML control element. The name attribute defines the group that the radio button belongs to.
+ The value to assign to the value attribute of the element.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML radio button control that has the specified name, value, and custom attributes defined by an attribute object.
+ The HTML markup that represents the radio button control.
+ The value to assign to the name attribute of the HTML control element. The name attribute defines the group that the radio button belongs to.
+ The value to assign to the value attribute of the element.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Wraps HTML markup in an instance so that it is interpreted as HTML markup.
+ The unencoded HTML.
+ The object to render HTML for.
+
+
+ Wraps HTML markup in an instance so that it is interpreted as HTML markup.
+ The unencoded HTML.
+ The string to interpret as HTML markup instead of being HTML-encoded.
+
+
+ Returns an HTML multi-line text input (text area) control that has the specified name.
+ The HTML markup that represents the text area control.
+ The value to assign to the name attribute of the HTML textarea element.
+
+ is null or empty.
+
+
+ Returns an HTML multi-line text input (text area) control that has the specified name and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the text area control.
+ The value to assign to the name attribute of the HTML textarea element.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML multi-line text input (text area) control that has the specified name and custom attributes defined by an attribute object.
+ The HTML markup that represents the text area control.
+ The value to assign to the name attribute of the HTML textarea element.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML multi-line text input (text area) control that has the specified name and value.
+ The HTML markup that represents the text area control.
+ The value to assign to the name attribute of the HTML textrarea element.
+ The text to display.
+
+ is null or empty.
+
+
+ Returns an HTML multi-line text input (text area) control that has the specified name, value, and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the text area control.
+ The value to assign to the name attribute of the HTML textarea element.
+ The text to display.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML multi-line text input (text area) control that has the specified name, value, row attribute, col attribute, and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the text area control.
+ The value to assign to the name attribute of the HTML textarea element.
+ The text to display.
+ The value to assign to the rows attribute of the element.
+ The value to assign to the cols attribute of the element.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML multi-line text input (text area) control that has the specified name, value, row attribute, col attribute, and custom attributes defined by an attribute object.
+ The HTML markup that represents the text area control.
+ The value to assign to the name attribute of the HTML textarea element.
+ The text to display.
+ The value to assign to the rows attribute of the element.
+ The value to assign to the cols attribute of the element.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML multi-line text input (text area) control that has the specified name, value, and custom attributes defined by an attribute object.
+ The HTML markup that represents the text area control.
+ The value to assign to the name attribute of the HTML textarea element.
+ The text to display.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML text control that has the specified name.
+ The HTML markup that represents the text control.
+ The value to assign to the name attribute of the HTML control element.
+
+ is null or empty.
+
+
+ Returns an HTML text control that has the specified name and value.
+ The HTML markup that represents the text control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+
+ is null or empty.
+
+
+ Returns an HTML text control that has the specified name, value, and custom attributes defined by an attribute dictionary.
+ The HTML markup that represents the text control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML text control that has the specified name, value, and custom attributes defined by an attribute object.
+ The HTML markup that represents the text control.
+ The value to assign to the name attribute of the HTML control element.
+ The value to assign to the value attribute of the element.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Gets or sets a value that indicates whether the page uses unobtrusive JavaScript for Ajax functionality.
+ true if the page uses unobtrusive JavaScript; otherwise, false.
+
+
+ Gets or sets the name of the CSS class that defines the appearance of input elements when validation fails.
+ The name of the CSS class. The default is field-validation-error.
+
+
+ Gets or sets the name of the CSS class that defines the appearance of input elements when validation passes.
+ The name of the CSS class. The default is input-validation-valid.
+
+
+ Returns an HTML span element that contains the first validation error message for the specified form field.
+ If the value in the specified field is valid, null; otherwise, the HTML markup that represents the validation error message that is associated with the specified field.
+ The name of the form field that was validated.
+
+ is null or empty.
+
+
+ Returns an HTML span element that has the specified custom attributes defined by an attribute dictionary, and that contains the first validation error message for the specified form field.
+ If the value in the specified field is valid, null; otherwise, the HTML markup that represents the validation error message that is associated with the specified field.
+ The name of the form field that was validated.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML span element that has the specified custom attributes defined by an attribute object, and that contains the first validation error message for the specified form field.
+ If the value in the specified field is valid, null; otherwise, the HTML markup that represents the validation error message that is associated with the specified field.
+ The name of the form field that was validated.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Returns an HTML span element that contains a validation error message for the specified form field.
+ If the value in the specified field is valid, null; otherwise, the HTML markup that represents the validation error message that is associated with the specified field.
+ The name of the form field that was validated.
+ The validation error message to display. If null, the first validation error message that is associated with the specified form field is displayed.
+
+ is null or empty.
+
+
+ Returns an HTML span element that has the specified custom attributes defined by an attribute dictionary, and that contains a validation error message for the specified form field.
+ If the specified field is valid, null; otherwise, the HTML markup that represents a validation error message that is associated with the specified field.
+ The name of the form field that was validated.
+ The validation error message to display. If null, the first validation error message that is associated with the specified form field is displayed.
+ The names and values of custom attributes for the element.
+
+ is null or empty.
+
+
+ Returns an HTML span element that has the specified custom attributes defined by an attribute object, and that contains a validation error message for the specified form field.
+ If the specified field is valid, null; otherwise, the HTML markup that represents a validation error message that is associated with the specified field.
+ The name of the form field that was validated.
+ The validation error message to display. If null, the first validation error message that is associated with the specified form field is displayed.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+ is null or empty.
+
+
+ Gets or sets the name of the CSS class that defines the appearance of validation error messages when validation fails.
+ The name of the CSS class. The default is field-validation-error.
+
+
+ Gets or sets the name of the CSS class that defines the appearance of validation error messages when validation passes.
+ The name of the CSS class. The default is field-validation-valid.
+
+
+ Returns an HTML div element that contains an unordered list of all validation error messages from the model-state dictionary.
+ The HTML markup that represents the validation error messages.
+
+
+ Returns an HTML div element that contains an unordered list of validation error message from the model-state dictionary, optionally excluding field-level errors.
+ The HTML markup that represents the validation error messages.
+ true to exclude field-level validation error messages from the list; false to include both model-level and field-level validation error messages.
+
+
+ Returns an HTML div element that has the specified custom attributes defined by an attribute dictionary, and that contains an unordered list of all validation error messages that are in the model-state dictionary.
+ The HTML markup that represents the validation error messages.
+ The names and values of custom attributes for the element.
+
+
+ Returns an HTML div element that has the specified custom attributes defined by an attribute object, and that contains an unordered list of all validation error messages that are in the model-state dictionary.
+ The HTML markup that represents the validation error messages.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+
+ Returns an HTML div element that contains a summary message and an unordered list of all validation error messages that are in the model-state dictionary.
+ The HTML markup that represents the validation error messages.
+ The message that comes before the list of validation error messages.
+
+
+ Returns an HTML div element that has the specified custom attributes defined by an attribute dictionary, and that contains a summary message and an unordered list of validation error message from the model-state dictionary, optionally excluding field-level errors.
+ The HTML markup that represents the validation error messages.
+ The summary message that comes before the list of validation error messages.
+ true to exclude field-level validation error messages from the results; false to include both model-level and field-level validation error messages.
+ The names and values of custom attributes for the element.
+
+
+ Returns an HTML div element that has the specified custom attributes defined by an attribute object, and that contains a summary message and an unordered list of validation error message from the model-state dictionary, optionally excluding field-level errors.
+ The HTML markup that represents the validation error messages.
+ The summary message that comes before the list of validation error messages.
+ true to exclude field-level validation error messages from the results; false to include and field-level validation error messages.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+
+ Returns an HTML div element that has the specified custom attributes defined by an attribute dictionary, and that contains a summary message and an unordered list of all validation error message from the model-state dictionary.
+ The HTML markup that represents the validation error messages.
+ The message that comes before the list of validation error messages.
+ The names and values of custom attributes for the element.
+
+
+ Returns an HTML div element that has the specified custom attributes defined by an attribute object, and that contains a summary message and an unordered list of all validation error message from the model-state dictionary.
+ The HTML markup that represents the validation error messages.
+ The summary message that comes before the list of validation error messages.
+ An object that contains custom attributes for the element. The attribute names and values are retrieved through reflection by examining the properties of the object.
+
+
+ Gets or sets the name of the CSS class that defines the appearance of a validation summary when validation fails.
+ The name of the CSS class. The default is validation-summary-errors.
+
+
+ Gets or sets the name of the CSS class that defines the appearance of a validation summary when validation passes.
+ The name of the CSS class. The default is validation-summary-valid.
+
+
+ Encapsulates the state of model binding to a property of an action-method argument, or to the argument itself.
+
+
+ Initializes a new instance of the class.
+
+
+ Returns a list of strings that contains any errors that occurred during model binding.
+ The errors that occurred during model binding.
+
+
+ Returns an object that encapsulates the value that was bound during model binding.
+ The value that was bound.
+
+
+ Represents the result of binding a posted form to an action method, which includes information such as validation status and validation error messages.
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class by using values that are copied from the specified model-state dictionary.
+ The model-state dictionary that values are copied from.
+
+
+ Adds the specified item to the model-state dictionary.
+ The item to add to the model-state dictionary.
+
+
+ Adds an item that has the specified key and value to the model-state dictionary.
+ The key.
+ The value.
+
+
+ Adds an error message to the model state that is associated with the specified key.
+ The key that is associated with the model state that the error message is added to.
+ The error message.
+
+
+ Adds an error message to the model state that is associated with the entire form.
+ The error message.
+
+
+ Removes all items from the model-state dictionary.
+
+
+ Determines whether the model-state dictionary contains the specified item.
+ true if the model-state dictionary contains the specified item; otherwise, false.
+ The item to look for.
+
+
+ Determines whether the model-state dictionary contains the specified key.
+ true if the model-state dictionary contains the specified key; otherwise, false.
+ The key to look for.
+
+
+ Copies the elements of the model-state dictionary to an array, starting at the specified index.
+ The one-dimensional instance where the elements will be copied to.
+ The index in at which copying begins.
+
+
+ Gets the number of model states that the model-state dictionary contains.
+ The number of model states in the model-state dictionary.
+
+
+ Returns an enumerator that can be used to iterate through the collection.
+ An enumerator that can be used to iterate through the collection.
+
+
+ Gets a value that indicates whether the model-state dictionary is read-only.
+ true if the model-state dictionary is read-only; otherwise, false.
+
+
+ Gets a value that indicates whether any error messages are associated with any model state in the model-state dictionary.
+ true if any error messages are associated with any model state in the dictionary; otherwise, false.
+
+
+ Determines whether any error messages are associated with the specified key.
+ true if no error messages are associated with the specified key, or the specified key does not exist; otherwise, false.
+ The key.
+
+ is null.
+
+
+ Gets or sets the model state that is associated with the specified key in the model-state dictionary.
+ The model state that is associated with the specified key in the dictionary.
+
+
+ Gets a list that contains the keys in the model-state dictionary.
+ The list of keys in the dictionary.
+
+
+ Copies the values from the specified model-state dictionary into this instance, overwriting existing values when the keys are the same.
+ The model-state dictionary that values are copied from.
+
+
+ Removes the first occurrence of the specified item from the model-state dictionary.
+ true if the item was successfully removed from the model-state dictionary; false if the item was not removed or if the item does not exist in the model-state dictionary.
+ The item to remove.
+
+
+ Removes the item that has the specified key from the model-state dictionary.
+ true if the item was successfully removed from the model-state dictionary; false if the item was not removed or does not exist in the model-state dictionary.
+ The key of the element to remove.
+
+
+ Sets the value of the model state that is associated with the specified key.
+ The key to set the value of.
+ The value to set the key to.
+
+
+ Returns an enumerator that can be used to iterate through the model-state dictionary.
+ An enumerator that can be used to iterate through the model-state dictionary.
+
+
+ Gets the model-state value that is associated with the specified key.
+ true if the model-state dictionary contains an element that has the specified key; otherwise, false.
+ The key to get the value of.
+ When this method returns, if the key is found, contains the model-state value that is associated with the specified key; otherwise, contains the default value for the type. This parameter is passed uninitialized.
+
+
+ Gets a list that contains the values in the model-state dictionary.
+ The list of values in the dictionary.
+
+
+ Represents an item in an HTML select list.
+
+
+ Initializes a new instance of the class using the default settings.
+
+
+ Initializes a new instance of the class by copying the specified select list item.
+ The select list item to copy.
+
+
+ Gets or sets a value that indicates whether the instance is selected.
+ true if the select list item is selected; otherwise, false.
+
+
+ Gets or sets the text that is used to display the instance on a web page.
+ The text that is used to display the select list item.
+
+
+ Gets or sets the value of the HTML value attribute of the HTML option element that is associated with the instance.
+ The value of the HTML value attribute that is associated with the select list item.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a web pages instrumentation service.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Called before it renders the output for the specified context.
+ The context.
+ The virtual path.
+ The writer.
+ The start position.
+ The length of the context.
+ Determines whether the context is literal.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Called after it renders the output for the specified context.
+ The context.
+ The virtual path.
+ The writer.
+ The start position.
+ The length of the context.
+ Determines whether the context is literal.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets a value indicating whether the service is available.
+ true if the service is available; otherwise, false.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Represents a position tagged.
+ The type of the position..
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Initializes a new instance of the class.
+ The value of this current instance.
+ The offset.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the specified object is equal to the current object.
+ true if the specified object is equal to the current object; otherwise, false.
+ The object to compare to.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets the hash code of the current instance.
+ The hash code of the current instance.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two objects are equal.
+ true if the two objects are equal; otherwise, false.
+ The first object.
+ The second object.
+
+
+ Converts the specified object to a object.
+ The that represents the converted .
+ The object to convert.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Converts the to a object.
+ The that represents the converted .
+ The object to convert.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Determines whether the two objects are not equal.
+ true if the two objects are not equal; otherwise, false.
+ The first object.
+ The second object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the position associated with the .
+ The position associated with the .
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Returns a string representation of the object.
+ A string that represents the object.
+
+
+ This type/member supports the .NET Framework infrastructure and is not intended to be used directly from your code.Gets or sets the value of the current instance.
+ The value of the current instance.
+
+
+ Defines an ASP.NET request scope storage provider.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets the dictionary to store data in the application scope.
+ The dictionary that stores application scope data.
+
+
+ Gets or sets the dictionary to store data in the current scope.
+ The dictionary that stores current scope data.
+
+
+ Gets the dictionary to store data in the global scope.
+ The dictionary that stores global scope data.
+
+
+ Gets the dictionary to store data in the request scope.
+ The dictionary that stores request scope data.
+
+
+ Defines a dictionary that provides scoped access to data.
+
+
+ Gets and sets the dictionary that is used to store data in the current scope.
+ The dictionary that stores current scope data.
+
+
+ Gets the dictionary that is used to store data in the global scope.
+ The dictionary that stores global scope data.
+
+
+ Defines a class that is used to contain storage for a transient scope.
+
+
+ Returns a dictionary that is used to store data in a transient scope, based on the scope in the property.
+ The dictionary that stores transient scope data.
+
+
+ Returns a dictionary that is used to store data in a transient scope.
+ The dictionary that stores transient scope data.
+ The context.
+
+
+ Gets or sets the current scope provider.
+ The current scope provider.
+
+
+ Gets the dictionary that is used to store data in the current scope.
+ The dictionary that stores current scope data.
+
+
+ Gets the dictionary that is used to store data in the global scope.
+ The dictionary that stores global scope data.
+
+
+ Represents a collection of keys and values that are used to store data at different scope levels (local, global, and so on).
+
+
+ Initializes a new instance of the class.
+
+
+ Initializes a new instance of the class using the specified base scope.
+ The base scope.
+
+
+ Adds a key/value pair to the object using the specified generic collection.
+ The key/value pair.
+
+
+ Adds the specified key and specified value to the object.
+ The key.
+ The value.
+
+
+ Gets the dictionary that stores the object data.
+
+
+ Gets the base scope for the object.
+ The base scope for the object.
+
+
+ Removes all keys and values from the concatenated and objects.
+
+
+ Returns a value that indicates whether the specified key/value pair exists in either the object or in the object.
+ true if the object or the object contains an element that has the specified key/value pair; otherwise, false.
+ The key/value pair.
+
+
+ Returns a value that indicates whether the specified key exists in the object or in the object.
+ true if the object or the object contains an element that has the specified key; otherwise, false.
+ The key.
+
+
+ Copies all of the elements in the object and the object to an object, starting at the specified index.
+ The array.
+ The zero-based index in .
+
+
+ Gets the number of key/value pairs that are in the concatenated and objects.
+ The number of key/value pairs.
+
+
+ Returns an enumerator that can be used to iterate through concatenated and objects.
+ An object.
+
+
+ Returns an enumerator that can be used to iterate through the distinct elements of concatenated and objects.
+ An enumerator that contains distinct elements from the concatenated dictionary objects.
+
+
+ Gets a value that indicates whether the object is read-only.
+ true if the object is read-only; otherwise, false.
+
+
+ Gets or sets the element that is associated with the specified key.
+ The element that has the specified key.
+
+
+ Gets a object that contains the keys from the concatenated and objects.
+ An object that contains that contains the keys.
+
+
+ Removes the specified key/value pair from the concatenated and objects.
+ true if the key/value pair is removed, or false if is not found in the concatenated and objects.
+ The key/value pair.
+
+
+ Removes the value that has the specified key from the concatenated and objects.
+ true if the key/value pair is removed, or false if is not found in the concatenated and objects.
+ The key.
+
+
+ Sets a value using the specified key in the concatenated and objects.
+ The key.
+ The value.
+
+
+ Returns an enumerator for the concatenated and objects.
+ The enumerator.
+
+
+ Gets the value that is associated with the specified key from the concatenated and objects.
+ true if the concatenated and objects contain an element that has the specified key; otherwise, false.
+ The key.
+ When this method returns, if the key is found, contains the value that is associated with the specified key; otherwise, the default value for the type of the parameter. This parameter is passed uninitialized.
+
+
+ Gets a object that contains the values from the concatenated and objects.
+ The object that contains the values.
+
+
+ Provides scoped access to static data.
+
+
+ Initializes a new instance of the class.
+
+
+ Gets or sets a dictionary that stores current data under a static context.
+ The dictionary that provides current scoped data.
+
+
+ Gets a dictionary that stores global data under a static context.
+ The dictionary that provides global scoped data.
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/WebGrease.dll b/samples/angular-aad-webapi/api/api.securecall/bin/WebGrease.dll
new file mode 100644
index 000000000..1d308f8ed
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/WebGrease.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.dll b/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.dll
new file mode 100644
index 000000000..0cb2d4faa
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.dll.config b/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.dll.config
new file mode 100644
index 000000000..3efc57005
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.dll.config
@@ -0,0 +1,94 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.pdb b/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.pdb
new file mode 100644
index 000000000..fc6edcb21
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/api.securecall.pdb differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.Build.Tasks.CodeAnalysis.dll b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.Build.Tasks.CodeAnalysis.dll
new file mode 100644
index 000000000..4aca434ef
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.Build.Tasks.CodeAnalysis.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CSharp.Core.targets b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CSharp.Core.targets
new file mode 100644
index 000000000..65629e5e5
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CSharp.Core.targets
@@ -0,0 +1,135 @@
+
+
+
+
+ $(NoWarn);1701;1702
+
+
+
+
+ $(NoWarn);2008
+
+
+
+
+
+
+
+
+
+
+ $(AppConfig)
+
+
+ $(IntermediateOutputPath)$(TargetName).compile.pdb
+
+
+
+
+ false
+
+
+
+
+
+
+
+
+ true
+
+
+
+
+
+
+ <_CoreCompileResourceInputs Remove="@(_CoreCompileResourceInputs)" />
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.CSharp.dll b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.CSharp.dll
new file mode 100644
index 000000000..c01c29fc0
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.CSharp.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.VisualBasic.dll b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.VisualBasic.dll
new file mode 100644
index 000000000..a48642f43
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.VisualBasic.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.dll b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.dll
new file mode 100644
index 000000000..c21619792
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.CodeAnalysis.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.VisualBasic.Core.targets b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.VisualBasic.Core.targets
new file mode 100644
index 000000000..4dc93e391
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/Microsoft.VisualBasic.Core.targets
@@ -0,0 +1,133 @@
+
+
+
+ <_NoWarnings Condition=" '$(WarningLevel)' == '0' ">true
+ <_NoWarnings Condition=" '$(WarningLevel)' == '1' ">false
+
+
+
+
+ $(IntermediateOutputPath)$(TargetName).compile.pdb
+
+
+
+
+
+
+
+
+
+
+ false
+
+
+
+
+
+
+
+
+ true
+
+
+
+
+
+
+ <_CoreCompileResourceInputs Remove="@(_CoreCompileResourceInputs)" />
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/System.Collections.Immutable.dll b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/System.Collections.Immutable.dll
new file mode 100644
index 000000000..888e9144f
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/System.Collections.Immutable.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/System.Reflection.Metadata.dll b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/System.Reflection.Metadata.dll
new file mode 100644
index 000000000..a3ac7a200
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/System.Reflection.Metadata.dll differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/VBCSCompiler.exe b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/VBCSCompiler.exe
new file mode 100644
index 000000000..b2dceff60
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/VBCSCompiler.exe differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/VBCSCompiler.exe.config b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/VBCSCompiler.exe.config
new file mode 100644
index 000000000..8b142580b
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/VBCSCompiler.exe.config
@@ -0,0 +1,14 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/csc.exe b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/csc.exe
new file mode 100644
index 000000000..44c3c41df
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/csc.exe differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/vbc.exe b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/vbc.exe
new file mode 100644
index 000000000..bc98748c7
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/bin/roslyn/vbc.exe differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/favicon.ico b/samples/angular-aad-webapi/api/api.securecall/favicon.ico
new file mode 100644
index 000000000..a3a799985
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/favicon.ico differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.eot b/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.eot
new file mode 100644
index 000000000..87eaa4342
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.eot differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.svg b/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.svg
new file mode 100644
index 000000000..5fee06854
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.svg
@@ -0,0 +1,228 @@
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.ttf b/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.ttf
new file mode 100644
index 000000000..be784dc1d
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.ttf differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.woff b/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.woff
new file mode 100644
index 000000000..2cc3e4852
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/fonts/glyphicons-halflings-regular.woff differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize.parameters.xml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize.parameters.xml
new file mode 100644
index 000000000..7ef34efac
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize.parameters.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Areas/HelpPage/Views/Web.config b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Areas/HelpPage/Views/Web.config
new file mode 100644
index 000000000..097173224
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Areas/HelpPage/Views/Web.config
@@ -0,0 +1,41 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Views/Web.config b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Views/Web.config
new file mode 100644
index 000000000..ccaa33499
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Views/Web.config
@@ -0,0 +1,43 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Web.config b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Web.config
new file mode 100644
index 000000000..3efc57005
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/original/Web.config
@@ -0,0 +1,94 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Areas/HelpPage/Views/Web.config b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Areas/HelpPage/Views/Web.config
new file mode 100644
index 000000000..097173224
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Areas/HelpPage/Views/Web.config
@@ -0,0 +1,41 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Views/Web.config b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Views/Web.config
new file mode 100644
index 000000000..ccaa33499
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Views/Web.config
@@ -0,0 +1,43 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Web.config b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Web.config
new file mode 100644
index 000000000..d99bd8815
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/CSAutoParameterize/transformed/Web.config
@@ -0,0 +1,94 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache
new file mode 100644
index 000000000..32c5f2999
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/HelpPage.css b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/HelpPage.css
new file mode 100644
index 000000000..aff223033
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/HelpPage.css
@@ -0,0 +1,134 @@
+.help-page h1,
+.help-page .h1,
+.help-page h2,
+.help-page .h2,
+.help-page h3,
+.help-page .h3,
+#body.help-page,
+.help-page-table th,
+.help-page-table pre,
+.help-page-table p {
+ font-family: "Segoe UI Light", Frutiger, "Frutiger Linotype", "Dejavu Sans", "Helvetica Neue", Arial, sans-serif;
+}
+
+.help-page pre.wrapped {
+ white-space: -moz-pre-wrap;
+ white-space: -pre-wrap;
+ white-space: -o-pre-wrap;
+ white-space: pre-wrap;
+}
+
+.help-page .warning-message-container {
+ margin-top: 20px;
+ padding: 0 10px;
+ color: #525252;
+ background: #EFDCA9;
+ border: 1px solid #CCCCCC;
+}
+
+.help-page-table {
+ width: 100%;
+ border-collapse: collapse;
+ text-align: left;
+ margin: 0px 0px 20px 0px;
+ border-top: 1px solid #D4D4D4;
+}
+
+.help-page-table th {
+ text-align: left;
+ font-weight: bold;
+ border-bottom: 1px solid #D4D4D4;
+ padding: 5px 6px 5px 6px;
+}
+
+.help-page-table td {
+ border-bottom: 1px solid #D4D4D4;
+ padding: 10px 8px 10px 8px;
+ vertical-align: top;
+}
+
+.help-page-table pre,
+.help-page-table p {
+ margin: 0px;
+ padding: 0px;
+ font-family: inherit;
+ font-size: 100%;
+}
+
+.help-page-table tbody tr:hover td {
+ background-color: #F3F3F3;
+}
+
+.help-page a:hover {
+ background-color: transparent;
+}
+
+.help-page .sample-header {
+ border: 2px solid #D4D4D4;
+ background: #00497E;
+ color: #FFFFFF;
+ padding: 8px 15px;
+ border-bottom: none;
+ display: inline-block;
+ margin: 10px 0px 0px 0px;
+}
+
+.help-page .sample-content {
+ display: block;
+ border-width: 0;
+ padding: 15px 20px;
+ background: #FFFFFF;
+ border: 2px solid #D4D4D4;
+ margin: 0px 0px 10px 0px;
+}
+
+.help-page .api-name {
+ width: 40%;
+}
+
+.help-page .api-documentation {
+ width: 60%;
+}
+
+.help-page .parameter-name {
+ width: 20%;
+}
+
+.help-page .parameter-documentation {
+ width: 40%;
+}
+
+.help-page .parameter-type {
+ width: 20%;
+}
+
+.help-page .parameter-annotations {
+ width: 20%;
+}
+
+.help-page h1,
+.help-page .h1 {
+ font-size: 36px;
+ line-height: normal;
+}
+
+.help-page h2,
+.help-page .h2 {
+ font-size: 24px;
+}
+
+.help-page h3,
+.help-page .h3 {
+ font-size: 20px;
+}
+
+#body.help-page {
+ font-size: 14px;
+ line-height: 143%;
+ color: #333;
+}
+
+.help-page a {
+ color: #0000EE;
+ text-decoration: none;
+}
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/Api.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/Api.cshtml
new file mode 100644
index 000000000..5d9f6fa9b
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/Api.cshtml
@@ -0,0 +1,22 @@
+@using System.Web.Http
+@using api.securecall.Areas.HelpPage.Models
+@model HelpPageApiModel
+
+@{
+ var description = Model.ApiDescription;
+ ViewBag.Title = description.HttpMethod.Method + " " + description.RelativePath;
+}
+
+
+
+
+
+
+ @Html.ActionLink("Help Page Home", "Index")
+
+
+
+
+ @Html.DisplayForModel()
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ApiGroup.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ApiGroup.cshtml
new file mode 100644
index 000000000..08fe9acb4
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ApiGroup.cshtml
@@ -0,0 +1,41 @@
+@using System.Web.Http
+@using System.Web.Http.Controllers
+@using System.Web.Http.Description
+@using api.securecall.Areas.HelpPage
+@using api.securecall.Areas.HelpPage.Models
+@model IGrouping
+
+@{
+ var controllerDocumentation = ViewBag.DocumentationProvider != null ?
+ ViewBag.DocumentationProvider.GetDocumentation(Model.Key) :
+ null;
+}
+
+@Model.Key.ControllerName
+@if (!String.IsNullOrEmpty(controllerDocumentation))
+{
+ @controllerDocumentation
+}
+
+
+ API | Description |
+
+
+ @foreach (var api in Model)
+ {
+
+ @api.HttpMethod.Method @api.RelativePath |
+
+ @if (api.Documentation != null)
+ {
+ @api.Documentation
+ }
+ else
+ {
+ No documentation available.
+ }
+ |
+
+ }
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/CollectionModelDescription.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/CollectionModelDescription.cshtml
new file mode 100644
index 000000000..89b2381a6
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/CollectionModelDescription.cshtml
@@ -0,0 +1,6 @@
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model CollectionModelDescription
+@if (Model.ElementDescription is ComplexTypeModelDescription)
+{
+ @Html.DisplayFor(m => m.ElementDescription)
+}
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ComplexTypeModelDescription.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ComplexTypeModelDescription.cshtml
new file mode 100644
index 000000000..75e629e64
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ComplexTypeModelDescription.cshtml
@@ -0,0 +1,3 @@
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model ComplexTypeModelDescription
+@Html.DisplayFor(m => m.Properties, "Parameters")
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/DictionaryModelDescription.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/DictionaryModelDescription.cshtml
new file mode 100644
index 000000000..b6e98fb60
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/DictionaryModelDescription.cshtml
@@ -0,0 +1,4 @@
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model DictionaryModelDescription
+Dictionary of @Html.DisplayFor(m => Model.KeyModelDescription.ModelType, "ModelDescriptionLink", new { modelDescription = Model.KeyModelDescription }) [key]
+and @Html.DisplayFor(m => Model.ValueModelDescription.ModelType, "ModelDescriptionLink", new { modelDescription = Model.ValueModelDescription }) [value]
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/EnumTypeModelDescription.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/EnumTypeModelDescription.cshtml
new file mode 100644
index 000000000..5c2d1dae9
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/EnumTypeModelDescription.cshtml
@@ -0,0 +1,24 @@
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model EnumTypeModelDescription
+
+Possible enumeration values:
+
+
+
+ Name | Value | Description |
+
+
+ @foreach (EnumValueDescription value in Model.Values)
+ {
+
+ @value.Name |
+
+ @value.Value
+ |
+
+ @value.Documentation
+ |
+
+ }
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/HelpPageApiModel.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/HelpPageApiModel.cshtml
new file mode 100644
index 000000000..b171663f7
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/HelpPageApiModel.cshtml
@@ -0,0 +1,67 @@
+@using System.Web.Http
+@using System.Web.Http.Description
+@using api.securecall.Areas.HelpPage.Models
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model HelpPageApiModel
+
+@{
+ ApiDescription description = Model.ApiDescription;
+}
+@description.HttpMethod.Method @description.RelativePath
+
+
@description.Documentation
+
+
Request Information
+
+
URI Parameters
+ @Html.DisplayFor(m => m.UriParameters, "Parameters")
+
+
Body Parameters
+
+
@Model.RequestDocumentation
+
+ @if (Model.RequestModelDescription != null)
+ {
+ @Html.DisplayFor(m => m.RequestModelDescription.ModelType, "ModelDescriptionLink", new { modelDescription = Model.RequestModelDescription })
+ if (Model.RequestBodyParameters != null)
+ {
+ @Html.DisplayFor(m => m.RequestBodyParameters, "Parameters")
+ }
+ }
+ else
+ {
+
None.
+ }
+
+ @if (Model.SampleRequests.Count > 0)
+ {
+
Request Formats
+ @Html.DisplayFor(m => m.SampleRequests, "Samples")
+ }
+
+
Response Information
+
+
Resource Description
+
+
@description.ResponseDescription.Documentation
+
+ @if (Model.ResourceDescription != null)
+ {
+ @Html.DisplayFor(m => m.ResourceDescription.ModelType, "ModelDescriptionLink", new { modelDescription = Model.ResourceDescription })
+ if (Model.ResourceProperties != null)
+ {
+ @Html.DisplayFor(m => m.ResourceProperties, "Parameters")
+ }
+ }
+ else
+ {
+
None.
+ }
+
+ @if (Model.SampleResponses.Count > 0)
+ {
+
Response Formats
+ @Html.DisplayFor(m => m.SampleResponses, "Samples")
+ }
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ImageSample.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ImageSample.cshtml
new file mode 100644
index 000000000..1c1755716
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ImageSample.cshtml
@@ -0,0 +1,4 @@
+@using api.securecall.Areas.HelpPage
+@model ImageSample
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/InvalidSample.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/InvalidSample.cshtml
new file mode 100644
index 000000000..7f4dc871c
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/InvalidSample.cshtml
@@ -0,0 +1,13 @@
+@using api.securecall.Areas.HelpPage
+@model InvalidSample
+
+@if (HttpContext.Current.IsDebuggingEnabled)
+{
+
+}
+else
+{
+ Sample not available.
+}
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/KeyValuePairModelDescription.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/KeyValuePairModelDescription.cshtml
new file mode 100644
index 000000000..4d2f971ee
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/KeyValuePairModelDescription.cshtml
@@ -0,0 +1,4 @@
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model KeyValuePairModelDescription
+Pair of @Html.DisplayFor(m => Model.KeyModelDescription.ModelType, "ModelDescriptionLink", new { modelDescription = Model.KeyModelDescription }) [key]
+and @Html.DisplayFor(m => Model.ValueModelDescription.ModelType, "ModelDescriptionLink", new { modelDescription = Model.ValueModelDescription }) [value]
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ModelDescriptionLink.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ModelDescriptionLink.cshtml
new file mode 100644
index 000000000..34a8643bb
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/ModelDescriptionLink.cshtml
@@ -0,0 +1,26 @@
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model Type
+@{
+ ModelDescription modelDescription = ViewBag.modelDescription;
+ if (modelDescription is ComplexTypeModelDescription || modelDescription is EnumTypeModelDescription)
+ {
+ if (Model == typeof(Object))
+ {
+ @:Object
+ }
+ else
+ {
+ @Html.ActionLink(modelDescription.Name, "ResourceModel", "Help", new { modelName = modelDescription.Name }, null)
+ }
+ }
+ else if (modelDescription is CollectionModelDescription)
+ {
+ var collectionDescription = modelDescription as CollectionModelDescription;
+ var elementDescription = collectionDescription.ElementDescription;
+ @:Collection of @Html.DisplayFor(m => elementDescription.ModelType, "ModelDescriptionLink", new { modelDescription = elementDescription })
+ }
+ else
+ {
+ @Html.DisplayFor(m => modelDescription)
+ }
+}
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/Parameters.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/Parameters.cshtml
new file mode 100644
index 000000000..f304b8388
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/Parameters.cshtml
@@ -0,0 +1,48 @@
+@using System.Collections.Generic
+@using System.Collections.ObjectModel
+@using System.Web.Http.Description
+@using System.Threading
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model IList
+
+@if (Model.Count > 0)
+{
+
+
+ Name | Description | Type | Additional information |
+
+
+ @foreach (ParameterDescription parameter in Model)
+ {
+ ModelDescription modelDescription = parameter.TypeDescription;
+
+ @parameter.Name |
+
+ @parameter.Documentation
+ |
+
+ @Html.DisplayFor(m => modelDescription.ModelType, "ModelDescriptionLink", new { modelDescription = modelDescription })
+ |
+
+ @if (parameter.Annotations.Count > 0)
+ {
+ foreach (var annotation in parameter.Annotations)
+ {
+ @annotation.Documentation
+ }
+ }
+ else
+ {
+ None.
+ }
+ |
+
+ }
+
+
+}
+else
+{
+ None.
+}
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/Samples.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/Samples.cshtml
new file mode 100644
index 000000000..c19596fb1
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/Samples.cshtml
@@ -0,0 +1,30 @@
+@using System.Net.Http.Headers
+@model Dictionary
+
+@{
+ // Group the samples into a single tab if they are the same.
+ Dictionary samples = Model.GroupBy(pair => pair.Value).ToDictionary(
+ pair => String.Join(", ", pair.Select(m => m.Key.ToString()).ToArray()),
+ pair => pair.Key);
+ var mediaTypes = samples.Keys;
+}
+
+ @foreach (var mediaType in mediaTypes)
+ {
+
+
+
Sample:
+ @{
+ var sample = samples[mediaType];
+ if (sample == null)
+ {
+
Sample not available.
+ }
+ else
+ {
+ @Html.DisplayFor(s => sample);
+ }
+ }
+
+ }
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/SimpleTypeModelDescription.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/SimpleTypeModelDescription.cshtml
new file mode 100644
index 000000000..6cf67f74e
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/SimpleTypeModelDescription.cshtml
@@ -0,0 +1,3 @@
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model SimpleTypeModelDescription
+@Model.Documentation
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/TextSample.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/TextSample.cshtml
new file mode 100644
index 000000000..2abcad679
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/DisplayTemplates/TextSample.cshtml
@@ -0,0 +1,6 @@
+@using api.securecall.Areas.HelpPage
+@model TextSample
+
+
+@Model.Text
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/Index.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/Index.cshtml
new file mode 100644
index 000000000..c4cf22c8b
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/Index.cshtml
@@ -0,0 +1,38 @@
+@using System.Web.Http
+@using System.Web.Http.Controllers
+@using System.Web.Http.Description
+@using System.Collections.ObjectModel
+@using api.securecall.Areas.HelpPage.Models
+@model Collection
+
+@{
+ ViewBag.Title = "ASP.NET Web API Help Page";
+
+ // Group APIs by controller
+ ILookup apiGroups = Model.ToLookup(api => api.ActionDescriptor.ControllerDescriptor);
+}
+
+
+
+
+
+
+
Introduction
+
+ Provide a general description of your APIs here.
+
+
+
+
+ @foreach (var group in apiGroups)
+ {
+ @Html.DisplayFor(m => group, "ApiGroup")
+ }
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/ResourceModel.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/ResourceModel.cshtml
new file mode 100644
index 000000000..ffaa29dbc
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Help/ResourceModel.cshtml
@@ -0,0 +1,19 @@
+@using System.Web.Http
+@using api.securecall.Areas.HelpPage.ModelDescriptions
+@model ModelDescription
+
+
+
+
+
+
+ @Html.ActionLink("Help Page Home", "Index")
+
+
+
+
@Model.Name
+
@Model.Documentation
+
+ @Html.DisplayFor(m => Model)
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Shared/_Layout.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Shared/_Layout.cshtml
new file mode 100644
index 000000000..896c833a0
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Shared/_Layout.cshtml
@@ -0,0 +1,12 @@
+
+
+
+
+
+ @ViewBag.Title
+ @RenderSection("scripts", required: false)
+
+
+ @RenderBody()
+
+
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Web.config b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Web.config
new file mode 100644
index 000000000..097173224
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/Web.config
@@ -0,0 +1,41 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/_ViewStart.cshtml b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/_ViewStart.cshtml
new file mode 100644
index 000000000..d735b1cb0
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Areas/HelpPage/Views/_ViewStart.cshtml
@@ -0,0 +1,4 @@
+@{
+ // Change the Layout path below to blend the look and feel of the help page with your existing web pages
+ Layout = "~/Views/Shared/_Layout.cshtml";
+}
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/Site.css b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/Site.css
new file mode 100644
index 000000000..d825a52a8
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/Site.css
@@ -0,0 +1,17 @@
+body {
+ padding-top: 50px;
+ padding-bottom: 20px;
+}
+
+/* Set padding to keep content from hitting the edges */
+.body-content {
+ padding-left: 15px;
+ padding-right: 15px;
+}
+
+/* Set width on the form input elements since they're 100% wide by default */
+input,
+select,
+textarea {
+ max-width: 280px;
+}
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/bootstrap.css b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/bootstrap.css
new file mode 100644
index 000000000..6d6e68281
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/bootstrap.css
@@ -0,0 +1,6816 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. The notices and licenses below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*!
+ * Bootstrap v3.0.0
+ *
+ * Copyright 2013 Twitter, Inc
+ * Licensed under the Apache License v2.0
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Designed and built with all the love in the world by @mdo and @fat.
+ */
+
+/*! normalize.css v2.1.0 | MIT License | git.io/normalize */
+
+article,
+aside,
+details,
+figcaption,
+figure,
+footer,
+header,
+hgroup,
+main,
+nav,
+section,
+summary {
+ display: block;
+}
+
+audio,
+canvas,
+video {
+ display: inline-block;
+}
+
+audio:not([controls]) {
+ display: none;
+ height: 0;
+}
+
+[hidden] {
+ display: none;
+}
+
+html {
+ font-family: sans-serif;
+ -webkit-text-size-adjust: 100%;
+ -ms-text-size-adjust: 100%;
+}
+
+body {
+ margin: 0;
+}
+
+a:focus {
+ outline: thin dotted;
+}
+
+a:active,
+a:hover {
+ outline: 0;
+}
+
+h1 {
+ margin: 0.67em 0;
+ font-size: 2em;
+}
+
+abbr[title] {
+ border-bottom: 1px dotted;
+}
+
+b,
+strong {
+ font-weight: bold;
+}
+
+dfn {
+ font-style: italic;
+}
+
+hr {
+ height: 0;
+ -moz-box-sizing: content-box;
+ box-sizing: content-box;
+}
+
+mark {
+ color: #000;
+ background: #ff0;
+}
+
+code,
+kbd,
+pre,
+samp {
+ font-family: monospace, serif;
+ font-size: 1em;
+}
+
+pre {
+ white-space: pre-wrap;
+}
+
+q {
+ quotes: "\201C" "\201D" "\2018" "\2019";
+}
+
+small {
+ font-size: 80%;
+}
+
+sub,
+sup {
+ position: relative;
+ font-size: 75%;
+ line-height: 0;
+ vertical-align: baseline;
+}
+
+sup {
+ top: -0.5em;
+}
+
+sub {
+ bottom: -0.25em;
+}
+
+img {
+ border: 0;
+}
+
+svg:not(:root) {
+ overflow: hidden;
+}
+
+figure {
+ margin: 0;
+}
+
+fieldset {
+ padding: 0.35em 0.625em 0.75em;
+ margin: 0 2px;
+ border: 1px solid #c0c0c0;
+}
+
+legend {
+ padding: 0;
+ border: 0;
+}
+
+button,
+input,
+select,
+textarea {
+ margin: 0;
+ font-family: inherit;
+ font-size: 100%;
+}
+
+button,
+input {
+ line-height: normal;
+}
+
+button,
+select {
+ text-transform: none;
+}
+
+button,
+html input[type="button"],
+input[type="reset"],
+input[type="submit"] {
+ cursor: pointer;
+ -webkit-appearance: button;
+}
+
+button[disabled],
+html input[disabled] {
+ cursor: default;
+}
+
+input[type="checkbox"],
+input[type="radio"] {
+ padding: 0;
+ box-sizing: border-box;
+}
+
+input[type="search"] {
+ -webkit-box-sizing: content-box;
+ -moz-box-sizing: content-box;
+ box-sizing: content-box;
+ -webkit-appearance: textfield;
+}
+
+input[type="search"]::-webkit-search-cancel-button,
+input[type="search"]::-webkit-search-decoration {
+ -webkit-appearance: none;
+}
+
+button::-moz-focus-inner,
+input::-moz-focus-inner {
+ padding: 0;
+ border: 0;
+}
+
+textarea {
+ overflow: auto;
+ vertical-align: top;
+}
+
+table {
+ border-collapse: collapse;
+ border-spacing: 0;
+}
+
+@media print {
+ * {
+ color: #000 !important;
+ text-shadow: none !important;
+ background: transparent !important;
+ box-shadow: none !important;
+ }
+ a,
+ a:visited {
+ text-decoration: underline;
+ }
+ a[href]:after {
+ content: " (" attr(href) ")";
+ }
+ abbr[title]:after {
+ content: " (" attr(title) ")";
+ }
+ .ir a:after,
+ a[href^="javascript:"]:after,
+ a[href^="#"]:after {
+ content: "";
+ }
+ pre,
+ blockquote {
+ border: 1px solid #999;
+ page-break-inside: avoid;
+ }
+ thead {
+ display: table-header-group;
+ }
+ tr,
+ img {
+ page-break-inside: avoid;
+ }
+ img {
+ max-width: 100% !important;
+ }
+ @page {
+ margin: 2cm .5cm;
+ }
+ p,
+ h2,
+ h3 {
+ orphans: 3;
+ widows: 3;
+ }
+ h2,
+ h3 {
+ page-break-after: avoid;
+ }
+ .navbar {
+ display: none;
+ }
+ .table td,
+ .table th {
+ background-color: #fff !important;
+ }
+ .btn > .caret,
+ .dropup > .btn > .caret {
+ border-top-color: #000 !important;
+ }
+ .label {
+ border: 1px solid #000;
+ }
+ .table {
+ border-collapse: collapse !important;
+ }
+ .table-bordered th,
+ .table-bordered td {
+ border: 1px solid #ddd !important;
+ }
+}
+
+*,
+*:before,
+*:after {
+ -webkit-box-sizing: border-box;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+}
+
+html {
+ font-size: 62.5%;
+ -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
+}
+
+body {
+ font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
+ font-size: 14px;
+ line-height: 1.428571429;
+ color: #333333;
+ background-color: #ffffff;
+}
+
+input,
+button,
+select,
+textarea {
+ font-family: inherit;
+ font-size: inherit;
+ line-height: inherit;
+}
+
+button,
+input,
+select[multiple],
+textarea {
+ background-image: none;
+}
+
+a {
+ color: #428bca;
+ text-decoration: none;
+}
+
+a:hover,
+a:focus {
+ color: #2a6496;
+ text-decoration: underline;
+}
+
+a:focus {
+ outline: thin dotted #333;
+ outline: 5px auto -webkit-focus-ring-color;
+ outline-offset: -2px;
+}
+
+img {
+ vertical-align: middle;
+}
+
+.img-responsive {
+ display: block;
+ height: auto;
+ max-width: 100%;
+}
+
+.img-rounded {
+ border-radius: 6px;
+}
+
+.img-thumbnail {
+ display: inline-block;
+ height: auto;
+ max-width: 100%;
+ padding: 4px;
+ line-height: 1.428571429;
+ background-color: #ffffff;
+ border: 1px solid #dddddd;
+ border-radius: 4px;
+ -webkit-transition: all 0.2s ease-in-out;
+ transition: all 0.2s ease-in-out;
+}
+
+.img-circle {
+ border-radius: 50%;
+}
+
+hr {
+ margin-top: 20px;
+ margin-bottom: 20px;
+ border: 0;
+ border-top: 1px solid #eeeeee;
+}
+
+.sr-only {
+ position: absolute;
+ width: 1px;
+ height: 1px;
+ padding: 0;
+ margin: -1px;
+ overflow: hidden;
+ clip: rect(0 0 0 0);
+ border: 0;
+}
+
+p {
+ margin: 0 0 10px;
+}
+
+.lead {
+ margin-bottom: 20px;
+ font-size: 16.099999999999998px;
+ font-weight: 200;
+ line-height: 1.4;
+}
+
+@media (min-width: 768px) {
+ .lead {
+ font-size: 21px;
+ }
+}
+
+small {
+ font-size: 85%;
+}
+
+cite {
+ font-style: normal;
+}
+
+.text-muted {
+ color: #999999;
+}
+
+.text-primary {
+ color: #428bca;
+}
+
+.text-warning {
+ color: #c09853;
+}
+
+.text-danger {
+ color: #b94a48;
+}
+
+.text-success {
+ color: #468847;
+}
+
+.text-info {
+ color: #3a87ad;
+}
+
+.text-left {
+ text-align: left;
+}
+
+.text-right {
+ text-align: right;
+}
+
+.text-center {
+ text-align: center;
+}
+
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+.h1,
+.h2,
+.h3,
+.h4,
+.h5,
+.h6 {
+ font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
+ font-weight: 500;
+ line-height: 1.1;
+}
+
+h1 small,
+h2 small,
+h3 small,
+h4 small,
+h5 small,
+h6 small,
+.h1 small,
+.h2 small,
+.h3 small,
+.h4 small,
+.h5 small,
+.h6 small {
+ font-weight: normal;
+ line-height: 1;
+ color: #999999;
+}
+
+h1,
+h2,
+h3 {
+ margin-top: 20px;
+ margin-bottom: 10px;
+}
+
+h4,
+h5,
+h6 {
+ margin-top: 10px;
+ margin-bottom: 10px;
+}
+
+h1,
+.h1 {
+ font-size: 36px;
+}
+
+h2,
+.h2 {
+ font-size: 30px;
+}
+
+h3,
+.h3 {
+ font-size: 24px;
+}
+
+h4,
+.h4 {
+ font-size: 18px;
+}
+
+h5,
+.h5 {
+ font-size: 14px;
+}
+
+h6,
+.h6 {
+ font-size: 12px;
+}
+
+h1 small,
+.h1 small {
+ font-size: 24px;
+}
+
+h2 small,
+.h2 small {
+ font-size: 18px;
+}
+
+h3 small,
+.h3 small,
+h4 small,
+.h4 small {
+ font-size: 14px;
+}
+
+.page-header {
+ padding-bottom: 9px;
+ margin: 40px 0 20px;
+ border-bottom: 1px solid #eeeeee;
+}
+
+ul,
+ol {
+ margin-top: 0;
+ margin-bottom: 10px;
+}
+
+ul ul,
+ol ul,
+ul ol,
+ol ol {
+ margin-bottom: 0;
+}
+
+.list-unstyled {
+ padding-left: 0;
+ list-style: none;
+}
+
+.list-inline {
+ padding-left: 0;
+ list-style: none;
+}
+
+.list-inline > li {
+ display: inline-block;
+ padding-right: 5px;
+ padding-left: 5px;
+}
+
+dl {
+ margin-bottom: 20px;
+}
+
+dt,
+dd {
+ line-height: 1.428571429;
+}
+
+dt {
+ font-weight: bold;
+}
+
+dd {
+ margin-left: 0;
+}
+
+@media (min-width: 768px) {
+ .dl-horizontal dt {
+ float: left;
+ width: 160px;
+ overflow: hidden;
+ clear: left;
+ text-align: right;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ }
+ .dl-horizontal dd {
+ margin-left: 180px;
+ }
+ .dl-horizontal dd:before,
+ .dl-horizontal dd:after {
+ display: table;
+ content: " ";
+ }
+ .dl-horizontal dd:after {
+ clear: both;
+ }
+ .dl-horizontal dd:before,
+ .dl-horizontal dd:after {
+ display: table;
+ content: " ";
+ }
+ .dl-horizontal dd:after {
+ clear: both;
+ }
+}
+
+abbr[title],
+abbr[data-original-title] {
+ cursor: help;
+ border-bottom: 1px dotted #999999;
+}
+
+abbr.initialism {
+ font-size: 90%;
+ text-transform: uppercase;
+}
+
+blockquote {
+ padding: 10px 20px;
+ margin: 0 0 20px;
+ border-left: 5px solid #eeeeee;
+}
+
+blockquote p {
+ font-size: 17.5px;
+ font-weight: 300;
+ line-height: 1.25;
+}
+
+blockquote p:last-child {
+ margin-bottom: 0;
+}
+
+blockquote small {
+ display: block;
+ line-height: 1.428571429;
+ color: #999999;
+}
+
+blockquote small:before {
+ content: '\2014 \00A0';
+}
+
+blockquote.pull-right {
+ padding-right: 15px;
+ padding-left: 0;
+ border-right: 5px solid #eeeeee;
+ border-left: 0;
+}
+
+blockquote.pull-right p,
+blockquote.pull-right small {
+ text-align: right;
+}
+
+blockquote.pull-right small:before {
+ content: '';
+}
+
+blockquote.pull-right small:after {
+ content: '\00A0 \2014';
+}
+
+q:before,
+q:after,
+blockquote:before,
+blockquote:after {
+ content: "";
+}
+
+address {
+ display: block;
+ margin-bottom: 20px;
+ font-style: normal;
+ line-height: 1.428571429;
+}
+
+code,
+pre {
+ font-family: Monaco, Menlo, Consolas, "Courier New", monospace;
+}
+
+code {
+ padding: 2px 4px;
+ font-size: 90%;
+ color: #c7254e;
+ white-space: nowrap;
+ background-color: #f9f2f4;
+ border-radius: 4px;
+}
+
+pre {
+ display: block;
+ padding: 9.5px;
+ margin: 0 0 10px;
+ font-size: 13px;
+ line-height: 1.428571429;
+ color: #333333;
+ word-break: break-all;
+ word-wrap: break-word;
+ background-color: #f5f5f5;
+ border: 1px solid #cccccc;
+ border-radius: 4px;
+}
+
+pre.prettyprint {
+ margin-bottom: 20px;
+}
+
+pre code {
+ padding: 0;
+ font-size: inherit;
+ color: inherit;
+ white-space: pre-wrap;
+ background-color: transparent;
+ border: 0;
+}
+
+.pre-scrollable {
+ max-height: 340px;
+ overflow-y: scroll;
+}
+
+.container {
+ padding-right: 15px;
+ padding-left: 15px;
+ margin-right: auto;
+ margin-left: auto;
+}
+
+.container:before,
+.container:after {
+ display: table;
+ content: " ";
+}
+
+.container:after {
+ clear: both;
+}
+
+.container:before,
+.container:after {
+ display: table;
+ content: " ";
+}
+
+.container:after {
+ clear: both;
+}
+
+.row {
+ margin-right: -15px;
+ margin-left: -15px;
+}
+
+.row:before,
+.row:after {
+ display: table;
+ content: " ";
+}
+
+.row:after {
+ clear: both;
+}
+
+.row:before,
+.row:after {
+ display: table;
+ content: " ";
+}
+
+.row:after {
+ clear: both;
+}
+
+.col-xs-1,
+.col-xs-2,
+.col-xs-3,
+.col-xs-4,
+.col-xs-5,
+.col-xs-6,
+.col-xs-7,
+.col-xs-8,
+.col-xs-9,
+.col-xs-10,
+.col-xs-11,
+.col-xs-12,
+.col-sm-1,
+.col-sm-2,
+.col-sm-3,
+.col-sm-4,
+.col-sm-5,
+.col-sm-6,
+.col-sm-7,
+.col-sm-8,
+.col-sm-9,
+.col-sm-10,
+.col-sm-11,
+.col-sm-12,
+.col-md-1,
+.col-md-2,
+.col-md-3,
+.col-md-4,
+.col-md-5,
+.col-md-6,
+.col-md-7,
+.col-md-8,
+.col-md-9,
+.col-md-10,
+.col-md-11,
+.col-md-12,
+.col-lg-1,
+.col-lg-2,
+.col-lg-3,
+.col-lg-4,
+.col-lg-5,
+.col-lg-6,
+.col-lg-7,
+.col-lg-8,
+.col-lg-9,
+.col-lg-10,
+.col-lg-11,
+.col-lg-12 {
+ position: relative;
+ min-height: 1px;
+ padding-right: 15px;
+ padding-left: 15px;
+}
+
+.col-xs-1,
+.col-xs-2,
+.col-xs-3,
+.col-xs-4,
+.col-xs-5,
+.col-xs-6,
+.col-xs-7,
+.col-xs-8,
+.col-xs-9,
+.col-xs-10,
+.col-xs-11 {
+ float: left;
+}
+
+.col-xs-1 {
+ width: 8.333333333333332%;
+}
+
+.col-xs-2 {
+ width: 16.666666666666664%;
+}
+
+.col-xs-3 {
+ width: 25%;
+}
+
+.col-xs-4 {
+ width: 33.33333333333333%;
+}
+
+.col-xs-5 {
+ width: 41.66666666666667%;
+}
+
+.col-xs-6 {
+ width: 50%;
+}
+
+.col-xs-7 {
+ width: 58.333333333333336%;
+}
+
+.col-xs-8 {
+ width: 66.66666666666666%;
+}
+
+.col-xs-9 {
+ width: 75%;
+}
+
+.col-xs-10 {
+ width: 83.33333333333334%;
+}
+
+.col-xs-11 {
+ width: 91.66666666666666%;
+}
+
+.col-xs-12 {
+ width: 100%;
+}
+
+@media (min-width: 768px) {
+ .container {
+ max-width: 750px;
+ }
+ .col-sm-1,
+ .col-sm-2,
+ .col-sm-3,
+ .col-sm-4,
+ .col-sm-5,
+ .col-sm-6,
+ .col-sm-7,
+ .col-sm-8,
+ .col-sm-9,
+ .col-sm-10,
+ .col-sm-11 {
+ float: left;
+ }
+ .col-sm-1 {
+ width: 8.333333333333332%;
+ }
+ .col-sm-2 {
+ width: 16.666666666666664%;
+ }
+ .col-sm-3 {
+ width: 25%;
+ }
+ .col-sm-4 {
+ width: 33.33333333333333%;
+ }
+ .col-sm-5 {
+ width: 41.66666666666667%;
+ }
+ .col-sm-6 {
+ width: 50%;
+ }
+ .col-sm-7 {
+ width: 58.333333333333336%;
+ }
+ .col-sm-8 {
+ width: 66.66666666666666%;
+ }
+ .col-sm-9 {
+ width: 75%;
+ }
+ .col-sm-10 {
+ width: 83.33333333333334%;
+ }
+ .col-sm-11 {
+ width: 91.66666666666666%;
+ }
+ .col-sm-12 {
+ width: 100%;
+ }
+ .col-sm-push-1 {
+ left: 8.333333333333332%;
+ }
+ .col-sm-push-2 {
+ left: 16.666666666666664%;
+ }
+ .col-sm-push-3 {
+ left: 25%;
+ }
+ .col-sm-push-4 {
+ left: 33.33333333333333%;
+ }
+ .col-sm-push-5 {
+ left: 41.66666666666667%;
+ }
+ .col-sm-push-6 {
+ left: 50%;
+ }
+ .col-sm-push-7 {
+ left: 58.333333333333336%;
+ }
+ .col-sm-push-8 {
+ left: 66.66666666666666%;
+ }
+ .col-sm-push-9 {
+ left: 75%;
+ }
+ .col-sm-push-10 {
+ left: 83.33333333333334%;
+ }
+ .col-sm-push-11 {
+ left: 91.66666666666666%;
+ }
+ .col-sm-pull-1 {
+ right: 8.333333333333332%;
+ }
+ .col-sm-pull-2 {
+ right: 16.666666666666664%;
+ }
+ .col-sm-pull-3 {
+ right: 25%;
+ }
+ .col-sm-pull-4 {
+ right: 33.33333333333333%;
+ }
+ .col-sm-pull-5 {
+ right: 41.66666666666667%;
+ }
+ .col-sm-pull-6 {
+ right: 50%;
+ }
+ .col-sm-pull-7 {
+ right: 58.333333333333336%;
+ }
+ .col-sm-pull-8 {
+ right: 66.66666666666666%;
+ }
+ .col-sm-pull-9 {
+ right: 75%;
+ }
+ .col-sm-pull-10 {
+ right: 83.33333333333334%;
+ }
+ .col-sm-pull-11 {
+ right: 91.66666666666666%;
+ }
+ .col-sm-offset-1 {
+ margin-left: 8.333333333333332%;
+ }
+ .col-sm-offset-2 {
+ margin-left: 16.666666666666664%;
+ }
+ .col-sm-offset-3 {
+ margin-left: 25%;
+ }
+ .col-sm-offset-4 {
+ margin-left: 33.33333333333333%;
+ }
+ .col-sm-offset-5 {
+ margin-left: 41.66666666666667%;
+ }
+ .col-sm-offset-6 {
+ margin-left: 50%;
+ }
+ .col-sm-offset-7 {
+ margin-left: 58.333333333333336%;
+ }
+ .col-sm-offset-8 {
+ margin-left: 66.66666666666666%;
+ }
+ .col-sm-offset-9 {
+ margin-left: 75%;
+ }
+ .col-sm-offset-10 {
+ margin-left: 83.33333333333334%;
+ }
+ .col-sm-offset-11 {
+ margin-left: 91.66666666666666%;
+ }
+}
+
+@media (min-width: 992px) {
+ .container {
+ max-width: 970px;
+ }
+ .col-md-1,
+ .col-md-2,
+ .col-md-3,
+ .col-md-4,
+ .col-md-5,
+ .col-md-6,
+ .col-md-7,
+ .col-md-8,
+ .col-md-9,
+ .col-md-10,
+ .col-md-11 {
+ float: left;
+ }
+ .col-md-1 {
+ width: 8.333333333333332%;
+ }
+ .col-md-2 {
+ width: 16.666666666666664%;
+ }
+ .col-md-3 {
+ width: 25%;
+ }
+ .col-md-4 {
+ width: 33.33333333333333%;
+ }
+ .col-md-5 {
+ width: 41.66666666666667%;
+ }
+ .col-md-6 {
+ width: 50%;
+ }
+ .col-md-7 {
+ width: 58.333333333333336%;
+ }
+ .col-md-8 {
+ width: 66.66666666666666%;
+ }
+ .col-md-9 {
+ width: 75%;
+ }
+ .col-md-10 {
+ width: 83.33333333333334%;
+ }
+ .col-md-11 {
+ width: 91.66666666666666%;
+ }
+ .col-md-12 {
+ width: 100%;
+ }
+ .col-md-push-0 {
+ left: auto;
+ }
+ .col-md-push-1 {
+ left: 8.333333333333332%;
+ }
+ .col-md-push-2 {
+ left: 16.666666666666664%;
+ }
+ .col-md-push-3 {
+ left: 25%;
+ }
+ .col-md-push-4 {
+ left: 33.33333333333333%;
+ }
+ .col-md-push-5 {
+ left: 41.66666666666667%;
+ }
+ .col-md-push-6 {
+ left: 50%;
+ }
+ .col-md-push-7 {
+ left: 58.333333333333336%;
+ }
+ .col-md-push-8 {
+ left: 66.66666666666666%;
+ }
+ .col-md-push-9 {
+ left: 75%;
+ }
+ .col-md-push-10 {
+ left: 83.33333333333334%;
+ }
+ .col-md-push-11 {
+ left: 91.66666666666666%;
+ }
+ .col-md-pull-0 {
+ right: auto;
+ }
+ .col-md-pull-1 {
+ right: 8.333333333333332%;
+ }
+ .col-md-pull-2 {
+ right: 16.666666666666664%;
+ }
+ .col-md-pull-3 {
+ right: 25%;
+ }
+ .col-md-pull-4 {
+ right: 33.33333333333333%;
+ }
+ .col-md-pull-5 {
+ right: 41.66666666666667%;
+ }
+ .col-md-pull-6 {
+ right: 50%;
+ }
+ .col-md-pull-7 {
+ right: 58.333333333333336%;
+ }
+ .col-md-pull-8 {
+ right: 66.66666666666666%;
+ }
+ .col-md-pull-9 {
+ right: 75%;
+ }
+ .col-md-pull-10 {
+ right: 83.33333333333334%;
+ }
+ .col-md-pull-11 {
+ right: 91.66666666666666%;
+ }
+ .col-md-offset-0 {
+ margin-left: 0;
+ }
+ .col-md-offset-1 {
+ margin-left: 8.333333333333332%;
+ }
+ .col-md-offset-2 {
+ margin-left: 16.666666666666664%;
+ }
+ .col-md-offset-3 {
+ margin-left: 25%;
+ }
+ .col-md-offset-4 {
+ margin-left: 33.33333333333333%;
+ }
+ .col-md-offset-5 {
+ margin-left: 41.66666666666667%;
+ }
+ .col-md-offset-6 {
+ margin-left: 50%;
+ }
+ .col-md-offset-7 {
+ margin-left: 58.333333333333336%;
+ }
+ .col-md-offset-8 {
+ margin-left: 66.66666666666666%;
+ }
+ .col-md-offset-9 {
+ margin-left: 75%;
+ }
+ .col-md-offset-10 {
+ margin-left: 83.33333333333334%;
+ }
+ .col-md-offset-11 {
+ margin-left: 91.66666666666666%;
+ }
+}
+
+@media (min-width: 1200px) {
+ .container {
+ max-width: 1170px;
+ }
+ .col-lg-1,
+ .col-lg-2,
+ .col-lg-3,
+ .col-lg-4,
+ .col-lg-5,
+ .col-lg-6,
+ .col-lg-7,
+ .col-lg-8,
+ .col-lg-9,
+ .col-lg-10,
+ .col-lg-11 {
+ float: left;
+ }
+ .col-lg-1 {
+ width: 8.333333333333332%;
+ }
+ .col-lg-2 {
+ width: 16.666666666666664%;
+ }
+ .col-lg-3 {
+ width: 25%;
+ }
+ .col-lg-4 {
+ width: 33.33333333333333%;
+ }
+ .col-lg-5 {
+ width: 41.66666666666667%;
+ }
+ .col-lg-6 {
+ width: 50%;
+ }
+ .col-lg-7 {
+ width: 58.333333333333336%;
+ }
+ .col-lg-8 {
+ width: 66.66666666666666%;
+ }
+ .col-lg-9 {
+ width: 75%;
+ }
+ .col-lg-10 {
+ width: 83.33333333333334%;
+ }
+ .col-lg-11 {
+ width: 91.66666666666666%;
+ }
+ .col-lg-12 {
+ width: 100%;
+ }
+ .col-lg-push-0 {
+ left: auto;
+ }
+ .col-lg-push-1 {
+ left: 8.333333333333332%;
+ }
+ .col-lg-push-2 {
+ left: 16.666666666666664%;
+ }
+ .col-lg-push-3 {
+ left: 25%;
+ }
+ .col-lg-push-4 {
+ left: 33.33333333333333%;
+ }
+ .col-lg-push-5 {
+ left: 41.66666666666667%;
+ }
+ .col-lg-push-6 {
+ left: 50%;
+ }
+ .col-lg-push-7 {
+ left: 58.333333333333336%;
+ }
+ .col-lg-push-8 {
+ left: 66.66666666666666%;
+ }
+ .col-lg-push-9 {
+ left: 75%;
+ }
+ .col-lg-push-10 {
+ left: 83.33333333333334%;
+ }
+ .col-lg-push-11 {
+ left: 91.66666666666666%;
+ }
+ .col-lg-pull-0 {
+ right: auto;
+ }
+ .col-lg-pull-1 {
+ right: 8.333333333333332%;
+ }
+ .col-lg-pull-2 {
+ right: 16.666666666666664%;
+ }
+ .col-lg-pull-3 {
+ right: 25%;
+ }
+ .col-lg-pull-4 {
+ right: 33.33333333333333%;
+ }
+ .col-lg-pull-5 {
+ right: 41.66666666666667%;
+ }
+ .col-lg-pull-6 {
+ right: 50%;
+ }
+ .col-lg-pull-7 {
+ right: 58.333333333333336%;
+ }
+ .col-lg-pull-8 {
+ right: 66.66666666666666%;
+ }
+ .col-lg-pull-9 {
+ right: 75%;
+ }
+ .col-lg-pull-10 {
+ right: 83.33333333333334%;
+ }
+ .col-lg-pull-11 {
+ right: 91.66666666666666%;
+ }
+ .col-lg-offset-0 {
+ margin-left: 0;
+ }
+ .col-lg-offset-1 {
+ margin-left: 8.333333333333332%;
+ }
+ .col-lg-offset-2 {
+ margin-left: 16.666666666666664%;
+ }
+ .col-lg-offset-3 {
+ margin-left: 25%;
+ }
+ .col-lg-offset-4 {
+ margin-left: 33.33333333333333%;
+ }
+ .col-lg-offset-5 {
+ margin-left: 41.66666666666667%;
+ }
+ .col-lg-offset-6 {
+ margin-left: 50%;
+ }
+ .col-lg-offset-7 {
+ margin-left: 58.333333333333336%;
+ }
+ .col-lg-offset-8 {
+ margin-left: 66.66666666666666%;
+ }
+ .col-lg-offset-9 {
+ margin-left: 75%;
+ }
+ .col-lg-offset-10 {
+ margin-left: 83.33333333333334%;
+ }
+ .col-lg-offset-11 {
+ margin-left: 91.66666666666666%;
+ }
+}
+
+table {
+ max-width: 100%;
+ background-color: transparent;
+}
+
+th {
+ text-align: left;
+}
+
+.table {
+ width: 100%;
+ margin-bottom: 20px;
+}
+
+.table thead > tr > th,
+.table tbody > tr > th,
+.table tfoot > tr > th,
+.table thead > tr > td,
+.table tbody > tr > td,
+.table tfoot > tr > td {
+ padding: 8px;
+ line-height: 1.428571429;
+ vertical-align: top;
+ border-top: 1px solid #dddddd;
+}
+
+.table thead > tr > th {
+ vertical-align: bottom;
+ border-bottom: 2px solid #dddddd;
+}
+
+.table caption + thead tr:first-child th,
+.table colgroup + thead tr:first-child th,
+.table thead:first-child tr:first-child th,
+.table caption + thead tr:first-child td,
+.table colgroup + thead tr:first-child td,
+.table thead:first-child tr:first-child td {
+ border-top: 0;
+}
+
+.table tbody + tbody {
+ border-top: 2px solid #dddddd;
+}
+
+.table .table {
+ background-color: #ffffff;
+}
+
+.table-condensed thead > tr > th,
+.table-condensed tbody > tr > th,
+.table-condensed tfoot > tr > th,
+.table-condensed thead > tr > td,
+.table-condensed tbody > tr > td,
+.table-condensed tfoot > tr > td {
+ padding: 5px;
+}
+
+.table-bordered {
+ border: 1px solid #dddddd;
+}
+
+.table-bordered > thead > tr > th,
+.table-bordered > tbody > tr > th,
+.table-bordered > tfoot > tr > th,
+.table-bordered > thead > tr > td,
+.table-bordered > tbody > tr > td,
+.table-bordered > tfoot > tr > td {
+ border: 1px solid #dddddd;
+}
+
+.table-bordered > thead > tr > th,
+.table-bordered > thead > tr > td {
+ border-bottom-width: 2px;
+}
+
+.table-striped > tbody > tr:nth-child(odd) > td,
+.table-striped > tbody > tr:nth-child(odd) > th {
+ background-color: #f9f9f9;
+}
+
+.table-hover > tbody > tr:hover > td,
+.table-hover > tbody > tr:hover > th {
+ background-color: #f5f5f5;
+}
+
+table col[class*="col-"] {
+ display: table-column;
+ float: none;
+}
+
+table td[class*="col-"],
+table th[class*="col-"] {
+ display: table-cell;
+ float: none;
+}
+
+.table > thead > tr > td.active,
+.table > tbody > tr > td.active,
+.table > tfoot > tr > td.active,
+.table > thead > tr > th.active,
+.table > tbody > tr > th.active,
+.table > tfoot > tr > th.active,
+.table > thead > tr.active > td,
+.table > tbody > tr.active > td,
+.table > tfoot > tr.active > td,
+.table > thead > tr.active > th,
+.table > tbody > tr.active > th,
+.table > tfoot > tr.active > th {
+ background-color: #f5f5f5;
+}
+
+.table > thead > tr > td.success,
+.table > tbody > tr > td.success,
+.table > tfoot > tr > td.success,
+.table > thead > tr > th.success,
+.table > tbody > tr > th.success,
+.table > tfoot > tr > th.success,
+.table > thead > tr.success > td,
+.table > tbody > tr.success > td,
+.table > tfoot > tr.success > td,
+.table > thead > tr.success > th,
+.table > tbody > tr.success > th,
+.table > tfoot > tr.success > th {
+ background-color: #dff0d8;
+ border-color: #d6e9c6;
+}
+
+.table-hover > tbody > tr > td.success:hover,
+.table-hover > tbody > tr > th.success:hover,
+.table-hover > tbody > tr.success:hover > td {
+ background-color: #d0e9c6;
+ border-color: #c9e2b3;
+}
+
+.table > thead > tr > td.danger,
+.table > tbody > tr > td.danger,
+.table > tfoot > tr > td.danger,
+.table > thead > tr > th.danger,
+.table > tbody > tr > th.danger,
+.table > tfoot > tr > th.danger,
+.table > thead > tr.danger > td,
+.table > tbody > tr.danger > td,
+.table > tfoot > tr.danger > td,
+.table > thead > tr.danger > th,
+.table > tbody > tr.danger > th,
+.table > tfoot > tr.danger > th {
+ background-color: #f2dede;
+ border-color: #eed3d7;
+}
+
+.table-hover > tbody > tr > td.danger:hover,
+.table-hover > tbody > tr > th.danger:hover,
+.table-hover > tbody > tr.danger:hover > td {
+ background-color: #ebcccc;
+ border-color: #e6c1c7;
+}
+
+.table > thead > tr > td.warning,
+.table > tbody > tr > td.warning,
+.table > tfoot > tr > td.warning,
+.table > thead > tr > th.warning,
+.table > tbody > tr > th.warning,
+.table > tfoot > tr > th.warning,
+.table > thead > tr.warning > td,
+.table > tbody > tr.warning > td,
+.table > tfoot > tr.warning > td,
+.table > thead > tr.warning > th,
+.table > tbody > tr.warning > th,
+.table > tfoot > tr.warning > th {
+ background-color: #fcf8e3;
+ border-color: #fbeed5;
+}
+
+.table-hover > tbody > tr > td.warning:hover,
+.table-hover > tbody > tr > th.warning:hover,
+.table-hover > tbody > tr.warning:hover > td {
+ background-color: #faf2cc;
+ border-color: #f8e5be;
+}
+
+@media (max-width: 768px) {
+ .table-responsive {
+ width: 100%;
+ margin-bottom: 15px;
+ overflow-x: scroll;
+ overflow-y: hidden;
+ border: 1px solid #dddddd;
+ }
+ .table-responsive > .table {
+ margin-bottom: 0;
+ background-color: #fff;
+ }
+ .table-responsive > .table > thead > tr > th,
+ .table-responsive > .table > tbody > tr > th,
+ .table-responsive > .table > tfoot > tr > th,
+ .table-responsive > .table > thead > tr > td,
+ .table-responsive > .table > tbody > tr > td,
+ .table-responsive > .table > tfoot > tr > td {
+ white-space: nowrap;
+ }
+ .table-responsive > .table-bordered {
+ border: 0;
+ }
+ .table-responsive > .table-bordered > thead > tr > th:first-child,
+ .table-responsive > .table-bordered > tbody > tr > th:first-child,
+ .table-responsive > .table-bordered > tfoot > tr > th:first-child,
+ .table-responsive > .table-bordered > thead > tr > td:first-child,
+ .table-responsive > .table-bordered > tbody > tr > td:first-child,
+ .table-responsive > .table-bordered > tfoot > tr > td:first-child {
+ border-left: 0;
+ }
+ .table-responsive > .table-bordered > thead > tr > th:last-child,
+ .table-responsive > .table-bordered > tbody > tr > th:last-child,
+ .table-responsive > .table-bordered > tfoot > tr > th:last-child,
+ .table-responsive > .table-bordered > thead > tr > td:last-child,
+ .table-responsive > .table-bordered > tbody > tr > td:last-child,
+ .table-responsive > .table-bordered > tfoot > tr > td:last-child {
+ border-right: 0;
+ }
+ .table-responsive > .table-bordered > thead > tr:last-child > th,
+ .table-responsive > .table-bordered > tbody > tr:last-child > th,
+ .table-responsive > .table-bordered > tfoot > tr:last-child > th,
+ .table-responsive > .table-bordered > thead > tr:last-child > td,
+ .table-responsive > .table-bordered > tbody > tr:last-child > td,
+ .table-responsive > .table-bordered > tfoot > tr:last-child > td {
+ border-bottom: 0;
+ }
+}
+
+fieldset {
+ padding: 0;
+ margin: 0;
+ border: 0;
+}
+
+legend {
+ display: block;
+ width: 100%;
+ padding: 0;
+ margin-bottom: 20px;
+ font-size: 21px;
+ line-height: inherit;
+ color: #333333;
+ border: 0;
+ border-bottom: 1px solid #e5e5e5;
+}
+
+label {
+ display: inline-block;
+ margin-bottom: 5px;
+ font-weight: bold;
+}
+
+input[type="search"] {
+ -webkit-box-sizing: border-box;
+ -moz-box-sizing: border-box;
+ box-sizing: border-box;
+}
+
+input[type="radio"],
+input[type="checkbox"] {
+ margin: 4px 0 0;
+ margin-top: 1px \9;
+ /* IE8-9 */
+
+ line-height: normal;
+}
+
+input[type="file"] {
+ display: block;
+}
+
+select[multiple],
+select[size] {
+ height: auto;
+}
+
+select optgroup {
+ font-family: inherit;
+ font-size: inherit;
+ font-style: inherit;
+}
+
+input[type="file"]:focus,
+input[type="radio"]:focus,
+input[type="checkbox"]:focus {
+ outline: thin dotted #333;
+ outline: 5px auto -webkit-focus-ring-color;
+ outline-offset: -2px;
+}
+
+input[type="number"]::-webkit-outer-spin-button,
+input[type="number"]::-webkit-inner-spin-button {
+ height: auto;
+}
+
+.form-control:-moz-placeholder {
+ color: #999999;
+}
+
+.form-control::-moz-placeholder {
+ color: #999999;
+}
+
+.form-control:-ms-input-placeholder {
+ color: #999999;
+}
+
+.form-control::-webkit-input-placeholder {
+ color: #999999;
+}
+
+.form-control {
+ display: block;
+ width: 100%;
+ height: 34px;
+ padding: 6px 12px;
+ font-size: 14px;
+ line-height: 1.428571429;
+ color: #555555;
+ vertical-align: middle;
+ background-color: #ffffff;
+ border: 1px solid #cccccc;
+ border-radius: 4px;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+ -webkit-transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
+ transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
+}
+
+.form-control:focus {
+ border-color: #66afe9;
+ outline: 0;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);
+}
+
+.form-control[disabled],
+.form-control[readonly],
+fieldset[disabled] .form-control {
+ cursor: not-allowed;
+ background-color: #eeeeee;
+}
+
+textarea.form-control {
+ height: auto;
+}
+
+.form-group {
+ margin-bottom: 15px;
+}
+
+.radio,
+.checkbox {
+ display: block;
+ min-height: 20px;
+ padding-left: 20px;
+ margin-top: 10px;
+ margin-bottom: 10px;
+ vertical-align: middle;
+}
+
+.radio label,
+.checkbox label {
+ display: inline;
+ margin-bottom: 0;
+ font-weight: normal;
+ cursor: pointer;
+}
+
+.radio input[type="radio"],
+.radio-inline input[type="radio"],
+.checkbox input[type="checkbox"],
+.checkbox-inline input[type="checkbox"] {
+ float: left;
+ margin-left: -20px;
+}
+
+.radio + .radio,
+.checkbox + .checkbox {
+ margin-top: -5px;
+}
+
+.radio-inline,
+.checkbox-inline {
+ display: inline-block;
+ padding-left: 20px;
+ margin-bottom: 0;
+ font-weight: normal;
+ vertical-align: middle;
+ cursor: pointer;
+}
+
+.radio-inline + .radio-inline,
+.checkbox-inline + .checkbox-inline {
+ margin-top: 0;
+ margin-left: 10px;
+}
+
+input[type="radio"][disabled],
+input[type="checkbox"][disabled],
+.radio[disabled],
+.radio-inline[disabled],
+.checkbox[disabled],
+.checkbox-inline[disabled],
+fieldset[disabled] input[type="radio"],
+fieldset[disabled] input[type="checkbox"],
+fieldset[disabled] .radio,
+fieldset[disabled] .radio-inline,
+fieldset[disabled] .checkbox,
+fieldset[disabled] .checkbox-inline {
+ cursor: not-allowed;
+}
+
+.input-sm {
+ height: 30px;
+ padding: 5px 10px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+
+select.input-sm {
+ height: 30px;
+ line-height: 30px;
+}
+
+textarea.input-sm {
+ height: auto;
+}
+
+.input-lg {
+ height: 45px;
+ padding: 10px 16px;
+ font-size: 18px;
+ line-height: 1.33;
+ border-radius: 6px;
+}
+
+select.input-lg {
+ height: 45px;
+ line-height: 45px;
+}
+
+textarea.input-lg {
+ height: auto;
+}
+
+.has-warning .help-block,
+.has-warning .control-label {
+ color: #c09853;
+}
+
+.has-warning .form-control {
+ border-color: #c09853;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+
+.has-warning .form-control:focus {
+ border-color: #a47e3c;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #dbc59e;
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #dbc59e;
+}
+
+.has-warning .input-group-addon {
+ color: #c09853;
+ background-color: #fcf8e3;
+ border-color: #c09853;
+}
+
+.has-error .help-block,
+.has-error .control-label {
+ color: #b94a48;
+}
+
+.has-error .form-control {
+ border-color: #b94a48;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+
+.has-error .form-control:focus {
+ border-color: #953b39;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #d59392;
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #d59392;
+}
+
+.has-error .input-group-addon {
+ color: #b94a48;
+ background-color: #f2dede;
+ border-color: #b94a48;
+}
+
+.has-success .help-block,
+.has-success .control-label {
+ color: #468847;
+}
+
+.has-success .form-control {
+ border-color: #468847;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+
+.has-success .form-control:focus {
+ border-color: #356635;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #7aba7b;
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #7aba7b;
+}
+
+.has-success .input-group-addon {
+ color: #468847;
+ background-color: #dff0d8;
+ border-color: #468847;
+}
+
+.form-control-static {
+ padding-top: 7px;
+ margin-bottom: 0;
+}
+
+.help-block {
+ display: block;
+ margin-top: 5px;
+ margin-bottom: 10px;
+ color: #737373;
+}
+
+@media (min-width: 768px) {
+ .form-inline .form-group {
+ display: inline-block;
+ margin-bottom: 0;
+ vertical-align: middle;
+ }
+ .form-inline .form-control {
+ display: inline-block;
+ }
+ .form-inline .radio,
+ .form-inline .checkbox {
+ display: inline-block;
+ padding-left: 0;
+ margin-top: 0;
+ margin-bottom: 0;
+ }
+ .form-inline .radio input[type="radio"],
+ .form-inline .checkbox input[type="checkbox"] {
+ float: none;
+ margin-left: 0;
+ }
+}
+
+.form-horizontal .control-label,
+.form-horizontal .radio,
+.form-horizontal .checkbox,
+.form-horizontal .radio-inline,
+.form-horizontal .checkbox-inline {
+ padding-top: 7px;
+ margin-top: 0;
+ margin-bottom: 0;
+}
+
+.form-horizontal .form-group {
+ margin-right: -15px;
+ margin-left: -15px;
+}
+
+.form-horizontal .form-group:before,
+.form-horizontal .form-group:after {
+ display: table;
+ content: " ";
+}
+
+.form-horizontal .form-group:after {
+ clear: both;
+}
+
+.form-horizontal .form-group:before,
+.form-horizontal .form-group:after {
+ display: table;
+ content: " ";
+}
+
+.form-horizontal .form-group:after {
+ clear: both;
+}
+
+@media (min-width: 768px) {
+ .form-horizontal .control-label {
+ text-align: right;
+ }
+}
+
+.btn {
+ display: inline-block;
+ padding: 6px 12px;
+ margin-bottom: 0;
+ font-size: 14px;
+ font-weight: normal;
+ line-height: 1.428571429;
+ text-align: center;
+ white-space: nowrap;
+ vertical-align: middle;
+ cursor: pointer;
+ border: 1px solid transparent;
+ border-radius: 4px;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ -o-user-select: none;
+ user-select: none;
+}
+
+.btn:focus {
+ outline: thin dotted #333;
+ outline: 5px auto -webkit-focus-ring-color;
+ outline-offset: -2px;
+}
+
+.btn:hover,
+.btn:focus {
+ color: #333333;
+ text-decoration: none;
+}
+
+.btn:active,
+.btn.active {
+ background-image: none;
+ outline: 0;
+ -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
+ box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
+}
+
+.btn.disabled,
+.btn[disabled],
+fieldset[disabled] .btn {
+ pointer-events: none;
+ cursor: not-allowed;
+ opacity: 0.65;
+ filter: alpha(opacity=65);
+ -webkit-box-shadow: none;
+ box-shadow: none;
+}
+
+.btn-default {
+ color: #333333;
+ background-color: #ffffff;
+ border-color: #cccccc;
+}
+
+.btn-default:hover,
+.btn-default:focus,
+.btn-default:active,
+.btn-default.active,
+.open .dropdown-toggle.btn-default {
+ color: #333333;
+ background-color: #ebebeb;
+ border-color: #adadad;
+}
+
+.btn-default:active,
+.btn-default.active,
+.open .dropdown-toggle.btn-default {
+ background-image: none;
+}
+
+.btn-default.disabled,
+.btn-default[disabled],
+fieldset[disabled] .btn-default,
+.btn-default.disabled:hover,
+.btn-default[disabled]:hover,
+fieldset[disabled] .btn-default:hover,
+.btn-default.disabled:focus,
+.btn-default[disabled]:focus,
+fieldset[disabled] .btn-default:focus,
+.btn-default.disabled:active,
+.btn-default[disabled]:active,
+fieldset[disabled] .btn-default:active,
+.btn-default.disabled.active,
+.btn-default[disabled].active,
+fieldset[disabled] .btn-default.active {
+ background-color: #ffffff;
+ border-color: #cccccc;
+}
+
+.btn-primary {
+ color: #ffffff;
+ background-color: #428bca;
+ border-color: #357ebd;
+}
+
+.btn-primary:hover,
+.btn-primary:focus,
+.btn-primary:active,
+.btn-primary.active,
+.open .dropdown-toggle.btn-primary {
+ color: #ffffff;
+ background-color: #3276b1;
+ border-color: #285e8e;
+}
+
+.btn-primary:active,
+.btn-primary.active,
+.open .dropdown-toggle.btn-primary {
+ background-image: none;
+}
+
+.btn-primary.disabled,
+.btn-primary[disabled],
+fieldset[disabled] .btn-primary,
+.btn-primary.disabled:hover,
+.btn-primary[disabled]:hover,
+fieldset[disabled] .btn-primary:hover,
+.btn-primary.disabled:focus,
+.btn-primary[disabled]:focus,
+fieldset[disabled] .btn-primary:focus,
+.btn-primary.disabled:active,
+.btn-primary[disabled]:active,
+fieldset[disabled] .btn-primary:active,
+.btn-primary.disabled.active,
+.btn-primary[disabled].active,
+fieldset[disabled] .btn-primary.active {
+ background-color: #428bca;
+ border-color: #357ebd;
+}
+
+.btn-warning {
+ color: #ffffff;
+ background-color: #f0ad4e;
+ border-color: #eea236;
+}
+
+.btn-warning:hover,
+.btn-warning:focus,
+.btn-warning:active,
+.btn-warning.active,
+.open .dropdown-toggle.btn-warning {
+ color: #ffffff;
+ background-color: #ed9c28;
+ border-color: #d58512;
+}
+
+.btn-warning:active,
+.btn-warning.active,
+.open .dropdown-toggle.btn-warning {
+ background-image: none;
+}
+
+.btn-warning.disabled,
+.btn-warning[disabled],
+fieldset[disabled] .btn-warning,
+.btn-warning.disabled:hover,
+.btn-warning[disabled]:hover,
+fieldset[disabled] .btn-warning:hover,
+.btn-warning.disabled:focus,
+.btn-warning[disabled]:focus,
+fieldset[disabled] .btn-warning:focus,
+.btn-warning.disabled:active,
+.btn-warning[disabled]:active,
+fieldset[disabled] .btn-warning:active,
+.btn-warning.disabled.active,
+.btn-warning[disabled].active,
+fieldset[disabled] .btn-warning.active {
+ background-color: #f0ad4e;
+ border-color: #eea236;
+}
+
+.btn-danger {
+ color: #ffffff;
+ background-color: #d9534f;
+ border-color: #d43f3a;
+}
+
+.btn-danger:hover,
+.btn-danger:focus,
+.btn-danger:active,
+.btn-danger.active,
+.open .dropdown-toggle.btn-danger {
+ color: #ffffff;
+ background-color: #d2322d;
+ border-color: #ac2925;
+}
+
+.btn-danger:active,
+.btn-danger.active,
+.open .dropdown-toggle.btn-danger {
+ background-image: none;
+}
+
+.btn-danger.disabled,
+.btn-danger[disabled],
+fieldset[disabled] .btn-danger,
+.btn-danger.disabled:hover,
+.btn-danger[disabled]:hover,
+fieldset[disabled] .btn-danger:hover,
+.btn-danger.disabled:focus,
+.btn-danger[disabled]:focus,
+fieldset[disabled] .btn-danger:focus,
+.btn-danger.disabled:active,
+.btn-danger[disabled]:active,
+fieldset[disabled] .btn-danger:active,
+.btn-danger.disabled.active,
+.btn-danger[disabled].active,
+fieldset[disabled] .btn-danger.active {
+ background-color: #d9534f;
+ border-color: #d43f3a;
+}
+
+.btn-success {
+ color: #ffffff;
+ background-color: #5cb85c;
+ border-color: #4cae4c;
+}
+
+.btn-success:hover,
+.btn-success:focus,
+.btn-success:active,
+.btn-success.active,
+.open .dropdown-toggle.btn-success {
+ color: #ffffff;
+ background-color: #47a447;
+ border-color: #398439;
+}
+
+.btn-success:active,
+.btn-success.active,
+.open .dropdown-toggle.btn-success {
+ background-image: none;
+}
+
+.btn-success.disabled,
+.btn-success[disabled],
+fieldset[disabled] .btn-success,
+.btn-success.disabled:hover,
+.btn-success[disabled]:hover,
+fieldset[disabled] .btn-success:hover,
+.btn-success.disabled:focus,
+.btn-success[disabled]:focus,
+fieldset[disabled] .btn-success:focus,
+.btn-success.disabled:active,
+.btn-success[disabled]:active,
+fieldset[disabled] .btn-success:active,
+.btn-success.disabled.active,
+.btn-success[disabled].active,
+fieldset[disabled] .btn-success.active {
+ background-color: #5cb85c;
+ border-color: #4cae4c;
+}
+
+.btn-info {
+ color: #ffffff;
+ background-color: #5bc0de;
+ border-color: #46b8da;
+}
+
+.btn-info:hover,
+.btn-info:focus,
+.btn-info:active,
+.btn-info.active,
+.open .dropdown-toggle.btn-info {
+ color: #ffffff;
+ background-color: #39b3d7;
+ border-color: #269abc;
+}
+
+.btn-info:active,
+.btn-info.active,
+.open .dropdown-toggle.btn-info {
+ background-image: none;
+}
+
+.btn-info.disabled,
+.btn-info[disabled],
+fieldset[disabled] .btn-info,
+.btn-info.disabled:hover,
+.btn-info[disabled]:hover,
+fieldset[disabled] .btn-info:hover,
+.btn-info.disabled:focus,
+.btn-info[disabled]:focus,
+fieldset[disabled] .btn-info:focus,
+.btn-info.disabled:active,
+.btn-info[disabled]:active,
+fieldset[disabled] .btn-info:active,
+.btn-info.disabled.active,
+.btn-info[disabled].active,
+fieldset[disabled] .btn-info.active {
+ background-color: #5bc0de;
+ border-color: #46b8da;
+}
+
+.btn-link {
+ font-weight: normal;
+ color: #428bca;
+ cursor: pointer;
+ border-radius: 0;
+}
+
+.btn-link,
+.btn-link:active,
+.btn-link[disabled],
+fieldset[disabled] .btn-link {
+ background-color: transparent;
+ -webkit-box-shadow: none;
+ box-shadow: none;
+}
+
+.btn-link,
+.btn-link:hover,
+.btn-link:focus,
+.btn-link:active {
+ border-color: transparent;
+}
+
+.btn-link:hover,
+.btn-link:focus {
+ color: #2a6496;
+ text-decoration: underline;
+ background-color: transparent;
+}
+
+.btn-link[disabled]:hover,
+fieldset[disabled] .btn-link:hover,
+.btn-link[disabled]:focus,
+fieldset[disabled] .btn-link:focus {
+ color: #999999;
+ text-decoration: none;
+}
+
+.btn-lg {
+ padding: 10px 16px;
+ font-size: 18px;
+ line-height: 1.33;
+ border-radius: 6px;
+}
+
+.btn-sm,
+.btn-xs {
+ padding: 5px 10px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+
+.btn-xs {
+ padding: 1px 5px;
+}
+
+.btn-block {
+ display: block;
+ width: 100%;
+ padding-right: 0;
+ padding-left: 0;
+}
+
+.btn-block + .btn-block {
+ margin-top: 5px;
+}
+
+input[type="submit"].btn-block,
+input[type="reset"].btn-block,
+input[type="button"].btn-block {
+ width: 100%;
+}
+
+.fade {
+ opacity: 0;
+ -webkit-transition: opacity 0.15s linear;
+ transition: opacity 0.15s linear;
+}
+
+.fade.in {
+ opacity: 1;
+}
+
+.collapse {
+ display: none;
+}
+
+.collapse.in {
+ display: block;
+}
+
+.collapsing {
+ position: relative;
+ height: 0;
+ overflow: hidden;
+ -webkit-transition: height 0.35s ease;
+ transition: height 0.35s ease;
+}
+
+@font-face {
+ font-family: 'Glyphicons Halflings';
+ src: url('../fonts/glyphicons-halflings-regular.eot');
+ src: url('../fonts/glyphicons-halflings-regular.eot?#iefix') format('embedded-opentype'), url('../fonts/glyphicons-halflings-regular.woff') format('woff'), url('../fonts/glyphicons-halflings-regular.ttf') format('truetype'), url('../fonts/glyphicons-halflings-regular.svg#glyphicons-halflingsregular') format('svg');
+}
+
+.glyphicon {
+ position: relative;
+ top: 1px;
+ display: inline-block;
+ font-family: 'Glyphicons Halflings';
+ -webkit-font-smoothing: antialiased;
+ font-style: normal;
+ font-weight: normal;
+ line-height: 1;
+}
+
+.glyphicon-asterisk:before {
+ content: "\2a";
+}
+
+.glyphicon-plus:before {
+ content: "\2b";
+}
+
+.glyphicon-euro:before {
+ content: "\20ac";
+}
+
+.glyphicon-minus:before {
+ content: "\2212";
+}
+
+.glyphicon-cloud:before {
+ content: "\2601";
+}
+
+.glyphicon-envelope:before {
+ content: "\2709";
+}
+
+.glyphicon-pencil:before {
+ content: "\270f";
+}
+
+.glyphicon-glass:before {
+ content: "\e001";
+}
+
+.glyphicon-music:before {
+ content: "\e002";
+}
+
+.glyphicon-search:before {
+ content: "\e003";
+}
+
+.glyphicon-heart:before {
+ content: "\e005";
+}
+
+.glyphicon-star:before {
+ content: "\e006";
+}
+
+.glyphicon-star-empty:before {
+ content: "\e007";
+}
+
+.glyphicon-user:before {
+ content: "\e008";
+}
+
+.glyphicon-film:before {
+ content: "\e009";
+}
+
+.glyphicon-th-large:before {
+ content: "\e010";
+}
+
+.glyphicon-th:before {
+ content: "\e011";
+}
+
+.glyphicon-th-list:before {
+ content: "\e012";
+}
+
+.glyphicon-ok:before {
+ content: "\e013";
+}
+
+.glyphicon-remove:before {
+ content: "\e014";
+}
+
+.glyphicon-zoom-in:before {
+ content: "\e015";
+}
+
+.glyphicon-zoom-out:before {
+ content: "\e016";
+}
+
+.glyphicon-off:before {
+ content: "\e017";
+}
+
+.glyphicon-signal:before {
+ content: "\e018";
+}
+
+.glyphicon-cog:before {
+ content: "\e019";
+}
+
+.glyphicon-trash:before {
+ content: "\e020";
+}
+
+.glyphicon-home:before {
+ content: "\e021";
+}
+
+.glyphicon-file:before {
+ content: "\e022";
+}
+
+.glyphicon-time:before {
+ content: "\e023";
+}
+
+.glyphicon-road:before {
+ content: "\e024";
+}
+
+.glyphicon-download-alt:before {
+ content: "\e025";
+}
+
+.glyphicon-download:before {
+ content: "\e026";
+}
+
+.glyphicon-upload:before {
+ content: "\e027";
+}
+
+.glyphicon-inbox:before {
+ content: "\e028";
+}
+
+.glyphicon-play-circle:before {
+ content: "\e029";
+}
+
+.glyphicon-repeat:before {
+ content: "\e030";
+}
+
+.glyphicon-refresh:before {
+ content: "\e031";
+}
+
+.glyphicon-list-alt:before {
+ content: "\e032";
+}
+
+.glyphicon-flag:before {
+ content: "\e034";
+}
+
+.glyphicon-headphones:before {
+ content: "\e035";
+}
+
+.glyphicon-volume-off:before {
+ content: "\e036";
+}
+
+.glyphicon-volume-down:before {
+ content: "\e037";
+}
+
+.glyphicon-volume-up:before {
+ content: "\e038";
+}
+
+.glyphicon-qrcode:before {
+ content: "\e039";
+}
+
+.glyphicon-barcode:before {
+ content: "\e040";
+}
+
+.glyphicon-tag:before {
+ content: "\e041";
+}
+
+.glyphicon-tags:before {
+ content: "\e042";
+}
+
+.glyphicon-book:before {
+ content: "\e043";
+}
+
+.glyphicon-print:before {
+ content: "\e045";
+}
+
+.glyphicon-font:before {
+ content: "\e047";
+}
+
+.glyphicon-bold:before {
+ content: "\e048";
+}
+
+.glyphicon-italic:before {
+ content: "\e049";
+}
+
+.glyphicon-text-height:before {
+ content: "\e050";
+}
+
+.glyphicon-text-width:before {
+ content: "\e051";
+}
+
+.glyphicon-align-left:before {
+ content: "\e052";
+}
+
+.glyphicon-align-center:before {
+ content: "\e053";
+}
+
+.glyphicon-align-right:before {
+ content: "\e054";
+}
+
+.glyphicon-align-justify:before {
+ content: "\e055";
+}
+
+.glyphicon-list:before {
+ content: "\e056";
+}
+
+.glyphicon-indent-left:before {
+ content: "\e057";
+}
+
+.glyphicon-indent-right:before {
+ content: "\e058";
+}
+
+.glyphicon-facetime-video:before {
+ content: "\e059";
+}
+
+.glyphicon-picture:before {
+ content: "\e060";
+}
+
+.glyphicon-map-marker:before {
+ content: "\e062";
+}
+
+.glyphicon-adjust:before {
+ content: "\e063";
+}
+
+.glyphicon-tint:before {
+ content: "\e064";
+}
+
+.glyphicon-edit:before {
+ content: "\e065";
+}
+
+.glyphicon-share:before {
+ content: "\e066";
+}
+
+.glyphicon-check:before {
+ content: "\e067";
+}
+
+.glyphicon-move:before {
+ content: "\e068";
+}
+
+.glyphicon-step-backward:before {
+ content: "\e069";
+}
+
+.glyphicon-fast-backward:before {
+ content: "\e070";
+}
+
+.glyphicon-backward:before {
+ content: "\e071";
+}
+
+.glyphicon-play:before {
+ content: "\e072";
+}
+
+.glyphicon-pause:before {
+ content: "\e073";
+}
+
+.glyphicon-stop:before {
+ content: "\e074";
+}
+
+.glyphicon-forward:before {
+ content: "\e075";
+}
+
+.glyphicon-fast-forward:before {
+ content: "\e076";
+}
+
+.glyphicon-step-forward:before {
+ content: "\e077";
+}
+
+.glyphicon-eject:before {
+ content: "\e078";
+}
+
+.glyphicon-chevron-left:before {
+ content: "\e079";
+}
+
+.glyphicon-chevron-right:before {
+ content: "\e080";
+}
+
+.glyphicon-plus-sign:before {
+ content: "\e081";
+}
+
+.glyphicon-minus-sign:before {
+ content: "\e082";
+}
+
+.glyphicon-remove-sign:before {
+ content: "\e083";
+}
+
+.glyphicon-ok-sign:before {
+ content: "\e084";
+}
+
+.glyphicon-question-sign:before {
+ content: "\e085";
+}
+
+.glyphicon-info-sign:before {
+ content: "\e086";
+}
+
+.glyphicon-screenshot:before {
+ content: "\e087";
+}
+
+.glyphicon-remove-circle:before {
+ content: "\e088";
+}
+
+.glyphicon-ok-circle:before {
+ content: "\e089";
+}
+
+.glyphicon-ban-circle:before {
+ content: "\e090";
+}
+
+.glyphicon-arrow-left:before {
+ content: "\e091";
+}
+
+.glyphicon-arrow-right:before {
+ content: "\e092";
+}
+
+.glyphicon-arrow-up:before {
+ content: "\e093";
+}
+
+.glyphicon-arrow-down:before {
+ content: "\e094";
+}
+
+.glyphicon-share-alt:before {
+ content: "\e095";
+}
+
+.glyphicon-resize-full:before {
+ content: "\e096";
+}
+
+.glyphicon-resize-small:before {
+ content: "\e097";
+}
+
+.glyphicon-exclamation-sign:before {
+ content: "\e101";
+}
+
+.glyphicon-gift:before {
+ content: "\e102";
+}
+
+.glyphicon-leaf:before {
+ content: "\e103";
+}
+
+.glyphicon-eye-open:before {
+ content: "\e105";
+}
+
+.glyphicon-eye-close:before {
+ content: "\e106";
+}
+
+.glyphicon-warning-sign:before {
+ content: "\e107";
+}
+
+.glyphicon-plane:before {
+ content: "\e108";
+}
+
+.glyphicon-random:before {
+ content: "\e110";
+}
+
+.glyphicon-comment:before {
+ content: "\e111";
+}
+
+.glyphicon-magnet:before {
+ content: "\e112";
+}
+
+.glyphicon-chevron-up:before {
+ content: "\e113";
+}
+
+.glyphicon-chevron-down:before {
+ content: "\e114";
+}
+
+.glyphicon-retweet:before {
+ content: "\e115";
+}
+
+.glyphicon-shopping-cart:before {
+ content: "\e116";
+}
+
+.glyphicon-folder-close:before {
+ content: "\e117";
+}
+
+.glyphicon-folder-open:before {
+ content: "\e118";
+}
+
+.glyphicon-resize-vertical:before {
+ content: "\e119";
+}
+
+.glyphicon-resize-horizontal:before {
+ content: "\e120";
+}
+
+.glyphicon-hdd:before {
+ content: "\e121";
+}
+
+.glyphicon-bullhorn:before {
+ content: "\e122";
+}
+
+.glyphicon-certificate:before {
+ content: "\e124";
+}
+
+.glyphicon-thumbs-up:before {
+ content: "\e125";
+}
+
+.glyphicon-thumbs-down:before {
+ content: "\e126";
+}
+
+.glyphicon-hand-right:before {
+ content: "\e127";
+}
+
+.glyphicon-hand-left:before {
+ content: "\e128";
+}
+
+.glyphicon-hand-up:before {
+ content: "\e129";
+}
+
+.glyphicon-hand-down:before {
+ content: "\e130";
+}
+
+.glyphicon-circle-arrow-right:before {
+ content: "\e131";
+}
+
+.glyphicon-circle-arrow-left:before {
+ content: "\e132";
+}
+
+.glyphicon-circle-arrow-up:before {
+ content: "\e133";
+}
+
+.glyphicon-circle-arrow-down:before {
+ content: "\e134";
+}
+
+.glyphicon-globe:before {
+ content: "\e135";
+}
+
+.glyphicon-tasks:before {
+ content: "\e137";
+}
+
+.glyphicon-filter:before {
+ content: "\e138";
+}
+
+.glyphicon-fullscreen:before {
+ content: "\e140";
+}
+
+.glyphicon-dashboard:before {
+ content: "\e141";
+}
+
+.glyphicon-heart-empty:before {
+ content: "\e143";
+}
+
+.glyphicon-link:before {
+ content: "\e144";
+}
+
+.glyphicon-phone:before {
+ content: "\e145";
+}
+
+.glyphicon-usd:before {
+ content: "\e148";
+}
+
+.glyphicon-gbp:before {
+ content: "\e149";
+}
+
+.glyphicon-sort:before {
+ content: "\e150";
+}
+
+.glyphicon-sort-by-alphabet:before {
+ content: "\e151";
+}
+
+.glyphicon-sort-by-alphabet-alt:before {
+ content: "\e152";
+}
+
+.glyphicon-sort-by-order:before {
+ content: "\e153";
+}
+
+.glyphicon-sort-by-order-alt:before {
+ content: "\e154";
+}
+
+.glyphicon-sort-by-attributes:before {
+ content: "\e155";
+}
+
+.glyphicon-sort-by-attributes-alt:before {
+ content: "\e156";
+}
+
+.glyphicon-unchecked:before {
+ content: "\e157";
+}
+
+.glyphicon-expand:before {
+ content: "\e158";
+}
+
+.glyphicon-collapse-down:before {
+ content: "\e159";
+}
+
+.glyphicon-collapse-up:before {
+ content: "\e160";
+}
+
+.glyphicon-log-in:before {
+ content: "\e161";
+}
+
+.glyphicon-flash:before {
+ content: "\e162";
+}
+
+.glyphicon-log-out:before {
+ content: "\e163";
+}
+
+.glyphicon-new-window:before {
+ content: "\e164";
+}
+
+.glyphicon-record:before {
+ content: "\e165";
+}
+
+.glyphicon-save:before {
+ content: "\e166";
+}
+
+.glyphicon-open:before {
+ content: "\e167";
+}
+
+.glyphicon-saved:before {
+ content: "\e168";
+}
+
+.glyphicon-import:before {
+ content: "\e169";
+}
+
+.glyphicon-export:before {
+ content: "\e170";
+}
+
+.glyphicon-send:before {
+ content: "\e171";
+}
+
+.glyphicon-floppy-disk:before {
+ content: "\e172";
+}
+
+.glyphicon-floppy-saved:before {
+ content: "\e173";
+}
+
+.glyphicon-floppy-remove:before {
+ content: "\e174";
+}
+
+.glyphicon-floppy-save:before {
+ content: "\e175";
+}
+
+.glyphicon-floppy-open:before {
+ content: "\e176";
+}
+
+.glyphicon-credit-card:before {
+ content: "\e177";
+}
+
+.glyphicon-transfer:before {
+ content: "\e178";
+}
+
+.glyphicon-cutlery:before {
+ content: "\e179";
+}
+
+.glyphicon-header:before {
+ content: "\e180";
+}
+
+.glyphicon-compressed:before {
+ content: "\e181";
+}
+
+.glyphicon-earphone:before {
+ content: "\e182";
+}
+
+.glyphicon-phone-alt:before {
+ content: "\e183";
+}
+
+.glyphicon-tower:before {
+ content: "\e184";
+}
+
+.glyphicon-stats:before {
+ content: "\e185";
+}
+
+.glyphicon-sd-video:before {
+ content: "\e186";
+}
+
+.glyphicon-hd-video:before {
+ content: "\e187";
+}
+
+.glyphicon-subtitles:before {
+ content: "\e188";
+}
+
+.glyphicon-sound-stereo:before {
+ content: "\e189";
+}
+
+.glyphicon-sound-dolby:before {
+ content: "\e190";
+}
+
+.glyphicon-sound-5-1:before {
+ content: "\e191";
+}
+
+.glyphicon-sound-6-1:before {
+ content: "\e192";
+}
+
+.glyphicon-sound-7-1:before {
+ content: "\e193";
+}
+
+.glyphicon-copyright-mark:before {
+ content: "\e194";
+}
+
+.glyphicon-registration-mark:before {
+ content: "\e195";
+}
+
+.glyphicon-cloud-download:before {
+ content: "\e197";
+}
+
+.glyphicon-cloud-upload:before {
+ content: "\e198";
+}
+
+.glyphicon-tree-conifer:before {
+ content: "\e199";
+}
+
+.glyphicon-tree-deciduous:before {
+ content: "\e200";
+}
+
+.glyphicon-briefcase:before {
+ content: "\1f4bc";
+}
+
+.glyphicon-calendar:before {
+ content: "\1f4c5";
+}
+
+.glyphicon-pushpin:before {
+ content: "\1f4cc";
+}
+
+.glyphicon-paperclip:before {
+ content: "\1f4ce";
+}
+
+.glyphicon-camera:before {
+ content: "\1f4f7";
+}
+
+.glyphicon-lock:before {
+ content: "\1f512";
+}
+
+.glyphicon-bell:before {
+ content: "\1f514";
+}
+
+.glyphicon-bookmark:before {
+ content: "\1f516";
+}
+
+.glyphicon-fire:before {
+ content: "\1f525";
+}
+
+.glyphicon-wrench:before {
+ content: "\1f527";
+}
+
+.caret {
+ display: inline-block;
+ width: 0;
+ height: 0;
+ margin-left: 2px;
+ vertical-align: middle;
+ border-top: 4px solid #000000;
+ border-right: 4px solid transparent;
+ border-bottom: 0 dotted;
+ border-left: 4px solid transparent;
+ content: "";
+}
+
+.dropdown {
+ position: relative;
+}
+
+.dropdown-toggle:focus {
+ outline: 0;
+}
+
+.dropdown-menu {
+ position: absolute;
+ top: 100%;
+ left: 0;
+ z-index: 1000;
+ display: none;
+ float: left;
+ min-width: 160px;
+ padding: 5px 0;
+ margin: 2px 0 0;
+ font-size: 14px;
+ list-style: none;
+ background-color: #ffffff;
+ border: 1px solid #cccccc;
+ border: 1px solid rgba(0, 0, 0, 0.15);
+ border-radius: 4px;
+ -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);
+ box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);
+ background-clip: padding-box;
+}
+
+.dropdown-menu.pull-right {
+ right: 0;
+ left: auto;
+}
+
+.dropdown-menu .divider {
+ height: 1px;
+ margin: 9px 0;
+ overflow: hidden;
+ background-color: #e5e5e5;
+}
+
+.dropdown-menu > li > a {
+ display: block;
+ padding: 3px 20px;
+ clear: both;
+ font-weight: normal;
+ line-height: 1.428571429;
+ color: #333333;
+ white-space: nowrap;
+}
+
+.dropdown-menu > li > a:hover,
+.dropdown-menu > li > a:focus {
+ color: #ffffff;
+ text-decoration: none;
+ background-color: #428bca;
+}
+
+.dropdown-menu > .active > a,
+.dropdown-menu > .active > a:hover,
+.dropdown-menu > .active > a:focus {
+ color: #ffffff;
+ text-decoration: none;
+ background-color: #428bca;
+ outline: 0;
+}
+
+.dropdown-menu > .disabled > a,
+.dropdown-menu > .disabled > a:hover,
+.dropdown-menu > .disabled > a:focus {
+ color: #999999;
+}
+
+.dropdown-menu > .disabled > a:hover,
+.dropdown-menu > .disabled > a:focus {
+ text-decoration: none;
+ cursor: not-allowed;
+ background-color: transparent;
+ background-image: none;
+ filter: progid:DXImageTransform.Microsoft.gradient(enabled=false);
+}
+
+.open > .dropdown-menu {
+ display: block;
+}
+
+.open > a {
+ outline: 0;
+}
+
+.dropdown-header {
+ display: block;
+ padding: 3px 20px;
+ font-size: 12px;
+ line-height: 1.428571429;
+ color: #999999;
+}
+
+.dropdown-backdrop {
+ position: fixed;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ z-index: 990;
+}
+
+.pull-right > .dropdown-menu {
+ right: 0;
+ left: auto;
+}
+
+.dropup .caret,
+.navbar-fixed-bottom .dropdown .caret {
+ border-top: 0 dotted;
+ border-bottom: 4px solid #000000;
+ content: "";
+}
+
+.dropup .dropdown-menu,
+.navbar-fixed-bottom .dropdown .dropdown-menu {
+ top: auto;
+ bottom: 100%;
+ margin-bottom: 1px;
+}
+
+@media (min-width: 768px) {
+ .navbar-right .dropdown-menu {
+ right: 0;
+ left: auto;
+ }
+}
+
+.btn-default .caret {
+ border-top-color: #333333;
+}
+
+.btn-primary .caret,
+.btn-success .caret,
+.btn-warning .caret,
+.btn-danger .caret,
+.btn-info .caret {
+ border-top-color: #fff;
+}
+
+.dropup .btn-default .caret {
+ border-bottom-color: #333333;
+}
+
+.dropup .btn-primary .caret,
+.dropup .btn-success .caret,
+.dropup .btn-warning .caret,
+.dropup .btn-danger .caret,
+.dropup .btn-info .caret {
+ border-bottom-color: #fff;
+}
+
+.btn-group,
+.btn-group-vertical {
+ position: relative;
+ display: inline-block;
+ vertical-align: middle;
+}
+
+.btn-group > .btn,
+.btn-group-vertical > .btn {
+ position: relative;
+ float: left;
+}
+
+.btn-group > .btn:hover,
+.btn-group-vertical > .btn:hover,
+.btn-group > .btn:focus,
+.btn-group-vertical > .btn:focus,
+.btn-group > .btn:active,
+.btn-group-vertical > .btn:active,
+.btn-group > .btn.active,
+.btn-group-vertical > .btn.active {
+ z-index: 2;
+}
+
+.btn-group > .btn:focus,
+.btn-group-vertical > .btn:focus {
+ outline: none;
+}
+
+.btn-group .btn + .btn,
+.btn-group .btn + .btn-group,
+.btn-group .btn-group + .btn,
+.btn-group .btn-group + .btn-group {
+ margin-left: -1px;
+}
+
+.btn-toolbar:before,
+.btn-toolbar:after {
+ display: table;
+ content: " ";
+}
+
+.btn-toolbar:after {
+ clear: both;
+}
+
+.btn-toolbar:before,
+.btn-toolbar:after {
+ display: table;
+ content: " ";
+}
+
+.btn-toolbar:after {
+ clear: both;
+}
+
+.btn-toolbar .btn-group {
+ float: left;
+}
+
+.btn-toolbar > .btn + .btn,
+.btn-toolbar > .btn-group + .btn,
+.btn-toolbar > .btn + .btn-group,
+.btn-toolbar > .btn-group + .btn-group {
+ margin-left: 5px;
+}
+
+.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {
+ border-radius: 0;
+}
+
+.btn-group > .btn:first-child {
+ margin-left: 0;
+}
+
+.btn-group > .btn:first-child:not(:last-child):not(.dropdown-toggle) {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+}
+
+.btn-group > .btn:last-child:not(:first-child),
+.btn-group > .dropdown-toggle:not(:first-child) {
+ border-bottom-left-radius: 0;
+ border-top-left-radius: 0;
+}
+
+.btn-group > .btn-group {
+ float: left;
+}
+
+.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {
+ border-radius: 0;
+}
+
+.btn-group > .btn-group:first-child > .btn:last-child,
+.btn-group > .btn-group:first-child > .dropdown-toggle {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+}
+
+.btn-group > .btn-group:last-child > .btn:first-child {
+ border-bottom-left-radius: 0;
+ border-top-left-radius: 0;
+}
+
+.btn-group .dropdown-toggle:active,
+.btn-group.open .dropdown-toggle {
+ outline: 0;
+}
+
+.btn-group-xs > .btn {
+ padding: 5px 10px;
+ padding: 1px 5px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+
+.btn-group-sm > .btn {
+ padding: 5px 10px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+
+.btn-group-lg > .btn {
+ padding: 10px 16px;
+ font-size: 18px;
+ line-height: 1.33;
+ border-radius: 6px;
+}
+
+.btn-group > .btn + .dropdown-toggle {
+ padding-right: 8px;
+ padding-left: 8px;
+}
+
+.btn-group > .btn-lg + .dropdown-toggle {
+ padding-right: 12px;
+ padding-left: 12px;
+}
+
+.btn-group.open .dropdown-toggle {
+ -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
+ box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
+}
+
+.btn .caret {
+ margin-left: 0;
+}
+
+.btn-lg .caret {
+ border-width: 5px 5px 0;
+ border-bottom-width: 0;
+}
+
+.dropup .btn-lg .caret {
+ border-width: 0 5px 5px;
+}
+
+.btn-group-vertical > .btn,
+.btn-group-vertical > .btn-group {
+ display: block;
+ float: none;
+ width: 100%;
+ max-width: 100%;
+}
+
+.btn-group-vertical > .btn-group:before,
+.btn-group-vertical > .btn-group:after {
+ display: table;
+ content: " ";
+}
+
+.btn-group-vertical > .btn-group:after {
+ clear: both;
+}
+
+.btn-group-vertical > .btn-group:before,
+.btn-group-vertical > .btn-group:after {
+ display: table;
+ content: " ";
+}
+
+.btn-group-vertical > .btn-group:after {
+ clear: both;
+}
+
+.btn-group-vertical > .btn-group > .btn {
+ float: none;
+}
+
+.btn-group-vertical > .btn + .btn,
+.btn-group-vertical > .btn + .btn-group,
+.btn-group-vertical > .btn-group + .btn,
+.btn-group-vertical > .btn-group + .btn-group {
+ margin-top: -1px;
+ margin-left: 0;
+}
+
+.btn-group-vertical > .btn:not(:first-child):not(:last-child) {
+ border-radius: 0;
+}
+
+.btn-group-vertical > .btn:first-child:not(:last-child) {
+ border-top-right-radius: 4px;
+ border-bottom-right-radius: 0;
+ border-bottom-left-radius: 0;
+}
+
+.btn-group-vertical > .btn:last-child:not(:first-child) {
+ border-top-right-radius: 0;
+ border-bottom-left-radius: 4px;
+ border-top-left-radius: 0;
+}
+
+.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {
+ border-radius: 0;
+}
+
+.btn-group-vertical > .btn-group:first-child > .btn:last-child,
+.btn-group-vertical > .btn-group:first-child > .dropdown-toggle {
+ border-bottom-right-radius: 0;
+ border-bottom-left-radius: 0;
+}
+
+.btn-group-vertical > .btn-group:last-child > .btn:first-child {
+ border-top-right-radius: 0;
+ border-top-left-radius: 0;
+}
+
+.btn-group-justified {
+ display: table;
+ width: 100%;
+ border-collapse: separate;
+ table-layout: fixed;
+}
+
+.btn-group-justified .btn {
+ display: table-cell;
+ float: none;
+ width: 1%;
+}
+
+[data-toggle="buttons"] > .btn > input[type="radio"],
+[data-toggle="buttons"] > .btn > input[type="checkbox"] {
+ display: none;
+}
+
+.input-group {
+ position: relative;
+ display: table;
+ border-collapse: separate;
+}
+
+.input-group.col {
+ float: none;
+ padding-right: 0;
+ padding-left: 0;
+}
+
+.input-group .form-control {
+ width: 100%;
+ margin-bottom: 0;
+}
+
+.input-group-lg > .form-control,
+.input-group-lg > .input-group-addon,
+.input-group-lg > .input-group-btn > .btn {
+ height: 45px;
+ padding: 10px 16px;
+ font-size: 18px;
+ line-height: 1.33;
+ border-radius: 6px;
+}
+
+select.input-group-lg > .form-control,
+select.input-group-lg > .input-group-addon,
+select.input-group-lg > .input-group-btn > .btn {
+ height: 45px;
+ line-height: 45px;
+}
+
+textarea.input-group-lg > .form-control,
+textarea.input-group-lg > .input-group-addon,
+textarea.input-group-lg > .input-group-btn > .btn {
+ height: auto;
+}
+
+.input-group-sm > .form-control,
+.input-group-sm > .input-group-addon,
+.input-group-sm > .input-group-btn > .btn {
+ height: 30px;
+ padding: 5px 10px;
+ font-size: 12px;
+ line-height: 1.5;
+ border-radius: 3px;
+}
+
+select.input-group-sm > .form-control,
+select.input-group-sm > .input-group-addon,
+select.input-group-sm > .input-group-btn > .btn {
+ height: 30px;
+ line-height: 30px;
+}
+
+textarea.input-group-sm > .form-control,
+textarea.input-group-sm > .input-group-addon,
+textarea.input-group-sm > .input-group-btn > .btn {
+ height: auto;
+}
+
+.input-group-addon,
+.input-group-btn,
+.input-group .form-control {
+ display: table-cell;
+}
+
+.input-group-addon:not(:first-child):not(:last-child),
+.input-group-btn:not(:first-child):not(:last-child),
+.input-group .form-control:not(:first-child):not(:last-child) {
+ border-radius: 0;
+}
+
+.input-group-addon,
+.input-group-btn {
+ width: 1%;
+ white-space: nowrap;
+ vertical-align: middle;
+}
+
+.input-group-addon {
+ padding: 6px 12px;
+ font-size: 14px;
+ font-weight: normal;
+ line-height: 1;
+ text-align: center;
+ background-color: #eeeeee;
+ border: 1px solid #cccccc;
+ border-radius: 4px;
+}
+
+.input-group-addon.input-sm {
+ padding: 5px 10px;
+ font-size: 12px;
+ border-radius: 3px;
+}
+
+.input-group-addon.input-lg {
+ padding: 10px 16px;
+ font-size: 18px;
+ border-radius: 6px;
+}
+
+.input-group-addon input[type="radio"],
+.input-group-addon input[type="checkbox"] {
+ margin-top: 0;
+}
+
+.input-group .form-control:first-child,
+.input-group-addon:first-child,
+.input-group-btn:first-child > .btn,
+.input-group-btn:first-child > .dropdown-toggle,
+.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle) {
+ border-top-right-radius: 0;
+ border-bottom-right-radius: 0;
+}
+
+.input-group-addon:first-child {
+ border-right: 0;
+}
+
+.input-group .form-control:last-child,
+.input-group-addon:last-child,
+.input-group-btn:last-child > .btn,
+.input-group-btn:last-child > .dropdown-toggle,
+.input-group-btn:first-child > .btn:not(:first-child) {
+ border-bottom-left-radius: 0;
+ border-top-left-radius: 0;
+}
+
+.input-group-addon:last-child {
+ border-left: 0;
+}
+
+.input-group-btn {
+ position: relative;
+ white-space: nowrap;
+}
+
+.input-group-btn > .btn {
+ position: relative;
+}
+
+.input-group-btn > .btn + .btn {
+ margin-left: -4px;
+}
+
+.input-group-btn > .btn:hover,
+.input-group-btn > .btn:active {
+ z-index: 2;
+}
+
+.nav {
+ padding-left: 0;
+ margin-bottom: 0;
+ list-style: none;
+}
+
+.nav:before,
+.nav:after {
+ display: table;
+ content: " ";
+}
+
+.nav:after {
+ clear: both;
+}
+
+.nav:before,
+.nav:after {
+ display: table;
+ content: " ";
+}
+
+.nav:after {
+ clear: both;
+}
+
+.nav > li {
+ position: relative;
+ display: block;
+}
+
+.nav > li > a {
+ position: relative;
+ display: block;
+ padding: 10px 15px;
+}
+
+.nav > li > a:hover,
+.nav > li > a:focus {
+ text-decoration: none;
+ background-color: #eeeeee;
+}
+
+.nav > li.disabled > a {
+ color: #999999;
+}
+
+.nav > li.disabled > a:hover,
+.nav > li.disabled > a:focus {
+ color: #999999;
+ text-decoration: none;
+ cursor: not-allowed;
+ background-color: transparent;
+}
+
+.nav .open > a,
+.nav .open > a:hover,
+.nav .open > a:focus {
+ background-color: #eeeeee;
+ border-color: #428bca;
+}
+
+.nav .nav-divider {
+ height: 1px;
+ margin: 9px 0;
+ overflow: hidden;
+ background-color: #e5e5e5;
+}
+
+.nav > li > a > img {
+ max-width: none;
+}
+
+.nav-tabs {
+ border-bottom: 1px solid #dddddd;
+}
+
+.nav-tabs > li {
+ float: left;
+ margin-bottom: -1px;
+}
+
+.nav-tabs > li > a {
+ margin-right: 2px;
+ line-height: 1.428571429;
+ border: 1px solid transparent;
+ border-radius: 4px 4px 0 0;
+}
+
+.nav-tabs > li > a:hover {
+ border-color: #eeeeee #eeeeee #dddddd;
+}
+
+.nav-tabs > li.active > a,
+.nav-tabs > li.active > a:hover,
+.nav-tabs > li.active > a:focus {
+ color: #555555;
+ cursor: default;
+ background-color: #ffffff;
+ border: 1px solid #dddddd;
+ border-bottom-color: transparent;
+}
+
+.nav-tabs.nav-justified {
+ width: 100%;
+ border-bottom: 0;
+}
+
+.nav-tabs.nav-justified > li {
+ float: none;
+}
+
+.nav-tabs.nav-justified > li > a {
+ text-align: center;
+}
+
+@media (min-width: 768px) {
+ .nav-tabs.nav-justified > li {
+ display: table-cell;
+ width: 1%;
+ }
+}
+
+.nav-tabs.nav-justified > li > a {
+ margin-right: 0;
+ border-bottom: 1px solid #dddddd;
+}
+
+.nav-tabs.nav-justified > .active > a {
+ border-bottom-color: #ffffff;
+}
+
+.nav-pills > li {
+ float: left;
+}
+
+.nav-pills > li > a {
+ border-radius: 5px;
+}
+
+.nav-pills > li + li {
+ margin-left: 2px;
+}
+
+.nav-pills > li.active > a,
+.nav-pills > li.active > a:hover,
+.nav-pills > li.active > a:focus {
+ color: #ffffff;
+ background-color: #428bca;
+}
+
+.nav-stacked > li {
+ float: none;
+}
+
+.nav-stacked > li + li {
+ margin-top: 2px;
+ margin-left: 0;
+}
+
+.nav-justified {
+ width: 100%;
+}
+
+.nav-justified > li {
+ float: none;
+}
+
+.nav-justified > li > a {
+ text-align: center;
+}
+
+@media (min-width: 768px) {
+ .nav-justified > li {
+ display: table-cell;
+ width: 1%;
+ }
+}
+
+.nav-tabs-justified {
+ border-bottom: 0;
+}
+
+.nav-tabs-justified > li > a {
+ margin-right: 0;
+ border-bottom: 1px solid #dddddd;
+}
+
+.nav-tabs-justified > .active > a {
+ border-bottom-color: #ffffff;
+}
+
+.tabbable:before,
+.tabbable:after {
+ display: table;
+ content: " ";
+}
+
+.tabbable:after {
+ clear: both;
+}
+
+.tabbable:before,
+.tabbable:after {
+ display: table;
+ content: " ";
+}
+
+.tabbable:after {
+ clear: both;
+}
+
+.tab-content > .tab-pane,
+.pill-content > .pill-pane {
+ display: none;
+}
+
+.tab-content > .active,
+.pill-content > .active {
+ display: block;
+}
+
+.nav .caret {
+ border-top-color: #428bca;
+ border-bottom-color: #428bca;
+}
+
+.nav a:hover .caret {
+ border-top-color: #2a6496;
+ border-bottom-color: #2a6496;
+}
+
+.nav-tabs .dropdown-menu {
+ margin-top: -1px;
+ border-top-right-radius: 0;
+ border-top-left-radius: 0;
+}
+
+.navbar {
+ position: relative;
+ z-index: 1000;
+ min-height: 50px;
+ margin-bottom: 20px;
+ border: 1px solid transparent;
+}
+
+.navbar:before,
+.navbar:after {
+ display: table;
+ content: " ";
+}
+
+.navbar:after {
+ clear: both;
+}
+
+.navbar:before,
+.navbar:after {
+ display: table;
+ content: " ";
+}
+
+.navbar:after {
+ clear: both;
+}
+
+@media (min-width: 768px) {
+ .navbar {
+ border-radius: 4px;
+ }
+}
+
+.navbar-header:before,
+.navbar-header:after {
+ display: table;
+ content: " ";
+}
+
+.navbar-header:after {
+ clear: both;
+}
+
+.navbar-header:before,
+.navbar-header:after {
+ display: table;
+ content: " ";
+}
+
+.navbar-header:after {
+ clear: both;
+}
+
+@media (min-width: 768px) {
+ .navbar-header {
+ float: left;
+ }
+}
+
+.navbar-collapse {
+ max-height: 340px;
+ padding-right: 15px;
+ padding-left: 15px;
+ overflow-x: visible;
+ border-top: 1px solid transparent;
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
+ -webkit-overflow-scrolling: touch;
+}
+
+.navbar-collapse:before,
+.navbar-collapse:after {
+ display: table;
+ content: " ";
+}
+
+.navbar-collapse:after {
+ clear: both;
+}
+
+.navbar-collapse:before,
+.navbar-collapse:after {
+ display: table;
+ content: " ";
+}
+
+.navbar-collapse:after {
+ clear: both;
+}
+
+.navbar-collapse.in {
+ overflow-y: auto;
+}
+
+@media (min-width: 768px) {
+ .navbar-collapse {
+ width: auto;
+ border-top: 0;
+ box-shadow: none;
+ }
+ .navbar-collapse.collapse {
+ display: block !important;
+ height: auto !important;
+ padding-bottom: 0;
+ overflow: visible !important;
+ }
+ .navbar-collapse.in {
+ overflow-y: visible;
+ }
+ .navbar-collapse .navbar-nav.navbar-left:first-child {
+ margin-left: -15px;
+ }
+ .navbar-collapse .navbar-nav.navbar-right:last-child {
+ margin-right: -15px;
+ }
+ .navbar-collapse .navbar-text:last-child {
+ margin-right: 0;
+ }
+}
+
+.container > .navbar-header,
+.container > .navbar-collapse {
+ margin-right: -15px;
+ margin-left: -15px;
+}
+
+@media (min-width: 768px) {
+ .container > .navbar-header,
+ .container > .navbar-collapse {
+ margin-right: 0;
+ margin-left: 0;
+ }
+}
+
+.navbar-static-top {
+ border-width: 0 0 1px;
+}
+
+@media (min-width: 768px) {
+ .navbar-static-top {
+ border-radius: 0;
+ }
+}
+
+.navbar-fixed-top,
+.navbar-fixed-bottom {
+ position: fixed;
+ right: 0;
+ left: 0;
+ border-width: 0 0 1px;
+}
+
+@media (min-width: 768px) {
+ .navbar-fixed-top,
+ .navbar-fixed-bottom {
+ border-radius: 0;
+ }
+}
+
+.navbar-fixed-top {
+ top: 0;
+ z-index: 1030;
+}
+
+.navbar-fixed-bottom {
+ bottom: 0;
+ margin-bottom: 0;
+}
+
+.navbar-brand {
+ float: left;
+ padding: 15px 15px;
+ font-size: 18px;
+ line-height: 20px;
+}
+
+.navbar-brand:hover,
+.navbar-brand:focus {
+ text-decoration: none;
+}
+
+@media (min-width: 768px) {
+ .navbar > .container .navbar-brand {
+ margin-left: -15px;
+ }
+}
+
+.navbar-toggle {
+ position: relative;
+ float: right;
+ padding: 9px 10px;
+ margin-top: 8px;
+ margin-right: 15px;
+ margin-bottom: 8px;
+ background-color: transparent;
+ border: 1px solid transparent;
+ border-radius: 4px;
+}
+
+.navbar-toggle .icon-bar {
+ display: block;
+ width: 22px;
+ height: 2px;
+ border-radius: 1px;
+}
+
+.navbar-toggle .icon-bar + .icon-bar {
+ margin-top: 4px;
+}
+
+@media (min-width: 768px) {
+ .navbar-toggle {
+ display: none;
+ }
+}
+
+.navbar-nav {
+ margin: 7.5px -15px;
+}
+
+.navbar-nav > li > a {
+ padding-top: 10px;
+ padding-bottom: 10px;
+ line-height: 20px;
+}
+
+@media (max-width: 767px) {
+ .navbar-nav .open .dropdown-menu {
+ position: static;
+ float: none;
+ width: auto;
+ margin-top: 0;
+ background-color: transparent;
+ border: 0;
+ box-shadow: none;
+ }
+ .navbar-nav .open .dropdown-menu > li > a,
+ .navbar-nav .open .dropdown-menu .dropdown-header {
+ padding: 5px 15px 5px 25px;
+ }
+ .navbar-nav .open .dropdown-menu > li > a {
+ line-height: 20px;
+ }
+ .navbar-nav .open .dropdown-menu > li > a:hover,
+ .navbar-nav .open .dropdown-menu > li > a:focus {
+ background-image: none;
+ }
+}
+
+@media (min-width: 768px) {
+ .navbar-nav {
+ float: left;
+ margin: 0;
+ }
+ .navbar-nav > li {
+ float: left;
+ }
+ .navbar-nav > li > a {
+ padding-top: 15px;
+ padding-bottom: 15px;
+ }
+}
+
+@media (min-width: 768px) {
+ .navbar-left {
+ float: left !important;
+ }
+ .navbar-right {
+ float: right !important;
+ }
+}
+
+.navbar-form {
+ padding: 10px 15px;
+ margin-top: 8px;
+ margin-right: -15px;
+ margin-bottom: 8px;
+ margin-left: -15px;
+ border-top: 1px solid transparent;
+ border-bottom: 1px solid transparent;
+ -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);
+}
+
+@media (min-width: 768px) {
+ .navbar-form .form-group {
+ display: inline-block;
+ margin-bottom: 0;
+ vertical-align: middle;
+ }
+ .navbar-form .form-control {
+ display: inline-block;
+ }
+ .navbar-form .radio,
+ .navbar-form .checkbox {
+ display: inline-block;
+ padding-left: 0;
+ margin-top: 0;
+ margin-bottom: 0;
+ }
+ .navbar-form .radio input[type="radio"],
+ .navbar-form .checkbox input[type="checkbox"] {
+ float: none;
+ margin-left: 0;
+ }
+}
+
+@media (max-width: 767px) {
+ .navbar-form .form-group {
+ margin-bottom: 5px;
+ }
+}
+
+@media (min-width: 768px) {
+ .navbar-form {
+ width: auto;
+ padding-top: 0;
+ padding-bottom: 0;
+ margin-right: 0;
+ margin-left: 0;
+ border: 0;
+ -webkit-box-shadow: none;
+ box-shadow: none;
+ }
+}
+
+.navbar-nav > li > .dropdown-menu {
+ margin-top: 0;
+ border-top-right-radius: 0;
+ border-top-left-radius: 0;
+}
+
+.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {
+ border-bottom-right-radius: 0;
+ border-bottom-left-radius: 0;
+}
+
+.navbar-nav.pull-right > li > .dropdown-menu,
+.navbar-nav > li > .dropdown-menu.pull-right {
+ right: 0;
+ left: auto;
+}
+
+.navbar-btn {
+ margin-top: 8px;
+ margin-bottom: 8px;
+}
+
+.navbar-text {
+ float: left;
+ margin-top: 15px;
+ margin-bottom: 15px;
+}
+
+@media (min-width: 768px) {
+ .navbar-text {
+ margin-right: 15px;
+ margin-left: 15px;
+ }
+}
+
+.navbar-default {
+ background-color: #f8f8f8;
+ border-color: #e7e7e7;
+}
+
+.navbar-default .navbar-brand {
+ color: #777777;
+}
+
+.navbar-default .navbar-brand:hover,
+.navbar-default .navbar-brand:focus {
+ color: #5e5e5e;
+ background-color: transparent;
+}
+
+.navbar-default .navbar-text {
+ color: #777777;
+}
+
+.navbar-default .navbar-nav > li > a {
+ color: #777777;
+}
+
+.navbar-default .navbar-nav > li > a:hover,
+.navbar-default .navbar-nav > li > a:focus {
+ color: #333333;
+ background-color: transparent;
+}
+
+.navbar-default .navbar-nav > .active > a,
+.navbar-default .navbar-nav > .active > a:hover,
+.navbar-default .navbar-nav > .active > a:focus {
+ color: #555555;
+ background-color: #e7e7e7;
+}
+
+.navbar-default .navbar-nav > .disabled > a,
+.navbar-default .navbar-nav > .disabled > a:hover,
+.navbar-default .navbar-nav > .disabled > a:focus {
+ color: #cccccc;
+ background-color: transparent;
+}
+
+.navbar-default .navbar-toggle {
+ border-color: #dddddd;
+}
+
+.navbar-default .navbar-toggle:hover,
+.navbar-default .navbar-toggle:focus {
+ background-color: #dddddd;
+}
+
+.navbar-default .navbar-toggle .icon-bar {
+ background-color: #cccccc;
+}
+
+.navbar-default .navbar-collapse,
+.navbar-default .navbar-form {
+ border-color: #e6e6e6;
+}
+
+.navbar-default .navbar-nav > .dropdown > a:hover .caret,
+.navbar-default .navbar-nav > .dropdown > a:focus .caret {
+ border-top-color: #333333;
+ border-bottom-color: #333333;
+}
+
+.navbar-default .navbar-nav > .open > a,
+.navbar-default .navbar-nav > .open > a:hover,
+.navbar-default .navbar-nav > .open > a:focus {
+ color: #555555;
+ background-color: #e7e7e7;
+}
+
+.navbar-default .navbar-nav > .open > a .caret,
+.navbar-default .navbar-nav > .open > a:hover .caret,
+.navbar-default .navbar-nav > .open > a:focus .caret {
+ border-top-color: #555555;
+ border-bottom-color: #555555;
+}
+
+.navbar-default .navbar-nav > .dropdown > a .caret {
+ border-top-color: #777777;
+ border-bottom-color: #777777;
+}
+
+@media (max-width: 767px) {
+ .navbar-default .navbar-nav .open .dropdown-menu > li > a {
+ color: #777777;
+ }
+ .navbar-default .navbar-nav .open .dropdown-menu > li > a:hover,
+ .navbar-default .navbar-nav .open .dropdown-menu > li > a:focus {
+ color: #333333;
+ background-color: transparent;
+ }
+ .navbar-default .navbar-nav .open .dropdown-menu > .active > a,
+ .navbar-default .navbar-nav .open .dropdown-menu > .active > a:hover,
+ .navbar-default .navbar-nav .open .dropdown-menu > .active > a:focus {
+ color: #555555;
+ background-color: #e7e7e7;
+ }
+ .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a,
+ .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:hover,
+ .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:focus {
+ color: #cccccc;
+ background-color: transparent;
+ }
+}
+
+.navbar-default .navbar-link {
+ color: #777777;
+}
+
+.navbar-default .navbar-link:hover {
+ color: #333333;
+}
+
+.navbar-inverse {
+ background-color: #222222;
+ border-color: #080808;
+}
+
+.navbar-inverse .navbar-brand {
+ color: #999999;
+}
+
+.navbar-inverse .navbar-brand:hover,
+.navbar-inverse .navbar-brand:focus {
+ color: #ffffff;
+ background-color: transparent;
+}
+
+.navbar-inverse .navbar-text {
+ color: #999999;
+}
+
+.navbar-inverse .navbar-nav > li > a {
+ color: #999999;
+}
+
+.navbar-inverse .navbar-nav > li > a:hover,
+.navbar-inverse .navbar-nav > li > a:focus {
+ color: #ffffff;
+ background-color: transparent;
+}
+
+.navbar-inverse .navbar-nav > .active > a,
+.navbar-inverse .navbar-nav > .active > a:hover,
+.navbar-inverse .navbar-nav > .active > a:focus {
+ color: #ffffff;
+ background-color: #080808;
+}
+
+.navbar-inverse .navbar-nav > .disabled > a,
+.navbar-inverse .navbar-nav > .disabled > a:hover,
+.navbar-inverse .navbar-nav > .disabled > a:focus {
+ color: #444444;
+ background-color: transparent;
+}
+
+.navbar-inverse .navbar-toggle {
+ border-color: #333333;
+}
+
+.navbar-inverse .navbar-toggle:hover,
+.navbar-inverse .navbar-toggle:focus {
+ background-color: #333333;
+}
+
+.navbar-inverse .navbar-toggle .icon-bar {
+ background-color: #ffffff;
+}
+
+.navbar-inverse .navbar-collapse,
+.navbar-inverse .navbar-form {
+ border-color: #101010;
+}
+
+.navbar-inverse .navbar-nav > .open > a,
+.navbar-inverse .navbar-nav > .open > a:hover,
+.navbar-inverse .navbar-nav > .open > a:focus {
+ color: #ffffff;
+ background-color: #080808;
+}
+
+.navbar-inverse .navbar-nav > .dropdown > a:hover .caret {
+ border-top-color: #ffffff;
+ border-bottom-color: #ffffff;
+}
+
+.navbar-inverse .navbar-nav > .dropdown > a .caret {
+ border-top-color: #999999;
+ border-bottom-color: #999999;
+}
+
+.navbar-inverse .navbar-nav > .open > a .caret,
+.navbar-inverse .navbar-nav > .open > a:hover .caret,
+.navbar-inverse .navbar-nav > .open > a:focus .caret {
+ border-top-color: #ffffff;
+ border-bottom-color: #ffffff;
+}
+
+@media (max-width: 767px) {
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .dropdown-header {
+ border-color: #080808;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu > li > a {
+ color: #999999;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:hover,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:focus {
+ color: #ffffff;
+ background-color: transparent;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:hover,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:focus {
+ color: #ffffff;
+ background-color: #080808;
+ }
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:hover,
+ .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:focus {
+ color: #444444;
+ background-color: transparent;
+ }
+}
+
+.navbar-inverse .navbar-link {
+ color: #999999;
+}
+
+.navbar-inverse .navbar-link:hover {
+ color: #ffffff;
+}
+
+.breadcrumb {
+ padding: 8px 15px;
+ margin-bottom: 20px;
+ list-style: none;
+ background-color: #f5f5f5;
+ border-radius: 4px;
+}
+
+.breadcrumb > li {
+ display: inline-block;
+}
+
+.breadcrumb > li + li:before {
+ padding: 0 5px;
+ color: #cccccc;
+ content: "/\00a0";
+}
+
+.breadcrumb > .active {
+ color: #999999;
+}
+
+.pagination {
+ display: inline-block;
+ padding-left: 0;
+ margin: 20px 0;
+ border-radius: 4px;
+}
+
+.pagination > li {
+ display: inline;
+}
+
+.pagination > li > a,
+.pagination > li > span {
+ position: relative;
+ float: left;
+ padding: 6px 12px;
+ margin-left: -1px;
+ line-height: 1.428571429;
+ text-decoration: none;
+ background-color: #ffffff;
+ border: 1px solid #dddddd;
+}
+
+.pagination > li:first-child > a,
+.pagination > li:first-child > span {
+ margin-left: 0;
+ border-bottom-left-radius: 4px;
+ border-top-left-radius: 4px;
+}
+
+.pagination > li:last-child > a,
+.pagination > li:last-child > span {
+ border-top-right-radius: 4px;
+ border-bottom-right-radius: 4px;
+}
+
+.pagination > li > a:hover,
+.pagination > li > span:hover,
+.pagination > li > a:focus,
+.pagination > li > span:focus {
+ background-color: #eeeeee;
+}
+
+.pagination > .active > a,
+.pagination > .active > span,
+.pagination > .active > a:hover,
+.pagination > .active > span:hover,
+.pagination > .active > a:focus,
+.pagination > .active > span:focus {
+ z-index: 2;
+ color: #ffffff;
+ cursor: default;
+ background-color: #428bca;
+ border-color: #428bca;
+}
+
+.pagination > .disabled > span,
+.pagination > .disabled > a,
+.pagination > .disabled > a:hover,
+.pagination > .disabled > a:focus {
+ color: #999999;
+ cursor: not-allowed;
+ background-color: #ffffff;
+ border-color: #dddddd;
+}
+
+.pagination-lg > li > a,
+.pagination-lg > li > span {
+ padding: 10px 16px;
+ font-size: 18px;
+}
+
+.pagination-lg > li:first-child > a,
+.pagination-lg > li:first-child > span {
+ border-bottom-left-radius: 6px;
+ border-top-left-radius: 6px;
+}
+
+.pagination-lg > li:last-child > a,
+.pagination-lg > li:last-child > span {
+ border-top-right-radius: 6px;
+ border-bottom-right-radius: 6px;
+}
+
+.pagination-sm > li > a,
+.pagination-sm > li > span {
+ padding: 5px 10px;
+ font-size: 12px;
+}
+
+.pagination-sm > li:first-child > a,
+.pagination-sm > li:first-child > span {
+ border-bottom-left-radius: 3px;
+ border-top-left-radius: 3px;
+}
+
+.pagination-sm > li:last-child > a,
+.pagination-sm > li:last-child > span {
+ border-top-right-radius: 3px;
+ border-bottom-right-radius: 3px;
+}
+
+.pager {
+ padding-left: 0;
+ margin: 20px 0;
+ text-align: center;
+ list-style: none;
+}
+
+.pager:before,
+.pager:after {
+ display: table;
+ content: " ";
+}
+
+.pager:after {
+ clear: both;
+}
+
+.pager:before,
+.pager:after {
+ display: table;
+ content: " ";
+}
+
+.pager:after {
+ clear: both;
+}
+
+.pager li {
+ display: inline;
+}
+
+.pager li > a,
+.pager li > span {
+ display: inline-block;
+ padding: 5px 14px;
+ background-color: #ffffff;
+ border: 1px solid #dddddd;
+ border-radius: 15px;
+}
+
+.pager li > a:hover,
+.pager li > a:focus {
+ text-decoration: none;
+ background-color: #eeeeee;
+}
+
+.pager .next > a,
+.pager .next > span {
+ float: right;
+}
+
+.pager .previous > a,
+.pager .previous > span {
+ float: left;
+}
+
+.pager .disabled > a,
+.pager .disabled > a:hover,
+.pager .disabled > a:focus,
+.pager .disabled > span {
+ color: #999999;
+ cursor: not-allowed;
+ background-color: #ffffff;
+}
+
+.label {
+ display: inline;
+ padding: .2em .6em .3em;
+ font-size: 75%;
+ font-weight: bold;
+ line-height: 1;
+ color: #ffffff;
+ text-align: center;
+ white-space: nowrap;
+ vertical-align: baseline;
+ border-radius: .25em;
+}
+
+.label[href]:hover,
+.label[href]:focus {
+ color: #ffffff;
+ text-decoration: none;
+ cursor: pointer;
+}
+
+.label:empty {
+ display: none;
+}
+
+.label-default {
+ background-color: #999999;
+}
+
+.label-default[href]:hover,
+.label-default[href]:focus {
+ background-color: #808080;
+}
+
+.label-primary {
+ background-color: #428bca;
+}
+
+.label-primary[href]:hover,
+.label-primary[href]:focus {
+ background-color: #3071a9;
+}
+
+.label-success {
+ background-color: #5cb85c;
+}
+
+.label-success[href]:hover,
+.label-success[href]:focus {
+ background-color: #449d44;
+}
+
+.label-info {
+ background-color: #5bc0de;
+}
+
+.label-info[href]:hover,
+.label-info[href]:focus {
+ background-color: #31b0d5;
+}
+
+.label-warning {
+ background-color: #f0ad4e;
+}
+
+.label-warning[href]:hover,
+.label-warning[href]:focus {
+ background-color: #ec971f;
+}
+
+.label-danger {
+ background-color: #d9534f;
+}
+
+.label-danger[href]:hover,
+.label-danger[href]:focus {
+ background-color: #c9302c;
+}
+
+.badge {
+ display: inline-block;
+ min-width: 10px;
+ padding: 3px 7px;
+ font-size: 12px;
+ font-weight: bold;
+ line-height: 1;
+ color: #ffffff;
+ text-align: center;
+ white-space: nowrap;
+ vertical-align: baseline;
+ background-color: #999999;
+ border-radius: 10px;
+}
+
+.badge:empty {
+ display: none;
+}
+
+a.badge:hover,
+a.badge:focus {
+ color: #ffffff;
+ text-decoration: none;
+ cursor: pointer;
+}
+
+.btn .badge {
+ position: relative;
+ top: -1px;
+}
+
+a.list-group-item.active > .badge,
+.nav-pills > .active > a > .badge {
+ color: #428bca;
+ background-color: #ffffff;
+}
+
+.nav-pills > li > a > .badge {
+ margin-left: 3px;
+}
+
+.jumbotron {
+ padding: 30px;
+ margin-bottom: 30px;
+ font-size: 21px;
+ font-weight: 200;
+ line-height: 2.1428571435;
+ color: inherit;
+ background-color: #eeeeee;
+}
+
+.jumbotron h1 {
+ line-height: 1;
+ color: inherit;
+}
+
+.jumbotron p {
+ line-height: 1.4;
+}
+
+.container .jumbotron {
+ border-radius: 6px;
+}
+
+@media screen and (min-width: 768px) {
+ .jumbotron {
+ padding-top: 48px;
+ padding-bottom: 48px;
+ }
+ .container .jumbotron {
+ padding-right: 60px;
+ padding-left: 60px;
+ }
+ .jumbotron h1 {
+ font-size: 63px;
+ }
+}
+
+.thumbnail {
+ display: inline-block;
+ display: block;
+ height: auto;
+ max-width: 100%;
+ padding: 4px;
+ line-height: 1.428571429;
+ background-color: #ffffff;
+ border: 1px solid #dddddd;
+ border-radius: 4px;
+ -webkit-transition: all 0.2s ease-in-out;
+ transition: all 0.2s ease-in-out;
+}
+
+.thumbnail > img {
+ display: block;
+ height: auto;
+ max-width: 100%;
+}
+
+a.thumbnail:hover,
+a.thumbnail:focus {
+ border-color: #428bca;
+}
+
+.thumbnail > img {
+ margin-right: auto;
+ margin-left: auto;
+}
+
+.thumbnail .caption {
+ padding: 9px;
+ color: #333333;
+}
+
+.alert {
+ padding: 15px;
+ margin-bottom: 20px;
+ border: 1px solid transparent;
+ border-radius: 4px;
+}
+
+.alert h4 {
+ margin-top: 0;
+ color: inherit;
+}
+
+.alert .alert-link {
+ font-weight: bold;
+}
+
+.alert > p,
+.alert > ul {
+ margin-bottom: 0;
+}
+
+.alert > p + p {
+ margin-top: 5px;
+}
+
+.alert-dismissable {
+ padding-right: 35px;
+}
+
+.alert-dismissable .close {
+ position: relative;
+ top: -2px;
+ right: -21px;
+ color: inherit;
+}
+
+.alert-success {
+ color: #468847;
+ background-color: #dff0d8;
+ border-color: #d6e9c6;
+}
+
+.alert-success hr {
+ border-top-color: #c9e2b3;
+}
+
+.alert-success .alert-link {
+ color: #356635;
+}
+
+.alert-info {
+ color: #3a87ad;
+ background-color: #d9edf7;
+ border-color: #bce8f1;
+}
+
+.alert-info hr {
+ border-top-color: #a6e1ec;
+}
+
+.alert-info .alert-link {
+ color: #2d6987;
+}
+
+.alert-warning {
+ color: #c09853;
+ background-color: #fcf8e3;
+ border-color: #fbeed5;
+}
+
+.alert-warning hr {
+ border-top-color: #f8e5be;
+}
+
+.alert-warning .alert-link {
+ color: #a47e3c;
+}
+
+.alert-danger {
+ color: #b94a48;
+ background-color: #f2dede;
+ border-color: #eed3d7;
+}
+
+.alert-danger hr {
+ border-top-color: #e6c1c7;
+}
+
+.alert-danger .alert-link {
+ color: #953b39;
+}
+
+@-webkit-keyframes progress-bar-stripes {
+ from {
+ background-position: 40px 0;
+ }
+ to {
+ background-position: 0 0;
+ }
+}
+
+@-moz-keyframes progress-bar-stripes {
+ from {
+ background-position: 40px 0;
+ }
+ to {
+ background-position: 0 0;
+ }
+}
+
+@-o-keyframes progress-bar-stripes {
+ from {
+ background-position: 0 0;
+ }
+ to {
+ background-position: 40px 0;
+ }
+}
+
+@keyframes progress-bar-stripes {
+ from {
+ background-position: 40px 0;
+ }
+ to {
+ background-position: 0 0;
+ }
+}
+
+.progress {
+ height: 20px;
+ margin-bottom: 20px;
+ overflow: hidden;
+ background-color: #f5f5f5;
+ border-radius: 4px;
+ -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
+ box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
+}
+
+.progress-bar {
+ float: left;
+ width: 0;
+ height: 100%;
+ font-size: 12px;
+ color: #ffffff;
+ text-align: center;
+ background-color: #428bca;
+ -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);
+ box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);
+ -webkit-transition: width 0.6s ease;
+ transition: width 0.6s ease;
+}
+
+.progress-striped .progress-bar {
+ background-image: -webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: -moz-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-size: 40px 40px;
+}
+
+.progress.active .progress-bar {
+ -webkit-animation: progress-bar-stripes 2s linear infinite;
+ -moz-animation: progress-bar-stripes 2s linear infinite;
+ -ms-animation: progress-bar-stripes 2s linear infinite;
+ -o-animation: progress-bar-stripes 2s linear infinite;
+ animation: progress-bar-stripes 2s linear infinite;
+}
+
+.progress-bar-success {
+ background-color: #5cb85c;
+}
+
+.progress-striped .progress-bar-success {
+ background-image: -webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: -moz-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+}
+
+.progress-bar-info {
+ background-color: #5bc0de;
+}
+
+.progress-striped .progress-bar-info {
+ background-image: -webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: -moz-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+}
+
+.progress-bar-warning {
+ background-color: #f0ad4e;
+}
+
+.progress-striped .progress-bar-warning {
+ background-image: -webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: -moz-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+}
+
+.progress-bar-danger {
+ background-color: #d9534f;
+}
+
+.progress-striped .progress-bar-danger {
+ background-image: -webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.15)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 0.15)), color-stop(0.75, transparent), to(transparent));
+ background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: -moz-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+ background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
+}
+
+.media,
+.media-body {
+ overflow: hidden;
+ zoom: 1;
+}
+
+.media,
+.media .media {
+ margin-top: 15px;
+}
+
+.media:first-child {
+ margin-top: 0;
+}
+
+.media-object {
+ display: block;
+}
+
+.media-heading {
+ margin: 0 0 5px;
+}
+
+.media > .pull-left {
+ margin-right: 10px;
+}
+
+.media > .pull-right {
+ margin-left: 10px;
+}
+
+.media-list {
+ padding-left: 0;
+ list-style: none;
+}
+
+.list-group {
+ padding-left: 0;
+ margin-bottom: 20px;
+}
+
+.list-group-item {
+ position: relative;
+ display: block;
+ padding: 10px 15px;
+ margin-bottom: -1px;
+ background-color: #ffffff;
+ border: 1px solid #dddddd;
+}
+
+.list-group-item:first-child {
+ border-top-right-radius: 4px;
+ border-top-left-radius: 4px;
+}
+
+.list-group-item:last-child {
+ margin-bottom: 0;
+ border-bottom-right-radius: 4px;
+ border-bottom-left-radius: 4px;
+}
+
+.list-group-item > .badge {
+ float: right;
+}
+
+.list-group-item > .badge + .badge {
+ margin-right: 5px;
+}
+
+a.list-group-item {
+ color: #555555;
+}
+
+a.list-group-item .list-group-item-heading {
+ color: #333333;
+}
+
+a.list-group-item:hover,
+a.list-group-item:focus {
+ text-decoration: none;
+ background-color: #f5f5f5;
+}
+
+.list-group-item.active,
+.list-group-item.active:hover,
+.list-group-item.active:focus {
+ z-index: 2;
+ color: #ffffff;
+ background-color: #428bca;
+ border-color: #428bca;
+}
+
+.list-group-item.active .list-group-item-heading,
+.list-group-item.active:hover .list-group-item-heading,
+.list-group-item.active:focus .list-group-item-heading {
+ color: inherit;
+}
+
+.list-group-item.active .list-group-item-text,
+.list-group-item.active:hover .list-group-item-text,
+.list-group-item.active:focus .list-group-item-text {
+ color: #e1edf7;
+}
+
+.list-group-item-heading {
+ margin-top: 0;
+ margin-bottom: 5px;
+}
+
+.list-group-item-text {
+ margin-bottom: 0;
+ line-height: 1.3;
+}
+
+.panel {
+ margin-bottom: 20px;
+ background-color: #ffffff;
+ border: 1px solid transparent;
+ border-radius: 4px;
+ -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
+ box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
+}
+
+.panel-body {
+ padding: 15px;
+}
+
+.panel-body:before,
+.panel-body:after {
+ display: table;
+ content: " ";
+}
+
+.panel-body:after {
+ clear: both;
+}
+
+.panel-body:before,
+.panel-body:after {
+ display: table;
+ content: " ";
+}
+
+.panel-body:after {
+ clear: both;
+}
+
+.panel > .list-group {
+ margin-bottom: 0;
+}
+
+.panel > .list-group .list-group-item {
+ border-width: 1px 0;
+}
+
+.panel > .list-group .list-group-item:first-child {
+ border-top-right-radius: 0;
+ border-top-left-radius: 0;
+}
+
+.panel > .list-group .list-group-item:last-child {
+ border-bottom: 0;
+}
+
+.panel-heading + .list-group .list-group-item:first-child {
+ border-top-width: 0;
+}
+
+.panel > .table {
+ margin-bottom: 0;
+}
+
+.panel > .panel-body + .table {
+ border-top: 1px solid #dddddd;
+}
+
+.panel-heading {
+ padding: 10px 15px;
+ border-bottom: 1px solid transparent;
+ border-top-right-radius: 3px;
+ border-top-left-radius: 3px;
+}
+
+.panel-title {
+ margin-top: 0;
+ margin-bottom: 0;
+ font-size: 16px;
+}
+
+.panel-title > a {
+ color: inherit;
+}
+
+.panel-footer {
+ padding: 10px 15px;
+ background-color: #f5f5f5;
+ border-top: 1px solid #dddddd;
+ border-bottom-right-radius: 3px;
+ border-bottom-left-radius: 3px;
+}
+
+.panel-group .panel {
+ margin-bottom: 0;
+ overflow: hidden;
+ border-radius: 4px;
+}
+
+.panel-group .panel + .panel {
+ margin-top: 5px;
+}
+
+.panel-group .panel-heading {
+ border-bottom: 0;
+}
+
+.panel-group .panel-heading + .panel-collapse .panel-body {
+ border-top: 1px solid #dddddd;
+}
+
+.panel-group .panel-footer {
+ border-top: 0;
+}
+
+.panel-group .panel-footer + .panel-collapse .panel-body {
+ border-bottom: 1px solid #dddddd;
+}
+
+.panel-default {
+ border-color: #dddddd;
+}
+
+.panel-default > .panel-heading {
+ color: #333333;
+ background-color: #f5f5f5;
+ border-color: #dddddd;
+}
+
+.panel-default > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #dddddd;
+}
+
+.panel-default > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #dddddd;
+}
+
+.panel-primary {
+ border-color: #428bca;
+}
+
+.panel-primary > .panel-heading {
+ color: #ffffff;
+ background-color: #428bca;
+ border-color: #428bca;
+}
+
+.panel-primary > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #428bca;
+}
+
+.panel-primary > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #428bca;
+}
+
+.panel-success {
+ border-color: #d6e9c6;
+}
+
+.panel-success > .panel-heading {
+ color: #468847;
+ background-color: #dff0d8;
+ border-color: #d6e9c6;
+}
+
+.panel-success > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #d6e9c6;
+}
+
+.panel-success > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #d6e9c6;
+}
+
+.panel-warning {
+ border-color: #fbeed5;
+}
+
+.panel-warning > .panel-heading {
+ color: #c09853;
+ background-color: #fcf8e3;
+ border-color: #fbeed5;
+}
+
+.panel-warning > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #fbeed5;
+}
+
+.panel-warning > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #fbeed5;
+}
+
+.panel-danger {
+ border-color: #eed3d7;
+}
+
+.panel-danger > .panel-heading {
+ color: #b94a48;
+ background-color: #f2dede;
+ border-color: #eed3d7;
+}
+
+.panel-danger > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #eed3d7;
+}
+
+.panel-danger > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #eed3d7;
+}
+
+.panel-info {
+ border-color: #bce8f1;
+}
+
+.panel-info > .panel-heading {
+ color: #3a87ad;
+ background-color: #d9edf7;
+ border-color: #bce8f1;
+}
+
+.panel-info > .panel-heading + .panel-collapse .panel-body {
+ border-top-color: #bce8f1;
+}
+
+.panel-info > .panel-footer + .panel-collapse .panel-body {
+ border-bottom-color: #bce8f1;
+}
+
+.well {
+ min-height: 20px;
+ padding: 19px;
+ margin-bottom: 20px;
+ background-color: #f5f5f5;
+ border: 1px solid #e3e3e3;
+ border-radius: 4px;
+ -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
+ box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
+}
+
+.well blockquote {
+ border-color: #ddd;
+ border-color: rgba(0, 0, 0, 0.15);
+}
+
+.well-lg {
+ padding: 24px;
+ border-radius: 6px;
+}
+
+.well-sm {
+ padding: 9px;
+ border-radius: 3px;
+}
+
+.close {
+ float: right;
+ font-size: 21px;
+ font-weight: bold;
+ line-height: 1;
+ color: #000000;
+ text-shadow: 0 1px 0 #ffffff;
+ opacity: 0.2;
+ filter: alpha(opacity=20);
+}
+
+.close:hover,
+.close:focus {
+ color: #000000;
+ text-decoration: none;
+ cursor: pointer;
+ opacity: 0.5;
+ filter: alpha(opacity=50);
+}
+
+button.close {
+ padding: 0;
+ cursor: pointer;
+ background: transparent;
+ border: 0;
+ -webkit-appearance: none;
+}
+
+.modal-open {
+ overflow: hidden;
+}
+
+body.modal-open,
+.modal-open .navbar-fixed-top,
+.modal-open .navbar-fixed-bottom {
+ margin-right: 15px;
+}
+
+.modal {
+ position: fixed;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ z-index: 1040;
+ display: none;
+ overflow: auto;
+ overflow-y: scroll;
+}
+
+.modal.fade .modal-dialog {
+ -webkit-transform: translate(0, -25%);
+ -ms-transform: translate(0, -25%);
+ transform: translate(0, -25%);
+ -webkit-transition: -webkit-transform 0.3s ease-out;
+ -moz-transition: -moz-transform 0.3s ease-out;
+ -o-transition: -o-transform 0.3s ease-out;
+ transition: transform 0.3s ease-out;
+}
+
+.modal.in .modal-dialog {
+ -webkit-transform: translate(0, 0);
+ -ms-transform: translate(0, 0);
+ transform: translate(0, 0);
+}
+
+.modal-dialog {
+ z-index: 1050;
+ width: auto;
+ padding: 10px;
+ margin-right: auto;
+ margin-left: auto;
+}
+
+.modal-content {
+ position: relative;
+ background-color: #ffffff;
+ border: 1px solid #999999;
+ border: 1px solid rgba(0, 0, 0, 0.2);
+ border-radius: 6px;
+ outline: none;
+ -webkit-box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
+ box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
+ background-clip: padding-box;
+}
+
+.modal-backdrop {
+ position: fixed;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ z-index: 1030;
+ background-color: #000000;
+}
+
+.modal-backdrop.fade {
+ opacity: 0;
+ filter: alpha(opacity=0);
+}
+
+.modal-backdrop.in {
+ opacity: 0.5;
+ filter: alpha(opacity=50);
+}
+
+.modal-header {
+ min-height: 16.428571429px;
+ padding: 15px;
+ border-bottom: 1px solid #e5e5e5;
+}
+
+.modal-header .close {
+ margin-top: -2px;
+}
+
+.modal-title {
+ margin: 0;
+ line-height: 1.428571429;
+}
+
+.modal-body {
+ position: relative;
+ padding: 20px;
+}
+
+.modal-footer {
+ padding: 19px 20px 20px;
+ margin-top: 15px;
+ text-align: right;
+ border-top: 1px solid #e5e5e5;
+}
+
+.modal-footer:before,
+.modal-footer:after {
+ display: table;
+ content: " ";
+}
+
+.modal-footer:after {
+ clear: both;
+}
+
+.modal-footer:before,
+.modal-footer:after {
+ display: table;
+ content: " ";
+}
+
+.modal-footer:after {
+ clear: both;
+}
+
+.modal-footer .btn + .btn {
+ margin-bottom: 0;
+ margin-left: 5px;
+}
+
+.modal-footer .btn-group .btn + .btn {
+ margin-left: -1px;
+}
+
+.modal-footer .btn-block + .btn-block {
+ margin-left: 0;
+}
+
+@media screen and (min-width: 768px) {
+ .modal-dialog {
+ right: auto;
+ left: 50%;
+ width: 600px;
+ padding-top: 30px;
+ padding-bottom: 30px;
+ }
+ .modal-content {
+ -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
+ box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
+ }
+}
+
+.tooltip {
+ position: absolute;
+ z-index: 1030;
+ display: block;
+ font-size: 12px;
+ line-height: 1.4;
+ opacity: 0;
+ filter: alpha(opacity=0);
+ visibility: visible;
+}
+
+.tooltip.in {
+ opacity: 0.9;
+ filter: alpha(opacity=90);
+}
+
+.tooltip.top {
+ padding: 5px 0;
+ margin-top: -3px;
+}
+
+.tooltip.right {
+ padding: 0 5px;
+ margin-left: 3px;
+}
+
+.tooltip.bottom {
+ padding: 5px 0;
+ margin-top: 3px;
+}
+
+.tooltip.left {
+ padding: 0 5px;
+ margin-left: -3px;
+}
+
+.tooltip-inner {
+ max-width: 200px;
+ padding: 3px 8px;
+ color: #ffffff;
+ text-align: center;
+ text-decoration: none;
+ background-color: #000000;
+ border-radius: 4px;
+}
+
+.tooltip-arrow {
+ position: absolute;
+ width: 0;
+ height: 0;
+ border-color: transparent;
+ border-style: solid;
+}
+
+.tooltip.top .tooltip-arrow {
+ bottom: 0;
+ left: 50%;
+ margin-left: -5px;
+ border-top-color: #000000;
+ border-width: 5px 5px 0;
+}
+
+.tooltip.top-left .tooltip-arrow {
+ bottom: 0;
+ left: 5px;
+ border-top-color: #000000;
+ border-width: 5px 5px 0;
+}
+
+.tooltip.top-right .tooltip-arrow {
+ right: 5px;
+ bottom: 0;
+ border-top-color: #000000;
+ border-width: 5px 5px 0;
+}
+
+.tooltip.right .tooltip-arrow {
+ top: 50%;
+ left: 0;
+ margin-top: -5px;
+ border-right-color: #000000;
+ border-width: 5px 5px 5px 0;
+}
+
+.tooltip.left .tooltip-arrow {
+ top: 50%;
+ right: 0;
+ margin-top: -5px;
+ border-left-color: #000000;
+ border-width: 5px 0 5px 5px;
+}
+
+.tooltip.bottom .tooltip-arrow {
+ top: 0;
+ left: 50%;
+ margin-left: -5px;
+ border-bottom-color: #000000;
+ border-width: 0 5px 5px;
+}
+
+.tooltip.bottom-left .tooltip-arrow {
+ top: 0;
+ left: 5px;
+ border-bottom-color: #000000;
+ border-width: 0 5px 5px;
+}
+
+.tooltip.bottom-right .tooltip-arrow {
+ top: 0;
+ right: 5px;
+ border-bottom-color: #000000;
+ border-width: 0 5px 5px;
+}
+
+.popover {
+ position: absolute;
+ top: 0;
+ left: 0;
+ z-index: 1010;
+ display: none;
+ max-width: 276px;
+ padding: 1px;
+ text-align: left;
+ white-space: normal;
+ background-color: #ffffff;
+ border: 1px solid #cccccc;
+ border: 1px solid rgba(0, 0, 0, 0.2);
+ border-radius: 6px;
+ -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
+ box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
+ background-clip: padding-box;
+}
+
+.popover.top {
+ margin-top: -10px;
+}
+
+.popover.right {
+ margin-left: 10px;
+}
+
+.popover.bottom {
+ margin-top: 10px;
+}
+
+.popover.left {
+ margin-left: -10px;
+}
+
+.popover-title {
+ padding: 8px 14px;
+ margin: 0;
+ font-size: 14px;
+ font-weight: normal;
+ line-height: 18px;
+ background-color: #f7f7f7;
+ border-bottom: 1px solid #ebebeb;
+ border-radius: 5px 5px 0 0;
+}
+
+.popover-content {
+ padding: 9px 14px;
+}
+
+.popover .arrow,
+.popover .arrow:after {
+ position: absolute;
+ display: block;
+ width: 0;
+ height: 0;
+ border-color: transparent;
+ border-style: solid;
+}
+
+.popover .arrow {
+ border-width: 11px;
+}
+
+.popover .arrow:after {
+ border-width: 10px;
+ content: "";
+}
+
+.popover.top .arrow {
+ bottom: -11px;
+ left: 50%;
+ margin-left: -11px;
+ border-top-color: #999999;
+ border-top-color: rgba(0, 0, 0, 0.25);
+ border-bottom-width: 0;
+}
+
+.popover.top .arrow:after {
+ bottom: 1px;
+ margin-left: -10px;
+ border-top-color: #ffffff;
+ border-bottom-width: 0;
+ content: " ";
+}
+
+.popover.right .arrow {
+ top: 50%;
+ left: -11px;
+ margin-top: -11px;
+ border-right-color: #999999;
+ border-right-color: rgba(0, 0, 0, 0.25);
+ border-left-width: 0;
+}
+
+.popover.right .arrow:after {
+ bottom: -10px;
+ left: 1px;
+ border-right-color: #ffffff;
+ border-left-width: 0;
+ content: " ";
+}
+
+.popover.bottom .arrow {
+ top: -11px;
+ left: 50%;
+ margin-left: -11px;
+ border-bottom-color: #999999;
+ border-bottom-color: rgba(0, 0, 0, 0.25);
+ border-top-width: 0;
+}
+
+.popover.bottom .arrow:after {
+ top: 1px;
+ margin-left: -10px;
+ border-bottom-color: #ffffff;
+ border-top-width: 0;
+ content: " ";
+}
+
+.popover.left .arrow {
+ top: 50%;
+ right: -11px;
+ margin-top: -11px;
+ border-left-color: #999999;
+ border-left-color: rgba(0, 0, 0, 0.25);
+ border-right-width: 0;
+}
+
+.popover.left .arrow:after {
+ right: 1px;
+ bottom: -10px;
+ border-left-color: #ffffff;
+ border-right-width: 0;
+ content: " ";
+}
+
+.carousel {
+ position: relative;
+}
+
+.carousel-inner {
+ position: relative;
+ width: 100%;
+ overflow: hidden;
+}
+
+.carousel-inner > .item {
+ position: relative;
+ display: none;
+ -webkit-transition: 0.6s ease-in-out left;
+ transition: 0.6s ease-in-out left;
+}
+
+.carousel-inner > .item > img,
+.carousel-inner > .item > a > img {
+ display: block;
+ height: auto;
+ max-width: 100%;
+ line-height: 1;
+}
+
+.carousel-inner > .active,
+.carousel-inner > .next,
+.carousel-inner > .prev {
+ display: block;
+}
+
+.carousel-inner > .active {
+ left: 0;
+}
+
+.carousel-inner > .next,
+.carousel-inner > .prev {
+ position: absolute;
+ top: 0;
+ width: 100%;
+}
+
+.carousel-inner > .next {
+ left: 100%;
+}
+
+.carousel-inner > .prev {
+ left: -100%;
+}
+
+.carousel-inner > .next.left,
+.carousel-inner > .prev.right {
+ left: 0;
+}
+
+.carousel-inner > .active.left {
+ left: -100%;
+}
+
+.carousel-inner > .active.right {
+ left: 100%;
+}
+
+.carousel-control {
+ position: absolute;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ width: 15%;
+ font-size: 20px;
+ color: #ffffff;
+ text-align: center;
+ text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
+ opacity: 0.5;
+ filter: alpha(opacity=50);
+}
+
+.carousel-control.left {
+ background-image: -webkit-gradient(linear, 0 top, 100% top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.0001)));
+ background-image: -webkit-linear-gradient(left, color-stop(rgba(0, 0, 0, 0.5) 0), color-stop(rgba(0, 0, 0, 0.0001) 100%));
+ background-image: -moz-linear-gradient(left, rgba(0, 0, 0, 0.5) 0, rgba(0, 0, 0, 0.0001) 100%);
+ background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5) 0, rgba(0, 0, 0, 0.0001) 100%);
+ background-repeat: repeat-x;
+ filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);
+}
+
+.carousel-control.right {
+ right: 0;
+ left: auto;
+ background-image: -webkit-gradient(linear, 0 top, 100% top, from(rgba(0, 0, 0, 0.0001)), to(rgba(0, 0, 0, 0.5)));
+ background-image: -webkit-linear-gradient(left, color-stop(rgba(0, 0, 0, 0.0001) 0), color-stop(rgba(0, 0, 0, 0.5) 100%));
+ background-image: -moz-linear-gradient(left, rgba(0, 0, 0, 0.0001) 0, rgba(0, 0, 0, 0.5) 100%);
+ background-image: linear-gradient(to right, rgba(0, 0, 0, 0.0001) 0, rgba(0, 0, 0, 0.5) 100%);
+ background-repeat: repeat-x;
+ filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);
+}
+
+.carousel-control:hover,
+.carousel-control:focus {
+ color: #ffffff;
+ text-decoration: none;
+ opacity: 0.9;
+ filter: alpha(opacity=90);
+}
+
+.carousel-control .icon-prev,
+.carousel-control .icon-next,
+.carousel-control .glyphicon-chevron-left,
+.carousel-control .glyphicon-chevron-right {
+ position: absolute;
+ top: 50%;
+ left: 50%;
+ z-index: 5;
+ display: inline-block;
+}
+
+.carousel-control .icon-prev,
+.carousel-control .icon-next {
+ width: 20px;
+ height: 20px;
+ margin-top: -10px;
+ margin-left: -10px;
+ font-family: serif;
+}
+
+.carousel-control .icon-prev:before {
+ content: '\2039';
+}
+
+.carousel-control .icon-next:before {
+ content: '\203a';
+}
+
+.carousel-indicators {
+ position: absolute;
+ bottom: 10px;
+ left: 50%;
+ z-index: 15;
+ width: 60%;
+ padding-left: 0;
+ margin-left: -30%;
+ text-align: center;
+ list-style: none;
+}
+
+.carousel-indicators li {
+ display: inline-block;
+ width: 10px;
+ height: 10px;
+ margin: 1px;
+ text-indent: -999px;
+ cursor: pointer;
+ border: 1px solid #ffffff;
+ border-radius: 10px;
+}
+
+.carousel-indicators .active {
+ width: 12px;
+ height: 12px;
+ margin: 0;
+ background-color: #ffffff;
+}
+
+.carousel-caption {
+ position: absolute;
+ right: 15%;
+ bottom: 20px;
+ left: 15%;
+ z-index: 10;
+ padding-top: 20px;
+ padding-bottom: 20px;
+ color: #ffffff;
+ text-align: center;
+ text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
+}
+
+.carousel-caption .btn {
+ text-shadow: none;
+}
+
+@media screen and (min-width: 768px) {
+ .carousel-control .icon-prev,
+ .carousel-control .icon-next {
+ width: 30px;
+ height: 30px;
+ margin-top: -15px;
+ margin-left: -15px;
+ font-size: 30px;
+ }
+ .carousel-caption {
+ right: 20%;
+ left: 20%;
+ padding-bottom: 30px;
+ }
+ .carousel-indicators {
+ bottom: 20px;
+ }
+}
+
+.clearfix:before,
+.clearfix:after {
+ display: table;
+ content: " ";
+}
+
+.clearfix:after {
+ clear: both;
+}
+
+.pull-right {
+ float: right !important;
+}
+
+.pull-left {
+ float: left !important;
+}
+
+.hide {
+ display: none !important;
+}
+
+.show {
+ display: block !important;
+}
+
+.invisible {
+ visibility: hidden;
+}
+
+.text-hide {
+ font: 0/0 a;
+ color: transparent;
+ text-shadow: none;
+ background-color: transparent;
+ border: 0;
+}
+
+.affix {
+ position: fixed;
+}
+
+@-ms-viewport {
+ width: device-width;
+}
+
+@media screen and (max-width: 400px) {
+ @-ms-viewport {
+ width: 320px;
+ }
+}
+
+.hidden {
+ display: none !important;
+ visibility: hidden !important;
+}
+
+.visible-xs {
+ display: none !important;
+}
+
+tr.visible-xs {
+ display: none !important;
+}
+
+th.visible-xs,
+td.visible-xs {
+ display: none !important;
+}
+
+@media (max-width: 767px) {
+ .visible-xs {
+ display: block !important;
+ }
+ tr.visible-xs {
+ display: table-row !important;
+ }
+ th.visible-xs,
+ td.visible-xs {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .visible-xs.visible-sm {
+ display: block !important;
+ }
+ tr.visible-xs.visible-sm {
+ display: table-row !important;
+ }
+ th.visible-xs.visible-sm,
+ td.visible-xs.visible-sm {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .visible-xs.visible-md {
+ display: block !important;
+ }
+ tr.visible-xs.visible-md {
+ display: table-row !important;
+ }
+ th.visible-xs.visible-md,
+ td.visible-xs.visible-md {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 1200px) {
+ .visible-xs.visible-lg {
+ display: block !important;
+ }
+ tr.visible-xs.visible-lg {
+ display: table-row !important;
+ }
+ th.visible-xs.visible-lg,
+ td.visible-xs.visible-lg {
+ display: table-cell !important;
+ }
+}
+
+.visible-sm {
+ display: none !important;
+}
+
+tr.visible-sm {
+ display: none !important;
+}
+
+th.visible-sm,
+td.visible-sm {
+ display: none !important;
+}
+
+@media (max-width: 767px) {
+ .visible-sm.visible-xs {
+ display: block !important;
+ }
+ tr.visible-sm.visible-xs {
+ display: table-row !important;
+ }
+ th.visible-sm.visible-xs,
+ td.visible-sm.visible-xs {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .visible-sm {
+ display: block !important;
+ }
+ tr.visible-sm {
+ display: table-row !important;
+ }
+ th.visible-sm,
+ td.visible-sm {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .visible-sm.visible-md {
+ display: block !important;
+ }
+ tr.visible-sm.visible-md {
+ display: table-row !important;
+ }
+ th.visible-sm.visible-md,
+ td.visible-sm.visible-md {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 1200px) {
+ .visible-sm.visible-lg {
+ display: block !important;
+ }
+ tr.visible-sm.visible-lg {
+ display: table-row !important;
+ }
+ th.visible-sm.visible-lg,
+ td.visible-sm.visible-lg {
+ display: table-cell !important;
+ }
+}
+
+.visible-md {
+ display: none !important;
+}
+
+tr.visible-md {
+ display: none !important;
+}
+
+th.visible-md,
+td.visible-md {
+ display: none !important;
+}
+
+@media (max-width: 767px) {
+ .visible-md.visible-xs {
+ display: block !important;
+ }
+ tr.visible-md.visible-xs {
+ display: table-row !important;
+ }
+ th.visible-md.visible-xs,
+ td.visible-md.visible-xs {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .visible-md.visible-sm {
+ display: block !important;
+ }
+ tr.visible-md.visible-sm {
+ display: table-row !important;
+ }
+ th.visible-md.visible-sm,
+ td.visible-md.visible-sm {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .visible-md {
+ display: block !important;
+ }
+ tr.visible-md {
+ display: table-row !important;
+ }
+ th.visible-md,
+ td.visible-md {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 1200px) {
+ .visible-md.visible-lg {
+ display: block !important;
+ }
+ tr.visible-md.visible-lg {
+ display: table-row !important;
+ }
+ th.visible-md.visible-lg,
+ td.visible-md.visible-lg {
+ display: table-cell !important;
+ }
+}
+
+.visible-lg {
+ display: none !important;
+}
+
+tr.visible-lg {
+ display: none !important;
+}
+
+th.visible-lg,
+td.visible-lg {
+ display: none !important;
+}
+
+@media (max-width: 767px) {
+ .visible-lg.visible-xs {
+ display: block !important;
+ }
+ tr.visible-lg.visible-xs {
+ display: table-row !important;
+ }
+ th.visible-lg.visible-xs,
+ td.visible-lg.visible-xs {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .visible-lg.visible-sm {
+ display: block !important;
+ }
+ tr.visible-lg.visible-sm {
+ display: table-row !important;
+ }
+ th.visible-lg.visible-sm,
+ td.visible-lg.visible-sm {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .visible-lg.visible-md {
+ display: block !important;
+ }
+ tr.visible-lg.visible-md {
+ display: table-row !important;
+ }
+ th.visible-lg.visible-md,
+ td.visible-lg.visible-md {
+ display: table-cell !important;
+ }
+}
+
+@media (min-width: 1200px) {
+ .visible-lg {
+ display: block !important;
+ }
+ tr.visible-lg {
+ display: table-row !important;
+ }
+ th.visible-lg,
+ td.visible-lg {
+ display: table-cell !important;
+ }
+}
+
+.hidden-xs {
+ display: block !important;
+}
+
+tr.hidden-xs {
+ display: table-row !important;
+}
+
+th.hidden-xs,
+td.hidden-xs {
+ display: table-cell !important;
+}
+
+@media (max-width: 767px) {
+ .hidden-xs {
+ display: none !important;
+ }
+ tr.hidden-xs {
+ display: none !important;
+ }
+ th.hidden-xs,
+ td.hidden-xs {
+ display: none !important;
+ }
+}
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .hidden-xs.hidden-sm {
+ display: none !important;
+ }
+ tr.hidden-xs.hidden-sm {
+ display: none !important;
+ }
+ th.hidden-xs.hidden-sm,
+ td.hidden-xs.hidden-sm {
+ display: none !important;
+ }
+}
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .hidden-xs.hidden-md {
+ display: none !important;
+ }
+ tr.hidden-xs.hidden-md {
+ display: none !important;
+ }
+ th.hidden-xs.hidden-md,
+ td.hidden-xs.hidden-md {
+ display: none !important;
+ }
+}
+
+@media (min-width: 1200px) {
+ .hidden-xs.hidden-lg {
+ display: none !important;
+ }
+ tr.hidden-xs.hidden-lg {
+ display: none !important;
+ }
+ th.hidden-xs.hidden-lg,
+ td.hidden-xs.hidden-lg {
+ display: none !important;
+ }
+}
+
+.hidden-sm {
+ display: block !important;
+}
+
+tr.hidden-sm {
+ display: table-row !important;
+}
+
+th.hidden-sm,
+td.hidden-sm {
+ display: table-cell !important;
+}
+
+@media (max-width: 767px) {
+ .hidden-sm.hidden-xs {
+ display: none !important;
+ }
+ tr.hidden-sm.hidden-xs {
+ display: none !important;
+ }
+ th.hidden-sm.hidden-xs,
+ td.hidden-sm.hidden-xs {
+ display: none !important;
+ }
+}
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .hidden-sm {
+ display: none !important;
+ }
+ tr.hidden-sm {
+ display: none !important;
+ }
+ th.hidden-sm,
+ td.hidden-sm {
+ display: none !important;
+ }
+}
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .hidden-sm.hidden-md {
+ display: none !important;
+ }
+ tr.hidden-sm.hidden-md {
+ display: none !important;
+ }
+ th.hidden-sm.hidden-md,
+ td.hidden-sm.hidden-md {
+ display: none !important;
+ }
+}
+
+@media (min-width: 1200px) {
+ .hidden-sm.hidden-lg {
+ display: none !important;
+ }
+ tr.hidden-sm.hidden-lg {
+ display: none !important;
+ }
+ th.hidden-sm.hidden-lg,
+ td.hidden-sm.hidden-lg {
+ display: none !important;
+ }
+}
+
+.hidden-md {
+ display: block !important;
+}
+
+tr.hidden-md {
+ display: table-row !important;
+}
+
+th.hidden-md,
+td.hidden-md {
+ display: table-cell !important;
+}
+
+@media (max-width: 767px) {
+ .hidden-md.hidden-xs {
+ display: none !important;
+ }
+ tr.hidden-md.hidden-xs {
+ display: none !important;
+ }
+ th.hidden-md.hidden-xs,
+ td.hidden-md.hidden-xs {
+ display: none !important;
+ }
+}
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .hidden-md.hidden-sm {
+ display: none !important;
+ }
+ tr.hidden-md.hidden-sm {
+ display: none !important;
+ }
+ th.hidden-md.hidden-sm,
+ td.hidden-md.hidden-sm {
+ display: none !important;
+ }
+}
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .hidden-md {
+ display: none !important;
+ }
+ tr.hidden-md {
+ display: none !important;
+ }
+ th.hidden-md,
+ td.hidden-md {
+ display: none !important;
+ }
+}
+
+@media (min-width: 1200px) {
+ .hidden-md.hidden-lg {
+ display: none !important;
+ }
+ tr.hidden-md.hidden-lg {
+ display: none !important;
+ }
+ th.hidden-md.hidden-lg,
+ td.hidden-md.hidden-lg {
+ display: none !important;
+ }
+}
+
+.hidden-lg {
+ display: block !important;
+}
+
+tr.hidden-lg {
+ display: table-row !important;
+}
+
+th.hidden-lg,
+td.hidden-lg {
+ display: table-cell !important;
+}
+
+@media (max-width: 767px) {
+ .hidden-lg.hidden-xs {
+ display: none !important;
+ }
+ tr.hidden-lg.hidden-xs {
+ display: none !important;
+ }
+ th.hidden-lg.hidden-xs,
+ td.hidden-lg.hidden-xs {
+ display: none !important;
+ }
+}
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .hidden-lg.hidden-sm {
+ display: none !important;
+ }
+ tr.hidden-lg.hidden-sm {
+ display: none !important;
+ }
+ th.hidden-lg.hidden-sm,
+ td.hidden-lg.hidden-sm {
+ display: none !important;
+ }
+}
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .hidden-lg.hidden-md {
+ display: none !important;
+ }
+ tr.hidden-lg.hidden-md {
+ display: none !important;
+ }
+ th.hidden-lg.hidden-md,
+ td.hidden-lg.hidden-md {
+ display: none !important;
+ }
+}
+
+@media (min-width: 1200px) {
+ .hidden-lg {
+ display: none !important;
+ }
+ tr.hidden-lg {
+ display: none !important;
+ }
+ th.hidden-lg,
+ td.hidden-lg {
+ display: none !important;
+ }
+}
+
+.visible-print {
+ display: none !important;
+}
+
+tr.visible-print {
+ display: none !important;
+}
+
+th.visible-print,
+td.visible-print {
+ display: none !important;
+}
+
+@media print {
+ .visible-print {
+ display: block !important;
+ }
+ tr.visible-print {
+ display: table-row !important;
+ }
+ th.visible-print,
+ td.visible-print {
+ display: table-cell !important;
+ }
+ .hidden-print {
+ display: none !important;
+ }
+ tr.hidden-print {
+ display: none !important;
+ }
+ th.hidden-print,
+ td.hidden-print {
+ display: none !important;
+ }
+}
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/bootstrap.min.css b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/bootstrap.min.css
new file mode 100644
index 000000000..df89a5030
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Content/bootstrap.min.css
@@ -0,0 +1,20 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. The notices and licenses below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*!
+ * Bootstrap v3.0.0
+ *
+ * Copyright 2013 Twitter, Inc
+ * Licensed under the Apache License v2.0
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Designed and built with all the love in the world by @mdo and @fat.
+ *//*! normalize.css v2.1.0 | MIT License | git.io/normalize */article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block}audio,canvas,video{display:inline-block}audio:not([controls]){display:none;height:0}[hidden]{display:none}html{font-family:sans-serif;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}a:focus{outline:thin dotted}a:active,a:hover{outline:0}h1{margin:.67em 0;font-size:2em}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:bold}dfn{font-style:italic}hr{height:0;-moz-box-sizing:content-box;box-sizing:content-box}mark{color:#000;background:#ff0}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em}pre{white-space:pre-wrap}q{quotes:"\201C" "\201D" "\2018" "\2019"}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-0.5em}sub{bottom:-0.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:0}fieldset{padding:.35em .625em .75em;margin:0 2px;border:1px solid #c0c0c0}legend{padding:0;border:0}button,input,select,textarea{margin:0;font-family:inherit;font-size:100%}button,input{line-height:normal}button,select{text-transform:none}button,html input[type="button"],input[type="reset"],input[type="submit"]{cursor:pointer;-webkit-appearance:button}button[disabled],html input[disabled]{cursor:default}input[type="checkbox"],input[type="radio"]{padding:0;box-sizing:border-box}input[type="search"]{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-webkit-appearance:textfield}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}textarea{overflow:auto;vertical-align:top}table{border-collapse:collapse;border-spacing:0}@media print{*{color:#000!important;text-shadow:none!important;background:transparent!important;box-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}.ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100%!important}@page{margin:2cm .5cm}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}.navbar{display:none}.table td,.table th{background-color:#fff!important}.btn>.caret,.dropup>.btn>.caret{border-top-color:#000!important}.label{border:1px solid #000}.table{border-collapse:collapse!important}.table-bordered th,.table-bordered td{border:1px solid #ddd!important}}*,*:before,*:after{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:62.5%;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.428571429;color:#333;background-color:#fff}input,button,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}button,input,select[multiple],textarea{background-image:none}a{color:#428bca;text-decoration:none}a:hover,a:focus{color:#2a6496;text-decoration:underline}a:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}img{vertical-align:middle}.img-responsive{display:block;height:auto;max-width:100%}.img-rounded{border-radius:6px}.img-thumbnail{display:inline-block;height:auto;max-width:100%;padding:4px;line-height:1.428571429;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border:0;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16.099999999999998px;font-weight:200;line-height:1.4}@media(min-width:768px){.lead{font-size:21px}}small{font-size:85%}cite{font-style:normal}.text-muted{color:#999}.text-primary{color:#428bca}.text-warning{color:#c09853}.text-danger{color:#b94a48}.text-success{color:#468847}.text-info{color:#3a87ad}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-weight:500;line-height:1.1}h1 small,h2 small,h3 small,h4 small,h5 small,h6 small,.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small{font-weight:normal;line-height:1;color:#999}h1,h2,h3{margin-top:20px;margin-bottom:10px}h4,h5,h6{margin-top:10px;margin-bottom:10px}h1,.h1{font-size:36px}h2,.h2{font-size:30px}h3,.h3{font-size:24px}h4,.h4{font-size:18px}h5,.h5{font-size:14px}h6,.h6{font-size:12px}h1 small,.h1 small{font-size:24px}h2 small,.h2 small{font-size:18px}h3 small,.h3 small,h4 small,.h4 small{font-size:14px}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}ul,ol{margin-top:0;margin-bottom:10px}ul ul,ol ul,ul ol,ol ol{margin-bottom:0}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline>li{display:inline-block;padding-right:5px;padding-left:5px}dl{margin-bottom:20px}dt,dd{line-height:1.428571429}dt{font-weight:bold}dd{margin-left:0}@media(min-width:768px){.dl-horizontal dt{float:left;width:160px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}.dl-horizontal dd:before,.dl-horizontal dd:after{display:table;content:" "}.dl-horizontal dd:after{clear:both}.dl-horizontal dd:before,.dl-horizontal dd:after{display:table;content:" "}.dl-horizontal dd:after{clear:both}}abbr[title],abbr[data-original-title]{cursor:help;border-bottom:1px dotted #999}abbr.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;border-left:5px solid #eee}blockquote p{font-size:17.5px;font-weight:300;line-height:1.25}blockquote p:last-child{margin-bottom:0}blockquote small{display:block;line-height:1.428571429;color:#999}blockquote small:before{content:'\2014 \00A0'}blockquote.pull-right{padding-right:15px;padding-left:0;border-right:5px solid #eee;border-left:0}blockquote.pull-right p,blockquote.pull-right small{text-align:right}blockquote.pull-right small:before{content:''}blockquote.pull-right small:after{content:'\00A0 \2014'}q:before,q:after,blockquote:before,blockquote:after{content:""}address{display:block;margin-bottom:20px;font-style:normal;line-height:1.428571429}code,pre{font-family:Monaco,Menlo,Consolas,"Courier New",monospace}code{padding:2px 4px;font-size:90%;color:#c7254e;white-space:nowrap;background-color:#f9f2f4;border-radius:4px}pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:1.428571429;color:#333;word-break:break-all;word-wrap:break-word;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}pre.prettyprint{margin-bottom:20px}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;background-color:transparent;border:0}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.container:before,.container:after{display:table;content:" "}.container:after{clear:both}.container:before,.container:after{display:table;content:" "}.container:after{clear:both}.row{margin-right:-15px;margin-left:-15px}.row:before,.row:after{display:table;content:" "}.row:after{clear:both}.row:before,.row:after{display:table;content:" "}.row:after{clear:both}.col-xs-1,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9,.col-xs-10,.col-xs-11,.col-xs-12,.col-sm-1,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-10,.col-sm-11,.col-sm-12,.col-md-1,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-10,.col-md-11,.col-md-12,.col-lg-1,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-10,.col-lg-11,.col-lg-12{position:relative;min-height:1px;padding-right:15px;padding-left:15px}.col-xs-1,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9,.col-xs-10,.col-xs-11{float:left}.col-xs-1{width:8.333333333333332%}.col-xs-2{width:16.666666666666664%}.col-xs-3{width:25%}.col-xs-4{width:33.33333333333333%}.col-xs-5{width:41.66666666666667%}.col-xs-6{width:50%}.col-xs-7{width:58.333333333333336%}.col-xs-8{width:66.66666666666666%}.col-xs-9{width:75%}.col-xs-10{width:83.33333333333334%}.col-xs-11{width:91.66666666666666%}.col-xs-12{width:100%}@media(min-width:768px){.container{max-width:750px}.col-sm-1,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-10,.col-sm-11{float:left}.col-sm-1{width:8.333333333333332%}.col-sm-2{width:16.666666666666664%}.col-sm-3{width:25%}.col-sm-4{width:33.33333333333333%}.col-sm-5{width:41.66666666666667%}.col-sm-6{width:50%}.col-sm-7{width:58.333333333333336%}.col-sm-8{width:66.66666666666666%}.col-sm-9{width:75%}.col-sm-10{width:83.33333333333334%}.col-sm-11{width:91.66666666666666%}.col-sm-12{width:100%}.col-sm-push-1{left:8.333333333333332%}.col-sm-push-2{left:16.666666666666664%}.col-sm-push-3{left:25%}.col-sm-push-4{left:33.33333333333333%}.col-sm-push-5{left:41.66666666666667%}.col-sm-push-6{left:50%}.col-sm-push-7{left:58.333333333333336%}.col-sm-push-8{left:66.66666666666666%}.col-sm-push-9{left:75%}.col-sm-push-10{left:83.33333333333334%}.col-sm-push-11{left:91.66666666666666%}.col-sm-pull-1{right:8.333333333333332%}.col-sm-pull-2{right:16.666666666666664%}.col-sm-pull-3{right:25%}.col-sm-pull-4{right:33.33333333333333%}.col-sm-pull-5{right:41.66666666666667%}.col-sm-pull-6{right:50%}.col-sm-pull-7{right:58.333333333333336%}.col-sm-pull-8{right:66.66666666666666%}.col-sm-pull-9{right:75%}.col-sm-pull-10{right:83.33333333333334%}.col-sm-pull-11{right:91.66666666666666%}.col-sm-offset-1{margin-left:8.333333333333332%}.col-sm-offset-2{margin-left:16.666666666666664%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-4{margin-left:33.33333333333333%}.col-sm-offset-5{margin-left:41.66666666666667%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-7{margin-left:58.333333333333336%}.col-sm-offset-8{margin-left:66.66666666666666%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-10{margin-left:83.33333333333334%}.col-sm-offset-11{margin-left:91.66666666666666%}}@media(min-width:992px){.container{max-width:970px}.col-md-1,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-10,.col-md-11{float:left}.col-md-1{width:8.333333333333332%}.col-md-2{width:16.666666666666664%}.col-md-3{width:25%}.col-md-4{width:33.33333333333333%}.col-md-5{width:41.66666666666667%}.col-md-6{width:50%}.col-md-7{width:58.333333333333336%}.col-md-8{width:66.66666666666666%}.col-md-9{width:75%}.col-md-10{width:83.33333333333334%}.col-md-11{width:91.66666666666666%}.col-md-12{width:100%}.col-md-push-0{left:auto}.col-md-push-1{left:8.333333333333332%}.col-md-push-2{left:16.666666666666664%}.col-md-push-3{left:25%}.col-md-push-4{left:33.33333333333333%}.col-md-push-5{left:41.66666666666667%}.col-md-push-6{left:50%}.col-md-push-7{left:58.333333333333336%}.col-md-push-8{left:66.66666666666666%}.col-md-push-9{left:75%}.col-md-push-10{left:83.33333333333334%}.col-md-push-11{left:91.66666666666666%}.col-md-pull-0{right:auto}.col-md-pull-1{right:8.333333333333332%}.col-md-pull-2{right:16.666666666666664%}.col-md-pull-3{right:25%}.col-md-pull-4{right:33.33333333333333%}.col-md-pull-5{right:41.66666666666667%}.col-md-pull-6{right:50%}.col-md-pull-7{right:58.333333333333336%}.col-md-pull-8{right:66.66666666666666%}.col-md-pull-9{right:75%}.col-md-pull-10{right:83.33333333333334%}.col-md-pull-11{right:91.66666666666666%}.col-md-offset-0{margin-left:0}.col-md-offset-1{margin-left:8.333333333333332%}.col-md-offset-2{margin-left:16.666666666666664%}.col-md-offset-3{margin-left:25%}.col-md-offset-4{margin-left:33.33333333333333%}.col-md-offset-5{margin-left:41.66666666666667%}.col-md-offset-6{margin-left:50%}.col-md-offset-7{margin-left:58.333333333333336%}.col-md-offset-8{margin-left:66.66666666666666%}.col-md-offset-9{margin-left:75%}.col-md-offset-10{margin-left:83.33333333333334%}.col-md-offset-11{margin-left:91.66666666666666%}}@media(min-width:1200px){.container{max-width:1170px}.col-lg-1,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-10,.col-lg-11{float:left}.col-lg-1{width:8.333333333333332%}.col-lg-2{width:16.666666666666664%}.col-lg-3{width:25%}.col-lg-4{width:33.33333333333333%}.col-lg-5{width:41.66666666666667%}.col-lg-6{width:50%}.col-lg-7{width:58.333333333333336%}.col-lg-8{width:66.66666666666666%}.col-lg-9{width:75%}.col-lg-10{width:83.33333333333334%}.col-lg-11{width:91.66666666666666%}.col-lg-12{width:100%}.col-lg-push-0{left:auto}.col-lg-push-1{left:8.333333333333332%}.col-lg-push-2{left:16.666666666666664%}.col-lg-push-3{left:25%}.col-lg-push-4{left:33.33333333333333%}.col-lg-push-5{left:41.66666666666667%}.col-lg-push-6{left:50%}.col-lg-push-7{left:58.333333333333336%}.col-lg-push-8{left:66.66666666666666%}.col-lg-push-9{left:75%}.col-lg-push-10{left:83.33333333333334%}.col-lg-push-11{left:91.66666666666666%}.col-lg-pull-0{right:auto}.col-lg-pull-1{right:8.333333333333332%}.col-lg-pull-2{right:16.666666666666664%}.col-lg-pull-3{right:25%}.col-lg-pull-4{right:33.33333333333333%}.col-lg-pull-5{right:41.66666666666667%}.col-lg-pull-6{right:50%}.col-lg-pull-7{right:58.333333333333336%}.col-lg-pull-8{right:66.66666666666666%}.col-lg-pull-9{right:75%}.col-lg-pull-10{right:83.33333333333334%}.col-lg-pull-11{right:91.66666666666666%}.col-lg-offset-0{margin-left:0}.col-lg-offset-1{margin-left:8.333333333333332%}.col-lg-offset-2{margin-left:16.666666666666664%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-4{margin-left:33.33333333333333%}.col-lg-offset-5{margin-left:41.66666666666667%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-7{margin-left:58.333333333333336%}.col-lg-offset-8{margin-left:66.66666666666666%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-10{margin-left:83.33333333333334%}.col-lg-offset-11{margin-left:91.66666666666666%}}table{max-width:100%;background-color:transparent}th{text-align:left}.table{width:100%;margin-bottom:20px}.table thead>tr>th,.table tbody>tr>th,.table tfoot>tr>th,.table thead>tr>td,.table tbody>tr>td,.table tfoot>tr>td{padding:8px;line-height:1.428571429;vertical-align:top;border-top:1px solid #ddd}.table thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.table caption+thead tr:first-child th,.table colgroup+thead tr:first-child th,.table thead:first-child tr:first-child th,.table caption+thead tr:first-child td,.table colgroup+thead tr:first-child td,.table thead:first-child tr:first-child td{border-top:0}.table tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed thead>tr>th,.table-condensed tbody>tr>th,.table-condensed tfoot>tr>th,.table-condensed thead>tr>td,.table-condensed tbody>tr>td,.table-condensed tfoot>tr>td{padding:5px}.table-bordered{border:1px solid #ddd}.table-bordered>thead>tr>th,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>tbody>tr>td,.table-bordered>tfoot>tr>td{border:1px solid #ddd}.table-bordered>thead>tr>th,.table-bordered>thead>tr>td{border-bottom-width:2px}.table-striped>tbody>tr:nth-child(odd)>td,.table-striped>tbody>tr:nth-child(odd)>th{background-color:#f9f9f9}.table-hover>tbody>tr:hover>td,.table-hover>tbody>tr:hover>th{background-color:#f5f5f5}table col[class*="col-"]{display:table-column;float:none}table td[class*="col-"],table th[class*="col-"]{display:table-cell;float:none}.table>thead>tr>td.active,.table>tbody>tr>td.active,.table>tfoot>tr>td.active,.table>thead>tr>th.active,.table>tbody>tr>th.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>tbody>tr.active>td,.table>tfoot>tr.active>td,.table>thead>tr.active>th,.table>tbody>tr.active>th,.table>tfoot>tr.active>th{background-color:#f5f5f5}.table>thead>tr>td.success,.table>tbody>tr>td.success,.table>tfoot>tr>td.success,.table>thead>tr>th.success,.table>tbody>tr>th.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>tbody>tr.success>td,.table>tfoot>tr.success>td,.table>thead>tr.success>th,.table>tbody>tr.success>th,.table>tfoot>tr.success>th{background-color:#dff0d8;border-color:#d6e9c6}.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover,.table-hover>tbody>tr.success:hover>td{background-color:#d0e9c6;border-color:#c9e2b3}.table>thead>tr>td.danger,.table>tbody>tr>td.danger,.table>tfoot>tr>td.danger,.table>thead>tr>th.danger,.table>tbody>tr>th.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>tbody>tr.danger>td,.table>tfoot>tr.danger>td,.table>thead>tr.danger>th,.table>tbody>tr.danger>th,.table>tfoot>tr.danger>th{background-color:#f2dede;border-color:#eed3d7}.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover,.table-hover>tbody>tr.danger:hover>td{background-color:#ebcccc;border-color:#e6c1c7}.table>thead>tr>td.warning,.table>tbody>tr>td.warning,.table>tfoot>tr>td.warning,.table>thead>tr>th.warning,.table>tbody>tr>th.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>tbody>tr.warning>td,.table>tfoot>tr.warning>td,.table>thead>tr.warning>th,.table>tbody>tr.warning>th,.table>tfoot>tr.warning>th{background-color:#fcf8e3;border-color:#fbeed5}.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover,.table-hover>tbody>tr.warning:hover>td{background-color:#faf2cc;border-color:#f8e5be}@media(max-width:768px){.table-responsive{width:100%;margin-bottom:15px;overflow-x:scroll;overflow-y:hidden;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0;background-color:#fff}.table-responsive>.table>thead>tr>th,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tfoot>tr>td{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>thead>tr>th:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child{border-left:0}.table-responsive>.table-bordered>thead>tr>th:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child{border-right:0}.table-responsive>.table-bordered>thead>tr:last-child>th,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>th,.table-responsive>.table-bordered>thead>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>td{border-bottom:0}}fieldset{padding:0;margin:0;border:0}legend{display:block;width:100%;padding:0;margin-bottom:20px;font-size:21px;line-height:inherit;color:#333;border:0;border-bottom:1px solid #e5e5e5}label{display:inline-block;margin-bottom:5px;font-weight:bold}input[type="search"]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}input[type="radio"],input[type="checkbox"]{margin:4px 0 0;margin-top:1px \9;line-height:normal}input[type="file"]{display:block}select[multiple],select[size]{height:auto}select optgroup{font-family:inherit;font-size:inherit;font-style:inherit}input[type="file"]:focus,input[type="radio"]:focus,input[type="checkbox"]:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}input[type="number"]::-webkit-outer-spin-button,input[type="number"]::-webkit-inner-spin-button{height:auto}.form-control:-moz-placeholder{color:#999}.form-control::-moz-placeholder{color:#999}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.form-control{display:block;width:100%;height:34px;padding:6px 12px;font-size:14px;line-height:1.428571429;color:#555;vertical-align:middle;background-color:#fff;border:1px solid #ccc;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-webkit-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(102,175,233,0.6);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(102,175,233,0.6)}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{cursor:not-allowed;background-color:#eee}textarea.form-control{height:auto}.form-group{margin-bottom:15px}.radio,.checkbox{display:block;min-height:20px;padding-left:20px;margin-top:10px;margin-bottom:10px;vertical-align:middle}.radio label,.checkbox label{display:inline;margin-bottom:0;font-weight:normal;cursor:pointer}.radio input[type="radio"],.radio-inline input[type="radio"],.checkbox input[type="checkbox"],.checkbox-inline input[type="checkbox"]{float:left;margin-left:-20px}.radio+.radio,.checkbox+.checkbox{margin-top:-5px}.radio-inline,.checkbox-inline{display:inline-block;padding-left:20px;margin-bottom:0;font-weight:normal;vertical-align:middle;cursor:pointer}.radio-inline+.radio-inline,.checkbox-inline+.checkbox-inline{margin-top:0;margin-left:10px}input[type="radio"][disabled],input[type="checkbox"][disabled],.radio[disabled],.radio-inline[disabled],.checkbox[disabled],.checkbox-inline[disabled],fieldset[disabled] input[type="radio"],fieldset[disabled] input[type="checkbox"],fieldset[disabled] .radio,fieldset[disabled] .radio-inline,fieldset[disabled] .checkbox,fieldset[disabled] .checkbox-inline{cursor:not-allowed}.input-sm{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-sm{height:30px;line-height:30px}textarea.input-sm{height:auto}.input-lg{height:45px;padding:10px 16px;font-size:18px;line-height:1.33;border-radius:6px}select.input-lg{height:45px;line-height:45px}textarea.input-lg{height:auto}.has-warning .help-block,.has-warning .control-label{color:#c09853}.has-warning .form-control{border-color:#c09853;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.has-warning .form-control:focus{border-color:#a47e3c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e}.has-warning .input-group-addon{color:#c09853;background-color:#fcf8e3;border-color:#c09853}.has-error .help-block,.has-error .control-label{color:#b94a48}.has-error .form-control{border-color:#b94a48;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.has-error .form-control:focus{border-color:#953b39;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392}.has-error .input-group-addon{color:#b94a48;background-color:#f2dede;border-color:#b94a48}.has-success .help-block,.has-success .control-label{color:#468847}.has-success .form-control{border-color:#468847;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.has-success .form-control:focus{border-color:#356635;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b}.has-success .input-group-addon{color:#468847;background-color:#dff0d8;border-color:#468847}.form-control-static{padding-top:7px;margin-bottom:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media(min-width:768px){.form-inline .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block}.form-inline .radio,.form-inline .checkbox{display:inline-block;padding-left:0;margin-top:0;margin-bottom:0}.form-inline .radio input[type="radio"],.form-inline .checkbox input[type="checkbox"]{float:none;margin-left:0}}.form-horizontal .control-label,.form-horizontal .radio,.form-horizontal .checkbox,.form-horizontal .radio-inline,.form-horizontal .checkbox-inline{padding-top:7px;margin-top:0;margin-bottom:0}.form-horizontal .form-group{margin-right:-15px;margin-left:-15px}.form-horizontal .form-group:before,.form-horizontal .form-group:after{display:table;content:" "}.form-horizontal .form-group:after{clear:both}.form-horizontal .form-group:before,.form-horizontal .form-group:after{display:table;content:" "}.form-horizontal .form-group:after{clear:both}@media(min-width:768px){.form-horizontal .control-label{text-align:right}}.btn{display:inline-block;padding:6px 12px;margin-bottom:0;font-size:14px;font-weight:normal;line-height:1.428571429;text-align:center;white-space:nowrap;vertical-align:middle;cursor:pointer;border:1px solid transparent;border-radius:4px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.btn:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.btn:hover,.btn:focus{color:#333;text-decoration:none}.btn:active,.btn.active{background-image:none;outline:0;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,0.125);box-shadow:inset 0 3px 5px rgba(0,0,0,0.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{pointer-events:none;cursor:not-allowed;opacity:.65;filter:alpha(opacity=65);-webkit-box-shadow:none;box-shadow:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default:hover,.btn-default:focus,.btn-default:active,.btn-default.active,.open .dropdown-toggle.btn-default{color:#333;background-color:#ebebeb;border-color:#adadad}.btn-default:active,.btn-default.active,.open .dropdown-toggle.btn-default{background-image:none}.btn-default.disabled,.btn-default[disabled],fieldset[disabled] .btn-default,.btn-default.disabled:hover,.btn-default[disabled]:hover,fieldset[disabled] .btn-default:hover,.btn-default.disabled:focus,.btn-default[disabled]:focus,fieldset[disabled] .btn-default:focus,.btn-default.disabled:active,.btn-default[disabled]:active,fieldset[disabled] .btn-default:active,.btn-default.disabled.active,.btn-default[disabled].active,fieldset[disabled] .btn-default.active{background-color:#fff;border-color:#ccc}.btn-primary{color:#fff;background-color:#428bca;border-color:#357ebd}.btn-primary:hover,.btn-primary:focus,.btn-primary:active,.btn-primary.active,.open .dropdown-toggle.btn-primary{color:#fff;background-color:#3276b1;border-color:#285e8e}.btn-primary:active,.btn-primary.active,.open .dropdown-toggle.btn-primary{background-image:none}.btn-primary.disabled,.btn-primary[disabled],fieldset[disabled] .btn-primary,.btn-primary.disabled:hover,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary:hover,.btn-primary.disabled:focus,.btn-primary[disabled]:focus,fieldset[disabled] .btn-primary:focus,.btn-primary.disabled:active,.btn-primary[disabled]:active,fieldset[disabled] .btn-primary:active,.btn-primary.disabled.active,.btn-primary[disabled].active,fieldset[disabled] .btn-primary.active{background-color:#428bca;border-color:#357ebd}.btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236}.btn-warning:hover,.btn-warning:focus,.btn-warning:active,.btn-warning.active,.open .dropdown-toggle.btn-warning{color:#fff;background-color:#ed9c28;border-color:#d58512}.btn-warning:active,.btn-warning.active,.open .dropdown-toggle.btn-warning{background-image:none}.btn-warning.disabled,.btn-warning[disabled],fieldset[disabled] .btn-warning,.btn-warning.disabled:hover,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning:hover,.btn-warning.disabled:focus,.btn-warning[disabled]:focus,fieldset[disabled] .btn-warning:focus,.btn-warning.disabled:active,.btn-warning[disabled]:active,fieldset[disabled] .btn-warning:active,.btn-warning.disabled.active,.btn-warning[disabled].active,fieldset[disabled] .btn-warning.active{background-color:#f0ad4e;border-color:#eea236}.btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a}.btn-danger:hover,.btn-danger:focus,.btn-danger:active,.btn-danger.active,.open .dropdown-toggle.btn-danger{color:#fff;background-color:#d2322d;border-color:#ac2925}.btn-danger:active,.btn-danger.active,.open .dropdown-toggle.btn-danger{background-image:none}.btn-danger.disabled,.btn-danger[disabled],fieldset[disabled] .btn-danger,.btn-danger.disabled:hover,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger:hover,.btn-danger.disabled:focus,.btn-danger[disabled]:focus,fieldset[disabled] .btn-danger:focus,.btn-danger.disabled:active,.btn-danger[disabled]:active,fieldset[disabled] .btn-danger:active,.btn-danger.disabled.active,.btn-danger[disabled].active,fieldset[disabled] .btn-danger.active{background-color:#d9534f;border-color:#d43f3a}.btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.btn-success:hover,.btn-success:focus,.btn-success:active,.btn-success.active,.open .dropdown-toggle.btn-success{color:#fff;background-color:#47a447;border-color:#398439}.btn-success:active,.btn-success.active,.open .dropdown-toggle.btn-success{background-image:none}.btn-success.disabled,.btn-success[disabled],fieldset[disabled] .btn-success,.btn-success.disabled:hover,.btn-success[disabled]:hover,fieldset[disabled] .btn-success:hover,.btn-success.disabled:focus,.btn-success[disabled]:focus,fieldset[disabled] .btn-success:focus,.btn-success.disabled:active,.btn-success[disabled]:active,fieldset[disabled] .btn-success:active,.btn-success.disabled.active,.btn-success[disabled].active,fieldset[disabled] .btn-success.active{background-color:#5cb85c;border-color:#4cae4c}.btn-info{color:#fff;background-color:#5bc0de;border-color:#46b8da}.btn-info:hover,.btn-info:focus,.btn-info:active,.btn-info.active,.open .dropdown-toggle.btn-info{color:#fff;background-color:#39b3d7;border-color:#269abc}.btn-info:active,.btn-info.active,.open .dropdown-toggle.btn-info{background-image:none}.btn-info.disabled,.btn-info[disabled],fieldset[disabled] .btn-info,.btn-info.disabled:hover,.btn-info[disabled]:hover,fieldset[disabled] .btn-info:hover,.btn-info.disabled:focus,.btn-info[disabled]:focus,fieldset[disabled] .btn-info:focus,.btn-info.disabled:active,.btn-info[disabled]:active,fieldset[disabled] .btn-info:active,.btn-info.disabled.active,.btn-info[disabled].active,fieldset[disabled] .btn-info.active{background-color:#5bc0de;border-color:#46b8da}.btn-link{font-weight:normal;color:#428bca;cursor:pointer;border-radius:0}.btn-link,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link,.btn-link:hover,.btn-link:focus,.btn-link:active{border-color:transparent}.btn-link:hover,.btn-link:focus{color:#2a6496;text-decoration:underline;background-color:transparent}.btn-link[disabled]:hover,fieldset[disabled] .btn-link:hover,.btn-link[disabled]:focus,fieldset[disabled] .btn-link:focus{color:#999;text-decoration:none}.btn-lg{padding:10px 16px;font-size:18px;line-height:1.33;border-radius:6px}.btn-sm,.btn-xs{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-xs{padding:1px 5px}.btn-block{display:block;width:100%;padding-right:0;padding-left:0}.btn-block+.btn-block{margin-top:5px}input[type="submit"].btn-block,input[type="reset"].btn-block,input[type="button"].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}.collapsing{position:relative;height:0;overflow:hidden;-webkit-transition:height .35s ease;transition:height .35s ease}@font-face{font-family:'Glyphicons Halflings';src:url('../fonts/glyphicons-halflings-regular.eot');src:url('../fonts/glyphicons-halflings-regular.eot?#iefix') format('embedded-opentype'),url('../fonts/glyphicons-halflings-regular.woff') format('woff'),url('../fonts/glyphicons-halflings-regular.ttf') format('truetype'),url('../fonts/glyphicons-halflings-regular.svg#glyphicons-halflingsregular') format('svg')}.glyphicon{position:relative;top:1px;display:inline-block;font-family:'Glyphicons Halflings';-webkit-font-smoothing:antialiased;font-style:normal;font-weight:normal;line-height:1}.glyphicon-asterisk:before{content:"\2a"}.glyphicon-plus:before{content:"\2b"}.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-print:before{content:"\e045"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-briefcase:before{content:"\1f4bc"}.glyphicon-calendar:before{content:"\1f4c5"}.glyphicon-pushpin:before{content:"\1f4cc"}.glyphicon-paperclip:before{content:"\1f4ce"}.glyphicon-camera:before{content:"\1f4f7"}.glyphicon-lock:before{content:"\1f512"}.glyphicon-bell:before{content:"\1f514"}.glyphicon-bookmark:before{content:"\1f516"}.glyphicon-fire:before{content:"\1f525"}.glyphicon-wrench:before{content:"\1f527"}.caret{display:inline-block;width:0;height:0;margin-left:2px;vertical-align:middle;border-top:4px solid #000;border-right:4px solid transparent;border-bottom:0 dotted;border-left:4px solid transparent;content:""}.dropdown{position:relative}.dropdown-toggle:focus{outline:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;font-size:14px;list-style:none;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.15);border-radius:4px;-webkit-box-shadow:0 6px 12px rgba(0,0,0,0.175);box-shadow:0 6px 12px rgba(0,0,0,0.175);background-clip:padding-box}.dropdown-menu.pull-right{right:0;left:auto}.dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.dropdown-menu>li>a{display:block;padding:3px 20px;clear:both;font-weight:normal;line-height:1.428571429;color:#333;white-space:nowrap}.dropdown-menu>li>a:hover,.dropdown-menu>li>a:focus{color:#fff;text-decoration:none;background-color:#428bca}.dropdown-menu>.active>a,.dropdown-menu>.active>a:hover,.dropdown-menu>.active>a:focus{color:#fff;text-decoration:none;background-color:#428bca;outline:0}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:hover,.dropdown-menu>.disabled>a:focus{color:#999}.dropdown-menu>.disabled>a:hover,.dropdown-menu>.disabled>a:focus{text-decoration:none;cursor:not-allowed;background-color:transparent;background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.open>.dropdown-menu{display:block}.open>a{outline:0}.dropdown-header{display:block;padding:3px 20px;font-size:12px;line-height:1.428571429;color:#999}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:990}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{border-top:0 dotted;border-bottom:4px solid #000;content:""}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}@media(min-width:768px){.navbar-right .dropdown-menu{right:0;left:auto}}.btn-default .caret{border-top-color:#333}.btn-primary .caret,.btn-success .caret,.btn-warning .caret,.btn-danger .caret,.btn-info .caret{border-top-color:#fff}.dropup .btn-default .caret{border-bottom-color:#333}.dropup .btn-primary .caret,.dropup .btn-success .caret,.dropup .btn-warning .caret,.dropup .btn-danger .caret,.dropup .btn-info .caret{border-bottom-color:#fff}.btn-group,.btn-group-vertical{position:relative;display:inline-block;vertical-align:middle}.btn-group>.btn,.btn-group-vertical>.btn{position:relative;float:left}.btn-group>.btn:hover,.btn-group-vertical>.btn:hover,.btn-group>.btn:focus,.btn-group-vertical>.btn:focus,.btn-group>.btn:active,.btn-group-vertical>.btn:active,.btn-group>.btn.active,.btn-group-vertical>.btn.active{z-index:2}.btn-group>.btn:focus,.btn-group-vertical>.btn:focus{outline:0}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group{margin-left:-1px}.btn-toolbar:before,.btn-toolbar:after{display:table;content:" "}.btn-toolbar:after{clear:both}.btn-toolbar:before,.btn-toolbar:after{display:table;content:" "}.btn-toolbar:after{clear:both}.btn-toolbar .btn-group{float:left}.btn-toolbar>.btn+.btn,.btn-toolbar>.btn-group+.btn,.btn-toolbar>.btn+.btn-group,.btn-toolbar>.btn-group+.btn-group{margin-left:5px}.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle){border-radius:0}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:last-child:not(:first-child),.btn-group>.dropdown-toggle:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.btn-group>.btn-group{float:left}.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group>.btn-group:first-child>.btn:last-child,.btn-group>.btn-group:first-child>.dropdown-toggle{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:last-child>.btn:first-child{border-bottom-left-radius:0;border-top-left-radius:0}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group-xs>.btn{padding:5px 10px;padding:1px 5px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-sm>.btn{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-lg>.btn{padding:10px 16px;font-size:18px;line-height:1.33;border-radius:6px}.btn-group>.btn+.dropdown-toggle{padding-right:8px;padding-left:8px}.btn-group>.btn-lg+.dropdown-toggle{padding-right:12px;padding-left:12px}.btn-group.open .dropdown-toggle{-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,0.125);box-shadow:inset 0 3px 5px rgba(0,0,0,0.125)}.btn .caret{margin-left:0}.btn-lg .caret{border-width:5px 5px 0;border-bottom-width:0}.dropup .btn-lg .caret{border-width:0 5px 5px}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group{display:block;float:none;width:100%;max-width:100%}.btn-group-vertical>.btn-group:before,.btn-group-vertical>.btn-group:after{display:table;content:" "}.btn-group-vertical>.btn-group:after{clear:both}.btn-group-vertical>.btn-group:before,.btn-group-vertical>.btn-group:after{display:table;content:" "}.btn-group-vertical>.btn-group:after{clear:both}.btn-group-vertical>.btn-group>.btn{float:none}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:first-child):not(:last-child){border-radius:0}.btn-group-vertical>.btn:first-child:not(:last-child){border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn:last-child:not(:first-child){border-top-right-radius:0;border-bottom-left-radius:4px;border-top-left-radius:0}.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group-vertical>.btn-group:first-child>.btn:last-child,.btn-group-vertical>.btn-group:first-child>.dropdown-toggle{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:last-child>.btn:first-child{border-top-right-radius:0;border-top-left-radius:0}.btn-group-justified{display:table;width:100%;border-collapse:separate;table-layout:fixed}.btn-group-justified .btn{display:table-cell;float:none;width:1%}[data-toggle="buttons"]>.btn>input[type="radio"],[data-toggle="buttons"]>.btn>input[type="checkbox"]{display:none}.input-group{position:relative;display:table;border-collapse:separate}.input-group.col{float:none;padding-right:0;padding-left:0}.input-group .form-control{width:100%;margin-bottom:0}.input-group-lg>.form-control,.input-group-lg>.input-group-addon,.input-group-lg>.input-group-btn>.btn{height:45px;padding:10px 16px;font-size:18px;line-height:1.33;border-radius:6px}select.input-group-lg>.form-control,select.input-group-lg>.input-group-addon,select.input-group-lg>.input-group-btn>.btn{height:45px;line-height:45px}textarea.input-group-lg>.form-control,textarea.input-group-lg>.input-group-addon,textarea.input-group-lg>.input-group-btn>.btn{height:auto}.input-group-sm>.form-control,.input-group-sm>.input-group-addon,.input-group-sm>.input-group-btn>.btn{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-group-sm>.form-control,select.input-group-sm>.input-group-addon,select.input-group-sm>.input-group-btn>.btn{height:30px;line-height:30px}textarea.input-group-sm>.form-control,textarea.input-group-sm>.input-group-addon,textarea.input-group-sm>.input-group-btn>.btn{height:auto}.input-group-addon,.input-group-btn,.input-group .form-control{display:table-cell}.input-group-addon:not(:first-child):not(:last-child),.input-group-btn:not(:first-child):not(:last-child),.input-group .form-control:not(:first-child):not(:last-child){border-radius:0}.input-group-addon,.input-group-btn{width:1%;white-space:nowrap;vertical-align:middle}.input-group-addon{padding:6px 12px;font-size:14px;font-weight:normal;line-height:1;text-align:center;background-color:#eee;border:1px solid #ccc;border-radius:4px}.input-group-addon.input-sm{padding:5px 10px;font-size:12px;border-radius:3px}.input-group-addon.input-lg{padding:10px 16px;font-size:18px;border-radius:6px}.input-group-addon input[type="radio"],.input-group-addon input[type="checkbox"]{margin-top:0}.input-group .form-control:first-child,.input-group-addon:first-child,.input-group-btn:first-child>.btn,.input-group-btn:first-child>.dropdown-toggle,.input-group-btn:last-child>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.input-group-addon:first-child{border-right:0}.input-group .form-control:last-child,.input-group-addon:last-child,.input-group-btn:last-child>.btn,.input-group-btn:last-child>.dropdown-toggle,.input-group-btn:first-child>.btn:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.input-group-addon:last-child{border-left:0}.input-group-btn{position:relative;white-space:nowrap}.input-group-btn>.btn{position:relative}.input-group-btn>.btn+.btn{margin-left:-4px}.input-group-btn>.btn:hover,.input-group-btn>.btn:active{z-index:2}.nav{padding-left:0;margin-bottom:0;list-style:none}.nav:before,.nav:after{display:table;content:" "}.nav:after{clear:both}.nav:before,.nav:after{display:table;content:" "}.nav:after{clear:both}.nav>li{position:relative;display:block}.nav>li>a{position:relative;display:block;padding:10px 15px}.nav>li>a:hover,.nav>li>a:focus{text-decoration:none;background-color:#eee}.nav>li.disabled>a{color:#999}.nav>li.disabled>a:hover,.nav>li.disabled>a:focus{color:#999;text-decoration:none;cursor:not-allowed;background-color:transparent}.nav .open>a,.nav .open>a:hover,.nav .open>a:focus{background-color:#eee;border-color:#428bca}.nav .nav-divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.nav>li>a>img{max-width:none}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.428571429;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:hover,.nav-tabs>li.active>a:focus{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{text-align:center}@media(min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}}.nav-tabs.nav-justified>li>a{margin-right:0;border-bottom:1px solid #ddd}.nav-tabs.nav-justified>.active>a{border-bottom-color:#fff}.nav-pills>li{float:left}.nav-pills>li>a{border-radius:5px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:hover,.nav-pills>li.active>a:focus{color:#fff;background-color:#428bca}.nav-stacked>li{float:none}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li{float:none}.nav-justified>li>a{text-align:center}@media(min-width:768px){.nav-justified>li{display:table-cell;width:1%}}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-bottom:1px solid #ddd}.nav-tabs-justified>.active>a{border-bottom-color:#fff}.tabbable:before,.tabbable:after{display:table;content:" "}.tabbable:after{clear:both}.tabbable:before,.tabbable:after{display:table;content:" "}.tabbable:after{clear:both}.tab-content>.tab-pane,.pill-content>.pill-pane{display:none}.tab-content>.active,.pill-content>.active{display:block}.nav .caret{border-top-color:#428bca;border-bottom-color:#428bca}.nav a:hover .caret{border-top-color:#2a6496;border-bottom-color:#2a6496}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-right-radius:0;border-top-left-radius:0}.navbar{position:relative;z-index:1000;min-height:50px;margin-bottom:20px;border:1px solid transparent}.navbar:before,.navbar:after{display:table;content:" "}.navbar:after{clear:both}.navbar:before,.navbar:after{display:table;content:" "}.navbar:after{clear:both}@media(min-width:768px){.navbar{border-radius:4px}}.navbar-header:before,.navbar-header:after{display:table;content:" "}.navbar-header:after{clear:both}.navbar-header:before,.navbar-header:after{display:table;content:" "}.navbar-header:after{clear:both}@media(min-width:768px){.navbar-header{float:left}}.navbar-collapse{max-height:340px;padding-right:15px;padding-left:15px;overflow-x:visible;border-top:1px solid transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,0.1);-webkit-overflow-scrolling:touch}.navbar-collapse:before,.navbar-collapse:after{display:table;content:" "}.navbar-collapse:after{clear:both}.navbar-collapse:before,.navbar-collapse:after{display:table;content:" "}.navbar-collapse:after{clear:both}.navbar-collapse.in{overflow-y:auto}@media(min-width:768px){.navbar-collapse{width:auto;border-top:0;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-collapse .navbar-nav.navbar-left:first-child{margin-left:-15px}.navbar-collapse .navbar-nav.navbar-right:last-child{margin-right:-15px}.navbar-collapse .navbar-text:last-child{margin-right:0}}.container>.navbar-header,.container>.navbar-collapse{margin-right:-15px;margin-left:-15px}@media(min-width:768px){.container>.navbar-header,.container>.navbar-collapse{margin-right:0;margin-left:0}}.navbar-static-top{border-width:0 0 1px}@media(min-width:768px){.navbar-static-top{border-radius:0}}.navbar-fixed-top,.navbar-fixed-bottom{position:fixed;right:0;left:0;border-width:0 0 1px}@media(min-width:768px){.navbar-fixed-top,.navbar-fixed-bottom{border-radius:0}}.navbar-fixed-top{top:0;z-index:1030}.navbar-fixed-bottom{bottom:0;margin-bottom:0}.navbar-brand{float:left;padding:15px 15px;font-size:18px;line-height:20px}.navbar-brand:hover,.navbar-brand:focus{text-decoration:none}@media(min-width:768px){.navbar>.container .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;padding:9px 10px;margin-top:8px;margin-right:15px;margin-bottom:8px;background-color:transparent;border:1px solid transparent;border-radius:4px}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}@media(min-width:768px){.navbar-toggle{display:none}}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media(max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;box-shadow:none}.navbar-nav .open .dropdown-menu>li>a,.navbar-nav .open .dropdown-menu .dropdown-header{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:hover,.navbar-nav .open .dropdown-menu>li>a:focus{background-image:none}}@media(min-width:768px){.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}@media(min-width:768px){.navbar-left{float:left!important}.navbar-right{float:right!important}}.navbar-form{padding:10px 15px;margin-top:8px;margin-right:-15px;margin-bottom:8px;margin-left:-15px;border-top:1px solid transparent;border-bottom:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1);box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1)}@media(min-width:768px){.navbar-form .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block}.navbar-form .radio,.navbar-form .checkbox{display:inline-block;padding-left:0;margin-top:0;margin-bottom:0}.navbar-form .radio input[type="radio"],.navbar-form .checkbox input[type="checkbox"]{float:none;margin-left:0}}@media(max-width:767px){.navbar-form .form-group{margin-bottom:5px}}@media(min-width:768px){.navbar-form{width:auto;padding-top:0;padding-bottom:0;margin-right:0;margin-left:0;border:0;-webkit-box-shadow:none;box-shadow:none}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-right-radius:0;border-top-left-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{border-bottom-right-radius:0;border-bottom-left-radius:0}.navbar-nav.pull-right>li>.dropdown-menu,.navbar-nav>li>.dropdown-menu.pull-right{right:0;left:auto}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-text{float:left;margin-top:15px;margin-bottom:15px}@media(min-width:768px){.navbar-text{margin-right:15px;margin-left:15px}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:hover,.navbar-default .navbar-brand:focus{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a{color:#777}.navbar-default .navbar-nav>li>a:hover,.navbar-default .navbar-nav>li>a:focus{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:hover,.navbar-default .navbar-nav>.active>a:focus{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:hover,.navbar-default .navbar-nav>.disabled>a:focus{color:#ccc;background-color:transparent}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:hover,.navbar-default .navbar-toggle:focus{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#ccc}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e6e6e6}.navbar-default .navbar-nav>.dropdown>a:hover .caret,.navbar-default .navbar-nav>.dropdown>a:focus .caret{border-top-color:#333;border-bottom-color:#333}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:hover,.navbar-default .navbar-nav>.open>a:focus{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.open>a .caret,.navbar-default .navbar-nav>.open>a:hover .caret,.navbar-default .navbar-nav>.open>a:focus .caret{border-top-color:#555;border-bottom-color:#555}.navbar-default .navbar-nav>.dropdown>a .caret{border-top-color:#777;border-bottom-color:#777}@media(max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover,.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus{color:#ccc;background-color:transparent}}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#999}.navbar-inverse .navbar-brand:hover,.navbar-inverse .navbar-brand:focus{color:#fff;background-color:transparent}.navbar-inverse .navbar-text{color:#999}.navbar-inverse .navbar-nav>li>a{color:#999}.navbar-inverse .navbar-nav>li>a:hover,.navbar-inverse .navbar-nav>li>a:focus{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:hover,.navbar-inverse .navbar-nav>.active>a:focus{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:hover,.navbar-inverse .navbar-nav>.disabled>a:focus{color:#444;background-color:transparent}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:hover,.navbar-inverse .navbar-toggle:focus{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:hover,.navbar-inverse .navbar-nav>.open>a:focus{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.dropdown>a:hover .caret{border-top-color:#fff;border-bottom-color:#fff}.navbar-inverse .navbar-nav>.dropdown>a .caret{border-top-color:#999;border-bottom-color:#999}.navbar-inverse .navbar-nav>.open>a .caret,.navbar-inverse .navbar-nav>.open>a:hover .caret,.navbar-inverse .navbar-nav>.open>a:focus .caret{border-top-color:#fff;border-bottom-color:#fff}@media(max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#999}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus{color:#444;background-color:transparent}}.navbar-inverse .navbar-link{color:#999}.navbar-inverse .navbar-link:hover{color:#fff}.breadcrumb{padding:8px 15px;margin-bottom:20px;list-style:none;background-color:#f5f5f5;border-radius:4px}.breadcrumb>li{display:inline-block}.breadcrumb>li+li:before{padding:0 5px;color:#ccc;content:"/\00a0"}.breadcrumb>.active{color:#999}.pagination{display:inline-block;padding-left:0;margin:20px 0;border-radius:4px}.pagination>li{display:inline}.pagination>li>a,.pagination>li>span{position:relative;float:left;padding:6px 12px;margin-left:-1px;line-height:1.428571429;text-decoration:none;background-color:#fff;border:1px solid #ddd}.pagination>li:first-child>a,.pagination>li:first-child>span{margin-left:0;border-bottom-left-radius:4px;border-top-left-radius:4px}.pagination>li:last-child>a,.pagination>li:last-child>span{border-top-right-radius:4px;border-bottom-right-radius:4px}.pagination>li>a:hover,.pagination>li>span:hover,.pagination>li>a:focus,.pagination>li>span:focus{background-color:#eee}.pagination>.active>a,.pagination>.active>span,.pagination>.active>a:hover,.pagination>.active>span:hover,.pagination>.active>a:focus,.pagination>.active>span:focus{z-index:2;color:#fff;cursor:default;background-color:#428bca;border-color:#428bca}.pagination>.disabled>span,.pagination>.disabled>a,.pagination>.disabled>a:hover,.pagination>.disabled>a:focus{color:#999;cursor:not-allowed;background-color:#fff;border-color:#ddd}.pagination-lg>li>a,.pagination-lg>li>span{padding:10px 16px;font-size:18px}.pagination-lg>li:first-child>a,.pagination-lg>li:first-child>span{border-bottom-left-radius:6px;border-top-left-radius:6px}.pagination-lg>li:last-child>a,.pagination-lg>li:last-child>span{border-top-right-radius:6px;border-bottom-right-radius:6px}.pagination-sm>li>a,.pagination-sm>li>span{padding:5px 10px;font-size:12px}.pagination-sm>li:first-child>a,.pagination-sm>li:first-child>span{border-bottom-left-radius:3px;border-top-left-radius:3px}.pagination-sm>li:last-child>a,.pagination-sm>li:last-child>span{border-top-right-radius:3px;border-bottom-right-radius:3px}.pager{padding-left:0;margin:20px 0;text-align:center;list-style:none}.pager:before,.pager:after{display:table;content:" "}.pager:after{clear:both}.pager:before,.pager:after{display:table;content:" "}.pager:after{clear:both}.pager li{display:inline}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;border-radius:15px}.pager li>a:hover,.pager li>a:focus{text-decoration:none;background-color:#eee}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:hover,.pager .disabled>a:focus,.pager .disabled>span{color:#999;cursor:not-allowed;background-color:#fff}.label{display:inline;padding:.2em .6em .3em;font-size:75%;font-weight:bold;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25em}.label[href]:hover,.label[href]:focus{color:#fff;text-decoration:none;cursor:pointer}.label:empty{display:none}.label-default{background-color:#999}.label-default[href]:hover,.label-default[href]:focus{background-color:#808080}.label-primary{background-color:#428bca}.label-primary[href]:hover,.label-primary[href]:focus{background-color:#3071a9}.label-success{background-color:#5cb85c}.label-success[href]:hover,.label-success[href]:focus{background-color:#449d44}.label-info{background-color:#5bc0de}.label-info[href]:hover,.label-info[href]:focus{background-color:#31b0d5}.label-warning{background-color:#f0ad4e}.label-warning[href]:hover,.label-warning[href]:focus{background-color:#ec971f}.label-danger{background-color:#d9534f}.label-danger[href]:hover,.label-danger[href]:focus{background-color:#c9302c}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;font-weight:bold;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;background-color:#999;border-radius:10px}.badge:empty{display:none}a.badge:hover,a.badge:focus{color:#fff;text-decoration:none;cursor:pointer}.btn .badge{position:relative;top:-1px}a.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#428bca;background-color:#fff}.nav-pills>li>a>.badge{margin-left:3px}.jumbotron{padding:30px;margin-bottom:30px;font-size:21px;font-weight:200;line-height:2.1428571435;color:inherit;background-color:#eee}.jumbotron h1{line-height:1;color:inherit}.jumbotron p{line-height:1.4}.container .jumbotron{border-radius:6px}@media screen and (min-width:768px){.jumbotron{padding-top:48px;padding-bottom:48px}.container .jumbotron{padding-right:60px;padding-left:60px}.jumbotron h1{font-size:63px}}.thumbnail{display:inline-block;display:block;height:auto;max-width:100%;padding:4px;line-height:1.428571429;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.thumbnail>img{display:block;height:auto;max-width:100%}a.thumbnail:hover,a.thumbnail:focus{border-color:#428bca}.thumbnail>img{margin-right:auto;margin-left:auto}.thumbnail .caption{padding:9px;color:#333}.alert{padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert .alert-link{font-weight:bold}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable{padding-right:35px}.alert-dismissable .close{position:relative;top:-2px;right:-21px;color:inherit}.alert-success{color:#468847;background-color:#dff0d8;border-color:#d6e9c6}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#356635}.alert-info{color:#3a87ad;background-color:#d9edf7;border-color:#bce8f1}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#2d6987}.alert-warning{color:#c09853;background-color:#fcf8e3;border-color:#fbeed5}.alert-warning hr{border-top-color:#f8e5be}.alert-warning .alert-link{color:#a47e3c}.alert-danger{color:#b94a48;background-color:#f2dede;border-color:#eed3d7}.alert-danger hr{border-top-color:#e6c1c7}.alert-danger .alert-link{color:#953b39}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-moz-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:0 0}to{background-position:40px 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f5f5f5;border-radius:4px;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1)}.progress-bar{float:left;width:0;height:100%;font-size:12px;color:#fff;text-align:center;background-color:#428bca;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);-webkit-transition:width .6s ease;transition:width .6s ease}.progress-striped .progress-bar{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-size:40px 40px}.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-moz-animation:progress-bar-stripes 2s linear infinite;-ms-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-bar-success{background-color:#5cb85c}.progress-striped .progress-bar-success{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-bar-info{background-color:#5bc0de}.progress-striped .progress-bar-info{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#f0ad4e}.progress-striped .progress-bar-warning{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#d9534f}.progress-striped .progress-bar-danger{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.media,.media-body{overflow:hidden;zoom:1}.media,.media .media{margin-top:15px}.media:first-child{margin-top:0}.media-object{display:block}.media-heading{margin:0 0 5px}.media>.pull-left{margin-right:10px}.media>.pull-right{margin-left:10px}.media-list{padding-left:0;list-style:none}.list-group{padding-left:0;margin-bottom:20px}.list-group-item{position:relative;display:block;padding:10px 15px;margin-bottom:-1px;background-color:#fff;border:1px solid #ddd}.list-group-item:first-child{border-top-right-radius:4px;border-top-left-radius:4px}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}a.list-group-item{color:#555}a.list-group-item .list-group-item-heading{color:#333}a.list-group-item:hover,a.list-group-item:focus{text-decoration:none;background-color:#f5f5f5}.list-group-item.active,.list-group-item.active:hover,.list-group-item.active:focus{z-index:2;color:#fff;background-color:#428bca;border-color:#428bca}.list-group-item.active .list-group-item-heading,.list-group-item.active:hover .list-group-item-heading,.list-group-item.active:focus .list-group-item-heading{color:inherit}.list-group-item.active .list-group-item-text,.list-group-item.active:hover .list-group-item-text,.list-group-item.active:focus .list-group-item-text{color:#e1edf7}.list-group-item-heading{margin-top:0;margin-bottom:5px}.list-group-item-text{margin-bottom:0;line-height:1.3}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0,0,0,0.05);box-shadow:0 1px 1px rgba(0,0,0,0.05)}.panel-body{padding:15px}.panel-body:before,.panel-body:after{display:table;content:" "}.panel-body:after{clear:both}.panel-body:before,.panel-body:after{display:table;content:" "}.panel-body:after{clear:both}.panel>.list-group{margin-bottom:0}.panel>.list-group .list-group-item{border-width:1px 0}.panel>.list-group .list-group-item:first-child{border-top-right-radius:0;border-top-left-radius:0}.panel>.list-group .list-group-item:last-child{border-bottom:0}.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.panel>.table{margin-bottom:0}.panel>.panel-body+.table{border-top:1px solid #ddd}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-right-radius:3px;border-top-left-radius:3px}.panel-title{margin-top:0;margin-bottom:0;font-size:16px}.panel-title>a{color:inherit}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel-group .panel{margin-bottom:0;overflow:hidden;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading{border-bottom:0}.panel-group .panel-heading+.panel-collapse .panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse .panel-body{border-top-color:#ddd}.panel-default>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#428bca}.panel-primary>.panel-heading{color:#fff;background-color:#428bca;border-color:#428bca}.panel-primary>.panel-heading+.panel-collapse .panel-body{border-top-color:#428bca}.panel-primary>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#428bca}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#468847;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse .panel-body{border-top-color:#d6e9c6}.panel-success>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#d6e9c6}.panel-warning{border-color:#fbeed5}.panel-warning>.panel-heading{color:#c09853;background-color:#fcf8e3;border-color:#fbeed5}.panel-warning>.panel-heading+.panel-collapse .panel-body{border-top-color:#fbeed5}.panel-warning>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#fbeed5}.panel-danger{border-color:#eed3d7}.panel-danger>.panel-heading{color:#b94a48;background-color:#f2dede;border-color:#eed3d7}.panel-danger>.panel-heading+.panel-collapse .panel-body{border-top-color:#eed3d7}.panel-danger>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#eed3d7}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#3a87ad;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse .panel-body{border-top-color:#bce8f1}.panel-info>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#bce8f1}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.05);box-shadow:inset 0 1px 1px rgba(0,0,0,0.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,0.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;font-weight:bold;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.close:hover,.close:focus{color:#000;text-decoration:none;cursor:pointer;opacity:.5;filter:alpha(opacity=50)}button.close{padding:0;cursor:pointer;background:transparent;border:0;-webkit-appearance:none}.modal-open{overflow:hidden}body.modal-open,.modal-open .navbar-fixed-top,.modal-open .navbar-fixed-bottom{margin-right:15px}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;display:none;overflow:auto;overflow-y:scroll}.modal.fade .modal-dialog{-webkit-transform:translate(0,-25%);-ms-transform:translate(0,-25%);transform:translate(0,-25%);-webkit-transition:-webkit-transform .3s ease-out;-moz-transition:-moz-transform .3s ease-out;-o-transition:-o-transform .3s ease-out;transition:transform .3s ease-out}.modal.in .modal-dialog{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.modal-dialog{z-index:1050;width:auto;padding:10px;margin-right:auto;margin-left:auto}.modal-content{position:relative;background-color:#fff;border:1px solid #999;border:1px solid rgba(0,0,0,0.2);border-radius:6px;outline:0;-webkit-box-shadow:0 3px 9px rgba(0,0,0,0.5);box-shadow:0 3px 9px rgba(0,0,0,0.5);background-clip:padding-box}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1030;background-color:#000}.modal-backdrop.fade{opacity:0;filter:alpha(opacity=0)}.modal-backdrop.in{opacity:.5;filter:alpha(opacity=50)}.modal-header{min-height:16.428571429px;padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.428571429}.modal-body{position:relative;padding:20px}.modal-footer{padding:19px 20px 20px;margin-top:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer:before,.modal-footer:after{display:table;content:" "}.modal-footer:after{clear:both}.modal-footer:before,.modal-footer:after{display:table;content:" "}.modal-footer:after{clear:both}.modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}@media screen and (min-width:768px){.modal-dialog{right:auto;left:50%;width:600px;padding-top:30px;padding-bottom:30px}.modal-content{-webkit-box-shadow:0 5px 15px rgba(0,0,0,0.5);box-shadow:0 5px 15px rgba(0,0,0,0.5)}}.tooltip{position:absolute;z-index:1030;display:block;font-size:12px;line-height:1.4;opacity:0;filter:alpha(opacity=0);visibility:visible}.tooltip.in{opacity:.9;filter:alpha(opacity=90)}.tooltip.top{padding:5px 0;margin-top:-3px}.tooltip.right{padding:0 5px;margin-left:3px}.tooltip.bottom{padding:5px 0;margin-top:3px}.tooltip.left{padding:0 5px;margin-left:-3px}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;text-decoration:none;background-color:#000;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-top-color:#000;border-width:5px 5px 0}.tooltip.top-left .tooltip-arrow{bottom:0;left:5px;border-top-color:#000;border-width:5px 5px 0}.tooltip.top-right .tooltip-arrow{right:5px;bottom:0;border-top-color:#000;border-width:5px 5px 0}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-right-color:#000;border-width:5px 5px 5px 0}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-left-color:#000;border-width:5px 0 5px 5px}.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-bottom-color:#000;border-width:0 5px 5px}.tooltip.bottom-left .tooltip-arrow{top:0;left:5px;border-bottom-color:#000;border-width:0 5px 5px}.tooltip.bottom-right .tooltip-arrow{top:0;right:5px;border-bottom-color:#000;border-width:0 5px 5px}.popover{position:absolute;top:0;left:0;z-index:1010;display:none;max-width:276px;padding:1px;text-align:left;white-space:normal;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,0.2);box-shadow:0 5px 10px rgba(0,0,0,0.2);background-clip:padding-box}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover-title{padding:8px 14px;margin:0;font-size:14px;font-weight:normal;line-height:18px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0}.popover-content{padding:9px 14px}.popover .arrow,.popover .arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.popover .arrow{border-width:11px}.popover .arrow:after{border-width:10px;content:""}.popover.top .arrow{bottom:-11px;left:50%;margin-left:-11px;border-top-color:#999;border-top-color:rgba(0,0,0,0.25);border-bottom-width:0}.popover.top .arrow:after{bottom:1px;margin-left:-10px;border-top-color:#fff;border-bottom-width:0;content:" "}.popover.right .arrow{top:50%;left:-11px;margin-top:-11px;border-right-color:#999;border-right-color:rgba(0,0,0,0.25);border-left-width:0}.popover.right .arrow:after{bottom:-10px;left:1px;border-right-color:#fff;border-left-width:0;content:" "}.popover.bottom .arrow{top:-11px;left:50%;margin-left:-11px;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,0.25);border-top-width:0}.popover.bottom .arrow:after{top:1px;margin-left:-10px;border-bottom-color:#fff;border-top-width:0;content:" "}.popover.left .arrow{top:50%;right:-11px;margin-top:-11px;border-left-color:#999;border-left-color:rgba(0,0,0,0.25);border-right-width:0}.popover.left .arrow:after{right:1px;bottom:-10px;border-left-color:#fff;border-right-width:0;content:" "}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner>.item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>img,.carousel-inner>.item>a>img{display:block;height:auto;max-width:100%;line-height:1}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:0;bottom:0;left:0;width:15%;font-size:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,0.6);opacity:.5;filter:alpha(opacity=50)}.carousel-control.left{background-image:-webkit-gradient(linear,0 top,100% top,from(rgba(0,0,0,0.5)),to(rgba(0,0,0,0.0001)));background-image:-webkit-linear-gradient(left,color-stop(rgba(0,0,0,0.5) 0),color-stop(rgba(0,0,0,0.0001) 100%));background-image:-moz-linear-gradient(left,rgba(0,0,0,0.5) 0,rgba(0,0,0,0.0001) 100%);background-image:linear-gradient(to right,rgba(0,0,0,0.5) 0,rgba(0,0,0,0.0001) 100%);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000',endColorstr='#00000000',GradientType=1)}.carousel-control.right{right:0;left:auto;background-image:-webkit-gradient(linear,0 top,100% top,from(rgba(0,0,0,0.0001)),to(rgba(0,0,0,0.5)));background-image:-webkit-linear-gradient(left,color-stop(rgba(0,0,0,0.0001) 0),color-stop(rgba(0,0,0,0.5) 100%));background-image:-moz-linear-gradient(left,rgba(0,0,0,0.0001) 0,rgba(0,0,0,0.5) 100%);background-image:linear-gradient(to right,rgba(0,0,0,0.0001) 0,rgba(0,0,0,0.5) 100%);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000',endColorstr='#80000000',GradientType=1)}.carousel-control:hover,.carousel-control:focus{color:#fff;text-decoration:none;opacity:.9;filter:alpha(opacity=90)}.carousel-control .icon-prev,.carousel-control .icon-next,.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right{position:absolute;top:50%;left:50%;z-index:5;display:inline-block}.carousel-control .icon-prev,.carousel-control .icon-next{width:20px;height:20px;margin-top:-10px;margin-left:-10px;font-family:serif}.carousel-control .icon-prev:before{content:'\2039'}.carousel-control .icon-next:before{content:'\203a'}.carousel-indicators{position:absolute;bottom:10px;left:50%;z-index:15;width:60%;padding-left:0;margin-left:-30%;text-align:center;list-style:none}.carousel-indicators li{display:inline-block;width:10px;height:10px;margin:1px;text-indent:-999px;cursor:pointer;border:1px solid #fff;border-radius:10px}.carousel-indicators .active{width:12px;height:12px;margin:0;background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,0.6)}.carousel-caption .btn{text-shadow:none}@media screen and (min-width:768px){.carousel-control .icon-prev,.carousel-control .icon-next{width:30px;height:30px;margin-top:-15px;margin-left:-15px;font-size:30px}.carousel-caption{right:20%;left:20%;padding-bottom:30px}.carousel-indicators{bottom:20px}}.clearfix:before,.clearfix:after{display:table;content:" "}.clearfix:after{clear:both}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.affix{position:fixed}@-ms-viewport{width:device-width}@media screen and (max-width:400px){@-ms-viewport{width:320px}}.hidden{display:none!important;visibility:hidden!important}.visible-xs{display:none!important}tr.visible-xs{display:none!important}th.visible-xs,td.visible-xs{display:none!important}@media(max-width:767px){.visible-xs{display:block!important}tr.visible-xs{display:table-row!important}th.visible-xs,td.visible-xs{display:table-cell!important}}@media(min-width:768px) and (max-width:991px){.visible-xs.visible-sm{display:block!important}tr.visible-xs.visible-sm{display:table-row!important}th.visible-xs.visible-sm,td.visible-xs.visible-sm{display:table-cell!important}}@media(min-width:992px) and (max-width:1199px){.visible-xs.visible-md{display:block!important}tr.visible-xs.visible-md{display:table-row!important}th.visible-xs.visible-md,td.visible-xs.visible-md{display:table-cell!important}}@media(min-width:1200px){.visible-xs.visible-lg{display:block!important}tr.visible-xs.visible-lg{display:table-row!important}th.visible-xs.visible-lg,td.visible-xs.visible-lg{display:table-cell!important}}.visible-sm{display:none!important}tr.visible-sm{display:none!important}th.visible-sm,td.visible-sm{display:none!important}@media(max-width:767px){.visible-sm.visible-xs{display:block!important}tr.visible-sm.visible-xs{display:table-row!important}th.visible-sm.visible-xs,td.visible-sm.visible-xs{display:table-cell!important}}@media(min-width:768px) and (max-width:991px){.visible-sm{display:block!important}tr.visible-sm{display:table-row!important}th.visible-sm,td.visible-sm{display:table-cell!important}}@media(min-width:992px) and (max-width:1199px){.visible-sm.visible-md{display:block!important}tr.visible-sm.visible-md{display:table-row!important}th.visible-sm.visible-md,td.visible-sm.visible-md{display:table-cell!important}}@media(min-width:1200px){.visible-sm.visible-lg{display:block!important}tr.visible-sm.visible-lg{display:table-row!important}th.visible-sm.visible-lg,td.visible-sm.visible-lg{display:table-cell!important}}.visible-md{display:none!important}tr.visible-md{display:none!important}th.visible-md,td.visible-md{display:none!important}@media(max-width:767px){.visible-md.visible-xs{display:block!important}tr.visible-md.visible-xs{display:table-row!important}th.visible-md.visible-xs,td.visible-md.visible-xs{display:table-cell!important}}@media(min-width:768px) and (max-width:991px){.visible-md.visible-sm{display:block!important}tr.visible-md.visible-sm{display:table-row!important}th.visible-md.visible-sm,td.visible-md.visible-sm{display:table-cell!important}}@media(min-width:992px) and (max-width:1199px){.visible-md{display:block!important}tr.visible-md{display:table-row!important}th.visible-md,td.visible-md{display:table-cell!important}}@media(min-width:1200px){.visible-md.visible-lg{display:block!important}tr.visible-md.visible-lg{display:table-row!important}th.visible-md.visible-lg,td.visible-md.visible-lg{display:table-cell!important}}.visible-lg{display:none!important}tr.visible-lg{display:none!important}th.visible-lg,td.visible-lg{display:none!important}@media(max-width:767px){.visible-lg.visible-xs{display:block!important}tr.visible-lg.visible-xs{display:table-row!important}th.visible-lg.visible-xs,td.visible-lg.visible-xs{display:table-cell!important}}@media(min-width:768px) and (max-width:991px){.visible-lg.visible-sm{display:block!important}tr.visible-lg.visible-sm{display:table-row!important}th.visible-lg.visible-sm,td.visible-lg.visible-sm{display:table-cell!important}}@media(min-width:992px) and (max-width:1199px){.visible-lg.visible-md{display:block!important}tr.visible-lg.visible-md{display:table-row!important}th.visible-lg.visible-md,td.visible-lg.visible-md{display:table-cell!important}}@media(min-width:1200px){.visible-lg{display:block!important}tr.visible-lg{display:table-row!important}th.visible-lg,td.visible-lg{display:table-cell!important}}.hidden-xs{display:block!important}tr.hidden-xs{display:table-row!important}th.hidden-xs,td.hidden-xs{display:table-cell!important}@media(max-width:767px){.hidden-xs{display:none!important}tr.hidden-xs{display:none!important}th.hidden-xs,td.hidden-xs{display:none!important}}@media(min-width:768px) and (max-width:991px){.hidden-xs.hidden-sm{display:none!important}tr.hidden-xs.hidden-sm{display:none!important}th.hidden-xs.hidden-sm,td.hidden-xs.hidden-sm{display:none!important}}@media(min-width:992px) and (max-width:1199px){.hidden-xs.hidden-md{display:none!important}tr.hidden-xs.hidden-md{display:none!important}th.hidden-xs.hidden-md,td.hidden-xs.hidden-md{display:none!important}}@media(min-width:1200px){.hidden-xs.hidden-lg{display:none!important}tr.hidden-xs.hidden-lg{display:none!important}th.hidden-xs.hidden-lg,td.hidden-xs.hidden-lg{display:none!important}}.hidden-sm{display:block!important}tr.hidden-sm{display:table-row!important}th.hidden-sm,td.hidden-sm{display:table-cell!important}@media(max-width:767px){.hidden-sm.hidden-xs{display:none!important}tr.hidden-sm.hidden-xs{display:none!important}th.hidden-sm.hidden-xs,td.hidden-sm.hidden-xs{display:none!important}}@media(min-width:768px) and (max-width:991px){.hidden-sm{display:none!important}tr.hidden-sm{display:none!important}th.hidden-sm,td.hidden-sm{display:none!important}}@media(min-width:992px) and (max-width:1199px){.hidden-sm.hidden-md{display:none!important}tr.hidden-sm.hidden-md{display:none!important}th.hidden-sm.hidden-md,td.hidden-sm.hidden-md{display:none!important}}@media(min-width:1200px){.hidden-sm.hidden-lg{display:none!important}tr.hidden-sm.hidden-lg{display:none!important}th.hidden-sm.hidden-lg,td.hidden-sm.hidden-lg{display:none!important}}.hidden-md{display:block!important}tr.hidden-md{display:table-row!important}th.hidden-md,td.hidden-md{display:table-cell!important}@media(max-width:767px){.hidden-md.hidden-xs{display:none!important}tr.hidden-md.hidden-xs{display:none!important}th.hidden-md.hidden-xs,td.hidden-md.hidden-xs{display:none!important}}@media(min-width:768px) and (max-width:991px){.hidden-md.hidden-sm{display:none!important}tr.hidden-md.hidden-sm{display:none!important}th.hidden-md.hidden-sm,td.hidden-md.hidden-sm{display:none!important}}@media(min-width:992px) and (max-width:1199px){.hidden-md{display:none!important}tr.hidden-md{display:none!important}th.hidden-md,td.hidden-md{display:none!important}}@media(min-width:1200px){.hidden-md.hidden-lg{display:none!important}tr.hidden-md.hidden-lg{display:none!important}th.hidden-md.hidden-lg,td.hidden-md.hidden-lg{display:none!important}}.hidden-lg{display:block!important}tr.hidden-lg{display:table-row!important}th.hidden-lg,td.hidden-lg{display:table-cell!important}@media(max-width:767px){.hidden-lg.hidden-xs{display:none!important}tr.hidden-lg.hidden-xs{display:none!important}th.hidden-lg.hidden-xs,td.hidden-lg.hidden-xs{display:none!important}}@media(min-width:768px) and (max-width:991px){.hidden-lg.hidden-sm{display:none!important}tr.hidden-lg.hidden-sm{display:none!important}th.hidden-lg.hidden-sm,td.hidden-lg.hidden-sm{display:none!important}}@media(min-width:992px) and (max-width:1199px){.hidden-lg.hidden-md{display:none!important}tr.hidden-lg.hidden-md{display:none!important}th.hidden-lg.hidden-md,td.hidden-lg.hidden-md{display:none!important}}@media(min-width:1200px){.hidden-lg{display:none!important}tr.hidden-lg{display:none!important}th.hidden-lg,td.hidden-lg{display:none!important}}.visible-print{display:none!important}tr.visible-print{display:none!important}th.visible-print,td.visible-print{display:none!important}@media print{.visible-print{display:block!important}tr.visible-print{display:table-row!important}th.visible-print,td.visible-print{display:table-cell!important}.hidden-print{display:none!important}tr.hidden-print{display:none!important}th.hidden-print,td.hidden-print{display:none!important}}
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Global.asax b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Global.asax
new file mode 100644
index 000000000..89bbac9c8
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Global.asax
@@ -0,0 +1 @@
+<%@ Application Codebehind="Global.asax.cs" Inherits="api.securecall.WebApiApplication" Language="C#" %>
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/_references.js b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/_references.js
new file mode 100644
index 000000000..cbe7a4708
Binary files /dev/null and b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/_references.js differ
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/bootstrap.js b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/bootstrap.js
new file mode 100644
index 000000000..5aa9982ed
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/bootstrap.js
@@ -0,0 +1,2014 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+
+/**
+* bootstrap.js v3.0.0 by @fat and @mdo
+* Copyright 2013 Twitter Inc.
+* http://www.apache.org/licenses/LICENSE-2.0
+*/
+if (!jQuery) { throw new Error("Bootstrap requires jQuery") }
+
+/* ========================================================================
+ * Bootstrap: transition.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#transitions
+ * ========================================================================
+ * Copyright 2013 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
+ // ============================================================
+
+ function transitionEnd() {
+ var el = document.createElement('bootstrap')
+
+ var transEndEventNames = {
+ 'WebkitTransition' : 'webkitTransitionEnd'
+ , 'MozTransition' : 'transitionend'
+ , 'OTransition' : 'oTransitionEnd otransitionend'
+ , 'transition' : 'transitionend'
+ }
+
+ for (var name in transEndEventNames) {
+ if (el.style[name] !== undefined) {
+ return { end: transEndEventNames[name] }
+ }
+ }
+ }
+
+ // http://blog.alexmaccaw.com/css-transitions
+ $.fn.emulateTransitionEnd = function (duration) {
+ var called = false, $el = this
+ $(this).one($.support.transition.end, function () { called = true })
+ var callback = function () { if (!called) $($el).trigger($.support.transition.end) }
+ setTimeout(callback, duration)
+ return this
+ }
+
+ $(function () {
+ $.support.transition = transitionEnd()
+ })
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: alert.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#alerts
+ * ========================================================================
+ * Copyright 2013 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // ALERT CLASS DEFINITION
+ // ======================
+
+ var dismiss = '[data-dismiss="alert"]'
+ var Alert = function (el) {
+ $(el).on('click', dismiss, this.close)
+ }
+
+ Alert.prototype.close = function (e) {
+ var $this = $(this)
+ var selector = $this.attr('data-target')
+
+ if (!selector) {
+ selector = $this.attr('href')
+ selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
+ }
+
+ var $parent = $(selector)
+
+ if (e) e.preventDefault()
+
+ if (!$parent.length) {
+ $parent = $this.hasClass('alert') ? $this : $this.parent()
+ }
+
+ $parent.trigger(e = $.Event('close.bs.alert'))
+
+ if (e.isDefaultPrevented()) return
+
+ $parent.removeClass('in')
+
+ function removeElement() {
+ $parent.trigger('closed.bs.alert').remove()
+ }
+
+ $.support.transition && $parent.hasClass('fade') ?
+ $parent
+ .one($.support.transition.end, removeElement)
+ .emulateTransitionEnd(150) :
+ removeElement()
+ }
+
+
+ // ALERT PLUGIN DEFINITION
+ // =======================
+
+ var old = $.fn.alert
+
+ $.fn.alert = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.alert')
+
+ if (!data) $this.data('bs.alert', (data = new Alert(this)))
+ if (typeof option == 'string') data[option].call($this)
+ })
+ }
+
+ $.fn.alert.Constructor = Alert
+
+
+ // ALERT NO CONFLICT
+ // =================
+
+ $.fn.alert.noConflict = function () {
+ $.fn.alert = old
+ return this
+ }
+
+
+ // ALERT DATA-API
+ // ==============
+
+ $(document).on('click.bs.alert.data-api', dismiss, Alert.prototype.close)
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: button.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#buttons
+ * ========================================================================
+ * Copyright 2013 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // BUTTON PUBLIC CLASS DEFINITION
+ // ==============================
+
+ var Button = function (element, options) {
+ this.$element = $(element)
+ this.options = $.extend({}, Button.DEFAULTS, options)
+ }
+
+ Button.DEFAULTS = {
+ loadingText: 'loading...'
+ }
+
+ Button.prototype.setState = function (state) {
+ var d = 'disabled'
+ var $el = this.$element
+ var val = $el.is('input') ? 'val' : 'html'
+ var data = $el.data()
+
+ state = state + 'Text'
+
+ if (!data.resetText) $el.data('resetText', $el[val]())
+
+ $el[val](data[state] || this.options[state])
+
+ // push to event loop to allow forms to submit
+ setTimeout(function () {
+ state == 'loadingText' ?
+ $el.addClass(d).attr(d, d) :
+ $el.removeClass(d).removeAttr(d);
+ }, 0)
+ }
+
+ Button.prototype.toggle = function () {
+ var $parent = this.$element.closest('[data-toggle="buttons"]')
+
+ if ($parent.length) {
+ var $input = this.$element.find('input')
+ .prop('checked', !this.$element.hasClass('active'))
+ .trigger('change')
+ if ($input.prop('type') === 'radio') $parent.find('.active').removeClass('active')
+ }
+
+ this.$element.toggleClass('active')
+ }
+
+
+ // BUTTON PLUGIN DEFINITION
+ // ========================
+
+ var old = $.fn.button
+
+ $.fn.button = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.button')
+ var options = typeof option == 'object' && option
+
+ if (!data) $this.data('bs.button', (data = new Button(this, options)))
+
+ if (option == 'toggle') data.toggle()
+ else if (option) data.setState(option)
+ })
+ }
+
+ $.fn.button.Constructor = Button
+
+
+ // BUTTON NO CONFLICT
+ // ==================
+
+ $.fn.button.noConflict = function () {
+ $.fn.button = old
+ return this
+ }
+
+
+ // BUTTON DATA-API
+ // ===============
+
+ $(document).on('click.bs.button.data-api', '[data-toggle^=button]', function (e) {
+ var $btn = $(e.target)
+ if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
+ $btn.button('toggle')
+ e.preventDefault()
+ })
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: carousel.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#carousel
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // CAROUSEL CLASS DEFINITION
+ // =========================
+
+ var Carousel = function (element, options) {
+ this.$element = $(element)
+ this.$indicators = this.$element.find('.carousel-indicators')
+ this.options = options
+ this.paused =
+ this.sliding =
+ this.interval =
+ this.$active =
+ this.$items = null
+
+ this.options.pause == 'hover' && this.$element
+ .on('mouseenter', $.proxy(this.pause, this))
+ .on('mouseleave', $.proxy(this.cycle, this))
+ }
+
+ Carousel.DEFAULTS = {
+ interval: 5000
+ , pause: 'hover'
+ , wrap: true
+ }
+
+ Carousel.prototype.cycle = function (e) {
+ e || (this.paused = false)
+
+ this.interval && clearInterval(this.interval)
+
+ this.options.interval
+ && !this.paused
+ && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
+
+ return this
+ }
+
+ Carousel.prototype.getActiveIndex = function () {
+ this.$active = this.$element.find('.item.active')
+ this.$items = this.$active.parent().children()
+
+ return this.$items.index(this.$active)
+ }
+
+ Carousel.prototype.to = function (pos) {
+ var that = this
+ var activeIndex = this.getActiveIndex()
+
+ if (pos > (this.$items.length - 1) || pos < 0) return
+
+ if (this.sliding) return this.$element.one('slid', function () { that.to(pos) })
+ if (activeIndex == pos) return this.pause().cycle()
+
+ return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos]))
+ }
+
+ Carousel.prototype.pause = function (e) {
+ e || (this.paused = true)
+
+ if (this.$element.find('.next, .prev').length && $.support.transition.end) {
+ this.$element.trigger($.support.transition.end)
+ this.cycle(true)
+ }
+
+ this.interval = clearInterval(this.interval)
+
+ return this
+ }
+
+ Carousel.prototype.next = function () {
+ if (this.sliding) return
+ return this.slide('next')
+ }
+
+ Carousel.prototype.prev = function () {
+ if (this.sliding) return
+ return this.slide('prev')
+ }
+
+ Carousel.prototype.slide = function (type, next) {
+ var $active = this.$element.find('.item.active')
+ var $next = next || $active[type]()
+ var isCycling = this.interval
+ var direction = type == 'next' ? 'left' : 'right'
+ var fallback = type == 'next' ? 'first' : 'last'
+ var that = this
+
+ if (!$next.length) {
+ if (!this.options.wrap) return
+ $next = this.$element.find('.item')[fallback]()
+ }
+
+ this.sliding = true
+
+ isCycling && this.pause()
+
+ var e = $.Event('slide.bs.carousel', { relatedTarget: $next[0], direction: direction })
+
+ if ($next.hasClass('active')) return
+
+ if (this.$indicators.length) {
+ this.$indicators.find('.active').removeClass('active')
+ this.$element.one('slid', function () {
+ var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()])
+ $nextIndicator && $nextIndicator.addClass('active')
+ })
+ }
+
+ if ($.support.transition && this.$element.hasClass('slide')) {
+ this.$element.trigger(e)
+ if (e.isDefaultPrevented()) return
+ $next.addClass(type)
+ $next[0].offsetWidth // force reflow
+ $active.addClass(direction)
+ $next.addClass(direction)
+ $active
+ .one($.support.transition.end, function () {
+ $next.removeClass([type, direction].join(' ')).addClass('active')
+ $active.removeClass(['active', direction].join(' '))
+ that.sliding = false
+ setTimeout(function () { that.$element.trigger('slid') }, 0)
+ })
+ .emulateTransitionEnd(600)
+ } else {
+ this.$element.trigger(e)
+ if (e.isDefaultPrevented()) return
+ $active.removeClass('active')
+ $next.addClass('active')
+ this.sliding = false
+ this.$element.trigger('slid')
+ }
+
+ isCycling && this.cycle()
+
+ return this
+ }
+
+
+ // CAROUSEL PLUGIN DEFINITION
+ // ==========================
+
+ var old = $.fn.carousel
+
+ $.fn.carousel = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.carousel')
+ var options = $.extend({}, Carousel.DEFAULTS, $this.data(), typeof option == 'object' && option)
+ var action = typeof option == 'string' ? option : options.slide
+
+ if (!data) $this.data('bs.carousel', (data = new Carousel(this, options)))
+ if (typeof option == 'number') data.to(option)
+ else if (action) data[action]()
+ else if (options.interval) data.pause().cycle()
+ })
+ }
+
+ $.fn.carousel.Constructor = Carousel
+
+
+ // CAROUSEL NO CONFLICT
+ // ====================
+
+ $.fn.carousel.noConflict = function () {
+ $.fn.carousel = old
+ return this
+ }
+
+
+ // CAROUSEL DATA-API
+ // =================
+
+ $(document).on('click.bs.carousel.data-api', '[data-slide], [data-slide-to]', function (e) {
+ var $this = $(this), href
+ var $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
+ var options = $.extend({}, $target.data(), $this.data())
+ var slideIndex = $this.attr('data-slide-to')
+ if (slideIndex) options.interval = false
+
+ $target.carousel(options)
+
+ if (slideIndex = $this.attr('data-slide-to')) {
+ $target.data('bs.carousel').to(slideIndex)
+ }
+
+ e.preventDefault()
+ })
+
+ $(window).on('load', function () {
+ $('[data-ride="carousel"]').each(function () {
+ var $carousel = $(this)
+ $carousel.carousel($carousel.data())
+ })
+ })
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: collapse.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#collapse
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // COLLAPSE PUBLIC CLASS DEFINITION
+ // ================================
+
+ var Collapse = function (element, options) {
+ this.$element = $(element)
+ this.options = $.extend({}, Collapse.DEFAULTS, options)
+ this.transitioning = null
+
+ if (this.options.parent) this.$parent = $(this.options.parent)
+ if (this.options.toggle) this.toggle()
+ }
+
+ Collapse.DEFAULTS = {
+ toggle: true
+ }
+
+ Collapse.prototype.dimension = function () {
+ var hasWidth = this.$element.hasClass('width')
+ return hasWidth ? 'width' : 'height'
+ }
+
+ Collapse.prototype.show = function () {
+ if (this.transitioning || this.$element.hasClass('in')) return
+
+ var startEvent = $.Event('show.bs.collapse')
+ this.$element.trigger(startEvent)
+ if (startEvent.isDefaultPrevented()) return
+
+ var actives = this.$parent && this.$parent.find('> .panel > .in')
+
+ if (actives && actives.length) {
+ var hasData = actives.data('bs.collapse')
+ if (hasData && hasData.transitioning) return
+ actives.collapse('hide')
+ hasData || actives.data('bs.collapse', null)
+ }
+
+ var dimension = this.dimension()
+
+ this.$element
+ .removeClass('collapse')
+ .addClass('collapsing')
+ [dimension](0)
+
+ this.transitioning = 1
+
+ var complete = function () {
+ this.$element
+ .removeClass('collapsing')
+ .addClass('in')
+ [dimension]('auto')
+ this.transitioning = 0
+ this.$element.trigger('shown.bs.collapse')
+ }
+
+ if (!$.support.transition) return complete.call(this)
+
+ var scrollSize = $.camelCase(['scroll', dimension].join('-'))
+
+ this.$element
+ .one($.support.transition.end, $.proxy(complete, this))
+ .emulateTransitionEnd(350)
+ [dimension](this.$element[0][scrollSize])
+ }
+
+ Collapse.prototype.hide = function () {
+ if (this.transitioning || !this.$element.hasClass('in')) return
+
+ var startEvent = $.Event('hide.bs.collapse')
+ this.$element.trigger(startEvent)
+ if (startEvent.isDefaultPrevented()) return
+
+ var dimension = this.dimension()
+
+ this.$element
+ [dimension](this.$element[dimension]())
+ [0].offsetHeight
+
+ this.$element
+ .addClass('collapsing')
+ .removeClass('collapse')
+ .removeClass('in')
+
+ this.transitioning = 1
+
+ var complete = function () {
+ this.transitioning = 0
+ this.$element
+ .trigger('hidden.bs.collapse')
+ .removeClass('collapsing')
+ .addClass('collapse')
+ }
+
+ if (!$.support.transition) return complete.call(this)
+
+ this.$element
+ [dimension](0)
+ .one($.support.transition.end, $.proxy(complete, this))
+ .emulateTransitionEnd(350)
+ }
+
+ Collapse.prototype.toggle = function () {
+ this[this.$element.hasClass('in') ? 'hide' : 'show']()
+ }
+
+
+ // COLLAPSE PLUGIN DEFINITION
+ // ==========================
+
+ var old = $.fn.collapse
+
+ $.fn.collapse = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.collapse')
+ var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
+
+ if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
+ if (typeof option == 'string') data[option]()
+ })
+ }
+
+ $.fn.collapse.Constructor = Collapse
+
+
+ // COLLAPSE NO CONFLICT
+ // ====================
+
+ $.fn.collapse.noConflict = function () {
+ $.fn.collapse = old
+ return this
+ }
+
+
+ // COLLAPSE DATA-API
+ // =================
+
+ $(document).on('click.bs.collapse.data-api', '[data-toggle=collapse]', function (e) {
+ var $this = $(this), href
+ var target = $this.attr('data-target')
+ || e.preventDefault()
+ || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
+ var $target = $(target)
+ var data = $target.data('bs.collapse')
+ var option = data ? 'toggle' : $this.data()
+ var parent = $this.attr('data-parent')
+ var $parent = parent && $(parent)
+
+ if (!data || !data.transitioning) {
+ if ($parent) $parent.find('[data-toggle=collapse][data-parent="' + parent + '"]').not($this).addClass('collapsed')
+ $this[$target.hasClass('in') ? 'addClass' : 'removeClass']('collapsed')
+ }
+
+ $target.collapse(option)
+ })
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: dropdown.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#dropdowns
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // DROPDOWN CLASS DEFINITION
+ // =========================
+
+ var backdrop = '.dropdown-backdrop'
+ var toggle = '[data-toggle=dropdown]'
+ var Dropdown = function (element) {
+ var $el = $(element).on('click.bs.dropdown', this.toggle)
+ }
+
+ Dropdown.prototype.toggle = function (e) {
+ var $this = $(this)
+
+ if ($this.is('.disabled, :disabled')) return
+
+ var $parent = getParent($this)
+ var isActive = $parent.hasClass('open')
+
+ clearMenus()
+
+ if (!isActive) {
+ if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
+ // if mobile we we use a backdrop because click events don't delegate
+ $('').insertAfter($(this)).on('click', clearMenus)
+ }
+
+ $parent.trigger(e = $.Event('show.bs.dropdown'))
+
+ if (e.isDefaultPrevented()) return
+
+ $parent
+ .toggleClass('open')
+ .trigger('shown.bs.dropdown')
+
+ $this.focus()
+ }
+
+ return false
+ }
+
+ Dropdown.prototype.keydown = function (e) {
+ if (!/(38|40|27)/.test(e.keyCode)) return
+
+ var $this = $(this)
+
+ e.preventDefault()
+ e.stopPropagation()
+
+ if ($this.is('.disabled, :disabled')) return
+
+ var $parent = getParent($this)
+ var isActive = $parent.hasClass('open')
+
+ if (!isActive || (isActive && e.keyCode == 27)) {
+ if (e.which == 27) $parent.find(toggle).focus()
+ return $this.click()
+ }
+
+ var $items = $('[role=menu] li:not(.divider):visible a', $parent)
+
+ if (!$items.length) return
+
+ var index = $items.index($items.filter(':focus'))
+
+ if (e.keyCode == 38 && index > 0) index-- // up
+ if (e.keyCode == 40 && index < $items.length - 1) index++ // down
+ if (!~index) index=0
+
+ $items.eq(index).focus()
+ }
+
+ function clearMenus() {
+ $(backdrop).remove()
+ $(toggle).each(function (e) {
+ var $parent = getParent($(this))
+ if (!$parent.hasClass('open')) return
+ $parent.trigger(e = $.Event('hide.bs.dropdown'))
+ if (e.isDefaultPrevented()) return
+ $parent.removeClass('open').trigger('hidden.bs.dropdown')
+ })
+ }
+
+ function getParent($this) {
+ var selector = $this.attr('data-target')
+
+ if (!selector) {
+ selector = $this.attr('href')
+ selector = selector && /#/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
+ }
+
+ var $parent = selector && $(selector)
+
+ return $parent && $parent.length ? $parent : $this.parent()
+ }
+
+
+ // DROPDOWN PLUGIN DEFINITION
+ // ==========================
+
+ var old = $.fn.dropdown
+
+ $.fn.dropdown = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('dropdown')
+
+ if (!data) $this.data('dropdown', (data = new Dropdown(this)))
+ if (typeof option == 'string') data[option].call($this)
+ })
+ }
+
+ $.fn.dropdown.Constructor = Dropdown
+
+
+ // DROPDOWN NO CONFLICT
+ // ====================
+
+ $.fn.dropdown.noConflict = function () {
+ $.fn.dropdown = old
+ return this
+ }
+
+
+ // APPLY TO STANDARD DROPDOWN ELEMENTS
+ // ===================================
+
+ $(document)
+ .on('click.bs.dropdown.data-api', clearMenus)
+ .on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
+ .on('click.bs.dropdown.data-api' , toggle, Dropdown.prototype.toggle)
+ .on('keydown.bs.dropdown.data-api', toggle + ', [role=menu]' , Dropdown.prototype.keydown)
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: modal.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#modals
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // MODAL CLASS DEFINITION
+ // ======================
+
+ var Modal = function (element, options) {
+ this.options = options
+ this.$element = $(element)
+ this.$backdrop =
+ this.isShown = null
+
+ if (this.options.remote) this.$element.load(this.options.remote)
+ }
+
+ Modal.DEFAULTS = {
+ backdrop: true
+ , keyboard: true
+ , show: true
+ }
+
+ Modal.prototype.toggle = function (_relatedTarget) {
+ return this[!this.isShown ? 'show' : 'hide'](_relatedTarget)
+ }
+
+ Modal.prototype.show = function (_relatedTarget) {
+ var that = this
+ var e = $.Event('show.bs.modal', { relatedTarget: _relatedTarget })
+
+ this.$element.trigger(e)
+
+ if (this.isShown || e.isDefaultPrevented()) return
+
+ this.isShown = true
+
+ this.escape()
+
+ this.$element.on('click.dismiss.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this))
+
+ this.backdrop(function () {
+ var transition = $.support.transition && that.$element.hasClass('fade')
+
+ if (!that.$element.parent().length) {
+ that.$element.appendTo(document.body) // don't move modals dom position
+ }
+
+ that.$element.show()
+
+ if (transition) {
+ that.$element[0].offsetWidth // force reflow
+ }
+
+ that.$element
+ .addClass('in')
+ .attr('aria-hidden', false)
+
+ that.enforceFocus()
+
+ var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget })
+
+ transition ?
+ that.$element.find('.modal-dialog') // wait for modal to slide in
+ .one($.support.transition.end, function () {
+ that.$element.focus().trigger(e)
+ })
+ .emulateTransitionEnd(300) :
+ that.$element.focus().trigger(e)
+ })
+ }
+
+ Modal.prototype.hide = function (e) {
+ if (e) e.preventDefault()
+
+ e = $.Event('hide.bs.modal')
+
+ this.$element.trigger(e)
+
+ if (!this.isShown || e.isDefaultPrevented()) return
+
+ this.isShown = false
+
+ this.escape()
+
+ $(document).off('focusin.bs.modal')
+
+ this.$element
+ .removeClass('in')
+ .attr('aria-hidden', true)
+ .off('click.dismiss.modal')
+
+ $.support.transition && this.$element.hasClass('fade') ?
+ this.$element
+ .one($.support.transition.end, $.proxy(this.hideModal, this))
+ .emulateTransitionEnd(300) :
+ this.hideModal()
+ }
+
+ Modal.prototype.enforceFocus = function () {
+ $(document)
+ .off('focusin.bs.modal') // guard against infinite focus loop
+ .on('focusin.bs.modal', $.proxy(function (e) {
+ if (this.$element[0] !== e.target && !this.$element.has(e.target).length) {
+ this.$element.focus()
+ }
+ }, this))
+ }
+
+ Modal.prototype.escape = function () {
+ if (this.isShown && this.options.keyboard) {
+ this.$element.on('keyup.dismiss.bs.modal', $.proxy(function (e) {
+ e.which == 27 && this.hide()
+ }, this))
+ } else if (!this.isShown) {
+ this.$element.off('keyup.dismiss.bs.modal')
+ }
+ }
+
+ Modal.prototype.hideModal = function () {
+ var that = this
+ this.$element.hide()
+ this.backdrop(function () {
+ that.removeBackdrop()
+ that.$element.trigger('hidden.bs.modal')
+ })
+ }
+
+ Modal.prototype.removeBackdrop = function () {
+ this.$backdrop && this.$backdrop.remove()
+ this.$backdrop = null
+ }
+
+ Modal.prototype.backdrop = function (callback) {
+ var that = this
+ var animate = this.$element.hasClass('fade') ? 'fade' : ''
+
+ if (this.isShown && this.options.backdrop) {
+ var doAnimate = $.support.transition && animate
+
+ this.$backdrop = $('')
+ .appendTo(document.body)
+
+ this.$element.on('click.dismiss.modal', $.proxy(function (e) {
+ if (e.target !== e.currentTarget) return
+ this.options.backdrop == 'static'
+ ? this.$element[0].focus.call(this.$element[0])
+ : this.hide.call(this)
+ }, this))
+
+ if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
+
+ this.$backdrop.addClass('in')
+
+ if (!callback) return
+
+ doAnimate ?
+ this.$backdrop
+ .one($.support.transition.end, callback)
+ .emulateTransitionEnd(150) :
+ callback()
+
+ } else if (!this.isShown && this.$backdrop) {
+ this.$backdrop.removeClass('in')
+
+ $.support.transition && this.$element.hasClass('fade')?
+ this.$backdrop
+ .one($.support.transition.end, callback)
+ .emulateTransitionEnd(150) :
+ callback()
+
+ } else if (callback) {
+ callback()
+ }
+ }
+
+
+ // MODAL PLUGIN DEFINITION
+ // =======================
+
+ var old = $.fn.modal
+
+ $.fn.modal = function (option, _relatedTarget) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.modal')
+ var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option)
+
+ if (!data) $this.data('bs.modal', (data = new Modal(this, options)))
+ if (typeof option == 'string') data[option](_relatedTarget)
+ else if (options.show) data.show(_relatedTarget)
+ })
+ }
+
+ $.fn.modal.Constructor = Modal
+
+
+ // MODAL NO CONFLICT
+ // =================
+
+ $.fn.modal.noConflict = function () {
+ $.fn.modal = old
+ return this
+ }
+
+
+ // MODAL DATA-API
+ // ==============
+
+ $(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
+ var $this = $(this)
+ var href = $this.attr('href')
+ var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
+ var option = $target.data('modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
+
+ e.preventDefault()
+
+ $target
+ .modal(option, this)
+ .one('hide', function () {
+ $this.is(':visible') && $this.focus()
+ })
+ })
+
+ $(document)
+ .on('show.bs.modal', '.modal', function () { $(document.body).addClass('modal-open') })
+ .on('hidden.bs.modal', '.modal', function () { $(document.body).removeClass('modal-open') })
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: tooltip.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#tooltip
+ * Inspired by the original jQuery.tipsy by Jason Frame
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // TOOLTIP PUBLIC CLASS DEFINITION
+ // ===============================
+
+ var Tooltip = function (element, options) {
+ this.type =
+ this.options =
+ this.enabled =
+ this.timeout =
+ this.hoverState =
+ this.$element = null
+
+ this.init('tooltip', element, options)
+ }
+
+ Tooltip.DEFAULTS = {
+ animation: true
+ , placement: 'top'
+ , selector: false
+ , template: ''
+ , trigger: 'hover focus'
+ , title: ''
+ , delay: 0
+ , html: false
+ , container: false
+ }
+
+ Tooltip.prototype.init = function (type, element, options) {
+ this.enabled = true
+ this.type = type
+ this.$element = $(element)
+ this.options = this.getOptions(options)
+
+ var triggers = this.options.trigger.split(' ')
+
+ for (var i = triggers.length; i--;) {
+ var trigger = triggers[i]
+
+ if (trigger == 'click') {
+ this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
+ } else if (trigger != 'manual') {
+ var eventIn = trigger == 'hover' ? 'mouseenter' : 'focus'
+ var eventOut = trigger == 'hover' ? 'mouseleave' : 'blur'
+
+ this.$element.on(eventIn + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
+ this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
+ }
+ }
+
+ this.options.selector ?
+ (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
+ this.fixTitle()
+ }
+
+ Tooltip.prototype.getDefaults = function () {
+ return Tooltip.DEFAULTS
+ }
+
+ Tooltip.prototype.getOptions = function (options) {
+ options = $.extend({}, this.getDefaults(), this.$element.data(), options)
+
+ if (options.delay && typeof options.delay == 'number') {
+ options.delay = {
+ show: options.delay
+ , hide: options.delay
+ }
+ }
+
+ return options
+ }
+
+ Tooltip.prototype.getDelegateOptions = function () {
+ var options = {}
+ var defaults = this.getDefaults()
+
+ this._options && $.each(this._options, function (key, value) {
+ if (defaults[key] != value) options[key] = value
+ })
+
+ return options
+ }
+
+ Tooltip.prototype.enter = function (obj) {
+ var self = obj instanceof this.constructor ?
+ obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
+
+ clearTimeout(self.timeout)
+
+ self.hoverState = 'in'
+
+ if (!self.options.delay || !self.options.delay.show) return self.show()
+
+ self.timeout = setTimeout(function () {
+ if (self.hoverState == 'in') self.show()
+ }, self.options.delay.show)
+ }
+
+ Tooltip.prototype.leave = function (obj) {
+ var self = obj instanceof this.constructor ?
+ obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
+
+ clearTimeout(self.timeout)
+
+ self.hoverState = 'out'
+
+ if (!self.options.delay || !self.options.delay.hide) return self.hide()
+
+ self.timeout = setTimeout(function () {
+ if (self.hoverState == 'out') self.hide()
+ }, self.options.delay.hide)
+ }
+
+ Tooltip.prototype.show = function () {
+ var e = $.Event('show.bs.'+ this.type)
+
+ if (this.hasContent() && this.enabled) {
+ this.$element.trigger(e)
+
+ if (e.isDefaultPrevented()) return
+
+ var $tip = this.tip()
+
+ this.setContent()
+
+ if (this.options.animation) $tip.addClass('fade')
+
+ var placement = typeof this.options.placement == 'function' ?
+ this.options.placement.call(this, $tip[0], this.$element[0]) :
+ this.options.placement
+
+ var autoToken = /\s?auto?\s?/i
+ var autoPlace = autoToken.test(placement)
+ if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
+
+ $tip
+ .detach()
+ .css({ top: 0, left: 0, display: 'block' })
+ .addClass(placement)
+
+ this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
+
+ var pos = this.getPosition()
+ var actualWidth = $tip[0].offsetWidth
+ var actualHeight = $tip[0].offsetHeight
+
+ if (autoPlace) {
+ var $parent = this.$element.parent()
+
+ var orgPlacement = placement
+ var docScroll = document.documentElement.scrollTop || document.body.scrollTop
+ var parentWidth = this.options.container == 'body' ? window.innerWidth : $parent.outerWidth()
+ var parentHeight = this.options.container == 'body' ? window.innerHeight : $parent.outerHeight()
+ var parentLeft = this.options.container == 'body' ? 0 : $parent.offset().left
+
+ placement = placement == 'bottom' && pos.top + pos.height + actualHeight - docScroll > parentHeight ? 'top' :
+ placement == 'top' && pos.top - docScroll - actualHeight < 0 ? 'bottom' :
+ placement == 'right' && pos.right + actualWidth > parentWidth ? 'left' :
+ placement == 'left' && pos.left - actualWidth < parentLeft ? 'right' :
+ placement
+
+ $tip
+ .removeClass(orgPlacement)
+ .addClass(placement)
+ }
+
+ var calculatedOffset = this.getCalculatedOffset(placement, pos, actualWidth, actualHeight)
+
+ this.applyPlacement(calculatedOffset, placement)
+ this.$element.trigger('shown.bs.' + this.type)
+ }
+ }
+
+ Tooltip.prototype.applyPlacement = function(offset, placement) {
+ var replace
+ var $tip = this.tip()
+ var width = $tip[0].offsetWidth
+ var height = $tip[0].offsetHeight
+
+ // manually read margins because getBoundingClientRect includes difference
+ var marginTop = parseInt($tip.css('margin-top'), 10)
+ var marginLeft = parseInt($tip.css('margin-left'), 10)
+
+ // we must check for NaN for ie 8/9
+ if (isNaN(marginTop)) marginTop = 0
+ if (isNaN(marginLeft)) marginLeft = 0
+
+ offset.top = offset.top + marginTop
+ offset.left = offset.left + marginLeft
+
+ $tip
+ .offset(offset)
+ .addClass('in')
+
+ // check to see if placing tip in new offset caused the tip to resize itself
+ var actualWidth = $tip[0].offsetWidth
+ var actualHeight = $tip[0].offsetHeight
+
+ if (placement == 'top' && actualHeight != height) {
+ replace = true
+ offset.top = offset.top + height - actualHeight
+ }
+
+ if (/bottom|top/.test(placement)) {
+ var delta = 0
+
+ if (offset.left < 0) {
+ delta = offset.left * -2
+ offset.left = 0
+
+ $tip.offset(offset)
+
+ actualWidth = $tip[0].offsetWidth
+ actualHeight = $tip[0].offsetHeight
+ }
+
+ this.replaceArrow(delta - width + actualWidth, actualWidth, 'left')
+ } else {
+ this.replaceArrow(actualHeight - height, actualHeight, 'top')
+ }
+
+ if (replace) $tip.offset(offset)
+ }
+
+ Tooltip.prototype.replaceArrow = function(delta, dimension, position) {
+ this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + "%") : '')
+ }
+
+ Tooltip.prototype.setContent = function () {
+ var $tip = this.tip()
+ var title = this.getTitle()
+
+ $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
+ $tip.removeClass('fade in top bottom left right')
+ }
+
+ Tooltip.prototype.hide = function () {
+ var that = this
+ var $tip = this.tip()
+ var e = $.Event('hide.bs.' + this.type)
+
+ function complete() {
+ if (that.hoverState != 'in') $tip.detach()
+ }
+
+ this.$element.trigger(e)
+
+ if (e.isDefaultPrevented()) return
+
+ $tip.removeClass('in')
+
+ $.support.transition && this.$tip.hasClass('fade') ?
+ $tip
+ .one($.support.transition.end, complete)
+ .emulateTransitionEnd(150) :
+ complete()
+
+ this.$element.trigger('hidden.bs.' + this.type)
+
+ return this
+ }
+
+ Tooltip.prototype.fixTitle = function () {
+ var $e = this.$element
+ if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
+ $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
+ }
+ }
+
+ Tooltip.prototype.hasContent = function () {
+ return this.getTitle()
+ }
+
+ Tooltip.prototype.getPosition = function () {
+ var el = this.$element[0]
+ return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : {
+ width: el.offsetWidth
+ , height: el.offsetHeight
+ }, this.$element.offset())
+ }
+
+ Tooltip.prototype.getCalculatedOffset = function (placement, pos, actualWidth, actualHeight) {
+ return placement == 'bottom' ? { top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2 } :
+ placement == 'top' ? { top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2 } :
+ placement == 'left' ? { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth } :
+ /* placement == 'right' */ { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width }
+ }
+
+ Tooltip.prototype.getTitle = function () {
+ var title
+ var $e = this.$element
+ var o = this.options
+
+ title = $e.attr('data-original-title')
+ || (typeof o.title == 'function' ? o.title.call($e[0]) : o.title)
+
+ return title
+ }
+
+ Tooltip.prototype.tip = function () {
+ return this.$tip = this.$tip || $(this.options.template)
+ }
+
+ Tooltip.prototype.arrow = function () {
+ return this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow')
+ }
+
+ Tooltip.prototype.validate = function () {
+ if (!this.$element[0].parentNode) {
+ this.hide()
+ this.$element = null
+ this.options = null
+ }
+ }
+
+ Tooltip.prototype.enable = function () {
+ this.enabled = true
+ }
+
+ Tooltip.prototype.disable = function () {
+ this.enabled = false
+ }
+
+ Tooltip.prototype.toggleEnabled = function () {
+ this.enabled = !this.enabled
+ }
+
+ Tooltip.prototype.toggle = function (e) {
+ var self = e ? $(e.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type) : this
+ self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
+ }
+
+ Tooltip.prototype.destroy = function () {
+ this.hide().$element.off('.' + this.type).removeData('bs.' + this.type)
+ }
+
+
+ // TOOLTIP PLUGIN DEFINITION
+ // =========================
+
+ var old = $.fn.tooltip
+
+ $.fn.tooltip = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.tooltip')
+ var options = typeof option == 'object' && option
+
+ if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
+ if (typeof option == 'string') data[option]()
+ })
+ }
+
+ $.fn.tooltip.Constructor = Tooltip
+
+
+ // TOOLTIP NO CONFLICT
+ // ===================
+
+ $.fn.tooltip.noConflict = function () {
+ $.fn.tooltip = old
+ return this
+ }
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: popover.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#popovers
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // POPOVER PUBLIC CLASS DEFINITION
+ // ===============================
+
+ var Popover = function (element, options) {
+ this.init('popover', element, options)
+ }
+
+ if (!$.fn.tooltip) throw new Error('Popover requires tooltip.js')
+
+ Popover.DEFAULTS = $.extend({} , $.fn.tooltip.Constructor.DEFAULTS, {
+ placement: 'right'
+ , trigger: 'click'
+ , content: ''
+ , template: ''
+ })
+
+
+ // NOTE: POPOVER EXTENDS tooltip.js
+ // ================================
+
+ Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype)
+
+ Popover.prototype.constructor = Popover
+
+ Popover.prototype.getDefaults = function () {
+ return Popover.DEFAULTS
+ }
+
+ Popover.prototype.setContent = function () {
+ var $tip = this.tip()
+ var title = this.getTitle()
+ var content = this.getContent()
+
+ $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
+ $tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
+
+ $tip.removeClass('fade top bottom left right in')
+
+ // IE8 doesn't accept hiding via the `:empty` pseudo selector, we have to do
+ // this manually by checking the contents.
+ if (!$tip.find('.popover-title').html()) $tip.find('.popover-title').hide()
+ }
+
+ Popover.prototype.hasContent = function () {
+ return this.getTitle() || this.getContent()
+ }
+
+ Popover.prototype.getContent = function () {
+ var $e = this.$element
+ var o = this.options
+
+ return $e.attr('data-content')
+ || (typeof o.content == 'function' ?
+ o.content.call($e[0]) :
+ o.content)
+ }
+
+ Popover.prototype.arrow = function () {
+ return this.$arrow = this.$arrow || this.tip().find('.arrow')
+ }
+
+ Popover.prototype.tip = function () {
+ if (!this.$tip) this.$tip = $(this.options.template)
+ return this.$tip
+ }
+
+
+ // POPOVER PLUGIN DEFINITION
+ // =========================
+
+ var old = $.fn.popover
+
+ $.fn.popover = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.popover')
+ var options = typeof option == 'object' && option
+
+ if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
+ if (typeof option == 'string') data[option]()
+ })
+ }
+
+ $.fn.popover.Constructor = Popover
+
+
+ // POPOVER NO CONFLICT
+ // ===================
+
+ $.fn.popover.noConflict = function () {
+ $.fn.popover = old
+ return this
+ }
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: scrollspy.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#scrollspy
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // SCROLLSPY CLASS DEFINITION
+ // ==========================
+
+ function ScrollSpy(element, options) {
+ var href
+ var process = $.proxy(this.process, this)
+
+ this.$element = $(element).is('body') ? $(window) : $(element)
+ this.$body = $('body')
+ this.$scrollElement = this.$element.on('scroll.bs.scroll-spy.data-api', process)
+ this.options = $.extend({}, ScrollSpy.DEFAULTS, options)
+ this.selector = (this.options.target
+ || ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
+ || '') + ' .nav li > a'
+ this.offsets = $([])
+ this.targets = $([])
+ this.activeTarget = null
+
+ this.refresh()
+ this.process()
+ }
+
+ ScrollSpy.DEFAULTS = {
+ offset: 10
+ }
+
+ ScrollSpy.prototype.refresh = function () {
+ var offsetMethod = this.$element[0] == window ? 'offset' : 'position'
+
+ this.offsets = $([])
+ this.targets = $([])
+
+ var self = this
+ var $targets = this.$body
+ .find(this.selector)
+ .map(function () {
+ var $el = $(this)
+ var href = $el.data('target') || $el.attr('href')
+ var $href = /^#\w/.test(href) && $(href)
+
+ return ($href
+ && $href.length
+ && [[ $href[offsetMethod]().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]]) || null
+ })
+ .sort(function (a, b) { return a[0] - b[0] })
+ .each(function () {
+ self.offsets.push(this[0])
+ self.targets.push(this[1])
+ })
+ }
+
+ ScrollSpy.prototype.process = function () {
+ var scrollTop = this.$scrollElement.scrollTop() + this.options.offset
+ var scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight
+ var maxScroll = scrollHeight - this.$scrollElement.height()
+ var offsets = this.offsets
+ var targets = this.targets
+ var activeTarget = this.activeTarget
+ var i
+
+ if (scrollTop >= maxScroll) {
+ return activeTarget != (i = targets.last()[0]) && this.activate(i)
+ }
+
+ for (i = offsets.length; i--;) {
+ activeTarget != targets[i]
+ && scrollTop >= offsets[i]
+ && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
+ && this.activate( targets[i] )
+ }
+ }
+
+ ScrollSpy.prototype.activate = function (target) {
+ this.activeTarget = target
+
+ $(this.selector)
+ .parents('.active')
+ .removeClass('active')
+
+ var selector = this.selector
+ + '[data-target="' + target + '"],'
+ + this.selector + '[href="' + target + '"]'
+
+ var active = $(selector)
+ .parents('li')
+ .addClass('active')
+
+ if (active.parent('.dropdown-menu').length) {
+ active = active
+ .closest('li.dropdown')
+ .addClass('active')
+ }
+
+ active.trigger('activate')
+ }
+
+
+ // SCROLLSPY PLUGIN DEFINITION
+ // ===========================
+
+ var old = $.fn.scrollspy
+
+ $.fn.scrollspy = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.scrollspy')
+ var options = typeof option == 'object' && option
+
+ if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
+ if (typeof option == 'string') data[option]()
+ })
+ }
+
+ $.fn.scrollspy.Constructor = ScrollSpy
+
+
+ // SCROLLSPY NO CONFLICT
+ // =====================
+
+ $.fn.scrollspy.noConflict = function () {
+ $.fn.scrollspy = old
+ return this
+ }
+
+
+ // SCROLLSPY DATA-API
+ // ==================
+
+ $(window).on('load', function () {
+ $('[data-spy="scroll"]').each(function () {
+ var $spy = $(this)
+ $spy.scrollspy($spy.data())
+ })
+ })
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: tab.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#tabs
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // TAB CLASS DEFINITION
+ // ====================
+
+ var Tab = function (element) {
+ this.element = $(element)
+ }
+
+ Tab.prototype.show = function () {
+ var $this = this.element
+ var $ul = $this.closest('ul:not(.dropdown-menu)')
+ var selector = $this.attr('data-target')
+
+ if (!selector) {
+ selector = $this.attr('href')
+ selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
+ }
+
+ if ($this.parent('li').hasClass('active')) return
+
+ var previous = $ul.find('.active:last a')[0]
+ var e = $.Event('show.bs.tab', {
+ relatedTarget: previous
+ })
+
+ $this.trigger(e)
+
+ if (e.isDefaultPrevented()) return
+
+ var $target = $(selector)
+
+ this.activate($this.parent('li'), $ul)
+ this.activate($target, $target.parent(), function () {
+ $this.trigger({
+ type: 'shown.bs.tab'
+ , relatedTarget: previous
+ })
+ })
+ }
+
+ Tab.prototype.activate = function (element, container, callback) {
+ var $active = container.find('> .active')
+ var transition = callback
+ && $.support.transition
+ && $active.hasClass('fade')
+
+ function next() {
+ $active
+ .removeClass('active')
+ .find('> .dropdown-menu > .active')
+ .removeClass('active')
+
+ element.addClass('active')
+
+ if (transition) {
+ element[0].offsetWidth // reflow for transition
+ element.addClass('in')
+ } else {
+ element.removeClass('fade')
+ }
+
+ if (element.parent('.dropdown-menu')) {
+ element.closest('li.dropdown').addClass('active')
+ }
+
+ callback && callback()
+ }
+
+ transition ?
+ $active
+ .one($.support.transition.end, next)
+ .emulateTransitionEnd(150) :
+ next()
+
+ $active.removeClass('in')
+ }
+
+
+ // TAB PLUGIN DEFINITION
+ // =====================
+
+ var old = $.fn.tab
+
+ $.fn.tab = function ( option ) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.tab')
+
+ if (!data) $this.data('bs.tab', (data = new Tab(this)))
+ if (typeof option == 'string') data[option]()
+ })
+ }
+
+ $.fn.tab.Constructor = Tab
+
+
+ // TAB NO CONFLICT
+ // ===============
+
+ $.fn.tab.noConflict = function () {
+ $.fn.tab = old
+ return this
+ }
+
+
+ // TAB DATA-API
+ // ============
+
+ $(document).on('click.bs.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e) {
+ e.preventDefault()
+ $(this).tab('show')
+ })
+
+}(window.jQuery);
+
+/* ========================================================================
+ * Bootstrap: affix.js v3.0.0
+ * http://twbs.github.com/bootstrap/javascript.html#affix
+ * ========================================================================
+ * Copyright 2012 Twitter, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ======================================================================== */
+
+
++function ($) { "use strict";
+
+ // AFFIX CLASS DEFINITION
+ // ======================
+
+ var Affix = function (element, options) {
+ this.options = $.extend({}, Affix.DEFAULTS, options)
+ this.$window = $(window)
+ .on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this))
+ .on('click.bs.affix.data-api', $.proxy(this.checkPositionWithEventLoop, this))
+
+ this.$element = $(element)
+ this.affixed =
+ this.unpin = null
+
+ this.checkPosition()
+ }
+
+ Affix.RESET = 'affix affix-top affix-bottom'
+
+ Affix.DEFAULTS = {
+ offset: 0
+ }
+
+ Affix.prototype.checkPositionWithEventLoop = function () {
+ setTimeout($.proxy(this.checkPosition, this), 1)
+ }
+
+ Affix.prototype.checkPosition = function () {
+ if (!this.$element.is(':visible')) return
+
+ var scrollHeight = $(document).height()
+ var scrollTop = this.$window.scrollTop()
+ var position = this.$element.offset()
+ var offset = this.options.offset
+ var offsetTop = offset.top
+ var offsetBottom = offset.bottom
+
+ if (typeof offset != 'object') offsetBottom = offsetTop = offset
+ if (typeof offsetTop == 'function') offsetTop = offset.top()
+ if (typeof offsetBottom == 'function') offsetBottom = offset.bottom()
+
+ var affix = this.unpin != null && (scrollTop + this.unpin <= position.top) ? false :
+ offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? 'bottom' :
+ offsetTop != null && (scrollTop <= offsetTop) ? 'top' : false
+
+ if (this.affixed === affix) return
+ if (this.unpin) this.$element.css('top', '')
+
+ this.affixed = affix
+ this.unpin = affix == 'bottom' ? position.top - scrollTop : null
+
+ this.$element.removeClass(Affix.RESET).addClass('affix' + (affix ? '-' + affix : ''))
+
+ if (affix == 'bottom') {
+ this.$element.offset({ top: document.body.offsetHeight - offsetBottom - this.$element.height() })
+ }
+ }
+
+
+ // AFFIX PLUGIN DEFINITION
+ // =======================
+
+ var old = $.fn.affix
+
+ $.fn.affix = function (option) {
+ return this.each(function () {
+ var $this = $(this)
+ var data = $this.data('bs.affix')
+ var options = typeof option == 'object' && option
+
+ if (!data) $this.data('bs.affix', (data = new Affix(this, options)))
+ if (typeof option == 'string') data[option]()
+ })
+ }
+
+ $.fn.affix.Constructor = Affix
+
+
+ // AFFIX NO CONFLICT
+ // =================
+
+ $.fn.affix.noConflict = function () {
+ $.fn.affix = old
+ return this
+ }
+
+
+ // AFFIX DATA-API
+ // ==============
+
+ $(window).on('load', function () {
+ $('[data-spy="affix"]').each(function () {
+ var $spy = $(this)
+ var data = $spy.data()
+
+ data.offset = data.offset || {}
+
+ if (data.offsetBottom) data.offset.bottom = data.offsetBottom
+ if (data.offsetTop) data.offset.top = data.offsetTop
+
+ $spy.affix(data)
+ })
+ })
+
+}(window.jQuery);
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/bootstrap.min.js b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/bootstrap.min.js
new file mode 100644
index 000000000..9c96832ae
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/bootstrap.min.js
@@ -0,0 +1,21 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+
+/**
+* bootstrap.js v3.0.0 by @fat and @mdo
+* Copyright 2013 Twitter Inc.
+* http://www.apache.org/licenses/LICENSE-2.0
+*/
+if(!jQuery)throw new Error("Bootstrap requires jQuery");+function(a){"use strict";function b(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"};for(var c in b)if(void 0!==a.style[c])return{end:b[c]}}a.fn.emulateTransitionEnd=function(b){var c=!1,d=this;a(this).one(a.support.transition.end,function(){c=!0});var e=function(){c||a(d).trigger(a.support.transition.end)};return setTimeout(e,b),this},a(function(){a.support.transition=b()})}(window.jQuery),+function(a){"use strict";var b='[data-dismiss="alert"]',c=function(c){a(c).on("click",b,this.close)};c.prototype.close=function(b){function c(){f.trigger("closed.bs.alert").remove()}var d=a(this),e=d.attr("data-target");e||(e=d.attr("href"),e=e&&e.replace(/.*(?=#[^\s]*$)/,""));var f=a(e);b&&b.preventDefault(),f.length||(f=d.hasClass("alert")?d:d.parent()),f.trigger(b=a.Event("close.bs.alert")),b.isDefaultPrevented()||(f.removeClass("in"),a.support.transition&&f.hasClass("fade")?f.one(a.support.transition.end,c).emulateTransitionEnd(150):c())};var d=a.fn.alert;a.fn.alert=function(b){return this.each(function(){var d=a(this),e=d.data("bs.alert");e||d.data("bs.alert",e=new c(this)),"string"==typeof b&&e[b].call(d)})},a.fn.alert.Constructor=c,a.fn.alert.noConflict=function(){return a.fn.alert=d,this},a(document).on("click.bs.alert.data-api",b,c.prototype.close)}(window.jQuery),+function(a){"use strict";var b=function(c,d){this.$element=a(c),this.options=a.extend({},b.DEFAULTS,d)};b.DEFAULTS={loadingText:"loading..."},b.prototype.setState=function(a){var b="disabled",c=this.$element,d=c.is("input")?"val":"html",e=c.data();a+="Text",e.resetText||c.data("resetText",c[d]()),c[d](e[a]||this.options[a]),setTimeout(function(){"loadingText"==a?c.addClass(b).attr(b,b):c.removeClass(b).removeAttr(b)},0)},b.prototype.toggle=function(){var a=this.$element.closest('[data-toggle="buttons"]');if(a.length){var b=this.$element.find("input").prop("checked",!this.$element.hasClass("active")).trigger("change");"radio"===b.prop("type")&&a.find(".active").removeClass("active")}this.$element.toggleClass("active")};var c=a.fn.button;a.fn.button=function(c){return this.each(function(){var d=a(this),e=d.data("bs.button"),f="object"==typeof c&&c;e||d.data("bs.button",e=new b(this,f)),"toggle"==c?e.toggle():c&&e.setState(c)})},a.fn.button.Constructor=b,a.fn.button.noConflict=function(){return a.fn.button=c,this},a(document).on("click.bs.button.data-api","[data-toggle^=button]",function(b){var c=a(b.target);c.hasClass("btn")||(c=c.closest(".btn")),c.button("toggle"),b.preventDefault()})}(window.jQuery),+function(a){"use strict";var b=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.paused=this.sliding=this.interval=this.$active=this.$items=null,"hover"==this.options.pause&&this.$element.on("mouseenter",a.proxy(this.pause,this)).on("mouseleave",a.proxy(this.cycle,this))};b.DEFAULTS={interval:5e3,pause:"hover",wrap:!0},b.prototype.cycle=function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},b.prototype.getActiveIndex=function(){return this.$active=this.$element.find(".item.active"),this.$items=this.$active.parent().children(),this.$items.index(this.$active)},b.prototype.to=function(b){var c=this,d=this.getActiveIndex();return b>this.$items.length-1||0>b?void 0:this.sliding?this.$element.one("slid",function(){c.to(b)}):d==b?this.pause().cycle():this.slide(b>d?"next":"prev",a(this.$items[b]))},b.prototype.pause=function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition.end&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),this.interval=clearInterval(this.interval),this},b.prototype.next=function(){return this.sliding?void 0:this.slide("next")},b.prototype.prev=function(){return this.sliding?void 0:this.slide("prev")},b.prototype.slide=function(b,c){var d=this.$element.find(".item.active"),e=c||d[b](),f=this.interval,g="next"==b?"left":"right",h="next"==b?"first":"last",i=this;if(!e.length){if(!this.options.wrap)return;e=this.$element.find(".item")[h]()}this.sliding=!0,f&&this.pause();var j=a.Event("slide.bs.carousel",{relatedTarget:e[0],direction:g});if(!e.hasClass("active")){if(this.$indicators.length&&(this.$indicators.find(".active").removeClass("active"),this.$element.one("slid",function(){var b=a(i.$indicators.children()[i.getActiveIndex()]);b&&b.addClass("active")})),a.support.transition&&this.$element.hasClass("slide")){if(this.$element.trigger(j),j.isDefaultPrevented())return;e.addClass(b),e[0].offsetWidth,d.addClass(g),e.addClass(g),d.one(a.support.transition.end,function(){e.removeClass([b,g].join(" ")).addClass("active"),d.removeClass(["active",g].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger("slid")},0)}).emulateTransitionEnd(600)}else{if(this.$element.trigger(j),j.isDefaultPrevented())return;d.removeClass("active"),e.addClass("active"),this.sliding=!1,this.$element.trigger("slid")}return f&&this.cycle(),this}};var c=a.fn.carousel;a.fn.carousel=function(c){return this.each(function(){var d=a(this),e=d.data("bs.carousel"),f=a.extend({},b.DEFAULTS,d.data(),"object"==typeof c&&c),g="string"==typeof c?c:f.slide;e||d.data("bs.carousel",e=new b(this,f)),"number"==typeof c?e.to(c):g?e[g]():f.interval&&e.pause().cycle()})},a.fn.carousel.Constructor=b,a.fn.carousel.noConflict=function(){return a.fn.carousel=c,this},a(document).on("click.bs.carousel.data-api","[data-slide], [data-slide-to]",function(b){var c,d=a(this),e=a(d.attr("data-target")||(c=d.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,"")),f=a.extend({},e.data(),d.data()),g=d.attr("data-slide-to");g&&(f.interval=!1),e.carousel(f),(g=d.attr("data-slide-to"))&&e.data("bs.carousel").to(g),b.preventDefault()}),a(window).on("load",function(){a('[data-ride="carousel"]').each(function(){var b=a(this);b.carousel(b.data())})})}(window.jQuery),+function(a){"use strict";var b=function(c,d){this.$element=a(c),this.options=a.extend({},b.DEFAULTS,d),this.transitioning=null,this.options.parent&&(this.$parent=a(this.options.parent)),this.options.toggle&&this.toggle()};b.DEFAULTS={toggle:!0},b.prototype.dimension=function(){var a=this.$element.hasClass("width");return a?"width":"height"},b.prototype.show=function(){if(!this.transitioning&&!this.$element.hasClass("in")){var b=a.Event("show.bs.collapse");if(this.$element.trigger(b),!b.isDefaultPrevented()){var c=this.$parent&&this.$parent.find("> .panel > .in");if(c&&c.length){var d=c.data("bs.collapse");if(d&&d.transitioning)return;c.collapse("hide"),d||c.data("bs.collapse",null)}var e=this.dimension();this.$element.removeClass("collapse").addClass("collapsing")[e](0),this.transitioning=1;var f=function(){this.$element.removeClass("collapsing").addClass("in")[e]("auto"),this.transitioning=0,this.$element.trigger("shown.bs.collapse")};if(!a.support.transition)return f.call(this);var g=a.camelCase(["scroll",e].join("-"));this.$element.one(a.support.transition.end,a.proxy(f,this)).emulateTransitionEnd(350)[e](this.$element[0][g])}}},b.prototype.hide=function(){if(!this.transitioning&&this.$element.hasClass("in")){var b=a.Event("hide.bs.collapse");if(this.$element.trigger(b),!b.isDefaultPrevented()){var c=this.dimension();this.$element[c](this.$element[c]())[0].offsetHeight,this.$element.addClass("collapsing").removeClass("collapse").removeClass("in"),this.transitioning=1;var d=function(){this.transitioning=0,this.$element.trigger("hidden.bs.collapse").removeClass("collapsing").addClass("collapse")};return a.support.transition?(this.$element[c](0).one(a.support.transition.end,a.proxy(d,this)).emulateTransitionEnd(350),void 0):d.call(this)}}},b.prototype.toggle=function(){this[this.$element.hasClass("in")?"hide":"show"]()};var c=a.fn.collapse;a.fn.collapse=function(c){return this.each(function(){var d=a(this),e=d.data("bs.collapse"),f=a.extend({},b.DEFAULTS,d.data(),"object"==typeof c&&c);e||d.data("bs.collapse",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.collapse.Constructor=b,a.fn.collapse.noConflict=function(){return a.fn.collapse=c,this},a(document).on("click.bs.collapse.data-api","[data-toggle=collapse]",function(b){var c,d=a(this),e=d.attr("data-target")||b.preventDefault()||(c=d.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,""),f=a(e),g=f.data("bs.collapse"),h=g?"toggle":d.data(),i=d.attr("data-parent"),j=i&&a(i);g&&g.transitioning||(j&&j.find('[data-toggle=collapse][data-parent="'+i+'"]').not(d).addClass("collapsed"),d[f.hasClass("in")?"addClass":"removeClass"]("collapsed")),f.collapse(h)})}(window.jQuery),+function(a){"use strict";function b(){a(d).remove(),a(e).each(function(b){var d=c(a(this));d.hasClass("open")&&(d.trigger(b=a.Event("hide.bs.dropdown")),b.isDefaultPrevented()||d.removeClass("open").trigger("hidden.bs.dropdown"))})}function c(b){var c=b.attr("data-target");c||(c=b.attr("href"),c=c&&/#/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,""));var d=c&&a(c);return d&&d.length?d:b.parent()}var d=".dropdown-backdrop",e="[data-toggle=dropdown]",f=function(b){a(b).on("click.bs.dropdown",this.toggle)};f.prototype.toggle=function(d){var e=a(this);if(!e.is(".disabled, :disabled")){var f=c(e),g=f.hasClass("open");if(b(),!g){if("ontouchstart"in document.documentElement&&!f.closest(".navbar-nav").length&&a('').insertAfter(a(this)).on("click",b),f.trigger(d=a.Event("show.bs.dropdown")),d.isDefaultPrevented())return;f.toggleClass("open").trigger("shown.bs.dropdown"),e.focus()}return!1}},f.prototype.keydown=function(b){if(/(38|40|27)/.test(b.keyCode)){var d=a(this);if(b.preventDefault(),b.stopPropagation(),!d.is(".disabled, :disabled")){var f=c(d),g=f.hasClass("open");if(!g||g&&27==b.keyCode)return 27==b.which&&f.find(e).focus(),d.click();var h=a("[role=menu] li:not(.divider):visible a",f);if(h.length){var i=h.index(h.filter(":focus"));38==b.keyCode&&i>0&&i--,40==b.keyCode&&i').appendTo(document.body),this.$element.on("click.dismiss.modal",a.proxy(function(a){a.target===a.currentTarget&&("static"==this.options.backdrop?this.$element[0].focus.call(this.$element[0]):this.hide.call(this))},this)),d&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in"),!b)return;d?this.$backdrop.one(a.support.transition.end,b).emulateTransitionEnd(150):b()}else!this.isShown&&this.$backdrop?(this.$backdrop.removeClass("in"),a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one(a.support.transition.end,b).emulateTransitionEnd(150):b()):b&&b()};var c=a.fn.modal;a.fn.modal=function(c,d){return this.each(function(){var e=a(this),f=e.data("bs.modal"),g=a.extend({},b.DEFAULTS,e.data(),"object"==typeof c&&c);f||e.data("bs.modal",f=new b(this,g)),"string"==typeof c?f[c](d):g.show&&f.show(d)})},a.fn.modal.Constructor=b,a.fn.modal.noConflict=function(){return a.fn.modal=c,this},a(document).on("click.bs.modal.data-api",'[data-toggle="modal"]',function(b){var c=a(this),d=c.attr("href"),e=a(c.attr("data-target")||d&&d.replace(/.*(?=#[^\s]+$)/,"")),f=e.data("modal")?"toggle":a.extend({remote:!/#/.test(d)&&d},e.data(),c.data());b.preventDefault(),e.modal(f,this).one("hide",function(){c.is(":visible")&&c.focus()})}),a(document).on("show.bs.modal",".modal",function(){a(document.body).addClass("modal-open")}).on("hidden.bs.modal",".modal",function(){a(document.body).removeClass("modal-open")})}(window.jQuery),+function(a){"use strict";var b=function(a,b){this.type=this.options=this.enabled=this.timeout=this.hoverState=this.$element=null,this.init("tooltip",a,b)};b.DEFAULTS={animation:!0,placement:"top",selector:!1,template:'',trigger:"hover focus",title:"",delay:0,html:!1,container:!1},b.prototype.init=function(b,c,d){this.enabled=!0,this.type=b,this.$element=a(c),this.options=this.getOptions(d);for(var e=this.options.trigger.split(" "),f=e.length;f--;){var g=e[f];if("click"==g)this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this));else if("manual"!=g){var h="hover"==g?"mouseenter":"focus",i="hover"==g?"mouseleave":"blur";this.$element.on(h+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(i+"."+this.type,this.options.selector,a.proxy(this.leave,this))}}this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},b.prototype.getDefaults=function(){return b.DEFAULTS},b.prototype.getOptions=function(b){return b=a.extend({},this.getDefaults(),this.$element.data(),b),b.delay&&"number"==typeof b.delay&&(b.delay={show:b.delay,hide:b.delay}),b},b.prototype.getDelegateOptions=function(){var b={},c=this.getDefaults();return this._options&&a.each(this._options,function(a,d){c[a]!=d&&(b[a]=d)}),b},b.prototype.enter=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget)[this.type](this.getDelegateOptions()).data("bs."+this.type);return clearTimeout(c.timeout),c.hoverState="in",c.options.delay&&c.options.delay.show?(c.timeout=setTimeout(function(){"in"==c.hoverState&&c.show()},c.options.delay.show),void 0):c.show()},b.prototype.leave=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget)[this.type](this.getDelegateOptions()).data("bs."+this.type);return clearTimeout(c.timeout),c.hoverState="out",c.options.delay&&c.options.delay.hide?(c.timeout=setTimeout(function(){"out"==c.hoverState&&c.hide()},c.options.delay.hide),void 0):c.hide()},b.prototype.show=function(){var b=a.Event("show.bs."+this.type);if(this.hasContent()&&this.enabled){if(this.$element.trigger(b),b.isDefaultPrevented())return;var c=this.tip();this.setContent(),this.options.animation&&c.addClass("fade");var d="function"==typeof this.options.placement?this.options.placement.call(this,c[0],this.$element[0]):this.options.placement,e=/\s?auto?\s?/i,f=e.test(d);f&&(d=d.replace(e,"")||"top"),c.detach().css({top:0,left:0,display:"block"}).addClass(d),this.options.container?c.appendTo(this.options.container):c.insertAfter(this.$element);var g=this.getPosition(),h=c[0].offsetWidth,i=c[0].offsetHeight;if(f){var j=this.$element.parent(),k=d,l=document.documentElement.scrollTop||document.body.scrollTop,m="body"==this.options.container?window.innerWidth:j.outerWidth(),n="body"==this.options.container?window.innerHeight:j.outerHeight(),o="body"==this.options.container?0:j.offset().left;d="bottom"==d&&g.top+g.height+i-l>n?"top":"top"==d&&g.top-l-i<0?"bottom":"right"==d&&g.right+h>m?"left":"left"==d&&g.left-h '}),b.prototype=a.extend({},a.fn.tooltip.Constructor.prototype),b.prototype.constructor=b,b.prototype.getDefaults=function(){return b.DEFAULTS},b.prototype.setContent=function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content")[this.options.html?"html":"text"](c),a.removeClass("fade top bottom left right in"),a.find(".popover-title").html()||a.find(".popover-title").hide()},b.prototype.hasContent=function(){return this.getTitle()||this.getContent()},b.prototype.getContent=function(){var a=this.$element,b=this.options;return a.attr("data-content")||("function"==typeof b.content?b.content.call(a[0]):b.content)},b.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".arrow")},b.prototype.tip=function(){return this.$tip||(this.$tip=a(this.options.template)),this.$tip};var c=a.fn.popover;a.fn.popover=function(c){return this.each(function(){var d=a(this),e=d.data("bs.popover"),f="object"==typeof c&&c;e||d.data("bs.popover",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.popover.Constructor=b,a.fn.popover.noConflict=function(){return a.fn.popover=c,this}}(window.jQuery),+function(a){"use strict";function b(c,d){var e,f=a.proxy(this.process,this);this.$element=a(c).is("body")?a(window):a(c),this.$body=a("body"),this.$scrollElement=this.$element.on("scroll.bs.scroll-spy.data-api",f),this.options=a.extend({},b.DEFAULTS,d),this.selector=(this.options.target||(e=a(c).attr("href"))&&e.replace(/.*(?=#[^\s]+$)/,"")||"")+" .nav li > a",this.offsets=a([]),this.targets=a([]),this.activeTarget=null,this.refresh(),this.process()}b.DEFAULTS={offset:10},b.prototype.refresh=function(){var b=this.$element[0]==window?"offset":"position";this.offsets=a([]),this.targets=a([]);var c=this;this.$body.find(this.selector).map(function(){var d=a(this),e=d.data("target")||d.attr("href"),f=/^#\w/.test(e)&&a(e);return f&&f.length&&[[f[b]().top+(!a.isWindow(c.$scrollElement.get(0))&&c.$scrollElement.scrollTop()),e]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){c.offsets.push(this[0]),c.targets.push(this[1])})},b.prototype.process=function(){var a,b=this.$scrollElement.scrollTop()+this.options.offset,c=this.$scrollElement[0].scrollHeight||this.$body[0].scrollHeight,d=c-this.$scrollElement.height(),e=this.offsets,f=this.targets,g=this.activeTarget;if(b>=d)return g!=(a=f.last()[0])&&this.activate(a);for(a=e.length;a--;)g!=f[a]&&b>=e[a]&&(!e[a+1]||b<=e[a+1])&&this.activate(f[a])},b.prototype.activate=function(b){this.activeTarget=b,a(this.selector).parents(".active").removeClass("active");var c=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',d=a(c).parents("li").addClass("active");d.parent(".dropdown-menu").length&&(d=d.closest("li.dropdown").addClass("active")),d.trigger("activate")};var c=a.fn.scrollspy;a.fn.scrollspy=function(c){return this.each(function(){var d=a(this),e=d.data("bs.scrollspy"),f="object"==typeof c&&c;e||d.data("bs.scrollspy",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.scrollspy.Constructor=b,a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=c,this},a(window).on("load",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);b.scrollspy(b.data())})})}(window.jQuery),+function(a){"use strict";var b=function(b){this.element=a(b)};b.prototype.show=function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.attr("data-target");if(d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),!b.parent("li").hasClass("active")){var e=c.find(".active:last a")[0],f=a.Event("show.bs.tab",{relatedTarget:e});if(b.trigger(f),!f.isDefaultPrevented()){var g=a(d);this.activate(b.parent("li"),c),this.activate(g,g.parent(),function(){b.trigger({type:"shown.bs.tab",relatedTarget:e})})}}},b.prototype.activate=function(b,c,d){function e(){f.removeClass("active").find("> .dropdown-menu > .active").removeClass("active"),b.addClass("active"),g?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu")&&b.closest("li.dropdown").addClass("active"),d&&d()}var f=c.find("> .active"),g=d&&a.support.transition&&f.hasClass("fade");g?f.one(a.support.transition.end,e).emulateTransitionEnd(150):e(),f.removeClass("in")};var c=a.fn.tab;a.fn.tab=function(c){return this.each(function(){var d=a(this),e=d.data("bs.tab");e||d.data("bs.tab",e=new b(this)),"string"==typeof c&&e[c]()})},a.fn.tab.Constructor=b,a.fn.tab.noConflict=function(){return a.fn.tab=c,this},a(document).on("click.bs.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"]',function(b){b.preventDefault(),a(this).tab("show")})}(window.jQuery),+function(a){"use strict";var b=function(c,d){this.options=a.extend({},b.DEFAULTS,d),this.$window=a(window).on("scroll.bs.affix.data-api",a.proxy(this.checkPosition,this)).on("click.bs.affix.data-api",a.proxy(this.checkPositionWithEventLoop,this)),this.$element=a(c),this.affixed=this.unpin=null,this.checkPosition()};b.RESET="affix affix-top affix-bottom",b.DEFAULTS={offset:0},b.prototype.checkPositionWithEventLoop=function(){setTimeout(a.proxy(this.checkPosition,this),1)},b.prototype.checkPosition=function(){if(this.$element.is(":visible")){var c=a(document).height(),d=this.$window.scrollTop(),e=this.$element.offset(),f=this.options.offset,g=f.top,h=f.bottom;"object"!=typeof f&&(h=g=f),"function"==typeof g&&(g=f.top()),"function"==typeof h&&(h=f.bottom());var i=null!=this.unpin&&d+this.unpin<=e.top?!1:null!=h&&e.top+this.$element.height()>=c-h?"bottom":null!=g&&g>=d?"top":!1;this.affixed!==i&&(this.unpin&&this.$element.css("top",""),this.affixed=i,this.unpin="bottom"==i?e.top-d:null,this.$element.removeClass(b.RESET).addClass("affix"+(i?"-"+i:"")),"bottom"==i&&this.$element.offset({top:document.body.offsetHeight-h-this.$element.height()}))}};var c=a.fn.affix;a.fn.affix=function(c){return this.each(function(){var d=a(this),e=d.data("bs.affix"),f="object"==typeof c&&c;e||d.data("bs.affix",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.affix.Constructor=b,a.fn.affix.noConflict=function(){return a.fn.affix=c,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var b=a(this),c=b.data();c.offset=c.offset||{},c.offsetBottom&&(c.offset.bottom=c.offsetBottom),c.offsetTop&&(c.offset.top=c.offsetTop),b.affix(c)})})}(window.jQuery);
\ No newline at end of file
diff --git a/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/jquery-1.10.2.js b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/jquery-1.10.2.js
new file mode 100644
index 000000000..d3e121b86
--- /dev/null
+++ b/samples/angular-aad-webapi/api/api.securecall/obj/Debug/Package/PackageTmp/Scripts/jquery-1.10.2.js
@@ -0,0 +1,9803 @@
+/* NUGET: BEGIN LICENSE TEXT
+ *
+ * Microsoft grants you the right to use these script files for the sole
+ * purpose of either: (i) interacting through your browser with the Microsoft
+ * website or online service, subject to the applicable licensing or use
+ * terms; or (ii) using the files as included with a Microsoft product subject
+ * to that product's license terms. Microsoft reserves all other rights to the
+ * files not expressly granted by Microsoft, whether by implication, estoppel
+ * or otherwise. Insofar as a script file is dual licensed under GPL,
+ * Microsoft neither took the code under GPL nor distributes it thereunder but
+ * under the terms set out in this paragraph. All notices and licenses
+ * below are for informational purposes only.
+ *
+ * NUGET: END LICENSE TEXT */
+/*!
+ * jQuery JavaScript Library v1.10.2
+ * http://jquery.com/
+ *
+ * Includes Sizzle.js
+ * http://sizzlejs.com/
+ *
+ * Copyright 2005, 2013 jQuery Foundation, Inc. and other contributors
+ * Released under the MIT license
+ * http://jquery.org/license
+ *
+ * Date: 2013-07-03T13:48Z
+ */
+(function( window, undefined ) {
+
+// Can't do this because several apps including ASP.NET trace
+// the stack via arguments.caller.callee and Firefox dies if
+// you try to trace through "use strict" call chains. (#13335)
+// Support: Firefox 18+
+//"use strict";
+var
+ // The deferred used on DOM ready
+ readyList,
+
+ // A central reference to the root jQuery(document)
+ rootjQuery,
+
+ // Support: IE<10
+ // For `typeof xmlNode.method` instead of `xmlNode.method !== undefined`
+ core_strundefined = typeof undefined,
+
+ // Use the correct document accordingly with window argument (sandbox)
+ location = window.location,
+ document = window.document,
+ docElem = document.documentElement,
+
+ // Map over jQuery in case of overwrite
+ _jQuery = window.jQuery,
+
+ // Map over the $ in case of overwrite
+ _$ = window.$,
+
+ // [[Class]] -> type pairs
+ class2type = {},
+
+ // List of deleted data cache ids, so we can reuse them
+ core_deletedIds = [],
+
+ core_version = "1.10.2",
+
+ // Save a reference to some core methods
+ core_concat = core_deletedIds.concat,
+ core_push = core_deletedIds.push,
+ core_slice = core_deletedIds.slice,
+ core_indexOf = core_deletedIds.indexOf,
+ core_toString = class2type.toString,
+ core_hasOwn = class2type.hasOwnProperty,
+ core_trim = core_version.trim,
+
+ // Define a local copy of jQuery
+ jQuery = function( selector, context ) {
+ // The jQuery object is actually just the init constructor 'enhanced'
+ return new jQuery.fn.init( selector, context, rootjQuery );
+ },
+
+ // Used for matching numbers
+ core_pnum = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
+
+ // Used for splitting on whitespace
+ core_rnotwhite = /\S+/g,
+
+ // Make sure we trim BOM and NBSP (here's looking at you, Safari 5.0 and IE)
+ rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
+
+ // A simple way to check for HTML strings
+ // Prioritize #id over