????

Your IP : 3.144.136.254


Current Path : C:/inetpub/vhost/xaydung.gdtsolutions.vn/api/
Upload File :
Current File : C:/inetpub/vhost/xaydung.gdtsolutions.vn/api/Microsoft.SqlServer.Assessment.dll

MZ����@���	�!�L�!This program cannot be run in DOS mode.

$PELV����" 0�
�   `o`�HO ��#@PT  H.text�
 �
 `.rsrc� �
@@.reloc@�
@B|H��	��(N��>�sv%}�*Z�sE
%}F
%}G
*0E(H
%-&rpsI
z}}}}rpsJ
}*{*"}*{*{*{*{*{*:(o�*Rs�}(J
*{*sK
zb(�}	}
*{	*{
*J(�%-&*o�*f((oL
oM
*�}sN
}(H
}}
*{*{*{
*{*
*0WoO

+8oP
(Q
�yoR
-(Q
(S
�yoT
o
-��
,o
�*DK
0u�yoU
(+oW

+@(X
rp(Y
�yoZ
�yo[
�yo\
&(]
-���{o
�*Me"(+*v(^
(_
�yo[
*0%s`

oa
ob
ob
ob
*v(Q
(S
�yoT
*N{c
sd
oe
*0Nsf

}g
{c
�h
si
oj
2{c
ok
(l
�R*�R*0Nsm

}n
{c
�o
si
oj
2{c
ok
(p
��*��*F{c
oq
��*(r
*Jss
}c
(H
*0�st

s\+Nou
u
	,:	o~�%-&~���sv
%��(+,	oWox
Xoy
2�oz
1Ho{
o|
+(}
o~
(
-����o
�oYo�
*~�(H
*0�rpo�

o�
@�o�
9�rprp(�
Xo�
<�o�
Y<�.rp(�
Xo�
/rp(�
Xo�
Q~�
Q+.rp(�
XYrp(�
Yo�
QXo�
Qrp(�
XYrp(�
Yo�
Q*QQQ*09rpo�

o�
3o�
,rp(�
Xo�
QQ*0Drpo�

/Q*o�
3 o�
,rp(�
Xo�
Q*Q*0=rpo�

2 o�
Qrp(�
Xo�
Q*~�
QQ*Rs�
}(�
*{*6(6o�
*6(6o�
*"o�*�(H
}}}}*{*{*{*{*0f(;(+,,(;~�%-&~���s�
%��(+-+(=~�%-&~���s�
%��(+**0~(;~�%-&~���s�
%��(+~�%-&~���s�
%��(+(=~�%-&~���s�
%��(	+(
+*0z{-k(>(;~�%-&~���s�
%��(+~�%-&~���s�
%���Ds�
(+sI}{*0%	s�
}�(=��s�
(+*j(<%-&+o�
%-&*N(�
o�(C*2(�*:(�*{*"}*V(H
}}*{*{*:s�%}�*(L*�(J~%-&~��s�
%�(+*0r
(Jo�

+Co�
(�
o�
/(K(�
(�
s�/(�
o�
Yo
-��
,o
�r%ps�
z*O[
�(�
} (H
}!}}}*{*{*{*{*{ *{!*0moGo�

+E(�
(X(�
o�
-sb(X(�
o�
(�
o_(�
-����o
�*R^{"*Z�s�%}%}
*0m(�

o�
YE4t8�(�
(�(�
([o�
o�o�(�
*(�
(�(�
([o�
o�o�o�
o�o�(�
*(�
(��%(�
([�%o�
o�o��%o�
o�o��%o�
o�o��(�
*(�
(��%(�
([�%o�
o�o��%o�
o�o��%o�
o�o��%o�
Y���(�
*0
o�-*o�*Js�
}"(H
*{#*{$*0�(]o�

-&(]o�
s�
%o�
(^o�
*+\(]o�
(
+
	o�
13(^o�
s�
%o�
(]	o�
(^o�
o�
-*X2�*:s�%}*(`*vs�
}#s�
}$(H
*N(H
s�
}�
*:{�
o�
*6{�
o�
*0{�
o�
&*{)*"})*6sq%oh*(g*0*s�
}~((g��s�
o�
*05oM
, u�,o�
(n�&�(m**
(20Ps�

o�
&@o�
&{o�
&o�
&(�
-:o�
&o�
&}o�
&o�
*0�s�

u�-u-+>(o*r1p(+~%-&~��s�
%�(+(�
*r7po�
&(�
-o�
&}o�
&(�
o�
(�
*0_(�
-(�
,*
+2o�
#3(p,o�
&
+Xo�
&Xo�
2�-*o�
*zo�
Y.Xo�
#��**J~�
})(H
*00sq�&@
(�
(�
r?p(�
s�
�(*fs�
}�
(H
}�
*{�
*2{�
o�
*
*:{�
o�
*0/s�

}�
}�
{�
��
s�
o�
�*F{�
o�
��*2{�
o
*&(�
&*2{�
o�
*0,s�

}�
}�
{�
��
s�
o�
*0,s�

}�
}�
{�
��
s�
o�
*0.(�

(�
�Ro�
-*{�
o�
*Vo�(5},*{,*{-*"}-*0)(�o�o�
,o�
Q*(�
*�(H
%-&r�psI
z}.}1}0}/(�
}3*v(��#%�}2*{.*{/*{0*{1*{2*0�s�

(�o�
 o�
(�o�
r�po�
(�o�o�
r�po�
&(�,+(�o�
r�po�
(�o�
r�po�
&(�o�
+o�
o�
o�
 o�
&o
-��
,o
�%o�

	Yo�
o�
*�'�
{3*>(�}4*:(H
}5*{4*{5*�o�,*(�,(�oM
*Q*0!Q,(�(3,	o�**{7*0`s1}7s�}8s}9(H
(�r�ps�
}:r�p(�sJ
};(�(�*0m�Is�
(+�]s�
(+�es�
(+�ps�
(+�rs
(+�Ws
(+*0(�o�sBo�(�o�sIo�(�o�s;o�(�o�s,o�(�o�s$o�(�o�so�*{8*{9*{:*{;*b-r�psI
z(�*00s�
}-r�psI
z��s
(�*�-r�psI
z-r�psI
z(+(�*0Cs�
}-r�psI
z-r�psI
z(+��s
(�*0O-r�psI
z-r�psI
z~%-&~��s
%�(+(+(�*0+-r�psI
z(�s
(�o
*0? (
}"}$}#}!|"(+|"(
*09-r�psI
z-r�psI
z(�s
(�o
*0G!(
}'}*}(})}&|'(+|'(
*6(�o+*�-r�psI
z-r�psI
z(+(�*>(�(�*>(�(�*>(�(�*09-rpsI
z%-&o�
(�o�(�o�o	
*0"s


(��
,o
�*

0#s

(��
,o
�*

0$(�
o+*07%(

}-}.},|-(+|-(
*Z�s�%}6%}8*0&(
rpo

s

*0?'(
};}=}<}:|;(+|;(
*0<,�j-s
(+*(�s
(���s
o+*0u((�~�
(�(�(�o�( +
(
(!+(
o�~6(�o�o�o�~6(�o�o�o�*Zo�tHo
u>*0?)(
}@}A}B}?|@("+|@(
*0?*(
}K}M}L}J|K(#+|K(!
*0�+
	u@-	uA-P+jo!(�
(�o!o��4o!o�(�
�#%�s�
�$%�Q*o"
o#
3o$
(�*Q*0?,(%
}X}Y}Z}W|X($+|X('
*0?-(%
}]}_}^}\|](%+|]('
*0s�%(�(io�%o�%(�o�%(�o�%o�%~�
o�%r�po�%o�%s(
o�%r�po�%(Qo��6*�()
s*
}+
(�(,
}-
*~()
s*
}+
(�}-
*�()
s*
}+
(�(,
}-
*�()
s*
}+
(�}-
*{-
*{+
*0 .(.
o/
,o0
Q*Q*�R*s1
*:(&+(�*0?/(H
}K}H}I(�
}L�i�#
o3
}J*{H*{I*2(�o�*2(�o�*{J*{K*0�s�

(�o�
 o�
&(�,+(�o�
r�po�
(�o�
r�po�
&(�o�
+o�
o�
o�
 o�
&o
-��
,o
�%o�

	Yo�
o�
*Y'�
{L*�o�o�(�}M}N*{M*2(�o�*{N*:(�o�*0T0(�,*
+4(�o6o4
o(��oL
oM
,*X
(��i2�Q*�s5
}SsN
}U(H
}Q}T*{O*"}O*{P*"}P*{Q*{R*"}R*{S*{T*0?1(%
}l}m}n}k|l('+|l('
*~V*0u2s�
}p-
{p�*{p-*o�{po�(6
,*o�o7
{po�o7
.*o���s8
((+*0�3o�%-&+o9

o�o:
~r%-&~q��s;
%�r()+o5
+so4
 �Zo9
a
 �Z
o�o=
%-
&��+
o9
s>
(?
-��+	(@
as>
(@

o
-��
,o
�*H�
0/4o�(A
oB
,(C
%-&�*oD
**(H
*.s��V*�(H
}Y}W}[}Z(�
}\*0W(�~t%-&~s��sE
%�t~u%-&~s��sF
%�u(*+}X*{W*{X*{Y*{Z*{[*F(�oG
(++*0�5s�

(�o�
 o�
&(�,0(�o�
r�po�
(�o�o�
r�po�
&(�,+(�o�
r�po�
(�o�
r�po�
&(�oH
+7oI
(J
o�
r�po�
(K
o�
o�
 o�
&o
-��
,o
�%o�

	Yo�
o�
*�C�
{\*0n6(�
(�o�o�
(�

(L
uf,%��%��sF%o�oH*��%��s�*�(H
}^}]}_}`}a}b(�
}c*{]*{^*{_*{`*{a*{b*{c*{f*{g*{h*{i*{j*{k*{l*0Bs�}isM
}j(H
}f}g}h}k}l*6(o,+*:(o+*6(o�*0,7�sN
(-+(+
r�ps�(*097�sN
(-+(+
r�ps�o�(o�*N((
o�*{q*0G8(O
}P
}Q
}R
}S
}T
|P
(.+|P
(V
*^s,sW
}q(H
*(X
*"(Y
*&(Z
*&([
*{r*(G*"(H*:(�(&*�(�
-+o�%-&~�
(�
(H*&(I*>(H}r*&(J*�-+o�%-&+o\
-+o�%-&+o\
(]
*0<9o�%-&��+o\
%-&��+
o9
s>

(@
*(H
*{s*"}s*{t*"}t*{u*"}u*{v*"}v*{w*"}w*{x*"}x*{y*"}y*{z*"}z*{{*"}{*F(9%-&*(^
*(3*(H
*(G*"(H*&(I*�(�
(�����(�
(H*&(J*(X
*"(Y
*&(Z
*&([
*(G*"(H*&(I*�(�
(�-+o_
%-&~�
(�
(H*�(�
(�-+o_
%-&~�
(�
-+o�
(�
(I*&(J*2(�(H*^(�
(�(�
(H*&(I*&(J*(G*"(H*&(I*^(�
(�(�
(H*b(�
(�(�
(I*&(J*(G*"(H*&(I*f(�
(�(�
(H*n(�
(�(�
(I*&(J*0D(H
%-&rpsI
z}�%-&r�psI
z}�rpsJ
}�*{�*{�*{�*:(bo�*�(H
}�}�(�
}�*2(no�*2(no�*(�*
*{�*{�*(&+*{�*���%(i�%r�p�%(��%r�p�%(g�(`
*{�*Z�y(a
(r�y*0�:з(a
(b
,_,u�-u�
-u-/+>��*(c
,
(�
(d
*o�
���*(+(/+��*(�
(d

�K-+(e
%-&�(a
%-&r�ps_zo�
sOzsYz	*(r�/Zr�2r�[Z(u,(0+�**0Z;}�}�(1+-/(|-&(2+,{�t�{�t�(f
*{�{�(g
*0\u�-Pu-Hu�-@u�-8u�-0u�-(u�- u�-u�-u�-u�,**0$<oh

oi
oj
ok
ol
&*0�=o�
Xsm

"o�
&~�on
+DYoo
&`o�
&~�~�o�
(3+�o�
&X~�oq
/�o�
Yoo
&"o�
&o�
*0Io�
Xsm

'o�
&o�
&r�pr�po�
Yor
&'o�
&o�
*0V>,,u�
-(u�,	��+u,,$�,+(�*ss
*st
*su
*(0+(�*���%��(v
����%��(v
��*0W{�uy,{�(4+�y}�
�.{�uy,{�(4+�y}�
��&�**PP60S{�(u-
{�(u,0{�(0+�}�{�(0+�}�
��&�**LL6(H
*0-?~�- r�p�>(a
ow
sx

��~�*~�*��*V(~rep~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r#p~�oy
*V(~rGp~�oy
*V(~rsp~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r9p~�oy
*V(~rYp~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r!p~�oy
*V(~rSp~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~rp~�oy
*V(~rUp~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~rp~�oy
*V(~rp~�oy
*V(~r9p~�oy
*V(~rwp~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r%p~�oy
*V(~rGp~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r	p~�oy
*V(~rE	p~�oy
*V(~r�	p~�oy
*V(~r�	p~�oy
*V(~r	
p~�oy
*V(~rC
p~�oy
*V(~r�
p~�oy
*V(~r�
p~�oy
*V(~r�
p~�oy
*V(~r-p~�oy
*V(~rqp~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r'p~�oy
*V(~rKp~�oy
*V(~rgp~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r
p~�oy
*V(~r-
p~�oy
*V(~rW
p~�oy
*V(~r�
p~�oy
*V(~r�
p~�oy
*V(~rp~�oy
*V(~rep~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*V(~r�p~�oy
*{�*"}�*{�*"}�*{�*0c(�
,(�rpsz
zo�
Yo�
({
,(�rpsz
zo�
({
,(�rpsz
z}�*{�*"}�*{�*{�*"}�*{�*"}�*{�*r(�%-&+o�
%-&~�
*�-rpsI
zsq%oh(�*{�*"}�*{�*"}�*{�*"}�*{�*"}�*{�*{�*"}�*{�*"}�*F(�%-&(�
*{�*"}�*0�@-r�psI
z-r!psI
z(�,W(�o|

+5	o}
(~
o�o�o
(�
(yo�
	o
-��
	,	o
�(�%-&+(�(5+,�T�#(�o�o�s��/(�ok
o�o�(�(�s**1Ar
��#60Q~�
}�s�
}�}�}�(�
s�
}�s�
}�~&}�(H
*V(H
}�}�*�(H
}�}�,s�
}�(�*{�*{�*{�*{�*"}�*0�A-*3*(�o�(6
-(�o�(6
,*(�o�3*(�,o�-*(�o�
o�o�
.*(�o�

+E(�
o�(�
o�
-
�>(~
-,
�.(~
oD
-
�(�
-����o
�*	*{R��-*3*(e
oe
(�
,*tA(�*04B(�%-&+o9

 �Z(�%-&��	+
o9
s>
(?
-��	+(@
as>

(@

(�9�(�~�%-&~���s�
%��(�
(6+o|
+ro}
 �Z(�
o9
a
 �Z(~
%-&��	+
o9
s>
(?
-��	+(@
as>

(@

o
-��,o
�*�&^~�o�
%-&*(�
*^~�o�
%-&*(�
*04(�,**:~�
(*0'C(o�
o�
,o�,*Q*0Do�

-*o�
(6
�*�o�
/Q*o�
(4+�yQ*Q*0YEs
}�-r+psI
z{�-Q*{�o�
~�o�
�s�
(7+(*0�F}�}�}�{�-r+psI
z{�-Q*{�{�o�
20{�~�o�
-+(�
%-&{�o�
Q*{�{�X}�o�
.3{�{�o�
3Q*~�(,*~�(,*Q*~�*0�Gr5p(�
��~�r�p(�
��~�r�p(�
��~�r�p(�
��~�r�p(�
��r�p(�
��r�p(�
��r�p(�
��r�p(�
��s�

~��s�o�
~�r�p(�
�s�o�
~�r�p(�
�8+s�o�
~�r�p(�
�s�o�
~�r�p(�
�9+s�o�
~�r�p(�
�8+s�o�
~�r�p(�
�8+s�o�
~�r�p(�
�8+s�o�
~�rp(�
�8+s�o�
~�rp(�
�8+s�o�
~�r
p(�
�8+s�o�
~�rp(�
�8+s�o�
~�r%p(�
�8+s�o�
~�r+p(�
�8+s�o�
~�r3p(�
�8+s�o�
~�r9p(�
�:+s�o�
~�r?p(�
�:+s�o�
~�rEp(�
�:+s�o�
~�rMp(�
�:+s�o�
~�rUp(�
�:+s�o�
~�r]p(�
�:+s�o�
~�rep(�
�:+s�o�
~�rmp(�
�:+s�o�
~�rup(�
�:+s�o�
~�r{p(�
�:+s�o�
~�r�p(�
�:+s�o�
��*0�H{�o�

9�o�
o�
+co�
(�
	,R{�{�		o�
(�
-7(o�
o�
,#{�{�	o�
Xo�,�o
-��
,o
�Q**o�
:(H
}�*{�*06Q(
(�
o�
(�
-(
o�
(**{�*:(H
}�*0M(o�
%-&+,(�
�s�
(;+�s�
(<+o7
%-&(=+o7
*(*�(o�
%-&*(�
�s�
(>+*�(o�
%-&+(�
(?+(*s	*0%D~�o�

,o�
r�p(6
�**V(H
}�}�*{�*{�*b(Q((6
�*Rooo�
*6~�o�
*6~�o�
*0~�o�
,*r�ps�
z0I~�o�
,*r�ps�
z0�Js�

�M(a
r�po�
�P(a
r�po�
�T(a
r�po�
�V(a
r�po�
�F(a
r�po�
�E(a
r�po�
��*{�
*N(H
o@+}�
*~�
*r~�
o-(A+*o�
*05Ks�
r�ps�
�R(a
(o�
&o�
��
*{�*r�y(a
(.uy�y*N(,o�
o�
*:(,o�
*0*Ls�

}�
�y(a
��
s�
(/*Js�
}�(H
*�(�
-rpsI
zo5
}�(<(>(7*0�(=
..
+h(>*(8o
�(<(;-<(8o4
(�
,(>*(8o4
o�
(:(9o
&(>*(9o
-(>*{�*{�*"}�*{�*"}�*{�*"}�*0-(;,*(=
..+
*
*(9o�
*09M(;,*(=..+

+

+(9o�

(7*:(H
}�*{�*(B*(�*�(B,(Bo�
��+(A+*2(Bo�
*0N(Bo�

o�
*6(Bo�
*2osA*{�*{�*{�*{�*�(H
}�}�}�}�*�(L(6
-
(MQ*(N(6
-
(OQ*Q*Rooo�
*(�*(A+*.rps�
z.rps�
zsX*(H
*"(�
*0?O(�
}�}�}�}�|�(B+|�(�
*0?P(�
}�}�}�}�|�(C+|�(�
*z�Z%(�
�%~��(�*sY*F~�o(A+*0Cs�%rups�
%r�po�
&o�
%r�ps�
%r�po�
&o�
��*"(�
*0GQ(�
}�}�}�}�}�|�(D+|�(�
*0@Ro�
~�%-&~��
s�
%��(;+(E+
o�
-*(dz0�Ss�

o�
+R(�
(�o�
&o�
&rp(,&	t�(�
-rCpo�
&	t�o�
&(�
-����o
�o�
sH*
_lsa*0�Ts�

9�o�
+po�

(C
(g,;��%rMp�%(A
�%rQp�%�%rUp�(`
o�
&+(�
(�(�
(A
s(zo
-��
,o
�(�
rYpo�
&(�
o�
o�
(�
rgp(�
*|�
0�Uu�-ku�-cu�-[u�-Su�-Ku�-Cu�-;u�-3u�-+u�-#u-u�
-u�,0��+(F+Q*(xQ*-r&p+r4pQ*oe
o�
Q*(A+*Js�
%o�
��*"(�
*(A+*R(�
(no`*0Vs�

(�
r@p(oo�
&,Xo�
1Oo�
+2o�
r�po�
&(�
r�p(^
(_
o�
&o
-��
,o
�o�
*0>n
(w*sk*"(�
*sq*0XW(�
}�}�}�}�}�}�}�|�(G+|�(�
*0OX(�
}�}�}�}�}�}�|�(H+|�(�
*z�Z%(�
�%~��(�*0?Y(�
}�}�}�}�|�(I+|�(�
*0aZ(%
}�}�}�}�}�}�}�}�|�(J+|�('
*0j[(%
}�}�}�}�}�}�}�}�}�|�(K+|�('
*0O\(%
}�}�}�}�}�}�|�(L+|�('
*0{s�%rUps�
%r�po�
&o�
%r�ps�
%r�po�
&o�
%r�ps�
%r�po�
&o�
%r/ps�
%r�po�
&o�
��*{�*"}�*0?](�
}�}�}�}�|�(M+|�(�
*(�
*{�*"}�*�(�(�
,sN
(N+*(�o*(�
*{�*�(H
}���s�
(O+(P+}�*6{�s#*F(�o�
��*(�*2(�o�
*6(�o�
*{�*"}�*�(�(�
,sN
(N+*(�o`*(�
*{�*"}�*{�*"}�*0G^(�
}�}�}�}�}�|�(Q+|�(�
*0%_s+
}�~��,s�
o�
*0@`s-
}�~���
s�
(R+,�.s;
(S+(+*(�
*Fr�ps�
��*~�
*0Ga(�
}�
}�
}�
}�
}�
|�
(T+|�
(�
*(�*f�%�R(a
���
*{�*"}�*{�*"}�*�(�(�
,sN
(N+*(�(�oj*(
*{�*"}�*{�*"}�*{�*"}�*{�*{�*(U+*{�*"}�*{�*"}�*0Gb(�
}}}}}|(V+|(�
*(H
*{�*"}�*{�*"}�*0Oc(�
}
}}}
}}	|
(W+|
(�
*(X+*0md-r�psI
zo�
o�

+o�
(A
(C
(�o
-��
,o
�o�(�
-r�po�(�*'D
0ger�p(�

o
o
,!o
o
tu%-&~
o
*o
o
%-&~
o
o
o
&*0?f(	
}}}}|(Y+|(
*>�s7%}*(
*{�*"}�*{�*"}�*{�*"}�*{�*"}�*{�*"}�*0Gg(�
} }!}"}#}| (Z+| (�
*(H
*{�*"}�*"(*&(*(*�~&%-&~%�Cs

%�&(
*�~'%-&~%�Ds

%�'(
(�*{�*"}�*�-rpsI
z(
(�o�*{�*N(�o�o
*0�h(�o

8�(
(
o
o
,f(
Qs
Q(
o

+8	�o
o
,o
,Po
o
X	�i2��$(
:p�����o
�QQ**��0Gi(%
}.}0}1}/}-|.([+|.('
*0Qj(�o

+#o
(�,{+{+o 
�o
-��
,o
�o!
*/?
0Ck(G
o�
+(�
(�(�(�
-����o
�*$4V{({((6
�*0?l(%
}4}6}5}3|4(\+|4('
*V(�
(�
(�*0!m(�-
�I*sE*Js"
}�(H
*~�*�(#
~:%-&~9�Qs$
%�:(]+*(%
*"(&
*&('
*R(%
s(
(�
*>(%
(�
*0bn-*o)

+@o*
(�
(+
,(�
o 
+(�
(�
s(
(�
o
-��
,o
�*LW
0lo-*o)

+Fo*
(�
,6(�
o�
,((�
(+
-
�)(�
o,
-
�o
-��
,o
�*	*R^
06ps�
,+o-
+o.
o�o
-��
,o
�**
(�*0]n-*o)

+;o*
(�
(+
,#(�
o/
o�
-(�
(0
&o
-��
,o
�*GR
0"q(+
-s�

(�
o�
&*0�r,o1
-(2
*s3

(�
+B(�
(�
o4
,(�
	o5
(�
o�
0
(�
o	
(�
-����o
�oW
+(X
(0
&(]
-���{o
�*On��0!q(+
-s�

(�
o 
*.s���*(U+*0Qss6
%r�po
o�o�
%r�po
o�o7
��o�

�m%�s8
(N+*(�*(X
*"(Y
*N(�
(�
(Y
*&(Z
*R(�
(�
(Z
*>�sR%}?*(�*{�* 8���*0Ht(%
}A}B}C}D}@|A(^+|A('
*~�*�r1p(�
rpo�
.r%p+~�
r)p(9
*07u(:
}Q}R}P|Q(_+|Q(<
*0?v(=
}U}V}W}T|U(`+|U(?
*Fr?prWp(*Frcpr�p(*Fr�pr�p(*fo7

1r�p*(*^(�
,*rMp(Y
*^(�
,*rMp(Y
*�rp�%�%o7
���(@
(A
*0+(�
,rp*\oB

/rp*Xo�
*08o�

,.o�
o�
&ooC
o�
oD
o�
*J~�}�(H
*0�wr�p��%r�p�s���rps�
��(�
sE

rWp�sF
oG
r�p�sF
oG
r�p�sF
oG
r+p�sF
oG
rEp�sF
oG
r]p�sF
oG
r}poG
��*~�*
*0Cxoo+
-s�

oo�
r�poH
,	(!*(*0?y(%
}Z}[}\}Y|Z(a+|Z('
*0u�,��
�*�*0Gz(%
}b}c}e}d}a|b(b+|b('
*(�*07r�poH
,r�p(c+(Y
*r1p(�
r�p(�
*(H
*nrp(�
(I
s�
��*~�*�*0H{(%
}n}p}o}q}m|n(d+|n('
*0?|s�
oJ
+(K
(+o�(L
-���o
�*
"/Zrcpr1p(�
(�
*0)}(-(�*o-(�*o(*(H
*Fryps�
��*07~(�
}y}z}x|y(e+|y(�
*(�*r�p*(H
*{�*�*{�*0P(%
}~}�}}�}�}}|~(f+|~('
*0N�s�
oJ
+$(K
(7oM
,	o3o�(L
-���o
�*
1>Zr1p(�
r�p(�
*�~�}�sN
%r�ps1oO
}�(H
*Fr�ps�
��*{*
*0G�(%
}�}�}�}�}�|�(g+|�('
*(�*0q�r1p(�
sP

r�poH
,r�p(Q
, o�
o�
&r�po�
&r�poH
,r�po�
o�
&o�
*J~}(H
*rr�p(�
(I
s�
�*{*
*0H�(%
}�}�}�}�}�|�(h+|�('
*(�*�r1p(�
rQpo�
.r%p+~�
(Y
*J~}(H
*Fr]ps�
�*�s1}s/}(H
(d*{*{*"}*~	*0O�(
}�}�}�}�}�}�|�(i+|�(!
*0G�(
}�}�}�}�}�|�(j+|�(!
*0|�s

oR
+WoS
(U-F(VoT

+$	oU
o�o�,oV
	o
-��
	,	o
�o
-��
,o
�*,0\

cp
0��
o6oW
+a(X
o,
oo�

+-	o�
o�oo�o�(oV
	o
-��
	,	o
�(Y
-���o
�*.9g
n|0\�s~
}�{�o6~�%-&~��ysZ
%��(k+(l+(�s[
(m+*07�(�
}�}�}�|�(n+|�(�
*0S�s�
}�{�o~�%-&~��zs\
%��(o+��s]
(p+(q+*0�s�
(Z*vs�o�o�o�([*0��o�(\o�o^
oB

+oA
(\o
-��
,o
�o�o_
+N(`

	o�,>	o�oa
ob
+(c
(\(d
-���o
�(e
-���o
�*(7
q�M[�0I�-*o�o5

+"o4
rp(1,	o�o
-��
,o
�*.>
Z�s�%}�%}�*0r�o�o
o�s�o�,No�o�
+'(�

o�(�
(~
o�of
(�
-����o
�*.4b00�o�
(�
,o�
s5o�-*s3
s�

o�o�
+q(�
(~
o�o5
+<o4
	(4,&og
-o	

oh
,	
o�
o
-��,o
�(�
-����o
�	oW
+7s�(X
}�	��s�
(+-
{�o7(Y
-���o
�o 
*(_I�A~��D0O�(%
}�}�}�}�}�}�|�(r+|�('
*0G�(i
}�}�}�}�}�|�(s+|�(k
*0G�(%
}�}�}�}�}�|�(t+|�('
*0��s�
sl
om
++on

	o�o�	o�o�	o�oo
o
-��
,o
�op
+)(q
r�p��%(�s�o�(r
-���!o
�o�oo�o�*7J
\6�0�(N�M(a
�Is�
o/(N�P(a
�]s�
o/(N�T(a
�es�
o/(N�V(a
�ps�
o/(N�F(a
�rs�
o/*.sM�	*(�*"(�*0��(�os
2(�os
],(�os
sEz(�ot
o�(0+
+:(�ot
o�(0+(u
,(�Yot
o�*X(�os
2�(�(u+o�*s�*�(�-rkpsI
z(�ow
*(�*0+�s�
}�(���sx
(v+om*{y
*{z
*r}z
(�}{
}y
*B(|
}z
*v}z
(�}{
}y
*J(}
}z
*�,-(~
�R*{{
(F+(F+(
o�
�R*b{{
(
(~
s�
*{*(�*"(�*"(x*:(�}*>(�}*&({*�,-��*(F+(F+(v(�
o
��*2(vsz*0�(�

(�
_(�
*0�(�

(�
`(�
*0�(�

(�
a(�
*(H
*~�
*>�R�R�*:�Ro9
*.s�
��
*:(	}*>(}*2{s�*^{(0+o�
�*(k*"(j*"(�*b�5+s�
(w+��*s�*v(�%-&rkpsI
z}*{*0*�s�
}�(���sx
(v+(x+*�(�~�%-&~���s�
%��(y+*�-*(e
oe
(�
,*(�o�(z+*�-*3*oe
(e
(�
,*t�(�*0��(e
o9

(�oB
+XoA
 �Z
-��+o9
s>
(?
-��+	(@
as>
(@

o
-��
,o
�*d|
(�*"(�*0V�u*
,/u*,({+*�(a
-+(e
s^z�(a
-+(e
s^zs�*Ro�(�
}�
*�(l��-{�
o���+��*2{�
s�
*�*�s�
}(�-rkpsI
z(�ow
*Js�
}(�*{*�-*(e
oe
(�
,*(�o�(z+*�-*3*oe
(e
(�
,*t�(�*0��(e
o9

(�o�
+Y(�
 �Z
-��+o9
s>
(?
-��+	(@
as>
(@

(�
-���,o
�*f~�(�~�%-&~���s�
%��(y+*0&�o�

(�(��
,o
�*
0
+X
o
-�1
XsEz*0.��
+o
-sEzo�
�X2�*"(j*(k*0�(�
��o�*�(�-rypsI
zo�
-(�rypsz
z}*{*00�(�oM
-(�sRzu�,o�
*>�s�%}�*z-*3*(�o�(f
*�-*3*oe
(e
(�
,*t�(�*2(�o9
*(�*"(�*0&.(|+
(|+�Ro�
o�
��*v(�%-&r�psI
z}*{*v-*3*(�o�(g
*�-*3*oe
(e
(�
,*t�(�*2(�o9
*04(�o�
(5+��*2(�o�*:(�}*>(�}*v{(0+(0+o�
�*2{s�*{*:}(�*>}(�*"(�*V}(�}*Z}(�}*&(�*N(�(t��*2(�s�*2(�
s�
*s�
*ss
*s�
*st
*0i�-r!psI
zo�o�
-(�sHzo�
�4u�-u�-u6,�(�sIzo�o�
�*)
3'#KZ

*(H
*~*�*(�
*(H
*.s��*(�
*"(�
*�*s�*{*:}(�*>}(�*V}(�}*Z}(�}*0^�s�
}�}�u-,+$(+��s�
(}+��*��*�(a
oe
s^z2(�s�*(�
*"(�
*�*s�*:(�}�
*{�
*2(�
�R*"�s�
*0 .-*(�

o�
�Ro�
*04�-*3*u1
-�1(a
oe
s^z(�
*6u1(�
*�-*3*(�
(�
o�
o�
*�(�
�R-*(�
(�
o�
*:(k} *>(j} *&(�*��0+s�
(~+{ (+�*2{ s�*(	*"(*>(5+���*s�*(�*~!**u��*
*
*"�s�*.s��!*(k*"(*"(j*b�5+s�
(}+��*s*"(j*(k*0�(�
�o*N(H
s�
}"*:(H
}"*N(H
s�
}"*j(H
s6
%o�
}"*
*V,r%ps�
z{"*:s�%}�*(*�(H
%-&r�psI
z}#%-&rkpsI
z}$*2((�+*6((�+*2(o7
*(*�{%-{#{$o(�+}%{%*
*0�-s'��
*s
*(H
*�%-&r�psI
z}'%-&rkpsI
z}&*2{&o�
*v{'{&oL
s%��*Ns�%q�}�*(#*�%-&r�psI
z}(%-&rkpsI
z})*R{({)o*�%-&r�psI
z}*%-&r�psI
z}+*2(,(�+*6(,(�+*2(,o7
*(**J{*{+o*v�0+s�
(~+(�
�*(H
*{,*"},*{-*"}-*0L�(2-+%~�%-&~���s�
%��(�+
(0,(�+
(�+��*V},}-(H
*v�0+s�
(~+(�
�*(H
*(x+*{/*"}/*{0*"}0*0r��F+s�
(+~%-&~���s�
%�(�+
(9,&~%-&~���s;
%�(S+
(;(�
*f}/r1p}0(H
*{1*
*6s ��*�oM
-(?oB
-*P(sQ*Js5
}1(H
*{2*6s ��*
*0s�oM
-*(Do�
,UP(so�
++(�

(C
(soD
,(A
Q�(�
-���5o
�*+8cJs�
}2(H
*V(H
}3}4*{3*{4*~(Ko�
-(JoM
**�r1p(K~%-&~��s�
%�(�+(�
*�(�-+(+%-&(�+}5(�+,(�s�
z*0L�,/(�+,'~%-&~��s�
%�(�+,(�+*(�s�

o7
8�o
{5�i�
+&{5�oM
,	�+	�X{5�i2�	o�
-X{5�is�
+{5�	�o�
X{5�i2�	��	}E		o�
{F-s�
}F	o�
{Ft;o�
o
:����
,o
�o�
*J�;
{6*"}6*{7*"}7*{8*Z�s�%}
%}*0��s6

(P(�
-+(R(�
-(To�
��
s�
(R+,*o7
+\o
(PoM
,E	(F+(�
-8(T	(F+oH
,#(�
-(RoM
,
o�
o
-��
,o
�*Gh�
^(�
s�
}8(*Z�s�%}%}*0C�s�

}�
��
s�
(�+,r�poM
,(4+*�y	*f ls�
}9(*V(H
}:};*{:*{;*�(\(Q
,	oM
*(]Q*{<*{=*"}=*
*0}�,7o�
1.(`(�
,*(`��s[
s ��*(`(�
-*(_(`o�
-(_(`��o�
(_s
*Js6
}<(H
*"(f*R%�gs�
(�+*(*{?*"}?*{@*"}@*{A*"}A*"(p*0F�(m,(q(r+�rs�
(�+
(k-*(s(�+of*0��s6

o7
+}o
(io�
o�

+J(�
oM
,5o�
-s3
s�
o�
tB(F+o�
(�
-���Ao
�o
:x����
,o
�(�+o�
+-(�
(A
(m(C
t1(�
o�
(�
-���Eo
�*('W~
��
�:�0N�s�
}��+s�
(i��s�
(�+(�+(�+��s�
(�+*0��sg%s3
od
(io�
8�(�
(�
o�

+](�
o
(�+o5
+'o4
oc(�
rp(Y
o	
o
-��,o
�(�
-���Lo
�(�
:g�����Io
�*(V4�7j���(*.s�
�>*{B*{C*"}C*Z�s�%}!%}#*vs�
}B~G}C(*{D*J(H
s�
}D*N(H
s�
}D*�({~&%-&~%�s�
%�&(�+*0��({~'%-&~%�s�
%�'o�

+({o�
o�
X2�2({o�
o�
X
+({	o�
o�
	X
	({o�
2�*>}E}F*(H
*.s��G*{H*
*6s ��*09�(�oH
,
+(�o�
(�+-
+Q*oM
*Js
}H(H
*:(�(�*{I*"}I*Z�s%}/%}.*0 4(�oM
,
,(F+*~�
*�o�
-(�+*��%s6
s���*(�*>�s%}>*(�*0��oM
-sRz-
�y*�y(a
(�
(d
�y�E�y(a
oe
s_z
�y(a
o�
	sOz�y(a
sYz*( =Z V2 n[0L�s�

o7
8�o
r�p(�+
	o�
-s�
	o�
r�p(�+o�
-m	r�p(�+rp(�+rp(�+r/p(�+rGp(�+r[p(�+rep(�+r}p(�+s(o�
o4r�p(�+r�p(�+r�p(�+r�p(�+r
p(�+s:o�
o
:�����
,o
�~a%-&~`�Ds�
%�a(�+*A

(*0J~d%-&~c�Ts�
%�d(�+~e%-&~c�Us�
%�e(�+*0Y�~f%-&~c�Vs�
%�f~g%-&~c�Ws�
%�g(�+
%��s�
(�+*(*>�s]%}p*(�*{�
*J(H
s�
}�
*N(H
s�
}�
*N(H
s�
}�
*0%�s�

}�
(�
��
s�
(�+*v-*3*(�
o�
(�+*F(�
o�
�_*�-*3*oe
(e
(�
,*t[(�
*2(�
o9
*2(�
o
*"(g
*.(g
�*0S�s
}Ks
}Ls
}M(H
o

+o
(�o
-��
,o
�*.H
{K*{L*{M*�(�o
(�o
X(�o
X*
*�(�(�(�(�+(�+o
*(�*0F�u�
-u�-u�-*(�o
*(�o	
*(�o

*�(�o
(�o
(�o

*�(�(�+-(�(�+-
(�(�+**sK
z0I�u�
-u�-u�-+'(�o
*(�o
*(�o
**{N*"}N*{O*"}O*{P*"}P*{Q*{R*"}R*0��-r�psI
z-r%psI
z-r-psI
z(�o�(�o�(�+o

+Lo
(�,;ou�-
u�
	-+o�o�
&+	oo 
o
-��
,o
�*KX�
08�(�+(�(�+(�+
(�(�+
(�(�+
*�o
,o
oS-
(�o
**&o
*bo1��s
(�+*>�sg%}v*0F�o

o(�
oo
�_
(�(+o
	``*0:�
(�o�o
+o
o
o
-��
,o
�*.
��so%}|%}~%}�%}�*v�s{%}�%}�%}�*Js-}Q(H
*�(H
}T}V}U}S(�
}W*{S*{T*{U*{V*{W*v(H
%-&r7psI
z}
*{
*B(
o
�*Js�
}
(H
*�s�
}
(H
-rIpsI
z(
o 
*{
*(!
*"("
*0%�s#

}$
(
�%
s�
(�+*s&
*(!
*"("
*0%�s'

}(
(
�)
s�
(�+*s*
*{[*{Z*V}Z{Z(�*{\*"}\*{]*"}]*{^*"}^*{_*0��s�
}�{�-r]psI
z(�%-&{�o�~�%-&~���s+
%��o,
{�o�{���s-
o.
&*"(�*&(�*0��-r�psI
z(�
,(�rgpsz
z(�o/
Y
+4(�o0
(�u�,o�o,	*Y
/�(�
(�(�
szv�s�%}�%}�%}�*Z�s�%}�%}�*0=�(�o1
,"o2
(�+(4
,
o5
,*rwps�
z�s6
}[s3
}\s�}_(H
*:(H
}l*{l*:(�(f
*z-*3*(�o�(f
*�-*3*oe
(e
(�
,*t�(�*J(�%-&*o9
*(�*�s7
}8
(H
%-&r�psI
z}9
*2{8
o:
*2{8
o;
*{9
*0O�s<

}=
{8
�>
s?
(�+- (�
(�{=
�R(�
s@
zoA
*J{8
oB
oA
*R{8
(C
oD
*�{8
~E
%-&~F
�G
sH
%�E
(�+oI
*(J
*N{8
(C
oK
*z{8
�C
sL
(�+oM
*~{8
�C
sL
(�+oN
*2{8
oO
*0%�sP

}Q
{8
�R
s?
(�+*0u�-r�psI
z/(�s�
z(S
Xj�j1(�s�
z
{8
oT
+(U
oA
��(V
-����o
�*D"f0(�sW

}X
{8
�Y
sZ
o[
�*0%�s\

}]
{8
�^
sZ
o_
*R{8
(C
o`
*6{8
oa
**job
(c
od
(�+*0?�sf

}g
{8
�h
s?
(�+-	��*oA
��*2{ooi
*
*2{ooj
*2{ook
*6{ool
*:{oom
*0�Q{oon
,	oo
**0@�-r�psI
zop

+on
o�(%o
-��
,o
�* 5
n{o(q
(r
os
&*2{oot
*6{o(�+*sK
zsK
zJ{ook
ou
*N{ook
ov
*sK
z0P�-r�psI
z-r�psI
z{o~�%-&~���sw
%��ox

oy
*2{ooz
*F{ook
o{
*o{
*>{oos
&*6{oo|
*sK
z:{oon
*^(�
s}
}o(H
*0(H
%
}~
}
*0'�(H
%
}~
}
%}�
}�
*0D(H
}�
}�
(�
�R(�
�R(g

`}
`}~
*{�
*{�
*{
*{~
*z(�
�R-(�
�R�**r(�
�R(�
�R(g
*0�u�
,(�
**0d-*3*(�
�Ro�
�R(g
,:(�
�Ro�
�R(g
,(�
o�
3(�
o�
�**0��(�
�R-+(�
�Ro9

 �Z(�
�R-+(�
�Ro9
a
 �Z(�
(�
a
 �Z(�
(�
a
*0�(�
�R,;(�
-(�
�Ro�
�+(�
�Ro�
��+
,H(�
�R,9(�
-(�
�Ro�
�*(�
�Ro�
��***0��(�
�R(�
�R(g
,/(�
%qR�R-&+�Ro�
%-&~�
*s�

(�
-(+[o�
(�
%qR�R-&+�Ro�
%-&~�
o�
,o�
(�
%qR�R-&+�Ro�
%-&~�
o�
(�
-)+]o�
&o�
*J(H
s�
}�
*N(H
s�
}�
*�(H
-r�psI
z�iXs�
%o�
}�
(�
o�
*~(H
s�
%s�
o�
}�
*�(H
s�
%s�
o�
}�
*{�
*�(�
~�
%-&~�
��
s�
%��
o�
*04�s�

}�
(�
o�
,(�
��
s�
(�+**"(�
*&(�
*No�
o�
(E*0�u�
,(I**2{�
o9
*V{�
{�
(6
�*"(�
*�(H
}|}}}~}}�}�}�*{|*{}*{~*{*{�*{�*{�*0��-*(N,(No�_o��+
(M,(Mo�%-&~�
o@
+(O,(Oo�%-&~�
o@
+(L,(Lo�o�
+
(R,(Ro�_o��+(P,(Po�o@
+(Q,(Qo�o@
+__	____*0�-*3*(MoM(g
,g(LoL(g
,T(OoO(g
,A(NoN33(RoR3%(PoP(g
,(QoQ(g
**�-*3*oe
(e
(�
,*t�(T*0�(M-+(Mo9

 �Z(L-+(Lo9
a
 �Z(O-+(Oo9
a
 �Z(Na
 �Z(Ra
 �Z(P-+(Po9
a
 �Z(Q-+(Qo9
a
*08�(�(�st
s�(�(�

��o�
(�*�-r�psI
z(�
(�o��4o�(�
*0F(�%-&+ok%-&~�

-+o�-+o�%-&~�
s�*
*:o�+�R*&o�
*(�
*
*s�
zsK
zrs�
%sbo�
%s�
o�
*(�
*{�*"}�*"(f*Z�s�%}�%}�*(*
*sK
z0*�o�
3	o�+*s�

o�+o�
*(�
*
*s�
z0c�(�+
o�
.o�+��o�
+/o�+
+	����o�
	X
	�i2����R*(�
*{�*"}�*{�*"}�*{�*"}�*{�*"}�*{�*{�*"}�*0m(r-(y(�r�p(�z(ro�

r�p(]
-r�p(]
-	+(}*(|*(y(�(r(�z0q(p-(y(�(�z(v-(p(t(xs*(t,(y(�r�p(�z(p(v(xs*0Y�(v,(y(�(�z(pu�
-(y(�(p(�zo�(t(xs*Js�
}�(H
*
*j(�
(�r/p(�
s�
z0����%�(�s~%oz
8���%�(�o�
t�rCp(]
-)r�p(]
-,rIp(]
--r�p(]
-7+L(�oq+Oo�
os+Ao�
&o�+ow+*o�
&o�+ou+ox(�o�
o�
,
o�

@:���o{*0�o�+s�

s�
*0�o�+
s�
s�
*0=�o�
t�
o�
&(r i;o45F ��$5 ���;, ��$;�8� H�`2.l ҿ�2;� i;o4;�8� Vf�5# ��y; �癛;� Vf�.@8� ���;� f���;� ���;�8vr�p(]
:�8arcp(]
:�8Lr{p(]
:�87r�p(]
:�8"r�p(]
:�8
r�p(]
:�8�r�p(]
:�8�r�p(]
:�8�r�p(]
:�8�r-p(]
:�8�r�p(]
:�8�(R(�*("(�+*((�+*(H(�+*(,(�+*(C(�+*(>(�+*((�+*('(�+*(M(�+*(�(�+*s6(�+*0l�o�
&��%	�%�(�o�
.	3#o�
t�
s�*o�+s*(�o�
��rp(�z(�
*
*j(�
(�r#p(�
s�
z0^�o�

.	.Y6*+.o�+sN*��%o�
(F+�sN*~G*��%	�%�(�z(�
*
*�Ъ(a
(b
-Й(a
(b
**0K�o�

.	3��%o�
o�
�*o�+*(�o�
��r3p(�zj(�
(�rOp(�
s�
z(�
*
*j(�
(�r[p(�
s�
z0:�o�

.	3(�*(�*(�o�
��(�z0'�~�o�
,-(�(�zo�
*0	7�(�

ryp��%�(�+(�o�
o�
*0o�
t�
(�*(�
*
*0.���%	�(�-sq+
o�+oh*j(�
(�r�p(�
s�
z(�
*
*j(�
(�r�p(�
s�
z0J�o�
..
+)o�+
+'o�+�j,s+(�
+	o�+
s�*(�
*
*j(�
(�r�p(�
s�
z0��o�

YEJSASS&/SSSS8+Q(�*(�*(�*(�*(�*(�*(�*(�*(�*(�o�
��r�p(�z��s�%}�%}�%}�%}�*v�s�%}�%}�%}�*0�o�+
s�*z��%�(�o�+su
*(�*z��%
�(�o�+st
*v��%�(�o�+s�
*0D��%	�(�o�
t�
(�
-o�
@3
o�
s�*ss
*Z�s�%}�%}�*v��%�(�o�+s�
*0Bo�
&o�

3(�*o�+
o�
&o�

3*
(�s�*0��s�
}�}�{�o�
t�}�{�o�
@3o�s�*~�{�o�
-{�(�{�(�z{�o�
&{�{�(�(�+o�
*(�
*
*j(�
(�r�p(�
s�
z0s�o�
3o�+s�
*o�
.	(�*(�

r�po�
,$o�

	o�
&	o�
s�
*o�
(�*0��
o�
	3?o�
t�/o�

o�
/3	/s�*	1c	o�
�+
o�+-,o�
����(�
-o�
o�
`s�
sF*(�
*0M-�R(a
(�
+	uR�-(�
(��R(a
(�
s�
z�Ro�
*0W��
-'uR-(�
(��R(a
(�
s�
z-�R+	�R�o�
�R*F�R(a
o�
*Fo�
,(�
**6(�
(�
*(�
*
*0T�-s-+
o�
&+2o�
u�o�
&s�o�
o�
&o)o�

3�*j(�
(�r�p(�
s�
z(�
*
*j(�
(�rOp(�
s�
z0��(�

rypo�
-(�ryp(�zo�
.(�o�
����(�z(�+(r
	 XCjE55	 ��)5	 �&.W	 ��).s8	 ��U2;�	 XCjE.I8	 X˖G5	 Xy)G.y	 X˖G.b8�	 ���.C	 �9Y�.k8�r�p(]
-w8�rp(]
-o8�rp(]
-g8�r�p(]
-_8�r�p(]
-W+}r�p(]
-R+nr%p(]
-M+_r�p(]
-H+P(�+*(�*(�*(�+*(�+*(�+*(�+*(�+*(�(�+r1p(�zR(�o�
(�*0D�-rGpsI
z(�

�*&(�
�&(�
�(�z(�z*4	�	#�	.
�	8
�05�(�

�*(�z(�z
	(�z(�z*4		
�	
�	
�	'�0��r�p(�
r�p��%�(�+rep��%�(�+(�
-	(�+(

	o�
s�%o�%o�
o�o�
o�
*0b�r�p(�
r�p��%�(�+(
o�

	(�
uco�
o�
o�
o�
*0:�(�+
o�
�yo�
r�p(�o�
�yo�
*(�
*
*j(�
(�rwp(�
s�
z0	��o�
.	;�8�(�

rCp��%�(�+rwp��%�(�+r�p��%�(�+
r�p��%�%�(�+	s�*o�
u�s�*s�
z(�
*
*j(�
(�r�p(�
s�
z0G�o�

..	3(�*(�*(�*(�o�
��(�z0o�
t�
(�*0'�~�o�
,-(�(�zo�
*0	7�(�

ryp��%�(�+(�o�
o�
*0�o�+
s}*(�
*:(�
}�
*{�
*6o�
o�
*0V�o�
	.@"s�
*o�
t�
~�
o
o
-(�r�p(�zo
r�po
o
,!o
r�po
o
o�
[�+o
r�po
o
,!o
r�po
o
o�
]�+
o
rpo
(�
o
rpo
o
,o
r!po
(�
+	_-(��R(�z	s�
*(�o�
��r�p(�z0^��Ro
,L(�
o
o�
�
	u�-	u�,�	�-(�o
r�p(�z*(#Br-ps�
��
*0G,
o�
o�
-o�
*o�
o�
3o�
o�
o�
*o�
o�
*zo�
.(�
s�
*s�
*Z�s�
%}�
%}�
*(�
*(�
*"(�
*&(�
*�(�
}�}�}�*{�*{�*{�*�-+o�
%-&~�
u�(�*0G�
,3o�
,+o�

o�
(�
(�����(�
s�*R(�
(�
(�*Z(�
(�
(�*Z(�
(�
(�*b(�
(�
(�*b(�
(�
(�*0/�s�
%o�
%o�
%o�
%~�o�

(�
*0B�o

-(�(�zo�
.(�o�
����(�z*0K�o

--(�(�z�y*o�
(�+/(�(�z(�+*0R�o

--(�(�z�y*o�
(�+/(�(�zo�
o�+*ro�
��o
-(�z*�(�o�
��r p(�+(�*6-	(�z*:-
(�z*B-(�z*0���%s��%s��%s��%�
s
s
�%s
�%s��%s��%s��%s��%	s��%
s��%s��%s��%
s
���s	
%r  p~���s

o
%r* p~���s

o
%r: p~���s

o
%rF p~���s

o
%rL p~���s

o
%rR p~���s

o
%rX p~���s

o
%r` p~���s

o
%rf p~���s

o
%r�p~���s

o
%rn p~���s

o
%rt p~���s

o
%r| p~���s

o
%r� p~���s

o
%r� p~���s

o
%r� p~���s

o
%r� p~���s

o
%r� p~���s

o
%r� p~���s

o
%r� p~���s

o
%r� p~���s

o
%r� p~���s

o
%r� p~���s

o
%r!p~���s

o
%r!p~���s

o
%r!p~��	s

o
%r!p~��	s

o
%r&!p~��	s

o
%r:!p~��	s

o
%rJ!p~��	s

o
%rV!p~��	s

o
%rb!p~��	s

o
%rp!p~��	s

o
%r�!p~��		s

o
%r�!p~��	s

o
%r�!p~��
	s

o
%r�!p~��	s

o
%r�!p~��	s

o
%r�!p~��	s

o
%r�!p~��	s

o
%r"p~��	s

o
��s
%r"p~��	s

o
%r"p~��	s

o
%r*"p~��	s

o
%rJ"p~��	s

o
%rl"p~��	s

o
%r�"p~��	s

o
%r�"p~��	s

o
%r�"p~��	s

o
%r�"p~��	s

o
%r�"p~��	s

o
%r�"p~�� 	s

o
��s
%r#p~��!	s
o
%r�p~��"	s
o
%r
#p~��#	s
o
%r�!p~��$	s
o
%r"p~��%	s
o
��*(H
*~�*0o�-r�psI
zo�%-&+o
,Lo
1Co�-s�
o�o|

+o}
o�o
o
-��
,o
�*Ed
V-r�psI
zo�*.s���*�((�
,
(�(�z}�*{�*Zo�(�(Q
�*Zr#p(�r#p(Y
*N(s(
}�*{�*�(o�o
-o�,o�(o
***�r#p(�
o
o
r�p(�
((�
r#p(Y
*0,�(,s�

(Rs�
(1o�
*Z�s&	%}�%}�*B(}�*{�*04�s�%(o�%o�%o�%(Qo�
o
*6(
oS*R(2(
o�*>(0(*{�*"}�*(H
*B((*{�*"}�*v(o,
(
oS**(H
*(H
*~�*Z-r�psI
zo�*V-r�psI
zo�*.s��*(H
*~�*Z-r�psI
zo�*V-r�psI
zo�*.s��*(H
*~�*Z-r�psI
zo�*V-r�psI
zo�*.s!��*(H
*~�*Z-r�psI
zo�*V-r�psI
zo�*.s&��*(H
*~�*Z-r�psI
zo�*V-r�psI
zo�*.s+��*�s�
}�(
-r#psI
z(1o
*{�*0E�-r�psI
z(1o

+(
o
(
-����o
�*60��-*3*(1o
o1o
.*(1o

+P(
o1o

+(
oD
,�(
-����o
�,�(
-����o
�**I$m1]��-*3*oe
(e
(�
,*t�(3*Z(1-*(1o9
*�(H
-r.#psI
zo�
-(�r.#psz
z}�*{�*�-r�psI
zo�(7o�
*0+-r�psI
zo�(7o�
,*(�*z-*3*(7o7(f
*�-*3*oe
(e
(�
,*t�(:*2(7o9
*(H
*~�*�-r�psI
zo�o
,o
1o�o 
*V-r�psI
zo�*.s=��*(H
*~�*Z-r�psI
zo�*V-r�psI
zo�*.sB��*(H
*~�*Z-r�psI
zo�*V-r�psI
zo�*.sG��*(H
*~�*�-r�psI
zo�o!
,�,o�o 
*j-r�psI
zo�(+*.sL��*(H
*~�*Z-r�psI
zo�*V-r�psI
zo�*.sQ��*(H
*�(H
%-&rJ#psI
z}"
%-&r�psI
z}#
*{"
*{#
*��R-r�psI
z($
(%
($
o&
o'
o(
*�-*3*($
o$
(g
,(%
o%
(g
**�-*3*oe
(e
(�
,*t�()
*z($
o9
 �Z(%
o9
a*�(H
%-&rJ#psI
z}*
%-&r�psI
z}+
*{*
*{+
*0O��R-r�psI
z(,
o-
oI

+o.
(/
o0
o
-��
,o
�*%D
�-*3*(,
o,
(g
,(/
o/
(g
**�-*3*oe
(e
(�
,*t�(1
*�(,
-+(,
o9
 �Z(/
-+(/
o9
a*:(2
}3
*{3
*(4
*0W�-*3*(4
�Ru
,!(+o4
�Ru(+(�+*(�
(4
o4
o�
*�-*3*oe
(e
(�
,*t�(5
*F(�
(4
o�
*
*(2
*0,�,' ŝ�
+o�
a �Z
Xo�
2�*.st��*(H
*Z*f(H
}�(6
}�**0��{�
,	;�*}�{�(�+,*{�~�%-&~��us7
%��(�+}�}�+i{�o9
��{�
+{�	o:
	��(;
	X
	�i2�}�}�*}�{�X}�{�{�2�*{�*s<
z{�*07�{��3{�(6
3}�
+sv
{�}�*(|*(H
*N{=
o>
o?
*.s@
�A
*(H
*oB
*2oC
t�*f(H
}D
(6
}E
*0{D

�.3
�(F
�*0K�{D
,;
�1}D
sG
}H
{H
{I
}=
{H
{=
~J
%-&~A
�K
sL
%�J
(�+(�+(~M
%-&~A
�N
sO
%�M
(�+(�+oP
}Q
�}D
+k|Q
(R

	{H
{S
%-"&{H
{H
�T
sU
%}S
(�+(�+{W
(�+}X
}D

�2�}D
|Q
(Y
-�(F
|Q
��
�(Z
�*ABBf}D
|Q
��o
*{X
*s<
z2{X
�R*0C�{D
�3{E
(6
3}D

+s[

{\
}I
{]
}W
*(^
*(H
*z|g
(p
����oD
*(H
*z|n
(l
�R�RoD
*.s���*(H
**uf�*.s���*(H
*6(�
o�*o*6(�
o�*6(�
o�*o*B(�
o��*"(_
*(H
*b{�.
{�o **:(H
}�*0{�
�.3
�(��*0��{�{�,.~
��}�(Jo�
}��}�8�{�o�
}�}+P(K|�(�
|�(�
{s}�}�
�d�}�{
	X}{|�(�
o�
2�|���{�o
:b���(�}�
�(��*��n}�{�,{�o
*{�*s<
z{�*.s��*(H
*6(�
o�
*.s��*(H
*2o�o�*f(H
}(6
}*00{
�Y63�..��(��(��*!(0��{{,;	
�`}(Xo`
-
�E(Xoa
}�}8�|(b
}|(c
o`}
�}8�{
o"

(�
~%-&~��sd
%�(�+(+{	|(e
	(Z(�
o�
o(�
o�
o�sP}}
�^�}{
o
:S���(�}
|��|(f
:����(�|��
�(��*Axxf}|��o
*r�}{
,{
o
*{*s<
z{*0C{�3{(6
3}
+s�
{}{
}	*(�*:(H
}**0�{
{,.a*}}+f(]{o�
o�
1=(]{o�
(^{o�
sg
}}*}{X}{(]o�
2�*{*s<
z2{��*(H
*0P{o
r�po
o
o
r\#po
o
-+o
r\#po
o
(l*.s��*(H
*o�
*(H
*b{�
(h
{�
oi
*(H
*b{�
(h
{�
oi
*(H
*b{�
(h
{�
oi
*(H
*Jo�{��*(H
*Jo�{��*.s��*(H
*o�*o�*o�*0�{!
{$,j{#-r�psI
z{#(�s
	(�oj
(k
(l
->%
}!}%|"(�+�]{%|%��%
}!(n
(�+��}!|"(o
��}!|"(p
*��#6|"(q
*0�{&
{*9�{(-r�psI
z{)-r�psI
z{((�{)s
	(�oj
(k
(l
->%
}&}+|'(�+�]{+|+��%
}&(n
(�+��}&|'(o
��}&|'(p
*��#6|'(q
*0�{,
9�;{.-r�psI
z{.o�uH-
{.o�+o
u>}/{/-e�(r
(s

(t
-?%
},	}0|-(�+�{0
|0�J%
},(v
{/o�
.�{/o�
,.l+j{/ow
ox
(y
(z
->%
},}1|-(�+�h{1|1�M%
},({
{/� �},}/|-(|
��},}/|-(}
*AY` #6|-(~
*f(H
}2(6
}4*0{2
�.3
�(��*0�{2,.Q
݅}2{5o=
}9�}2+>{9o<
u?
	,	}3}2
�;�}2+{7o
{9o
-�(�}9
�(��*��n}2{9,{9o
*{3*s<
z{3*0C{2�3{4(6
3}2
+s�
{6}5{8}7*(�*0�{:
{=,}{<o,{<o�j-(�+ݡ(�{<��s
o+o�
(�

(�
-<%
}:	}>|;(�+�_{>
|>��%
}:(�
&{<o��}:|;(�
��}:|;(�
*��#6|;(�
*0V{?
{A,a;�s
}C{Boco�o�
(�
(�
-A%
}?}E|@(�+��{E|E��%
}?(�

	}D.:{Bod~%-&~��s�
%�(�+o�
}F.8�{Fo�
.h{C}Go�
{B{D(�oKo�
		(�
(�
-A%
}?}H|@(�+��{H|H��%
}?(�
{Go�
}G�"

{B(�,
{Co�
�{Fo
:����/{F,{Fo
�}F�/{D,{Do
�}D{C� �}?}C|@(�
��}?}C|@(�
*Ad���"#����S� #6|@(�
*(H
*�(�
(�o�(�
{Io	o�{Io	o�s�*04{J
{M9�YC�s�}N{N{L}Is
}O{N{Io	o�o�
(�
(�
-A%
}J}Q|K(�+ݛ{Q|Q��%
}J(�

	}P;�YC�{N{Io	{P(�(�{N{Ios}R{R(�ox


(y
		(z
-A%
}J	}S|K	(�+��{S	|S�M%
}J	({
{N{Io,2(�{N{Io	{N{Ioo�(�++ (�{N{Io	o�(�+{N{Io,{N{Io(�+(�+s�
(�(�+�-�?%~6�{N{Io
,{N{Io8M{O{N��s�
(�+o�
~ %-&~��s�
%� (�+o�
}TY6$8�{To�
{N{Io;�;+o�


uv-
:�8C{O}U{N{I{RoLo�
(�
(�
-A%
}J}V|K(�+ݵ{V|V��%
}J(�
{Uo�
}U8�{O}U
{N{I{P(�oKo�
(�
(�
-A%
}J}V|K(�+�{V|V��%
}J(�
{Uo�
}U�'{N{I(�,
{Oo�
�{To
:4����/{T,{To
�}T}R�/{P,{Po
�}P{O�'�}J}N}O|K(�
�"�}J}N}O|K(�
*Ad�ua'#��������'#6|K(�
*0�	{W
{Y,D{Z(�ox

(y
(z
-<%
}W}[|X(�+�Q{[|[�M%
}W({
��}W|X(�
��}W|X(�
*lz#6|X(�
*0
{\
{_6{^o
o�,��E|L��v��z(�o�{^r�p��%r�p�%r�p�%r�p�s�o�ox
		(y
(z
-A%
}\}f|](�+�5{f|f�M%
}\({
{^o


u3}`{`,{`o=(�
-��{^o�+}a{a�-|{a{^o)o�
(�
(�
-A%
}\}g|](�+�e{g|g��%
}\(�


�,�{arj#po3}h.I{ho�
o�
(�
(�
-A%
}\}i|](�+��{i|i��%
}\(�
��,.+'{`r�#po>�i{`r�#po>+{`r�#po>�B�/{h,{ho
�}h{^o�+}b{b�-|{b{^o)o�
(�
(�
-A%
}\}g|](�+�{g|g��%
}\(�
�,�x{br$pojo�
(�
(�
-A%
}\}j|](�+�;{j|j��%
}\(�
o�
-��{br�$pojo�
(�
(�
-A%
}\}j|](�+ݵ{j|j��%
}\(�
o�
,?oL
r%p|coM
,&{cu�}d{d,
{d(�
,�-{^o�+}e{e�-|{e{^o)o�
(�
  (�
-A%
}\ }g|] (�+��{g |g��%
}\ (�
�,݄(�
r/%p{d(�

{e	oo�
(�
""(�
-A%
}\"}j|]"(�+�7{j"|j��%
}\"(�
!!o�
-��oL
rCpoM
-��r(poM
-ݸ(�oC
r"(p{co[
(�oC
r:(po[
(�oC
rh(po[
{`r�(po>}`}a}b}c}d}e�##u�-	#u�,���$�}\|]$(�
��}\|](�
*AL���*��#��#6|](�
*0�{k
{m9�(�- (�,{n(�o�o-{U(��9{n(�o�o,{n(�o�o-C(�s�%{n(�o�(�o�oo�(�(���,S(�{n(�o�o�
(�

(�
-?%
}k	}o|l(�+݂{o
|o��%
}k(�
(��'u�-	u�,�(�(����}k|l(�
��}k|l(�
*A4��D'#_m#6|l(�
*(H
*6{p(�*.s��q*(H
*
*.s��s*(H
*"(J
*"(K
*.s�
��
*(H
*"s�
*0�{�

{�
9�;�{�
�R-r�(psI
z{�
-r�(psI
z(|�
�Ro!~�
%-&~�
��
s�
%��
o�
}�
{�
o�
ox
(y

(z
-?%
}�
	}�
|�
(+��{�

|�
�M%
}�
({
.L{�
{�
o�
o�
(�
(�
->%
}�
}�
|�
(+�w{�
|�
��%
}�
(�
�1/{�
o�
&��}�
}�
|�
(�
��}�
}�
|�
(�
*A4�{mp~ #6|�
(�
*.s���*(H
*"(�
*(H
*�~�{�~�o�
%-&+(�
(*(H
*^{�
o�
�RtJ*03
{�
{�69{�(�
,s3
��s3
}�(�
r�(po3}�9�;�{�oh

	r�(poi
	{�oj
{�ok
	ol
&{�o�
o�
(�
(�
-A%
}�}�|�(+�[{�|���%
}�(�
}�.u+*{�o�
-{�{�o�
o�
o	
{�o�
o�
		(�
(�
-A%
}�}�|�(+ݳ{�|���%
}�(�
:`����/{�,{�o
�}��/{�,{�o
�}�{�� 
�}�}�|�
(�
��}�}�|�(�
*AL��L���� #6|�(�
*0�{�
{�,G{�(Zo�
(�
(�
->%
}�}�|�(+�_{�|���%
}�(�

	s6��}�|�(�
��}�|�(�
*|�#6|�(�
*.s��*(H
*>r)p(6
�*F~�r)p(*0�{�
{�,\{�{�(f
(�
	oJo�
(�
(�
-A%
}�}�|�(+�B{�|���%
}�(�
~�%-&~��s�
%��(�+(�
s�
		~�(�

�%~�s�
�s�

o�
&+/
o�
+o�

(�
o�

o�
3�
o�
&
o�
3
o�
(�
~�(�
-�(cs
�9/
,
o
�/	,	o
��}�|�(�
��}�|�(�
*AL��b��rt�#6|�(�
*0�{�
{�6;s�
}�(�
95(�
{�-r$)p+rt)po3}�9�;�{�r�)p{�(v&{�r�)p~�
(v}�{�r�)p~�
(v}�s
}�{�{�{�{�rp(wox
(y

(z
-?%
}�	}�|�(+ݏ{�
|��M%
}�({
{�o�
}�;�8�|�(�
(^
(_
{�{�{�{�{�(xox
(y
(z
-A%
}�}�|�(+��{�|��M%
}�({
|�(�
:P����/|���o
�|���}�}�}��/{�,{�o
�}�{�� �}�}�|�(�
��}�}�|�(�
*ALG�N�>Xf #6|�(�
*0�{�
{�9�s
}�{�{���%\�o�
r*p(�
{�{�rp(wox
(y

(z
-<%
}�	}�|�(+�g{�
|��M%
}�({
{�� �}�}�|�(�
��}�}�|�(�
*�� #6|�(�
*0�{�
{�,7(�
,{�~�o-�9(�
r$)po3}�,C{�r�)pr*p(v&{�r�)pr.*p(v
{�r�)prp*p(v,I{�o�
o�
(�
(�
-A%
}�}�|�(+ݣ{�|���%
}�(�
o�
�[/,o
�		u�-		u�,��1/{�,{�o
�
�}�|�
(�
��}�|�(�
*Ad
�� #I�:DR#6|�(�
*0�{�
{�C�;�{�*oB
/{�{�{�o
8B{�o�
}�s
}�X
+	X
{�o�
	1{�	o�
\.�{�	o�
}�(�
{�-r�*p+r�*po3}�,~;�{�r�)p{�(v&{�r&+p{�(v&{�o�
o�
(�
(�
-A%
}�}�|�(	+�q{�|���%
}�(�
}�;�{�o�
9�+J{�o�
u�,3{�{�(�
{�(
	{�	o
{�o�
o�
(�
(�
-A%
}�}�|�(
+ݖ{�|���%
}�(�


:@����/{�,{�o
�}��/{�,{�o
�}�{�o�
}�.v8�|�(�

{�
(_
{�{�
(^
(wox
(y
(z
-A%
}�}�|�(+ݛ{�|��M%
}�({
|�(�
:[����/|���o
�|���}�}�}���}�|�(�
��}�|�(�
*Adx�S��t��U��#6|�(�
*(H
*Nr6+p{�of
*.s��*(H
**o7
�*0�{�
,Is}�{�{�}�{�{�oj
s
}�{�o5
}�,g8�{�o4

	{�{�{�(yox
(y
(z
-A%
}�}�|�(+�{�|��M%
}�({
{�o
:j����/{�,{�o
�}��
+s
{�(+~�%-&~��s
%��(+{�{�(�
-{��s
(+{�o
�'�}�}�}�|�(�
�!�}�}�}�|�(�
*A4T����'#6|�(�
*0P{�
,i;�s�
}�{�{�oj
{�o�
o�

(�
(�
-?%
}�}�|�(+��{�|���%
}�(�
}�;{�o�
98�{�o
.
.48�{�s5
%{�{�o�
(sof
o
+W{�o�
~
.{�o�
(s+{�o�
(s{�s5
%{�of
o
{�o�
o�
(�
(�
-A%
}�}�|�(+ݩ{�|���%
}�(�
:���/{�,{�o
�}�{�o
1{�{�o	
� 	�}�}�|�	(�
��}�}�|�(�
*A4�6� #6|�(�
*0�{�
{�,L{�({oJo�
(�
(�
->%
}�}�|�(+�d{�|���%
}�(�

	rV+ps���}�|�(�
��}�|�(�
*��#6|�(�
*V(H
}�}�*v{�(]
,
{�Q*Q*.s&��*(H
**o7
�*s�
*0|{�
{�,/(�-sN
�<s
}�(�o

}�,,8V|�(
}�|�(
o

}�9�8�|�(
|�(
{�(�(
{�(�(
{�(�{�(�oo
(
(
-A%
}�}�|�(+�]{�|���%
}�(


		o
1
{�	o	
|�(
:
����/|���o
�|���|���|�(
:�����/|���o
�|����
+s

{�	(+~�%-&~��'s
%��(+~�%-&~��(s
%��(+s
� 
�}�}�|�
(�
��}�}�|�(�
*ALqqAp�2@ #6|�(�
*(H
*0<4o
o
1 {�o
o
o
o�
-o
*(F+*(H
*6{�(�*0�{�

{�
,{�
o@+
,N{�
	{�
o
o�
(�
(�
->%
}�
}
|�
(+�~{
|
��%
}�
(�
�?(�r�po�
(Y
o"s&z�}�
|�
(�
��}�
|�
(�
*|�&1��#6|�
(�
*0T{
{9�(�(�
us
	-(�(�o�
sz(�(�
-(�	(
	{o
%-&+o�o
	{o
%-&+o�o 
	{o
%-&+o�o!
	{o"
	o#
o�
(�
(�
->%
}}|(+�X{|��%
}(�
��}|(�
��}|(�
*A&#6|(�
*0�{	
{,q{-rd+psI
z(�,E{o
o�32{o
o�(�
-{
{o
o�o4{
o2}9�s$
}(�}}8�{{�
{{o
	{o�{}{(�o%
(&
('
-A%
}	}|
(+ݺ{|�%
}	((
{o)
}{X}{{�i?#���}{o*
s8
�1/{,{o
��}	|
(�
��}	|
(�
*A4� ���#6|
(�
*0�{
{,I{o�
o�
(�
(�
-A%
}}|(+݄{|��%
}(�

	(�%��s,
(+(+�'/		,	o
��}|(-
��}|(.
*� ���#6|(/
*f(H
}(6
}**0\{
,.8*}{o�
,){o0
,{}}*}{o1
-�*{*s<
z{*07{�3{(6
3}
+s7
{}*(=*0�{
{!,M{"{#o�o�
(�
(�
->%
}}$| (+�p{$|$��%
}(�

(�,(�	o�

	��}| (�
��}| (�
*��#6| (�
*.sB�%*(H
*o�*o�*z}(})}*}+*0q{)-Jo�,{({+s�}d{({+s�}eo2
(3
*{){({*{+o�*�{)%-&+{*{+o�%-&(�*0.{)%-&+o�
{)%-&+o�(4
e*(H
*.sI�,*0�{-
{09�{/��s5
(+(+
+	o6
{1(�	X
	o7
2�~,o8
{1(�ox
(y
(z
->%
}-}2|.(+�R{2|2�M%
}-({
��}-|.(�
��}-|.(�
*��#6|.(�
*0� {3
,{5o9
}7,V+w|7(:
{6(Fox

(y
(z
-?%
}3}8|4( +݅{8|8�M%
}3({
|7(;
:y����/|7�o
�|7���}3|4(�
��}3|4(�
*����#6|4(�
*.sP�9*(H
*o�
*f(H
};(6
}=**0�!{;
,.b*};{>o�
-*s6
+"{>o<
{>o�
o�
X{>o
2�}<};*};{>o0
-�*{<*s<
z{<*07"{;�3{=(6
3};
+sR
{?}>*(X*0#{@
9;�{B~�o-Z~�s�{Boo�{Bo�,{C{Ds�}d}eo2
�J{Bo{C|Eo+
-'s�
}E{Bo{C{Eo�
{Bo!+}F{F-��{F(o=
(>
(?
-A%
}@}J|A("+��{J|J�	%
}@(@

	}G{Bo
o�(}Hrv+psP
}I{Irpo�
&{DoJ
}K;�8�|K(K
}L~�{LoA
9~-+#{L{H{Bo
o�oB
%-&{L}M{Go
}N{N9�}M{F(oC
(D


(E
-A%
}@
}O|A
(#+�u{O
|O�%
}@
(F
		{E{Lo�
&{I{Lo�
&{B{I{N��({B{I{Mr�p({B{Ir�+p({Irv+p(�
rp(�
Xo�
}M}L|K(L
:J����/|K�o
�|K��<�}@}E}F}G}H}I|A(�
�6�}@}E}F}G}H}I|A(�
*A4��j��<#6|A(�
*0�${P
,Q{Rr*pr�+pooG
(H
(I
->%
}P}S|Q($+�g{S|S�%
}P(K

	oL
(�
sM
��}P|Q(N
��}P|Q(O
*��#6|Q(P
*0%{T
,m{Vr*pr�+p{W(�
��%r ,p�oo
(
(
-A%
}T}X|U(%+ݐ{X|X��%
}T(
o
1oR
r ,poS
-+oR
r ,po=
t�
	��}T|U(T
��}T|U(U
*��#6|U(V
*0&{Y
6+{[o�+-��{\o!
o2}],^;�{]r6,po�
{]o�
o�
(�

(�
-?%
}Y	}_|Z(&+�u{_
|_��%
}Y(�
}^;�+A{^o�
u�{^o�
(�
-( ,{\o�
&{^o�
,s{^o�
o�
(�


(�
-A%
}Y
}`|Z
('+ݡ{`
|`��%
}Y
(�
		:0����/{^,{^o
�}^�/{],{]o
�}]��}Y|Z(�
��}Y|Z(�
*AL���7����#6|Z(�
*0X'{a
,+{co�+-�&{do!
o2}f9�{fr�,po�
{foh
r)-poi
{eoj
{fok
ol
&{fo�
o�
(�
(�
-A%
}a}g|b((+ݍ{g|g��%
}a(�

	,{d	(F+o�
&�/{f,{fo
�}f��}a|b(�
��}a|b(�
*A46�
$+#6|b(�
*(H
*Z(�
{h(6
�*.sg�j*(H
*^(�
%-&+(�
�*^(�
%-&+(�
�*0,({m
9�sd{o}h{po{h|ro+
-'s�
}r{po{h{ro�
sW
}ssX
}t{qoJ
8�(K

	(9�{po,s{t	oY
{po({i%-&�esZ
%	}i	()+

(�
,	s(
+{s	s[
o\
(L
:Y����/
�o
�{s~k%-&~j�hs]
%�ko^
}u8L{s{uo_


(�
}v{t{vo`
{po)o�


(�
(�
-A%
}m}w|n(*+�6{w|w��%
}m(�
,{r{vo�
&{soa
+"(b
(�
%-&+{v(c
&(d
-��/
�o
�{s{uoe
}v{s~l%-&~j�is]
%�lo^
}u{u<�����.�}m}r}s}t|n(�
�(�}m}r}s}t|n(�
*AL��4>/m��.#6|n(�
*0�){x
,{zo�+o2}{,V{{r5-po�
{{o�
o�
(�
(�
->%
}x}||y(++�y{|||��%
}x(�

	��oD
�1/{{,{{o
��}x|y(�
��}x|y(�
*#����#6|y(�
*0*{}
{�9�{o{�|�o+
-'s�
}�{o{�{�o�
s%
}�{�oJ
8)(K

(7	oM
-H{���%	�s�{o�,}d}eo2
8�o3{o-W{���%	�s�{oo�{o�,}d}eo2
+Zo�
	+2	(�

(5
(�
o�
,{�	
(�
o�
+		(�
-��/
	��o
�(L
:����/
�o
�s3
}�8�{�of
{�o�
}�9�85|�(�
}�|�(�
o�
:(7|�(�
og
{o2o�


(�
(�
-A%
}}}�|~(,+ݐ{�|���%
}}(�
,{�|�(�
o�
&{�|�(�
o	
{�o�
+!(�
(�
|�(�
oc
&(�
-��/
��o
�|���|�(�
:�����/|���o
�|���{�oW
+(X
{�o0
&(]
-��/
�{o
�{�oh
=����.�}}}�}�}�|~(�
�(�}}}�}�}�|~(�
*A�M?�p<��.
�R=l$���.#6|~(�
*0+{�
6~{�o{�|�o+
-'s�
}�{�o{�{�o�
{�o�+9d{�r�poi
(�
oj
o2}�9,;S{�r�-po�
{�oh

	r8.poi
	oj
{�oh
rX.poi
{�r�poi
,{�r�poi
oj
+Erv.p(6
-,{�o
o�3{�o
o�oj
+~
oj
{�ok
	ol
&{�ok
ol
&{�o�
o�
(�
(�
-A%
}�}�|�(-+�F{�|���%
}�(�
}�.h+{�{�o�
o�
o�
&{�o�
o�


(�
		(�
-A%
}�	}�|�	(.+ݫ{�	|���%
}�	(�
:m����/{�,{�o
�}��/{�,{�o
�}�� �}�}�|�(�
��}�}�|�(�
*AL������� #6|�(�
*0,{�
,c{�o{�|�o+
-'s�
}�{�o{�{�o�
{�o�+9|o2}�,Y{�r�.po�
{�oh
}�{�r�.poi
{�ok
{�ol
&{�oJ
}�,n8�|�(K
}�{�{�oj
{�o�
o�
(�

(�
-?%
}�	}�|�(/+��{�
|���%
}�(�
��,{�{�o�
&}�|�(L
:B����/|��o
�|��}��/{�,{�o
�}�� �}�}�|�(�
��}�}�|�(�
*AL���nP��� #6|�(�
*0�-{�
{�,v{�o!{�(N{�{�os
{�	(So�
(�
(�
->%
}�}�|�(0+�X{�|���%
}�(�
��}�|�(�
��}�|�(�
*��#6|�(�
*.sw��*(H
*2o�o�*2oo�
*o�*"(k
*0.{�
{�ETr+ps
}�{�(Wo�
(�
(�
-A%
}�}�|�(1+ݘ{�|���%
}�(�

	-0{�o
(�s�{�oV
{��{�(X}�s�}�{�ol
+(m
	{�	o�o�(n
-��/
�o
�{�oo�{�{�o�ox
(y


(z
-A%
}�
}�|�
(2+�z{�
|��M%
}�
({
{�{�{�(]o�
{�{�~�%-&~��xso
%��(3+{�(box
(y
(z
-A%
}�}�|�(2+�{�|��M%
}�({
(�sp
}�{�ol
}�.o8�|�(m

{�

o�o�{�(`ox
(y
(z
-A%
}�}�|�(2+�{�|��M%
}�({
|�(n
:b����/|��o
�|��{�{�o!{�(To�
(O{�oo�{�o0{��5�}�}�}�}�}�|�(�
�0�}�}�}�}�}�|�(�
*AL�(%��>��5#6|�(�
*(H
*6{�s�*0�/{�
,){�o�+-+o59,o2}�9�{�o
o�
	E	FFFFFFF+D{�r�.po�
+9{�oq
{�o
o�o�
{�r�/po�
+ݮ{�o�
o�
(�
(�
->%
}�}�|�(4+�|{�|���%
}�(�
����5/{�,{�o
���}�|�(�
��}�|�(�
*A44;PW#6|�(�
*(H
*J{�o(Y*f(H
}�(6
}�*0{�
�.3
�(��*0�0{�,;*
��}�st
}�}�8A{�{�{�or
o�o:	{�{�ox
{�oos
}��}�8�|�(t
{ds�
	{�{�or
o�o�	oh
1v(�s�%{eo�{�{�or
o�~�
{�o
o�{�o
o�(}�}�
ݦ�}�|�(u
:=���(�|��{�X}�{�{�ov
?����{�o{
{�o|
+(}
{�ow
(
-����o
�
�(��*A4�#���f}�|��o
*{�*s<
z{�*0C1{��3{�(6
3}�
+s�
{�}�{�}�*(�*(H
*b{�.
{�o **(H
*Z{�(x
o
�*02{�
,7s�}�sy
}�{�s�
}�{�oz
}�,>8�{�o{
}�{�{�{�{�{�(_}�,!s|
}�{�(VoT
}�,~8�{�oU
}�{�{�{�(^{�{�(ao}
(~
(
-A%
}�}�|�(5+��{�|�� %
}�(�

{�{�	o�
}�{�o
:5����/{�,{�o
�}�{�o�{�{�o�{�o6s:}��Hu#%-&+u0-u6�+��&{�o��#%�s�{�oo�
}�}�{�o
:�����/{�,{�o
�}�{�{�{���s�
(6+~�%-&~��{s�
%��(7+o8�'�}�}�}�|�(�
�!�}�}�}�|�(�
*Ad��~�O��BM��'#6|�(�
*0�3{�
,b{�{�o�
:�{�{�o�ox
(y

(z
-<%
}�	}�|�(8+�l{�
|��M%
}�({
{�{�o�
{���}�|�(�
��}�|�(�
*��#6|�(�
*04{�
9�s�
{�oz
+=o{

{�	o�oo�
&�u�-	u�,��o
-��/	,o
�{�{�(cox
(y
(z
->%
}�}�|�(9+�R{�|��M%
}�({
��}�|�(�
��}�|�(�
*((F#Ih��#6|�(�
*(H
*6{�o�*(H
*6{�o�*.s���*(H
*o�*.s���*(H
*o�*f(H
}�(6
}�**0<5{�
{�,.*}�(�}�}�*}�*{�*s<
z{�*076{��3{�(6
3}�
+s�
{�}�*(�*(H
*b{�{�(�(t*f(H
}�
(6
}�
**0{�

,*}�
*{�
*s<
z{�
*0+7{�
�3{�
(6
3}�

+s�

*(�
*f(H
}�(6
}�**0{�
,*}�*{�*s<
z{�*0+8{��3{�(6
3}�
+s�
*(�*:(H
}�**0<9{�
{�,.*}�{"}�}�*}�*{�*s<
z{�*:(H
}�*0{�
�.3
�(��*0�:{�,.a
݇}�|�{&o7
}��}�+;{�o
|�{'s%��}�}�
�-�}�{�o
-�(�}�
�(��*��n}�{�,{�o
*{�*s<
z{�*.s���*(H
*�*.s���*(H
*�*o�
*.s��*(H
*fr�0p(A
(C
(�
*~*(H
*6(�
o�
*2(�
o�
*.s��*.s��*(H
*�*f(H
}(6
}	**0B;{
{
,.$*}{(V}}*}*{*s<
z{*0C<{�3{	(6
3}
+s�
{
}
{}*(�*f(H
}
(6
}**0�={

{,	;�*}
s6
%r�0p(�
{r�0p(:+(�

(�
i��o�
%r�0p{r1p(:+{9(�

(�
i��o�
%r81p{rT1p(;+��o�
%rx1p{r�1p(;+��o�
}}
*}
*{*s<
z{*0C>{
�3{(6
3}

+s�
{}{}*(�*(H
*0$4r�1poM
,t�{�
o�
**(H
*6{sI*0^?s�
}{|(�
oM
,-~>*(F+}|(�
��s�
(<+(=+*(H
*0I@s�
}o
(�+(+}{o�
(>+��s�
(?+*(H
*0�As�
}�@+s�
{��s�
(A+~%-&~��s�
%�(B+(C+(D+{|(�
�E+s�
(F+*(H
*0DBs�
}{o
{o
o�
(G+��s�
(H+(I+*(H
*J{o
s�
*.s��*(H
**o�
�*(H
*04|(�
oM
-**f(H
}(6
} *0{
�.3
�(��*0eC{{!,;
�D}(w{"o�o9
}$�}8�{$o8

(vo�
8�s�(�
}	{E|(�
o�
,!r�1p|(�
r�1p(Y
sHz	{F��s�
(J+	{E|(�
|(�
o-o�
(�
:a�����.o
�	{E}}
�0�}{$o
:���(�}$
�(��*A4h�\\n}{$,{$o
*{*s<
z{*0CD{�3{ (6
3}
+s�
{!}!{#}"*(*.s�%*(H
*o�
**o�
�*(H
*n{)(�{((6
�*f(H
}*(6
},*0{*
�.3
�(�*0�E{*{/,;�
��}*{-��s�
(K+(�
(L+
	o5
}0�}*+ws	}){0o4
}(s6
%(�{(o�
{-�
s�
(M+s�}+}*
�0�}*{0o
:y���(}0
�(�*��n}*{0,{0o
*{+*s<
z2{+��*0CF{*�3{,(6
3}*
+s
{/}/{.}-*(*(H
*6{1��*.s�2*(H
*oN*FoL,oM**oN*FoL-oM**oN*oF*oF*f(H
}:(6
}<*0{:
�.3
�("�*0*G{:,;�
�}:{=(�o�
}?�}:8�{?o�
s
	~3%-&~2�s�
%�3(N+~4%-&~2�s�
%�4(O+}1	{1-O	~5%-&~2�s�
%�5(N+~6%-&~2�s�
%�6(O+}1	{1-0	~7%-&~2�s�
%�7(N+(P+}1	�s�
(Q+(R+(S+9�s6
%rJ2p{=o�
o�
%rV2prf2p~8%-&~2�s�
%�8(T+(�
o�
%rj2prf2p~9%-&~2�s�
%�9(T+(�
o�
};}:
�0�}:{?o
:2���("}?
�( �*A!!n}:{?,{?o
*{;*s<
z{;*07H{:�3{<(6
3}:
+s
{>}=*(&*0_(H
}P}O}Q}R}T}U}S}V	}W
}Xs�
}Y*{O*{P*^(*rp()(Y
*{Q*{R*{S*{T*{U*{V*{W*{X*{Y*0s(4~�%-&~��1	s�
%��(U+~�%-&~��2	s�
%��(V+~�%-&~��3	s�
%��(W+*0s(4~�%-&~��4	s�
%��(U+~�%-&~��5	s�
%��(V+~�%-&~��6	s�
%��(W+*0s(4~�%-&~��7	s�
%��(U+~�%-&~��8	s�
%��(V+~�%-&~��9	s�
%��(W+*0P(4~%-&~��:	s�
%�(U+~%-&~��;	s�
%�(X+j*07s6
%r�p()o�
%r�po�
%r|2p(,��o�
%r�2p(.��o�
%r�2p(-��o�
%r�2p(5(+o�
%r�2p(6(+o�
%r�2p(7(+o�
%r3p(+o�
%r3p(8��o�
%r(3p(/��o�
%r>3p(0��o�
%r[p(1�o�
%rT3p(2�o�
%rj3p(3o�
*�(H
}Z}[}\}]}^*{Z*{[*{\*{]*{^*(H
*b(�
|_(�
o9*.sC�`*(H
*0*Is@
}_|_(�
�As�
(Y+*:(H
}b*F{br�p(�+*F{brj3p(�+*F{br�2p(Z+*F{br�2p(Z+*�(I~%-&~�>	s;
%�()+*�rf2p(H(�
rf2prf2p(I(�
(Y
*F{br|2p(�+*F{br�2p(�+*0srf2p(H~%-&~�?	s;
%�()+(�
rf2prf2p(I~%-&~�@	s;
%�()+(�
(Y
*�(H~%-&~�A	s;
%�()+*0@rf2p(H(I([+~%-&~�B	s;
%�()+(�
*0�J(FoF(]
-(I(\+,
oI(\+-*(HoH(]+,(IoI(]+,*(OoO(]+
(JoJ(]+,-((KoK(]
-(PoP(]
,*.*(PoP(]
,(GoG(�
**.sS�c*(H
*JoKoN(�
**(^+�*2r�p(�+*sE*.sY�h*(H
*�~i%-&~h�[s�
%�i(T+*oF*oF*f(H
}l(6
}n**0IK{l
,	;/*}l{o(�~j%-&~h�Zs�
%�j(_+s(
s�
{o(R+
+`X+K	�	�oQ,6	�oFo
-
	�o�
	�oFo
-
	�o�
X	�i2�X	�iY2�(S+,ps6
%rJ2p{oo�
o�
%rV2prf2p~k%-&~h�\s�
%�k(T+(`+(�
o�
}m}l*}l*{m*s<
z{m*07L{l�3{n(6
3}l
+s]
{p}o*(c*(H
*6{�
o
*f(H
}r(6
}t**0�M{r
,.k*}r{uu=,o�
u�,ro�

	u>,ao�
}w}x+5{w{x�}s}r*}r{xX}x{x{w�i2�}w*{s*s<
z{s*07N{r�3{t(6
3}r
+sg
{v}u*(m*f(H
}y(6
}{*0{y
�.3
�(r�*0�O{y{|,.w
ݝ}y(�o�o�
}��}y+Q{�o�

{}	{{�(�,+	(�(�o	}z}y
�-�}y{�o
-�(r}�
�(p�*��n}y{�,{�o
*{z*s<
z{z*0[P{y�3{{(6
3}y
+so
{|}|{~}}{�}{�}�*(v*(H
*(H
*b{�{�{�o*f(H
}�(6
}�*0{�
�.3
�(~�*0�Q{�{�,;�
��}�sx}�{�{�}�{�o(
}��}�+osy
	{�}�	{�o'
}�(�o�	�zs�
(a+	{���s�
(b+}�}�
�-�}�{�o
-�(~}�
�(|�*��n}�{�,{�o
*{�*s<
z{�*0OR{��3{�(6
3}�
+s{
{�}�{�}�{�}�*(�*(H
*6{$
o
*(H
*6{(
o
*(H
*{�*.s���*(H
*s�
*f(H
}�(6
}�*0{�
�.3
�(��*0�S{�{�,;�
ݯ}�{�(+}�{�(�o=
}��}�+Q{�o<

{�	o�(�
(c+-	o�{�o
,	}�}�
�-�}�{�o
-�(�}�
�(��*��n}�{�,{�o
*{�*s<
z{�*0OT{��3{�(6
3}�
+s�
{�}�{�}�{�}�*(�*f(H
}�(6
}�*0{�
�.3
�(��*0MU{�{�,;
�,}�(�
s�

(�
s�
(�o/
Y+'(�o0
(�{�	o�Y/�(d+(�oW
+#(X
(�{�	o�(]
-���{o
�o=
}��}�+C{�o<
		o�%-&+{�o�
,	}�}�
�-�}�{�o
-�(�}�
�(��*A4�0�DDn}�{�,{�o
*{�*s<
z{�*0CV{��3{�(6
3}�
+s�
{�}�{�}�*(�*(H
*bo�
%-&*{=
o
*.s�
�F
*(H
*oA
*(H
*0 WoA

{Q
����oD
*(H
*0 WoA

{X
����oD
*(H
*0 WoA

{]
����oD
*(H
*bo�
%-&*{g
o
*.s���*(H
*s�*.s�
��
*(H
*o�
*(H
*6{�
o�
*f(H
}�(6
}�*00{�
�Y63�..��(��(��*!(0X{�{�E�K
�V}�(c-
�@s6

{�o7
}��}�8�{�o
}�(coW
}��}�+}|�(X
}�{�{�|�oM
,E	{�o�
,#	}�}�
ݡ�}�s6

	{�{�o�
}�}�|�(]
:s���(�|��{}�{�o
:���(�}�	o�
1	}�}�
�}�
�(��*Avvn}�{�,{�o
*j�}�|��{o
*{�*s<
z{�*0CY{��3{�(6
3}�
+s�
{�}�{�}�*(�*f(H
}�(6
}�*0{�
�.3
�(��*0�Z{�E%v
ݜ}�{�}�}�
�~}�{�{�{�(�oB
}��}�+&{�oA
}�}�
�-�}�{�o
-�(�}�
�(��*��n}�{�,{�o
*{�*s<
z{�*0[[{��3{�(6
3}�
+s�
{�}�{�}�{�}�{�}�*(�*f(H
}�(6
}�**0t{�
,.+*}�+F{�{�o�+}�}�*}�{�o�
-{�(�(�z{�o�
{�3�*{�*s<
z{�*0O\{��3{�(6
3}�
+s�
{�}�{�}�{�}�*(�*f(H
}�(6
}�**0�]{�
E7~*}�{�o�
.){�{�o�+}�}�*}�+j{�{�o�+}�}�+3{�{��}�}�*}�{�X}�{�{��i2�}�*{�*s<
z{�*0C^{��3{�(6
3}�
+s�
{�}�{�}�*(�*(H
*0_�sC	
}*f(H
}�
(6
}�
**0`{�

EN�*}�
{�
o�
.A	@�{�
{�
oe+o�
:�}�
}�
*}�
8�{�
{�
of+}�
}�
+3{�
{�
�
	}�
}�
*}�
{�
X}�
{�
{�
�i2�}�
+'{�
(�{�
o�
��r�3p(�z*{�
*s<
z{�
*0Ca{�
�3{�
(6
3}�

+s�

{�
}�
{�
}�
*(�
*.s���*(H
*s�*s�*s�*s�*s�*s�*"s�*s�*"s�*s�*s*s�*N��
s�
s�*N��
s�
s�*N��
s�
s�*N��
s�
s�*N��
s�
s�*N�s�
s�*N��s�
s�*N��s�
s�*2s�s�
*2s�s�
*V��%s��s�*2s�s�
*2s�s�
*V��%s��s�*Z��%s��s�*s�*N��
s�
s�*N��
s�
s�*sx*"s{*�~�%-&~��	s�
%��s�
*&o�
*�~�%-&~��
	s�
%��s�
*&o�
*�~�%-&~��	s�
%��s�
*&o�
*�~�%-&~��	s�
%��s�
*&o�
*�~�%-&~��	s�
%��s�
*&o�
*�~�%-&~��	s�
%��s�
*&o�
*sg*N��
s�
s�*N��
s�
s�*sz*s�*s�*s�*s�*sZ*sd*sW*st*sH*sC*s>*0b����*s5*s7*s/*f(H
}�(6
}�*0{�
�.3
�()	�*0�c{�{�,.\
݂}�{�o(
}��}�+;{�o'

(	o,	o
	}�}�
�-�}�{�o
-�()	}�
�('	�*��n}�{�,{�o
*{�*s<
z{�*0Cd{��3{�(6
3}�
+s&	
{�}�{�}�*(-	*.s0	��*(H
**o<�*o=*o;*o<*o=*o;**o<�*o=*o>**o=�*o?*.s=	�*(H
*
*
*
*
*
*f(H
}(6
}
**0�e{
{E)\*}{�o�
s�}	}*}{�o�
&{�{�o�+}	}*}*{	*s<
z{	*07_{�3{
(6
3}
+sC	
{}*(I	*BSJBv4.0.30319l�~#~x�#Strings�"�3#US,V#GUID<Vh�#BlobW��+	�3��J	����e�8�BG�nf 8ZTM�HN�O�uLڀgMlc�Mlc�Llc�Mlc�Nlc|Nlc�NlcMlc�M�SLJ��N�\#M�R��\I�\�L��J$�J$��\L�@�\<w��J$�?�<M^�\J$�|
^���
��i�\�N�\�J$"J$�J$�J$
�T���Mlc�J$I��\+J$��|Q�CJ$�z�i�\/p��Tz��J$�N�)��L�\7#�n7#�nej�n7#�tejej�_�\�fj�g�\X)��G�\G���s
��?�\@�'s�KQ#@�3s��m�o��:j
9d��t�\�s)��MejO]�\�\@R�l�bӝ�b9N�\7i�\pi�\�j�\yrjL�p6LxpJ��l�b�KIY�LIY*Oej�<�m�@�m���m�K�mK�\7��\CW�\���m
Y���eQ#[nj���Zun7#�n�Z
Kb���:Q#hrQ#�Rej�mz��J$#J$��\��|��\��c��|X�\%�z���\�\�F�\�?�\�LIYoRejh]�\�J$�Od'�|�cz�
Jz�Nej�J$�'ejZRejcejhNejz�\�(�\^tej�nej@sej�]ejE�\���mq]�m%�lc%i�\�h�\7g7#�f7#Jf7#�i�Khej�lej�ejtH�m�g�\�f�\�?�mIT�\~g�\�o�\^�\�|z�n�\DJ$�*Yi��\��m�IY�llcQ@�\`]�\qZ�\���\ZO�\7@�\��\��\YO�\u@�\��\]�\��\dj��>@�\�q�\���m�p�mHw�\h�\QR�wY�ZdQ#YrQ#S���cz�<��ZS�\Li�\�i�\MgJ$|@�\�|�\�?�\9��mrf7#�Rejm�be��\�V�\�f�\>�m�G�Z�V7#��ej����q��cz�#��Y��I�����I���I���x���t	Q���I�����D����ȋ��!��Y��I"��Y��I'���I(jq��I.�7q��0�,���I1����&5W���I:Yu���EA���II�R��IPp��I"Wm���I#]���I%c𜐏I&g���I*s����D,�5u��I.��P���I4��F��I6���tF�@u��IH���R��M��pu��M���K��M������M��'���M���v��M����tM�Z��IO��q��IV�*u��IW��K��I]�I��
d
�<��If
�Y��Um�p��Iq  g���r �h���r"�q��Is*�v��Is-�H��U|B �i����B *h����G �h����K �f����Q ci����U �g����[9���I�aKu��I�f�j���I�qQ���I�}�W��I���hW����&=��I����Z��I������I�	,���I��
[�����[���,���I�����
�����I�"��Z���(�]����*����I�,��[���2�n����6�[��I�A�J[���JC���I�L[��I�SX[��^�Y�g[���`w[��b�a�7[���j@[��f�k�Z��^�q};�j�{��c���;�z��7��I���;�~���;�����L����b;����o;�I���G;�����9;�����n�����;�I���h����.������=�I�� �c�����;���bg����;����oy~I�
�oy~I�doy~I�&�oy~I�.�|oy~�2$oy~I�5Boy~I=	oy~ID��o#~K��#~Lj~#~IM��G#~I
f[`D�f��_D�jnD�n5`D�v�B$D�I/D�I��_D�T��_D���aD�,��`D��ND����`D�,��/aD���{`D�,��WD���eD�,�(aD���`D���5aD�I��qD�I��`D���n`D���`D����D�,�`D�� ��`D�T!�E`D�,!��`D��"�aD��"��]#I"	�]#I#��U]#&�XV]#&�[U]#I&�]#
& ��]#
(%�]#
*'�$]#,-�$-I,.�$-I,0�$-I.6�$-
.8�$-I.9�U,�I1?�U,�I2D��,�I3Iq,��5NDV,�h6PV,�h9XbV,�I:[2U,�I<_�HU,�h>e�U,�h>iwU,�hBvU,�ID{�m,�
E��wq,�IG��T,�IH��p,��I�'q,��J�V;��J��U;�hJ��sV;�hJ�.V;��J�����aJ���aIJ��c�aIK�A��aIN��R�aIS���aIX����aIY���a�Z���a�Z�$R�aIZ���W�a`�Ye�aU`��k�aIl����am���aIm��c�aIo^�aIp.��aIt<Il�a�uDl�aIuK�W�a��Wh(jU�ZOt(j:�^!U(jh�c}t(j>�h�(jB�l=p(jI�pt(jN�lt(jR���t(jU��ts(jV���s(jZ��<t(j^���s(jb���t(jn���|(jU��#t(jr���s(jv���s(jz���s(j~��W(j����(j���fh(j�����Y(jI��_v&cI��9}&c���X}&c��?&c���e&c����@&c���~}&cI��b&c���&cI��u&cI�	v&cI��u&cI�!�u&cI�&�u&cI�+]&c��0"v&cI�69v&cI�=�v&cI�B�u&cI�GMv&cI�Lsv&cI�Q��&c�V�f&c�X��&c�Y�&cI�Zm&cI�\e&cI�c)&c��j>&c��p#I�r!"$I�s�	I�vI�~!(I��1I��DI��I��!"$I��!"$I���I��� I��!"$I�!"$I�tI�� I��I�!"$I��I�bI��I��I��I�!"$I�
!�[
&��
,�}!I2�l
:��
?��II�W
J� 
W��!
\�
k�Ip�!"$Iq�!"$Is�!IIv�R
x�
��!"$I���t����I��
�.I�
��
�!"$I�
f
�� 
�5"
�
�^

��I�!"$I�
��
�>
�!�FI�#!"$I�%"
�)�I�+�I�-m
�/F!
1�"
	3
5�I7"
?!"$I%A
.Z
(E)rI,H� 
-K

3M!"$I9O�	I;R%

@Z6
P\�
T^� 
Y`�"
ab&Ihd!"$Ijf
mj�

xl�"
}n"
�p� 
�rB

�t!"$I�v�
�|bI�~�
���I��6I��vI��xI��
���
���
��DI��I��!"$I��!"$I��`I���I��`I��!I���"I��� I��!"$I��!"$I��!"$I��qI�!"$I�
I��
I
�I��I�TI�I��I�yI�!"$I��I�� I�!"$I%�I(	PI*KI1!"$I2�	I:
t:
@(mIO(_IZ:I_@!"$I`B]�IbE!"$IcR!"$IhX�	Il]&IqewIrg�Iyo�I�x�I�yZ!I�{DI��DI���I��!"$I���I��qI���I��!"$I���I���I���I���I��!"$I��!"$I���I��oI��SI��+I���I��bI��
K����I��!"$I��I�&	I
�/	!"$I�/	!"$I<	�%IC	V��� 95/Y!{38Y!�,<Y!:9FY!�7MY!�1<(!�3�!y)RY!�9>!�* !�)<(!6WY!c)RY!ym�V��C V��v V�*w`Y!�6cY$kY!i5oY!e-|Y!7�Y!�* �4�!i5�Y!�* !y* !�-�Y!�- !},�Y!2�Y!4�Y!�6�Y!�8�Y!�8�Y!ym
66��YQ��^`Y1jk�,�, !ym�
!�2�
!�-�Y57�!�-�Y!�- !},�Y!y* !S6�Y!2�Y!9�Y!�* 1�W�Y!:�Y!�/�Y!m2*!�9FY!]9FYQ�S� Q�?� Q�.� Q�^D Q�zD Q�b� Q��D Q��@ Q��@ Q��@ !c)p!�-\!y* !�-�Y!S6�Y!�7MY!2�Y!�8�Y!j4�Y#8RY�)<(!�* �0�Y!t6�Y!�/Z!4dZ1*Z!y* !-6Z!�-�Y!�- !},�Y!2�Y!y* !�-�Y!�- !},�Y!�- !I: Z!2�Y)���j�!�7MY!
0%Z!:*Z!�3�!�3/Z!�/�Y!:9FYI#>V��a ZV�S ZV�X Z!�88Z!N+ �* �+�Yt/EZ�0 &0JZm+ 
0%Z�. , I#>V�3G�YV��t�YV��J�YV��m�YV��m�Y!"�OZ!:9FY!�7MY!�- !I: Z!�7MY!2�Y1NGUZ1�aUZT]YZ�I^Z�F �0 �+ �- !R4cZ�)<(1. Z!#5lZE0tZ�7yZ2+ �/EZ!t6�Z�*�Y�3�ZQ5�Z!�* !�3 !t6�Ze-|Y6�<�Z6*\�Z6O\�Z6?\�Z17\�Z6F\�Z6�}�Z6�}�Z6�}�ZV��A V��A V��A Q���`Y15�Z!\8�Z!u8�Z!�* !�,�Z1um�ZV��[ V�[Z V�dZ V�;W V��� V�J !v.w1k�!/:�Z!�+�Z#2�Z2-<(a.>!
0%Z!�( !)�Z!/) !K)�Z1ʉ�Q�ƛ 1��ZQ�5& Q�UK Q�UK Q�uK Q��� Q�͡ Q�� Q�� 1ʉ�S�B �8 �9 !(B !�4�Z�8 �9�Z*<(1
l�,1e$:�9 94
[�7[�+ e-|Y!n7[!57[=, [�/ T��B �88Y�,<(�7[�+ e-|Yn7[57[�4��* !/:$[1c:�V�ޠ Q��P Q��� 1ʉ�1Pk�,1��1[!1�,Q�7B 1Pk�,V�ޠ 1Pk�,V��P 1Pk�,!1�,!/:D[Q��C Q�fC 1Pk�,!1�,V�ޠ 1Pk�,!1�,!:�Y�2O[1*S[V�
X V��[ V��u V��p !�ae!;8w!�0`!�5X[1*�!u$][!�5i[V�IB !�}~!�.r[!$/ !�/{[!�a�[!�0`S�'�`Y1*�[!�0`!�,w!�a�[1*�[!4��[!�V�[!�=RY�?�[!�=RY!�V�[!�V�[!�=�[!�V�[!�=RY�7<(H.<(V�w �.<(*3 !�1�Y!�1�[!�9�[!y)i��8YY/ </ !�1
[!|P�[!$/ !�,�Z!�+�[G- 1���[�1�[�.<(/ !�1�[�2�[!�.�[͎�[$�[6�\!�1
[�* !�1=#!�5
\!�4\!�5\�* t/EZ�/EZ!R4(\�4-\!y* !�-�Y!�- !},�Y!2�Y!�-�$!S7=#:�2\!�67\�6J\t/EZ�* !K*Q\I#>V�3GJZV��FJZV�;JZV��JJZV���JZV�KJJZV��JJZV�yJJZV��<JZV�JJZV�ՂJZ!0* !ym�%!�1�%!ymV\!�7w!�7w!�7<(!8<(!�4}(S�zE S�eE S�E S��D S��E S��D S�E !t/a\!�.k\!a,�Y!(1k\!E1k\!h1k\!&0JZ�5J\V�vF V��D V��E V��D V�(E V�=E V�F V��E V��D V�)F V��D V��E V�E V�:F V�=H V�,H a3s\#, �7[�2[!�.x\U2-Q�E Q��^`YQ��^ V�E V��E V�dF V��F V�H^ V�l^ V�^ V�^ V�0^ V��] V�Y^ V�}^ V��D V�MF V�F V�OE Q�E V�l�`YV���`YV�nB V��B V��B V��B V�RB 1�k�,!�2�,!|- !92>!�0>6S��\6���\6ˀ�\6���\1*�\!�) !#5lZ!�) �7[a3s\1*�\1*�\1*�\1*�\1*�\!�.x\!N+ 1*�\1*�\1*�\1*�\1*�\!3�.!�.�.!3�.!�.�.!�,w3 �\3��\6�"�\�]�K>D��Y�%>�%]~%]�>�>1����06�"�/!0#N0�K>D�w�%>1��,���
0�v��v�{{0t�&;�w6�"]�]6�""]+']�9];']�B]AV]\']
e]֎y]�K>D��[b�kY{}]�]�>6�"�]��]6�"�]��]�K>D��]�%>b��]�=Q\�=Q\{�]�]��]�K>D��]b�^�>��Y6�"^?^b��
�\wb��
�\wb��
�Pw�Y Z�Y Z6�"^i^�'^('^�K>Vp3^��MYb�A^E^�K>Vp3^��MYσ8Yb�A^E^�K>VpS^��MY�%Z]^
�5�K>D��Y�%>՜b^Мb^�(k^�(k^{u^�K>Vp~^K��^b�A^�^�K>Vp�^b�A^K��^{�^�%Z�^��^��^
�^K��^�K>Vp�^K��^b�A^�
�^{�^�%Z�^�d
�5��^��^��^�K>Vp�^b�A^�<d�5�K>Vp�^�<db�A^��^��^��^��Z� � �^�5
_�!	_�_�C;�K>Vp�^b�_�<dC;t�_6�"_� _6�"(_-_#=_6�"p5��5�K>Vp!K�w�I/b�*��5�5
6g�Z}�Z6�"O_;T_$��Z$��Z�V X�>�}�K>Vpd_כ b�p_HJ\�	_�u_z_
_�K>Vp�_b�p_כ �_6�"�_��_��_�K>VpQכ �ib��_�_�K>Vp�_b��_=<(�P Vl ��Y��_�	_��_��_�
[�5.�_�K>Vp�_b��_�P Vl =<(�
[�5�K>Vp�_b��_�<d�	_z_�K>Vp�^Vl ��
[.D b��_=<(�P � 5
[� �	_�u_z_
_.�_��5.D 6�"�_?`�K>Vp�^.D �r�_�V �`�:	_�r�_�
`Q��_`��Z�5�K>Vp�^�r�_�F �:	_^m`T�_u_z_
_�K>VpQ�[.`b�3`�_!�} !(B 6�"8``�=`�K>VpQb�M`�i�[R``�W`Cj`�}`�`�i�i�K>VpQ�<db�[�iC;�K>VpQb��`�<d�iC;�K>VpQ�<db��`�[�^�i�	_R�`�8Y�>��`�`�K>Vp�`�:	_b��`z_�K>D�u_�%>�nu_�nu_�K>VpQb��`�<d�iC;6�"�`��`�`&ޠ &�o�`&��
[KalZ6=�`�K>Vp�^���b�Q\�<d�5�K>Vp�^z��`�<d{�`�56�"�`�a�K>D��[�%>�nu_�nu_�K>Vp�^�<d� YalZlZ�R`lZ� �aa.!a�! �" <(
)a�K>Vp1a�[R`>a�K>VpLa�[R`�< �`�K>Vp�^�<d�lZ�	_u_z_
_�K>Vp�^�<d�lZ�F �	__� Ta6�"gajlala�K>Vp�^� �<dYalZ�lZ�a��a�>� _�K>Vp�_�<d�	__�K>Vp�^�<d� YalZb��a�lZC�a�J\��a��a_�K>Vp�^�<d� '�
[`lZ�	_�u_z_
_�K>Vp�^�<d� YalZ3lZ�	_�_�!a� _�K>Vp�^K��ae%Zb�S[*b�Y�^6�"�a?�a+�a;�a
�a�K>Vp�^�<dK��ab�S[{�^&b+��b_
�5�b��Y�K>Vp�_�<d�	__K��a�K>D��]�%>�<d�<d��b��b� b�>�'bтy]��lZ�K>Vp�^?�1b�:b�
>b�<d�?b{Cb�Mb�Vb��Y�[b.hb�!qbvb�K>Vp�b�?b3Z_�<d�5�K>Vp�^?�1b�<d����5$�Y$�Y6�"�b��b6�"�b�b�K>D� �%>b��bg�Zb��b�K>D� �%>�K>D� �%>�K>D��[b��b�K>D��[b��b{�b6�"�b�b6�"�b��_g
 _6�"�b�b1*�b6�"�b��b�K>D��[�%>b��b�=RY�=RY�K>D��[�%>�=RY�=RYb��b� }��[$ uc�J\�c�Tc�B 6�"c\ cu2c�K>D��[�%>b�=c�=RY�=RY{Bc6�"Kc�Pc�Zc�F b�dc�K>D�ic�%>�=RY�=RYb�dc{�Z}mnc6�"sc�xc�
�c�xcj�c'xcSxc` xc�K>D��[�%>���c���c{�cV�HA V��C V��� V��� V��e V��� V��P V�I V��� V�"D V�tQ V�' V�} V�+� V�4m !�* !�* !�9<(!�+�c!-<(!E3�c!�)<(!�6�c!�1�c!`0 !�5�c!�* !�)<(!.�c!+ !-�c�l�c6�"�c��c!ӟ�[6�"�c(xcR�c�d�d6�"d�
xc�d�xc�K>D��[�%>���c���c�Pw�K>D� �%>)?0d$?0d{8Y�>�K>D��Y�%>b�:d��MY��MY�lZ�lZ�lZ�lZ{?d��MY�W�Y�Hd�K>D��Y�%>��MY��MY�=/Y�=/Y�
Hdb�:d{Md�Pw�Pw�\2\6�"Vd�[d�K>D��Y�%>��`��`b��Y��MY��MY8Y�u^�K>D��Y�%>b��Y��MY��MY{u^�w6�"�&U}&�\&�\&�\&�w6�"md�rd6�"�(��(�Pw�K>D��[�%>b�|d�=�[�=�[{�bc�[��d� ��Z�K>D�{[�%>�\{[�\{[�n-�n-u$-�t$-�]�d�]�d{�d�K>D�{[�%>u$-�t$-�n-�n-�]�d�]�d�K>D�{[�%>�n-�n-u$-�t$-{�d�>�= �n-u$-�K>D��G�%>�n-�n-u$-�t$-{�G�>6�"�d�
�dd�d=�d��d;�d&�d�K>D��Y�%>�=/Y�=/Yb��d{Md6�"�d��d��dc�d��d@
�d��d��d�
�d��d��d~�d6�"�d` _\ _
 _� _i _�K>D�{[�%>b��dP ����d` ���ex ��|$e� �	Մ;e	� ��Ee	� �z}q
� ��JPe
� �	:�[e
� �	�ce
� �il 
!��#	
!��|�&!��~ie.!�VI	5!��|oeN!��#{eV!�ߟ�^!�ZW�eq!�VI	�!��|�e�!�	�@a
�!�	5' �!�	2��e�!�	�#{e�!�逞e�
Մ;e�
:�[e�
�@a
�
5' �
2��e�
�#{e�逞e�
�ce�!��V�eL"�9��e�"�9��e�"��&�e #�&W�e"9#��&�e$W#��&W&l#�gP�(�#�gPZ	*"$��|�,4$��|D,<$��|,P$��Jf,(%��|.��Jf.0%��Qf0(&��Qf5p&��f8�&��"f;	'��|�>'�5�+f@&'��&4f@4'��&:fAB'���DfBK'��|KfCp'�p�dfGx'��TrfG�'�F�xfG�'�	�@a
G�'�	5' G(�	2��eG�(�	�#{eG)�逞eGI)�~V�fHd)���fIx)��|�fJ�)��|�fN�)�0�ieS�)�H��fS�)��|�fT�)�p��fV�)��@a
V�)��|�fV�)��|DV�)�	y��V*�	_\�fV�*��|�fW�*�	>a
[�*�	oWg[�*�	�Va
[�*�	I
g[�*�	�mg[�*�kg[+��:g[�+���$g\�+��R/g\�+�,><g](-�DUg`M-��|c`-�Y�cgch-�{�pgcp-��&}gc.��|�ge%.��|De-.��|eK.��|
e_.��&%fn.�Յ%g|.�UQ�h�.�;Ka
i�.�HKi�.�΍�gj�.��Sa
k�.��S�gk�.�HS�glL/��}�
o�/��S�gqH0��S�gs�0�HO�gv�0��|x�0�}�gx$1��|
x>1�q(1yF1�	y��yS1�	:� yV1��l�
yh1�UQ%{�1��|;|�1��|D|�1��&�|�1�n}�1�Յ%}2��:~L2��&�2��|�g��2�oW�g��2���ie��2����f��2�VI	��2��|�f�,3��|�g�J3�	oWg�R3�	�Va
�Z3�	I
g�b3�	>a
�j3�	Z��g�t3��Sa
�`4�	�mg�h4��|��x4��|��4����g��4�	�@a
��
ZW�e��4��#	��4��#	��VI	��4�h�h��4��|�d5�v���5��k6�bh�s6��ph�{6���[e��6���[e��6���h��6���$h��6���9h�7���Ph�\7���jh��7���h��7�7%�h�<8���h��8�7%�h��8��[�h��8����h�9��j�h�!9��j�h�19��ji�D9�,�
i��9��ji��9��ji�:��j$i� :��$-i�c:��;i�|:��[Ti��:�rIZi��:��Iki�4;�1R��;�8G�i��;�f%�i�<�2��i�d<��g�i��<�3$�i�D=�H�i��=�}�g�>��|�?>��|�i�_>��|���>��|�i��>��#��>�ZW�e��>�VI	��>������>��#e��>��|�i�?��|�i�O?�	>a
�W?�	oWg�_?�	�Va
�l?�	I
g�y?�	Z��g��?��ce��?��Sa
�L@�	�mg��
Z��g��
�Wa
��
�i��
>a
��
oWg��
�Va
��
I
g��
�mg��
�@a
��
ZW�e��
(]a
��
�d�A��
�@a
��
aG
g��
<_j��
4ka
��
5ej��
Ca
��
�Ga
�T@��|
j�v@���j�~@�ZW�e��@��j��@�VI	��@��#	�A��|j�0A�!�{e�8A�,�'j�AA�5' �IA�@'�RA��@a
�ZA�Vf
�bA�df�1�kA��.j�sA�8b8j�|A��?�i��A��<>j��A�V�Dj�TB��=Nj�DC��rUj�C��|��C�}�g��C��|�f��C��|�f�'D�	>a
�/D�A�cj�7D�	oWg�?D�	�Va
�GD�	I
g�OD�	Z��g�dD��Sa
�xE�	�mg��E�Koj��E��|�j�:F�	>a
�BF�	oWg�JF�	�Va
�RF�	I
g�ZF�	�Wa
�bF�	�i�jF�	�mg�rF��ce�zF��d�A��F�h��j��F��~ie��F��~�j��F�bh��F�:�[e��F��|�j��F��[�j�G��[�j�G���j(G��Y�j`G�`��j�G�`b�j�G����j�G�{l�jH��|/H��|7H��|@H��|YJH��|a
TH��Ba
\H��|dH��|mH��|k
|H��|k�H��|Y�H��|�H��|a�H�V�#kI��=-kHI��|PI�	�@a
XI��@aI�	aG
giI�jG4krI�	<_jzI�H_;k�I�	4ka
�I�<k�I�	5ej�I�GeBk�I�	Ca
 �I�C �I�	�d�A!�I��dIk!�I�	(]a
"�I�5]"�I�	�Ga
#�I��G#�I��J$�I��Sa
$J��|$J��|$J��|$J��|Y%&J��|4'IJ��|a)SJ��|+[J��|+dJ��|Y,nJ��|a.xJ��|0�J��|0�J��|Y1�J��|Pk3�J��|Wk5�J��|a8	K��|:K��|:.K��|Y;8K��|a=BK��|?JK��|?SK��|Y@]K��|BuK��|akC�K��|aE�K��|G�K��|G�K��|YH�K��|jkJ�K��|skM�K��|aQ�K��|kSDL�	:�[eVLL�	�ceVTL�	Մ;eV\L��#	VkL��|�kX�L�	�Va
Y�L�	I
gY�L�	>a
Y�L�	oWgY�L��Wa
Y�L��iY�L�	Z��gY�L��ceY�L��Sa
YM�	�mgYM��Q�kY(M��Q�kZ,N��Q�k\DN�Y�k]�N�@$�k`O��r�kaDO�lS�kd�O��S�ke8P��X�kf�P�}�gg�P�4�kg@Q���kg�Q��|g�Q�tp�kg�Q��I�	g�Q��I�kgR�T�khR�E?�kh,R�&�khBR�Ң�khXR��#�khnR����kh�R�k��kh�R��T�kh�R��>�kh�R�<��kh�R�ga�kh�R��n�khS��(�khS��P�kh4S�я�khJS�x]�kh`S��a�khvS��]�kh�S�P�kh�S�<�kh�S�&S�kh�S�2T�kh�S�0<�kh�S��r�khT�)(�kh&T�I(�kh<T��O�khRT�_O�khhT��'�kh~T��'�kh�T��:�kh�T��:�kh�T�Q�kh�T�)Q�kh�T�w(�khU�S<�khU����kh.U�Y��khDU��e�khZU�PH�khpU��'�kh�U��p�kh�U�9>�kh�U��i�kh�U��C�kh�U��#�kh�U�wb�kh
V����kh V�&�kh6V����khLV�K'�khbV�f�khxV��Q�kh�V���kh�V��>�kh�V�݉�kh�V�xZ�kh�V�I�kh�V�"�khW�8�kh(W���kh>W�Ċ�khTW�	�ia
h\W�	�iheW�	�Ca
imW�	�CivW�	�%a
j�W��%j�W�	�Wa
k�W�	�WkX���klX�	' lX�	'lX�	_Y�im!X�	iY�km*X�	���kn2X�>a
nOX� >nqX��eloyX��elo�X�	�lp�X�	�� lp�X�	�Aa
q�X�
Bq�X�	x_jr�X��_;kr�X��,ls�X�f>8ls�X�|>=ls�X�	T~Clt�X�_~Ilt�X��Sa
u�X�@�,lu�X�K�PluY���]lv Z��|x�
�ia
x�
�ix�
�Ca
y�
�Cy�
' z�
'z�
�Wa
{�
�W{�
_Y�i|�
iY�k|�
�%a
}�
���k}�
�l}�
�� l}�
�Aa
~�
x_j~�
T~Cl~}Z��|~�Z��|il��Z�Aa
��Z��}a
��Z��{l��Z��Trf��Z��T�l��Z�V��l��[�V�J�\��=��h]��A�l��]��A�l��]�"P�l��]�P�l��]�P�l��]�,N�l�!^�gP�l�D^�9P�l�L^��O�l��^�UP�l��_�t��l��_�}�g��c���l�dd��|�l�sd��@�|d��#	��d���d��|�l��d��|�f�1e��|D�9e�	y���be�	_\�f��e�g��l��e�y\m�� �m�� �m��@O&m��$�Am��e��|���e��@a
��e��O0��e��#	�f��^Sm�f�gP_m�#f�gPgm�4f��\om�\f��\um��f�}�g�g�*[+�#g��|?�7g�w�r�>g��?����?��\g�}�g��w�r���?����[{m���[�m��g����m��g��[{m��g��[�m��g��&�m��g��&�h�h��|���:3���:�m��<J��
�d�m�1h��|�m�hh�ۜ�i��FC�
i�n�m�i�n�m�i��Q �#i��Q�,i��Z��4i��Z�@i��W��|i�K&���i��|Ik��i��d�A��i�	�d�m��i�w�r��i��?��j��:3�j��:�m�9j�<J�Gj�K�m��<��m���n�m�Tj�;a
�\j�U0�dj�Qa
�lj�k0�tj��|�m��j��#	��j��^Sm��j�w�r��j��?���j� �m��j� �m�k�Kn�k��|�k��|?�$k�<��m�pk��n�m��k�w�r��k�Kn��k��?���k�}�g��@Om�Cl��|?�Ll�@Om��l���n��l�gn��m�K+n��m��:4n��n��X@n�9o��?��Ao�}�g�@OGnTo��|?]o��?�eo�@OGn|o��:anp�ZG�k
 p�Kmn(p��|?1p�Kvn
<p�@O&m�p�$�Am�p�w�rq��?�hq�-�n�q�٠�nPr�TD�n#�r�}�g'3s��a
';s��'Ds��[�n(�s��|+��&+�s���a
-�s���-�s��[�n.�s��|1�s�2��n1�s��|o1t��Fo3t��|�f4+t��|D43t�	y��4@t�	_\�f4Nt��a
5Vt��5_t��[o6�t��|9�t���0o9�t���Do9�t��< :�t��<:�t��[Yo;u�NO4n>8u�NOqo@�u��|B�u�}�gB�u����oB�u��[�oB��[,;D�u��|Gv�}�gGv���a
G%v���G.v���oH6v���oH?v��[�oIlv��|Ltv�	��oL|v�	���oL�v�	6Da
M�v�	EDM�v�	�TrfN�v�	�T�lN�v�	��oO�v�	���oO�v�	���oO�v��H�O�v��HO�v�ba
P�v�bP�v��$�oQ3w��|S;w��qSCw���oSLw�YJ TTw�iJT`w��[�oU�w�-�pX�w��:pX��#p\Px��r*p]�x�F%3p`y�ވBpay��|b�
��ob�
���ob�
6Da
c�
EDc�
�Trfd�
�T�ld�
��oe�
���oe�
���oe��$�oe�
DkOpg�
���g��~Upg�w�lpk�D�pn'y�	��oq/y�	���oq8y�	6Da
r@y�	EDrIy�	�TrfsQy�	�T�lsZy�	��otby�%��ptky�	���ousy����pu�
���ov|y��$�ov��[�ox�y��|z�y�0�iez�y�H��fz�y��|{�y��|Y|�y��|~z��|~*z��|~Xz��@a
`z��@iz�q\�p��z����p��z��&�p��z��o�p��{��J�p��{�Z�p�D|��&�p��|��T�p��|��#�p�}�(Zq� }�(Zq�M}��|�`}��q�g}��X���}��|��}��|�p��}��|a��}��|%q��}��|,q��}��V�p�T~��Q�j��~�6_7q�0�6_Dq�8�0W�p����&���W�p�����:Nq���}�g�������o����[�o�]���|�e���|�m���|�v���|������|Y�����|Xq�����#p�����|����	DkOp�Ɂ�	����Ё��~Up�$��w�lp�+��D�p�\��3�bq������sq����[�q����q���cm�q�!���t�q�;���<�q�S���<��k���_�q����+A�k�̃��V�q����|�$��}�g���	DkOp���	�������~Up�`��?=�q����o��k�ԅ�n'�q�'��w�lp�0��D�p�s���|�{��}�g����	DkOp����	��������~Up����w�lp�T��D�p�l��w��q�����|����}�g����o������w�ie���	��a
�
���|��o����w�ie��
��a
���	DkOp���	����!�����q�,���~Up����w�lp���D�p����|�9��}�g�K��	DkOp�S��	����X���~Up����w�lp���D�p1���|	D��}�g	a��	DkOp	i��	���	l���~Up	���w�lp
NJ�D�p���|��}�g�d��q�d��q���|<��h�hD��Fq�qL��Xq�qU���<r\��d��q���d��q��d�r�����r d����)r#̍��T5r$����Ar%p����Lr&����Yr(����_r)����ir+����sr-��Z�r/������r2���#�r6h��Z�r:����r=���r@��v�C���}�gC����|C����|kCĔ�eIsDu��n�sE|���|kE����|F���eIsF�eIsGߕ�c�+H���j�H���|sH���|�J���|�M;���|�GPN��eIsT���n�sV�����(V����|V����|kV����| sW����|(sXΖ��|/sYޖ��|=s[��eIs]��n�s_(���:�G_L���m�Gap��u�Gc����|e����<Ce���V�me����=�g���}�gh͗��|Hshܗ��|Vsi��n�sk���eIksk���|l���|kl"���| sm+��eIsnD��n�soK���|koi��Ņpspt��eIsp���)�zsq֘�V��sq��V�Jr4���=�sؙ��|s���|ks��eIstN��n�svU���|�vj��eIsw���n�sx���eI�x����|kyӚ��|z���]�sz��V��sz��V�J{L���=�|���)�zs|�n�s|$��B��s|h��q��s~���P��s�Μ��|k�ל��|���eIs��eIs����|�6���^a
�@��eIs�|��)�zs����V��s����V�J�ٝ��=�����|����|k����eIs��eI��*���|�s�H��8b�s�P��V��s�n��V�J�����=�����eIs�ў�)�zs�ޞ��|�s����|�s����eIs���n�s�(���j��0���|�?���|k�O���| s�X���|�s�n���|t�����|t����eIs����n�s����΍t����΍%t�ş�΍.t�͟�΍5t�՟�΍>t����Ks�t��eIs��)�zs�w���|����<Et����V�Kt�����=Ut�����|����}�g�����|�����|k����eI�����n�s�Ơ��j��Π��|�ݠ��|k����|�s����|t���eIs����n�s�����|�����|k����eI�����n�s�����|������O+�ȡ�eIs�ա�)�zs���l=���l��L��V�J�Z��V�H�}���=������|�s�����|�s�����|\t�Ǣ�eIs���n�s�����|����|k�	��eIks���n�s� ���|�(���<qt�/��V�J�:���=��=��eIs�@��)�zs�I��}�g�U���|�]���| s�f���|k�o��eIs����n�s�����|k�����|����eIs��eIks�����|�ң��|wt����|y�����|����	y�����	_\�f�)���|�f�8���|D�@���|~t�t��	y������	_\�f�����|�f�����|D�����#�t��]�t���#�t�Ф�	p? �Ԥ��li��]�t�����|����|�t�2��	y���?��	_\�f�]���|�f�q���|D�y���|�t�����#	�����|~t���	y������	_\�f����|�f����|D����#�t��.Ks�-��.Ks�K���|�S��Y� �[��f��d���Z �l���Z�x��.Ks�Ц��|���.Ks����|���.Ks����\ ����\�%���va
�-���v�8��.Ks�����|�Ч�Jm.j�ا�	p? �ۧ��li����#�t����|�#��Jm�t�+���li�9��	p? �<���#�t�̨��|�ߨ��|�t�������t�����#�t����#	�%���Sa
�[���|�m����]�t����_a
���!_�
���^a
����^���Jm�o&��]�t@��t��t���|0��]�tH���Ou����|����|�Ǭ��^a
Ϭ��O0׬��#�t����Fu
���Qa


��R
��	p? ���li����|
���]�t
����u�]"uҭ��|ڭ�Jm/u��Rm?u���] ���]����^a
���^
��]�t���ul����Pu���]"u����p]u����|��}�g��Jmcu���pou ���puu)��]�t@���|^���]|uf���|y���|�u���	p? ����li[���|�u�]�tk���|s��}�g��Jm�o���	p? ����li����#�t!ݲ��|$���|$����@a
%���@%��]�t&(��aB�u'T��]�t(|���|)���y��u)����|*���$�u*T��]�t,ȵ��|-�y��u-е���u.(��]�t/����|0���y��u0����|1�
�@a
1�
�@1�
<_j2�
H_;k2�҈�u3���u6���qmh#:����|:ȶ��|+:ܶ��|�$;���T%<!��V��#=?���|v>Q��V�J>���=�?����|D?�����v?�����vA����|/vC ���:vD(���EvD0��̆PvD8��	y��D]��	:� D`���|[vD����|DD����&evD޸�nE��ՅlvE-���lsvF4��UQlvH���	�@a
I���	�@I���	<_jJ���	H_;kJ���T_jK���f_;kK����|vLĹ�恂vL̹��vLع�҈�uM�����uP��@��vT��R��vW���vY1���vZD���T�v[���Y?�v_����v`��|Qwc3���|eF���|wev��	>a
i~��	oWgi���	�Va
i���	I
gi���	�mgi����|J+i���JX�$jļ��T%jռ��|k���|�$k��c�h#l��T%l�n�&wm���|m%���|�$m0���T%na��n�&woh���|op���|�$o|���T%p���n�&wq����0wq����DwqĽ�'�Jwqڽ���Qwr���Ywr��<_js��H_;ks����@a
t���@t
��~=bwu����hwu�����hw����pwx���`b�wzH��rIpw|f��rI�h~���	��wɿ��|��[>�w����|���=a
�	���T&���V��w�7��V�J�e���=��x���Sa
���T%�����|����	y������	:� ���/l�'���_\��'��	_\�w�:��	h\�w�O���|�&�����|D�����&�����>�w�����>�w���n���Յ�w����l�w����UQ�w�����Q�w���䛧w�*��D��8��q\�:��,;Y&�X��gPZ	����	y������	:� ����	��w����	��w����	_\�w����	h\�w�����b�w���Z&x�t���&
x����n����Յx�����l'x����UQx����Յ6x�����l=x����UQ6x�����&j�D���wFx�Q���|Vx�c���|D�k���&�w�{����&����UQ&����gP`x�����|�����|�����|�����|�(�`��c�+�h����+�p��l� �x���� ����0� ����n ����V�J����V�O(�L���=������T%�����Sa
�z���|�����|-�����|ix�����|������|�(����(�%��0� �T���T%�����|�����|�
�����||x����V�J�����=�����V��x����gT&����|�x�E��<_�x�M��(]�x�U���H
g�]��zk�x�e���k�x�m���k�x�u��5ej�����T�x����V��x���V�J�P���=�����|�T��[>�w������]l�����w+����uj�x����~j�x�����|�����K ���~j�x���uj�x���f�
y�,���|�4��ޅQw�<���Yw�E��]�t�N���u�e���|�m���K �p��~jy�x��uj)y�����|�����K ����~jk+����uj3+�/���|�7��}Cy�?��,}Iy�H��Ha
�P��H�Y����o�a�����o�j��Rs�o�r��cs�o�{���]Py���En�*���Pn_y���cpfy���=fy����Wly����|���K ��~jry(��ujy$��?�y	H��4?�yl���>�y���K}�y0���|8���K ;��~j�yX��ujz����|����K ����w+���uj�xK��~j�x f���|#n���K #q��~jz#���uj!z&����U3z+����=z-L���C=z/l���|1t���K 1x��ujIz1���~jYz6����|9����K 9���~jez9���ujrz<J���|AR���K AU��~j�zAp��uj�zD;��N=�zI`��N=�zM���M��zP���pX�zR����X�zT����X�zV����X�zX��S�zZP��N=�z\g���X�z^������z`����_�zb����|d����K d���~j�zd���uj�zg(��^k{l����|n���~j�xn�~jk+q$��uj�xt�uj3+x����w+}����?e+~����Ge+����|�����K ����uj{�$��~j1{�?���|�G���K �J��~j>{�h��ujK{�-���f]{�D���j{�����\j{�@��k;t{�����;�{�H��P;�{�����|�����K ����~j�{����uj�{�r���|�z���K �}��~j�{����uj�{�����C�{����U�{�@����{�����U�{�����|�����|�-����Gr�,����~j�{����uj|�0��s��,����}�g����~j |���uj1|�2�����,�I���|�Q���|�Y���|�b���|Y�l���|K|�����Va
����+n�����f�����KV|����Kc|���Kq|�4��K|�K��K�|�b��K�|�{��K�|�����t�|������|� ���P�|�x���P�|�����H�|����g}���Z}	%���Z}4���Z%}H��}�g���|���<0}��sP6}���jPF}���}�g����|U}����%a
����T]}���Sa
���|�o0�����k8���T]}j���Sa
����|d}���R��v ����|z}!���%a
$��yW�}$H���T�x&V���l�}'k���|�}({����o*������o*��T]}+����|,����|d},���}Cy/���,}Iy/����T�}0�R�2����|3����|3����<�}3���sP�}3��jP�}5��}�g6$���|6,���<�}63��sP�}6J��jP�}8`��}�g9l���|9t���<�}9{��sP�}9���jP�};���}�g<����|<����<�}<��sP�}<��jP]}>��}�g?����|?���<�}?��sP�}?"��jP�}A8��}�gBD���|~Bq���]PyC|���l�}C��V�~D���V�JE���=�F���|F&���Ba
G.��sP~GP��jP%~I���V�.~J���V�JK���=�L���|L���<5~L��sP;~L#��jPI~N9��}�gOE���|OM���<V~OT��sP\~Ok��jPf~Q���}�gR����|R����<o~R���sP�}R���jP�}T��}�gU���|U���<u~U��sP{~U��jP�~W-��}�gX9���|XA���<�~XH��sP�~X_��jP�~Zu��}�g[�sPW[�jP�]��l�^�*� /_��l�`����|a����|�)a����u�.c���\�.c���l�c��V��.d8��V�Jef���=�f����|�~f����u
/h����\2/h���l�h8��V�D/ik��V�Jj����=�k���|�k���O+l��R�l��V�^/mS��V�Jn����=�o���R�o����|p����V�~p��}�gq���|q��3�~q���|s���Jt��ۜ t���	�jt��Ќt��	�0t��xx�~tS���|Dt[���|tc����0tw��}�gv����|v���'.0v���:X0w����|x����Jy��ۜ yh��y��	��+y��Ќy��	�0y��"{;y���|Dy���|y��u*y��|z&�u*zE�}�g{Q��|{Y���~{d�}�g|p��||x�5�~|����e}��Z�~~����~��K�~���f�~���
����|���	�e����|����J�4�ۜ �L���h�	���t�p�Ќ�w�	�0��}�g����|�������}�g����|����*����|����J�4�ۜ ����������	ؙ0��Ќ�&�	�0�0�`{6���|D����|����J���ۜ �F�	��@�N�Ќ�U�	�0�b��|�l��T���}�g����|���I[����|����%�	��|�
	�'	%�&	��|�.	�!%�G	��|�O	�U	`�b	��|�j	�U	`�}	�}�g��	��|��	��g��	��n��	�2n��	�ۜ��
�G���
�ۜ���G����ۜ��
�G���
��|��
��J��
�ۜ �������	���g���Ќ���	�0���yw�3��|D�<�ۜ�H�G��X�ۜ� �G��.��|�6�6	��t�ۜ��G��(�ۜ���G����ۜ�X!�G��h!�ۜ�D#�G��R#��|�Z#�	��h#�}�g�t#��|�|#����#�}�g��#��|��#����#�,���#�}�g��#��|��#��5��#�ۜ��%�G���%�}�g��%��|��%�E����|F���?����?����?���%��|��%�`��&��|�$&��<&�ۜ��(�G���(�ۜ��)�G���)�}�g��)��|��)��&��)�����)�ۜ��+�G��,�ۜ�/�G��/�ۜ�00�G��@0�ۜ�02�G��@2�ۜ�l6�G��z6��|��6��
���6�}�g��6��|��6�����6�ۜ��8�G���8�ۜ�l;�G��|;�ۜ�\<�G��j<��|��<��#	��<�}�g��<��|��<�7���<�����<�ۜ��?�G���?��|��?�?T��?��|�@�?��@�ۜ�,A�G��<A�ۜ��B�G���B�ۜ��D�G��E�ۜ�F�G��F��|�4F��J�8F�ۜ ��F�	H����F�Ќ��F�	�0��F��z���F��|D�G�ۜ��G�G���G�}�g�
H��|�H�	(��H�(��"H��|6��DH��J�i��H��&K���H�HIT��&I��|�.I�}�g�<I�ۜ�TJ�G��dJ�ۜ��K�G���K�}�g��K��|��K��^���K��|��K��J��K�ۜ �bL�	H�u�jL�Ќ�qL�	�0�|L��{h���L��|D��L�ۜ�Q�G��Q�ۜ��Q�G��R�ۜ�0S�G��@S�ۜ��U�G���U�ۜ�PW�G��^W��|�fW��r��}W�}�g��W��|��W�sr���W�#r���W�ۜ�H[�G��X[�ۜ�x\�G���\�ۜ�4a�G��Da�ۜ��d�G���d�ۜ�$g�G��4g�ۜ�0h�G��>h�}�g�Jh��|�Rh�l���_h�I���lh�r]}�th�����h�ۜ��l�G���l��|�m��
���m�ۜ��n�G���n��|��n��
���o��|�o��J�To�ۜ �xq����q�	ؙ0��q�Ќ��q�	�0��q�`{6��q��|D�r��|�r�t	�e�$r��|�,r�	���Dr�ۜ��u�G���u�ۜ��v�G���v�ۜ�x�G��*x��|�2x�,Df�@x��|�Hx�,Df�Vx�}�g�bx��|�jx�����rx�}�g�~x��|��x�K����x��|�x��J�x�ۜ �x�	C�a
�x�Ќy�	�0y��xCOy��|DWy��|_y�,Jxy��|�y��J�y�ۜ �y�	C�a
�y�Ќ�y�	�0�y��xCz��|Dz��|%z��J(z�ۜ Iz�	C�a
Qz�ЌXz�	�0`z��xC�z��|D�z��|�z��J�z�ۜ �z�	���t{�Ќ{�	�0{��| {��JX{�ۜ |��0|�	���t8|�Ќ?|�	�0G|�}�gS|��|[|�Ja|�}�gm|��|u|��&{|�p
��|�}�g	�|��|	�|�!Ȁ	�|��<Ӏ
�|��|
�|�V�ـ
�|��=��|�}�g
�|�}�g
�|��|
�|��
}��|}��J }�ۜ n}�	���tv}�Ќ}}�	�0�}�>|�f�}��|D�}��|�}��J�}�ۜ �~�	���t�~�Ќ�	�0�>|�f[��|Dc��|l�P����|�����������|(����}���|���� ����| ���1�p���|x��@����}�g����|���fM�����|����\�ف��|���J,��ۜ ԃ����	���t���Ќ���	�0��>|�fW���|D_��}�gk���|s��c�{���c�����|���������|Ą��J���ۜ ���4��	јj�<��ЌC��	�0P��Szp�����|D����|���z����}�gɆ��|ц���ن��
z� �����!��sz�"��0��#
��\��$��i ��%���|&8���J'p��ۜ 'ĉ��'��	H�u'��Ќ'��	�0'����{h�';���|D'D���|��'����@a
1����?a
1����Ca
1׊��� 1ߊ�aG��1���P 1���|��1���' 1���'���1��0m��1���ea
1��ޅ��1 ���zs1�����zs1 ��~�zs1���낮�1���W���1?���|��2l���@a
7t���& 7|��WX��7���iAa
7���_Q7����|7����
Ɓ7���}�g8����|8̎�Ձ8���|�9���@a
:#���ea
:5���q:G����q:Y��z'zs:����ea
:����� :Ï��P :؏�
�a
:W���'zs:����'a
:А��lz�:���}�g;����|;Ƒ�1��;ّ�[��<���u=����>���}�g?���|?
���?4���
��@<�����AD���|B^���JC`��ۜ C���	H�uC���ЌCē�	�0C̓��{h�C���|DC���|C���v#C-���|DG���JEL��ۜ E���	C�a
E��ЌE��	�0E���xCE[���|DEc���|E����JF���ۜ F����F���	���gF���ЌF���	�0FĖ�ywF+���|DF3���|F;���|FC����F\���|Gx���JH���ۜ H����Hܘ�	���gH��ЌH��	�0H��ywHO���|DHW���|H_���v#Hm���|Iu���v#I����|J����
#�J���}�gL����|L����/�L����|Mș��JN��ۜ N���N��	�gN��ЌN��	�0N ��ny>�N{���|DN����|N����JO؛�ۜ Oh���O���	�gO���ЌO���	�0O���ny>�O���|DO���|O����&O��}�gP ���|P(��_�&P0���|Q8��'	&Qd���|Rl���&R����|S����&S̞��|TԞ�u&T��}�gU����|U����wU	��}�gV���|V���O(V%���|W-���O(W;���|XX���JY���ۜ YX���Yt���Y���	���tY���ЌY���	�0Y���>|�fY����|DY����|Y���JZT��ۜ Z0���ZL��	\��sZT��ЌZ[��	�0Zd���yH�Zˣ��|DZӣ��|Z���J[��ۜ [p��	\��s[x��Ќ[��	�0[����yH�[���|D[���|[���J\��ۜ \٥�	\��s\��Ќ\��	�0\���yH�\?���|D\G���|\P���	ps\��|F\��?�,^��?R�`��?`�dm���|f����Jg���ۜ g���	��j�g���Ќg���	�0g���Ww�Gg���|Dg��}�gg���|g#��Yt�g+��nt�h3���t�i;���t�jC��Lt�kK���t�lS��xt�m\��� t�nd���!t�om���"t�pu��t�q}���	t�r����t�s����t�t���t�u����t�vը��t�w��9t�x���$!t�y��D"t�z%��9t�{2��q
t�|?��t�}U��
t�~b��ft�o���t������t�����Jt�����5!t�����U"t��̩�Jt��ԩ��
t��ݩ�Lt�����
�����,t��8��o���B���t��j��H���t��*t������������t��Ϫ�F���٪��t����1�����l!t����f"t��(��[t��<���rf�C���!rf�J��w"rf�Q���rf�X���
rf�_���rf�f��Yrf�m���rf�t��wrf�{��Brf�����rf�����!�������"��������������
��������������|�ܫ��J���ۜ �Ь�����	���g���Ќ����	�0���yw�S���|D�[��}�g�g���|�o������z���������m�������������J
�������������������������������������ȭ�����Э�}�g�ܭ��|���j����x����$
���������s�����|�
���J���ۜ ����	\��s����Ќ����	�0�����yH������|D��%1��v�vǝ�}�Jvl�P/_�P�Fǝ/_�P�Fǝ�#�/_�P�F~�֎֎T��p6�����6���u������u;�t�t�;�;�t��=y��=y����Fe�P�Y���F�Y���F�Y�F���Y�Fǝ֎y�@a�Fz��VW�֎�=�m�W�>I�V�W�>n�I�V�P�Fz��I�V�>x�}�=�=��m�=�YaYa�}>r�\�\�\�P�K�$RA��RA�����P���P$��=W>ro���\�\�\�P�Pǝ�W�P/_�P�W�>I�V�W�>�hI�V�Fǝ�F/_�P/_�P/_�P�����Y��σ��σ�Y��"�������σ��σ�}��"��}\~�n~�n~U�~\�n�n��՜�(K���k}�}��K�K��i1�֎�<�<�F�F$�Fǝ�Fǝ$/_�P�P���>���>n�����F�P/_�P�F�b�P�P�P�<;�t�?W3Zs�W�>I�V�W�>n�I�V�i�W!AI�V�W�>�VI�W���e��*bҞ�G ��� ����FK��I�>�>�h+m��>�;�B�>�;�B�>�h�>�B+m�;�t�?W�P�P�P�P�P�P�P�P�P�>�>�hĢ��+m��>�>�h+m��>�>�hCI�PCI�P�h+m��A�>�h+m��>�>�hCICI�h+m��>�>�hn(#Y�Pn(#Y�P�h+m�i��v"�/_�P���P�PCI�Pg}�jcT�:�F�P�}�}�P�P�P�P�P�P�P�P�P�P�P�P�P�P�P�P��$�P�P�P�P�P�P!A~!A�~>U�P�p?W�Q�Q�Q�Q�P�Q�VX��P�Q"C�P�Q�VX��P��P$��VX��P$��VX��PZC.P$�/_�P���\Q$�
�&���P��=�P�=	A�P/_�P&$�\��G�G��G��<�<�<�<�<�<�<�<�G�<�<�GCI�}�}"�AI��P�P�Pe�<�<"�A�<ככJ``v/_�P&$�\�<�<
�&��cT�<ככ�<�<�<כ��<כ�z%ň�<כ��P�}�<&����<�<&���&��&��<�<�<�PVl�=�PVl=�<�<�PVl��=.D.D�V�Q��:�r�r�F�:�r^m�P�<�[���P�P�<�[�I�(B�}��P�<�[��P�P�<�[�al�����<��<�[��P�P�<�[��P�P�P�P�P�<��P�P�<�[��:�v"���n�:�F�P�:�n�P�P�P�<��<�'�Ya�<��Ya���Ya�P�P�P�P�P�<��<��P�>�>�h�F�P�P�o��o���<�����\�<���\�<ZT�V�<z�u�Ya�p�l��Ya�Ya�p�p�����p��P�p��P�<��>�>cT�>�h�h�>'��n�<�'�Ya�<��Ya���Ya�[�[�<*$;A�_*$;A�_*$;A�_*$;A�_*$;A�_NC�;A*$;A�_s=�<6�$'n�<�'�Ya�<�J�<�F��<��Ya���Ya�<�'�Ya�<��Ya���Ya�<��<�<�<�'�Ya�<��Ya���Ya�<�'�Ya�<��Ya���Ya�<�'�Ya�<��Ya���YaK�e*bK��<�PK�e*bK��<�������֎��<K���W��W&�@a&��<���<�Q���Qy����<�?��?�<3Z�?�<?����<����=$�=$'��$w��$�jw��$�=w��$�j�=w�g}�=�=�����=���=g};�t�;�t�;�t�;�t�?W$e$e�=cT�=�='��=$�p?W�=g}�`$���=�p?W'�}l}l�|�|}l�='�g}/_$�p?W�=g}���b�p?W$�$�$�=g}�=�=�j�j�=�j�=g}�P�P�P�P�P$$;�t�?W�=���=�j�j�=g}�=���P$�p?W?W�p�$�$�=�$�='��=cT?W$�=�='��='�cT��$����P��V�=��=�=/_�P�=g?�=�V�=��V�=/_�P�V�=�[=[=�P�P[=[=[=�P�P[=�=g?�=/_�P�=g?�=/_�P���#/_�P��=�P�P�=�=�=�=�/_�P�=/_�P�P�=g?�=�=}��P�P�P�=�=�}��P�=�]�=g?֎$�=�=g?�=/_�P	A�P�=ӟ�=��ӟ�A�=�����=���P�P�����������υυ�P�p?W��������υ�\�\o���\�P�P�P�P�����������`?�����%B��v)?���@���=�����=���WI�V�>gX�P���P���P���P�P�P�P�P�\~�������%��������~��5=�P�p?W�P>l����P�\]d�]d�\o���\�\��\��P�P��P���P�F���P�\�\�\o���\�\o���\�F�\��P����P�O����}���?W�p�P!�P&��O����}����Palal���p?W�p�P�_B]�H�kje�k�k�P�p?W�>����$�H�n�H�OuKs�PuKs�Pu�n�H�O�Ou�P�=�=Ks�Pu�n�H�O�OuKs�Pu�n�H�O�Ou�P�P�P�P�PKs�Pu�n�H�O�Ou�nu�v�nu�v�nu�nuKs�Pu�n�H�O�Ou�H�n�H�OuKs�PuKs�Pu�n�H�O�Ou�=�n�nu�n�n�H�O�OuKs�PuKs�Pu�n�H�O�OuKs�Pu�n�H�O�Ou�\�nu�]�nu�]�nu�nu�nu�nu�n�nu�nu�nu�nuKs�Pu�n�H�O�Ou�nuKs�PuKs�Pu�n�H�Ou�n�H�O�Ou�H���n�H�O�OuKs�PuKs�Pu�n�H�O�OuT�n�hT�nT�nym�nuym�nuym�nuKs�Pu�n�H�O�OuKs�Pu�n�H�O�Ou�n�=�n�nu�nuRrKs�Pu�n�H�O�Ou�b�nKs�Pu�n�H�O�Ou�nu�>�>�h�>�V:n=f�h�n�>�h�V�l�>�h�neKl�h�V�leKl�h�neKl��h�V�leKl��h�neKl���hym�F�H�n��F�n�Z����F�nu�Z���nn(�nn(�P�n�>�P�n�>�	�P�n�>�	g���P��-&�n�W���W�}����=-&���BC�_��������P�W�}����P�=��gX���P�����P�����P�����P�����P����W�p?W�B���P���p?W���P�����P�����P�����P�����P�����P���������v]���p?W�v]���p?W�PgX�p?WgXB�g���KAW=W�%$�K�m�m��m�}�m�m�}�m�m�}�K�m�Q�K�K�T=W=W=W=W�%�%�%�%�%&G&G&G�K&G&G=W&G&G&G&G�mB��m�mB�&G=W�;�Q�VX��P�Q�VX��PQW��P֎�Q��&G&G�[�Q&G&G&G&G&G�}�}&G&G&G�}(B/_�P�}7;&GR]=W&G&G&G&G�K&G�P�P��o��Ya�<�<;�t�&G&G��K&G&G&G&G&G�}�m�m&G&G&G&G&G&G�%�%�W�m&G=W&G�W�K�}�m&G&G&G�=W=W=W�KHm�K�K�K�K?WB�B��m;�t�?WB��K�Ku��%ual�T�B�%Zmӟ�K�%�%�}�K7;=W=W=W=W=W7;7;�K1@�F̠CI
}*'�P0�	?m
�e_A�F�&BXvAhQ!m�lu�=W۟uӟӟB�=W7;�K=W�K�KB��K�\�\�_U�}l�K�K�m=W/$/$/$�m�\=W�}�K�K�K�K�;՜֎՜֎QW�֎Ԏ�K'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'�'��[�}�%'��[�}�%'��[�}�%'��[�}�%'��[�}�%'��[�}�%'�'�'��K�%�%�%�%�%�%�%�%�%�%�%�%�%�%�%�%�K �($�(
"
q<$�*.q2��BqJq���� � �!�"�#�%�&e)V*�*�+�+�2Z3�3e; ;�;(<�<�?C�D�D*D.DqD2E(F(G�I(L,M(O4O(P(Q�RR(S@S(T(UPU(V(WXW(XX(ZnZrZvZq\�\*\.\q\2a�e�ihiniriviqm�n�o�p�r�s�t�v�w�w�~�������������������*�.�q�2���*�.�q�2���`���*�.�q�2�����*�.�q�2�x�x�x�x�x���d���d���d�������d�������q�����q������������
�����q��&�q�*�.�"�����
�2�6���������������������������������������
qieqie
6
i
e>q:ieFieRqNie!"#$)0134567:;<=�?BCDEF�FqF�FiFeGJ�KLN�NqN�NiNeOPQRSVWXYZ[]_a>aqa:aiaedefk�kqk�kikem�mqm�mimen�nqn�nineo6oioep6pipet�v.vqv6vivew.wqw6wiwe�.�q�6�i�e���q���i�e���q���i�e���q���i�e���q���i�e�R�q�N�i�e�R�q�N�i�e��q��i�e��q��i�e�.�q�6�i�e�j�q�f�i�e�j�q�f�i�e�j�q�f�i�e���q���i�e�R�q�N�i�e�j�q�f�i�e	�|�|�|!�|
1�|9�|A�|I�|Q�|Y�|a�|i�|q�|y�|��|��|��|��|��J�ۜ 8�+���8�0�|;��|D��|8�+$�|;!�|Q�|l8�+t8�+|�|;�8�+��|��|!ۜ!G��8�+��|;��|��|��|��|�|!�|!�|8�+$�|;D8�+L�|;�8�+��|;)�|\�|;�8�+��|;i�|��|�8�+�|;<�&�D�|;�T%�8�+��|;8�+�|;��|�,����v���|9�|,�|�A�|T_\	�#	��|��|;�8�+���+4��%��OR4�&W<�jIf�t��|��8�+QW��<_\�<�&W<UQ%�ۜ ���+��OR��|��W��0W��ym���|W�&��|t�&u*�|F�L_\���+�|;�wu*��OR�|���|��|4�|<_\D�|FI_��4�&�<y��4y��4�J4�|�L8�+<D�Lۜ <�>�Q�Q�Q�V�Q
WQ�QQ�QQPTQ6� QPT#T�|L�|�T�&�T�>�I_�4\�|FI�Y�d�|FIPIkl�|FI9��t�|FIc��IW��|�|F��|FI��,I�li��OR��|FIK]���|;�8�+��ORdy�����+Y�|aV��<�|	�8�8	���+�gPZ	��&W��OR�ۜ ��OR�y��	�I�	���+�_\Q~��	Q~��	Q~��	��|�y����&���|��&���&��_\�y���_\��|���|��|�|
ym
�& 
��%RQZ	q�|F�<2
��|�nH
��:N
��:U
Q"�\
��Sa
I�n
�|FQ�^�
Qz<\
	�I�	Q~��
Q���
y�S�
QW��
��|�
�|$ym�
$�2�
y���l�
,�|,b��
,�\w,�%4�|F�YL�|�$�&nD�|Db��
D�\wD'	%��+L�|Lb��
L�PwL!%�:H$�:T�cTV�m�&�\gPZ	L���LVI	d�|;l8�+>a
��V���V,�|t�|F|�|F��|F��|F��|F��|F��|FIg�%��|F�!�+�Km�ޛw��W���&���|���|���Q��Km�ޛw��W������[��Km�ޛw��W�<�|��
��|FIʜi
��OR��ORAHG0�Km�ޛw��W��Km�ޛw��W�	Z��
�y���h
yKyޛwy�W"��|4�<C�|
�-\�#ec)p�#gPZ	���$�|�6����l�T_\,�|Q3X�,y��4�|F��=�,�<�|FIE�,_\�D�|�DHP D��+L��+,gPZ	L�OR�V�JT�|F\�|Fd��l�|;t8�+|��+|�OR|�|W��|��|F�Km�Vp!�b�*�K�w��I/��K>�ޛw��W���|
�|�|�|Y�|a�d=a
Q��k��J��@a
QW�z�c@�������J���G���H�QV���V����r���B��O�����&���|QX����:��Q	QX��<��|���|���|�!W�G��W�|]Te��|y�<m��|;�8�+��ORL�#���+\h\W��|1&J���|
��|��|��y����|	�8�8	�gPZ	�ۜ ������|F1'X�IE�=96OjA�Oa
9�@y�gPZ	9�Oa
9ď�A����|FI
��A��)΍�)xe�1΍1s���|��&WA���|;8�+Q3X7a��@�|FI6�ZI��jIM�|i�&�$gP�$gPZ	$�|$�&W,v.w,k�,�?���|��&%<�&W4_\�<�?�4h\WD�|D�}D<�|F4�|��|Q�|L8�+��K-��:3���<JQ�|��|?TKmTޛwT�W�\Km\ޛw\�W��w�r��|?dKmdޛwd�W�A��ly��l�|�t8�+��:���FH
��FU
tۜ |�|;�8�+�^��Y>Y��S
��Aa
��|�sY��|?�*[+�y����|;�8�+�^�\�Km�ޛw��W��Km�ޛw��W��Km�ޛw��W���|��|��|F��|��y���_\��|��T&��|F�|�e$:�VpQ�b�[��<d��i��K>�|���iՅ&i_\���P�q�O���r�q�By�&��Km�ޛw��W��|��|F,�|,q\��&W��|	8�8	��+��Tb��� �OR�|��q���v�_\|a�Oa
�&Wۜ �|;$8�+��V�,�&���|<��4�|F<�|<�|�<�|a��|���|;<8�+<gPZ	��QlD�|;L8�+�0W�<UQ%�y��<n��|�gPZ	�W�i�|�u���|�QW��TKmTޛwT�W�\Km\ޛw\�W��K��"Q�Q),�#<h\Wd�|
l�|Fd�&WgPZ	Q�S�
��|�t8�+tۜ |gPZ	|�||�&W��|QHI���|;�8�+��|;�8�+<�&�T�|��8�+�ۜ ��|F��|F��|F��|F\���|��8�+�����|6�8�R�ۜ �ۜ ,�&W�Յ%�gPZ	�Km�ޛw��W���|��|;	8�+��V���|�	8�+	ۜ 	y��	_\�Y2I�i
	�>�	�|F$	;8w$	�0`$	�ae$	�|s$	�|�$	c�+$	�j�,	�?�$	�|���T��ڍ��΍�4	*�4	�|<	�?�D	�|FL	�|FI�X,IJ��d�|k\	�}~\	�|�	�|	�|�d	8�+d	ۜ T	�|;l	8�+ll�deI�t	�?�|	�|��	�|��&%UQ�!�=��|��|k�	�,w�	�O+�	�|�	l=�	V�HT�=��	�|FI1Kci�|i�|yI���Iן�Ij��I�^��	gPZ	,�|	�	8�8	�	ۜ �	�|�	gPZ	�	�|FIՅ��|�	�|F�	�|
�	gPZ	�	�&W�	�|�	h\W�	�&��	�����|
�	�|�	� �	P��|�i��&�	�|F�	�
�|( 
8�+i�#	L�|Wi�&B 
�&�
ۜ $
�|�,
8�+ih\�,
ۜ 4
�|F<
�|FD
�|F�	�|	L
8�8	T
�OR\
�|�d
8�+I�m�!T
��+d
ۜ L
ۜ l
�|t
�||
�||
�|��
�|F�
�|F|
�L|
_\|
y���
�|�
gPZ	�
�|�
h\W�
gPZ	�
h\W�
�&��
�|F�
�|FI=�{"�
�|F�
�|F�
�|FI=��"�
�|F�
�1=#�
�|�
�|��
�|�
�Pw�
qmh#�
�v#�
�|F�
�|��
V��#�|�|�|��|;8�+$y��,y��4y��,�&�4�&�$�&�$n,n4n$UQ%,UQ%4UQ%<�|;D8�+I�Gn
L��lD�l�T�|F�Յ%���l\�|;d8�+l�-�$lJX�$��T%�S7=#�c�h#�
�>���|��|�$t�|t�Pwt�v#|�|��|��Pw��v#��|��|F��&.%��|F��JW%�y���_\�gPZ	��jIןi
����%�gPZ	��|��|�ym�%��1�%�y���:� ��|��w��&��|F��|��R�_\�,;Y&�h\l&�U}&��"�&�_�&��|F4�|;��|�&��&���|F��>���>��n��|��\&�'	&�y����|�8�+ۜ �|�\&�&�|F��YL�|�\&�&��L��l&�D��q\�/l�'$�?��K�',�|,�w,u&4y��4�j4�4_\�4h\W4gPZ	,gPZ	,�|�&<��+<�OR4�& 
4n<Յ%<�l�
D�|F4�&.%,�&4�|�L�|;4��%4�|
L8<(L�7<(L�7wL�7wLc�+L��+LV�O(Ll� L�� ��=�T�|\�4}(T�|�T�|T�&�\�(T�>�L�|�L�|�(d��(d�"�(d�O(l�|FT�Y+t�|t�PwTy��t�O(|�|F��|���(�al ��T%��()��Q")��|Q�|��|��&���|t�|�HN)\
�|\
�&�|�|��<q)��&���|Qݎa
��|A�|��O0��Sa
�K& ��&���|���|�)��|���|�)��|��|�gPZ	��?+�U&x*�hn�*��K�*��|��|��|�gPZ	��?���|��|+�gP*+�uj3+��|J+Q�Q)�R^+��|��?e+�|�~jk+�uj3+��\w+��G ��Ge+��G}+��|�gP�+�aG�+��P�+�U&�+��\�+��H,��<(,��|��|��|
gPZ	
�?+��|�|
�2�,��OL�|
�k�,
s��,
Gr�,
�?�,��ZT_\$
���,\�|-\�|,
�|,
�n-,
�t$-�|�|�|Y��Va
!�l !+n�!f�)�|)�R8-)�R?-)kRF-)D�M-�KY-�_\h-�_\w-yՅJQ�^�-��J�-4
�|F<
�|�-D
�|L
�|��|��|F��&W
�|
�|F
�&W��|��|F��&WT
nT
y��T
�&�	
m.�wa
D�|��>���|�\
8�+d
�l�\
ۜ �y���n�y����>��nl
3�.l
�.�.l
�u�.l
�\�.t
jP�|
R�t
sPWl
V��.�
3�.�
�.�.�
�u
/�
*� /�
8�+�
�\2/�
�l��
V�D/��|�
�,w�
�O+�
V�^/��%n/�
�|FI1K�/�
y���
_\�#\�/��|�
1���
_\�
_\�
�|�
�"�/�
y���HG0�
�K>�
�%>�
��
�|�
�
0�
1���
!0�
'.0�
�|F�
#N0�
:X0�|F�|��
{{08�+�
��0�
��0�|FI9��0�
�v��
D�wۜ �
�J�
�|�
,���
�v��
"{;���+�y����|	$8�8	,�OR4�|F,��+$ۜ ��|W$q(1TV�m���c1<5s{1D�( ��(�1D��+�i�1�����G�z:�1I5s�1Q�( ��(�1Q����$"���1a5s2i�( i���i�1�����G�L�&�T��c1\5s{1d�( ��(�1d��+�i�1�����G�l��c1t5s{1|�( ��(�1|��+��|F��|;�8�+���+<�>��i�1�����G���(�1��|��|F�i�1�����G�y�(�1yi�1y��yG����c1�5s{1��( ���+�%�4���c1�5s{1��( ���+���c1�5s{1��( ���+��|��"p5��|4�K>b�*K�w�I/���5��5�|F��&.%��5�\%"�5Vp!�(�1�?�$��c1,5s{14�( 
64��+��J�i�1���G�<�}D�?��*[+�$%n6L��c1T5s{1\�( T�(�1\��+yoZ�y_\�6y�$�6Ti�1T���TG�d��c1l5s{1t�( \�(�1t��+\i�1\���\G��*[+d�(�1��|�K^79�|j7a�|q7�K& ���\w7A�&��sG�7��@a
1���7di�1d���dG�|�|��(�1�|	�8�8	�ۜ �i�1�����G�Q�:�7��(�1�i�1�����G���(�1y� �i�1�����G��F��F�
��|��|F��|F��|F|�>�y���|�&�|y����&���|	�8�8	��OR��|	�8�8	���+���+��OR���c1�5s{1��( ���+�ۜ �ۜ ��|F��|�:�y���_\�:��[,;�C;؋�;�C�3C�<k���;��$�;��|��c15s{1�( ��+��>��g�<��(�1�|F�i�1�����G�yK& yɎ ��&��W�<il�<$�|F,_\,y��,��<,�|�48�+4ۜ y+C<��c1D5s{1L�( L��+dgPZ	l�?�T��c1\5s{1d�( d��+l��c1t5s{1|�( T�(�1|��+���|2>Ti�1T���TG�\�(�1|_\,��%\i�1\���\G���|��|��&W��|F��|W��&���|F��L�_\�_\���|��8�+�UQ%�ۜ �D��n|_\�<y��_\�Q�p�@��OR��|��8�+�ۜ ��|F��|
��d�A�_\��|��8�+�ۜ �y���D����+��|��|;�8�+��|���c1�5s{1�( ��+��&W��&W�|F�|F��:��(�1��&��i�1�����G��|�&%�	�K>�	�%>�	D� �	�xCQ�\a
Q~�)C!
r0C)V�6C)�=�V�VC��bC9
�kC$� ,�|F�(��C4�|F<�|FD�|FL�|FT�|F�Ȃ�D\�|F��|Wdy��l��+t
�|	t8�8	|�|Fl�ORtۜ Ip? Ij�+E��|;�8�+��|FI
�i
���+�
�|��|F��|F��|F��|F��OR���+��OR��|FQ�^FI6_�Q��k��|F��|��&���u�.��\�.��O+��|;8�+�|F�|F��|IՅ�Fd�T%�q+��|d�|L0� L�T%iy��,
�K>,
�%>,
�n-,
u$-,
D��G,
{�G,
�>,
Ww�G��&�Gt	�|F����G�I��G��=�G�jp�G�|���R�G<	�|F�$u�G$�|F,�|�,�|�G4�|F<�|�<�|�GQW��^�G�ן�G�HzPzP!+Y@�KD�KH�K��K��K��K��L�
MMMPP.PMP�zP�P��P�zP�P��P�P�P��P��P��P�zP��K�zP�zP�zP��P��P��P��P��P�Q�zP�zPQ$GQ(R,R0wR4S8lS<�S@THiT�vT��T��T��T�U�U�U#UU.U(7U,HU0YU4nUTyUp�U��U}�P�zP�P��P��P��P��U��U��U��U��U��U��U��U��U�U��U��U�V�zP	zP
zP"V/VFV]V lV$}V(�V,�V0�V4�V8
M<�V@�VD�VH�VLWh�UlWp Wt�Ux'W|#U�DW��P�UW�\W��P��P��P�mW��P�
M�xW��W��W��U��W��W��W��W��W��W��WmYzP%
zP1
zP=
zPM
zPa-Y�-Y�-Y1-Ym-Y�-Y�WXX3XRXsX�X�X �X$�X(�X,�X0�X4
Y8Y�zP�-Y�-Y-Y	-Y-zP1zP5zP9zP=zPAzPEzP]zPmzP}zP�zP�zP�zP�zP ���.P.��.��.#��.+��.3��.;��.C�.K�.S�.[(�.cM�.k��.k�.k��.k�.k��.k�.k��.k��.kl�.kѕ.s>�.{I�.�O�@�ٗA�Pa�P��P��P��P��P��P��P��P��P�P�P �P!�P@�PA�Pa�PcP��P�P��P��P��P�PP �Pa�P��(���P��P��P��P��P��P��P�P�P!�PA�Pa�P��P�2���P��P��P�P!�P@PA�P`Pa�P�P��P�P�P�P!�PC2�a�PcG���P��P��P�K`���P�P!�PA�Pa�P�P��P�SP��P��P��P�P!�PA�P`�Pa�P��P�볠�P�P��P�[��cP��P�M�CP��P��(���P��P��P	�P	�P!	�P@	�PA	�P`	�Pa	�P�	�.��	�P�	�P�	�P�	�P
�P 
�P!
�P@
�PA
�P`
�Pa
�P�
�P�
�P�
�P�
�P�
�P�
�P�P�P ���!�PA�Pa�P��P��(���P��P��P��P��P�ۘ�P!�PA�Pa�P��P��P��P
�P
�P!
�PA
�Pa
�P�
�P!�PA�Pa�P��P��P��P��P��P�P!�PA�Pa�P �P@�P`�Pa�P��P��P��P��P��P�P�P �P@�P`�P��P��P��P�P�P �P!�PA�PIk��a�Pik����P��P��P��P��(���P��(��P!�P@�PA�P`�Pa�Pc�(���P��P��P��P��(���P��P�P�#,��#x��]���P��P#ę�P ��!�PA�P`#l��#��#�@#^�A�P`#����P�t���P��P��P�P �P!�P@�PA�PC���a�P��P�SP��P��(��P�(� �P��P������P��Pa�P��P��P��P��P�P!�P��P��P��P��P�P!�PA�Pa�P��P��P��P��P��P�P!�P@�PA�P`�Pa�P��P��P��P��P��P��P��P��P�P�P �P)sд@�P`#��P��P��P��P��P��P��P��P �PC �P` �Pa �Pc �P� �P� �P� �P� �P� �P� sߴ� �P� �P� �P� {P!�P!�P!�P !�P!!�P#!�P@!�PC!�P`!�Pc!�Pi!sߴ�!�P�!�P�!{P�!�P�!�P�!{P�!�P�!�P�!�P�!�P�!�P�!{P"�P"�P"�P	"{P "�P!"�P#"�P@"�PA"�PC"�P`"�Pc"�Pi"sд�"�P�"�P�"�P�"�P�"�P�"�P#�P#�P!#�P##�P)#s�)#K��C#�PI#sX�`#�Pa#�Pc#�P�##:��#�P�#�P�#�P�#�P�#�P�#�P�#�P$�P!$�P#$�P@$�PC$�Pc$�P�$�P�$�P�$sд�$�P�$s���$K��$�P�$s���$K�%�P#%�PC%�Pc%�P�%�P�%�P�%�P�%�P�%�P�%�P�%�P�%�P�%�P&�P&�P&�P &�P!&�P#&�P@&�PA&�PC&�P`&�Pa&�Pc&�P�&�P�&�P�&�P�&�P�&�P�&�P�&�P�&�P�&�P�&�P�&�P'�P'�P'�P '�P#'�P@'�PA'�PC'�P`'�Pa'�Pc'�P�'�P�'�P�'�P�'�P�'�P�'�P�'�P�'�P�'�P(�P(�P!(�P#(�PA(�PC(�Pa(�Pc(�P�(�P�(�P�(�P�(�P�(�P)�P)�P!)�P#)��A)�Pa)�Pc)�P�)�P�)�P�)�P�)�P�)�P�)�P�)�P�)�P*�P*�P!*�P#*�PA*�PC*�Pa*�Pc*�P�*�P�*�P�*�P�*�P�*�P�*�P�*�P�*�P�*s���*�I�+�P+�P	+s`�	+�I�!+�P#+�P)+s�)+�I�C+�PI+s��a+�Pc+�P�+�P�+�P�+�P�+�P�+�P�+�P�+�P�+�P,�P#,�P@,�PC,�P`,�Pc,�P�,�P�,�P�,�P�,�P-�P#-�P)-{PC-�PI-{P`-�Pc-�Pi-{P�-�P�-�P�-�P�-�P�-sB��-�P�-�P�-�P�-�P.�P.�P.�P .P!.�P#.�P@.PA.�PC.�P`.Pa.�Pc.�P�.�P�.P�.�P�.P�.�P�.�P/�P#/�PC/�P`/�Pc/�Pi/sM��/�P�/�P�/�P�/sչ�/�P�/�P�/s`��/�P�/�P�/{��/�P�/�P�/s��0�P0�P!0�P#0�PA0�PC0�Pa0�Pc0�P�0�P�0�P�0�PC1�PI1{��c1�Pi1{���1�P�1�P�1�P2�P#2�PC2�Pc2�P�2�P�2�P�2�P�2�P�2�P�2�P�2�P�2�P3�P3�P!3�P#3�PC3�Pc3�P�3�P�3�P�3�P�3�P4�P	4s�#4�P)4s�C4�PI4s-�c4�Pi4s7��4�P�4sA��4�P�4sv��4�P�4s���4�P5�P#5�Pc5�P�5�P�5�P�5�P6�P�6�P�6�P7�P!7�P�7�P�7�P�7�P8�P8�P 8�P!8�P@8�PA8�Pa8�P�8�P�8�P�8�P�8�P�8�P�8�P�8�P9�P9�P 9�P!9�P@9�PA9�P`9�Pa9�P�9�P�9�P�9�P�9�P�9�P�9�P:�P:�P :�P!:�P@:�PA:�P`:�Pa:�P�:�P�:�P�:�P�:�P�:�P;�P ;�P@;�P`;�P�;�P�;�P�>�P�>�P�>�P�>�P?�P�?P�?P�?P�?P@P @P@@P�@P�@P�@�PA�P@A�P�A�P C�P@C�P@D�P�E�PG�P G�P@G�P`G�P�G�P�G�P�G�P@H�P�I�P�I�P�I�P�I�P@K#�`K#֜@L#2�`N#���N#՝�N#$��N#~�O#ў O#!�`O�P�O�P�O#r�P�P P�P�P�P`Q�P�Q�P�Q�PR�P R�P@R�P`R#ȟS�P S#��S�P�S�P�S�P�S�PT�P`T�P�T�P�T�P�T�P�T�PU�P U�P@U�P�U�P�U�P�U�P�U�P�U�PV#x�@V�P`V�P�V�P�V�P�V#Р`W#!��W�}��Y�P�Y�P�Y�PZ�P Z�P@Z�P`Z�P�Z�P�Z�P�Z�P[#ѡ`[�P�[�P@\�P`\�P�\�P]#!��]#��^�Pa��@a�P�a#0��a#��b#��c#~� d#�e#e��e#ߥ�f�P�f�Pg#B��g�P�g#¦�h�P�h#G��i�P�i�Pj�P j�P@j#ħ`j#%��j#���j�P�k�P�k�بl#3� l#��@l#㩤m�P�m�P�m�P�n�P`p�P r�Ps�P�s�P t�P�u�P v�F�@w�P�w�P�x�P�x�P�z�P�{�P`}�P�}�����P �������P@��U�`������P ��P@��P`��P ��P@��PD��P`��P���P��P���P@��P`��P��P��P��P ��P!��P@��PA��P`��Pa��P���P���P�������P���P��P��f���P!��PA��Pa��P���P���P���P���P���P��P��P ��P ��P@��P`��P���P���P���P���P��P��P ����`��P���P@��P`��P������z� ��� ��P���P���P��P��P@��P`��P���P���P���P���P��P��P ��P@��P��`�`�������
���P��P ��P@��P`��P���P ��P���P��P��P ��P@��P`��P���P���P@��d�`��ï��P@��P ��P@��P`��P���P ��P`��P���P���P���P��P��P ��P@��P`��P���P���"���P ��P@��P`��P���P���P���P��P��P ��P@��P@����`���@��[���P���ű���P���P���P ��P���PĿ�P@��P���P���-���P��P��P���P���P@��P`��P��P���P@��P���P���P ��P���P���P`��P��P���P@��P���P���P���P���P`��P���P���P ��P@��P`��P���P���P���P���P��P ��P@��P`��P���P���P��P`��P���P���P���P���P ��P@��P`��P���P���P���P���P ��P@��P`��P ��P`��P���P���P���P@��P`��P���P���P���P��P@��P���P��P@��P���P@��P���P ��P���P ��P`��P���P���P���P��P@��P@��P��P@��P���P���P���P��P@��P`��P���P���P���P��P���P���P@��P`��P���P���P���P��P ��P`��P���P���P ��P`��P`��P���P���P ��P`��P���P���P ��P���P���P��P ��P@��P`��P���P@��P���P���P ��P@��P���P���P���P���P��P`��P���P���P��P��P ��P@��P`��P���P���P��P��P ��P@��P`��P���P���P��P��P ��P@��P���P���P��P@��P@��P`��P���P���P��P��P ��P@��P`��P���P���P��P��P ��P���P���P�P �P@�P`�P��P`�P��P��P�P �P@�P`�P��P�P`�P��P��P��P��P �P@�P��P��P��P��P�P �P@�P`�P��P`�P��P��P��P��P��P��P�P �P@�P`�P��P��P
�P@
�P`
�P�
�P�
�P�
�P�
�P�P`�P��P��P��P��P`�P��P��P�P �P@�P`�P��P��P �P@�P`�P��P��P��P��P@�P`�P��P��P��P��P��P �P@�P`�P��P��P��P��P@�P`�P��P��P��P��P�P@�P`�P��P��P��P��P�P@�P`�P��P��P��P�����P��P�P �P@�P`�P��P�$�P�$�P@%�P`%�P�%�P�%�P�%�P`(�P�(�P�(�P�(�P)�P )�P@)�PH���_�W��)c�	c	�	�	(
,
:
B
e
�
�
�
6Tu��2HZ�������J
�
�
�
(z�����>���q����(Qr�s��������(9F]{���h������ ?������&�����Fv�����.`jv��������'d�����LXs���� B�=X�����3����x����t ,!�!�!�!�!�"V#�#�#
$$B$n$x$�$�$�$j%w%�%
' 'Y'�'�'((?(E(Z(a(�(�())A)d)�)�)�)�)
*9*B*K*n*�*�*�*�*�*U+�+�+�+�+,,.,6,Z,},�,�,�,)-/-b-o-�-
.*.0._.�.Y/i/r/�/0�0�0�01!121�12)2/2�2_3*4B485{5<6�67�7�7�708�8;9~9�9;_;�;<U<[<�<�<�<='=-=�=C>�>�>?�?@s@�@�@6A�A�A�AB�B�B�B�BCCC!C<CCCICoC}C�C�C�D�DE
EBEHE�E�EFF[FaF�F�F�F�F�F�FGG4G:G?GKGQGYG_GeGlGrGxG�G#H)H4H:H	
#)*,-028;@ B"I#J$L%Q&S'\(_)e*f+m-t/{1|3};�<�>�?�@�A�B�C�D�G�I�L�M�N�OQY[\]^_`abcd!e#f)g*h+i,j.m/n1o3p5q6r7s:t<w>{A|C~D�E�F�G�H�I�J�K�L�M�N�P�R�S�U�W�Y�[�]�_�a�d�f�i�l�n�p�r�s�u�v�{�����������������������������������������������������������������������������������������������������
����F�N�a�k�m�n�o�p�t�v�w�������������!�#�%�'�)�+�-�/�1�3�5�7���~}���JĂ��ς��ׂml݂�~��#���^W��F��g'݂s���$������ς�F��g'݂s���$���ׂ9�	�t���V �J�&��F��g'݂s���$�c��t�/��F������\=��>���WD��V��IJ��mP�oV���^�]�i��v�~K��5r�����>�݂�W�����WD��V��IJ��>��^����mP������F��^W�����b���p����ς��ς$��^W��>���WD��V��IJ�^�����ׂ�mP�^����W�����>���WD��V��IJ��mP��F��^W�9]��eǃ�F��IJ��_̓@k��\eӃC���G����ك^W��ރ͎�g'݂�F���i����b�=���>��E����WD��V��IJ�^����mP��>���WD��V��IJ��W�����mP���ׂeǃ����~��~�b����ς����B���F��IJ��_̓@k��\eӃC��eǃ9]���G����ς��ׂ����V��IJ��>���WD��W����^�����ׂ�mP�xp)�J/�"T5�I?5�&5�֢5��#5���5�o�5��T5��>5�@�5�ka5��n5��(5��P5�Տ5�|]5��a5��]5�P5�<5�*S5�6T5�4<5��r5�-(5�M(5��O5�cO5��'5��'5��:5��:5�Q5�-Q5�{(5�W<5���5�]�5��e5�TH5�(5��p5�=>5��i5��C5��#5�{b5���5�&5���5�O'5�f5��Q5��5��>5��5�|Z5�"I5�&5�<5��5�Ȋ5�	j��"D��2&���W���9�'݂�Y���C��>���eL���R�B���_̓�]��>i�r~n�O�]�	j��"D��'݂�W���Y��2&���C���R�B���_̓r~n�A���}���t��V �‚�������������\=��@���P��.[������e���F��nń�Q݂�Z�eǃhd��?��Y��U��o����� ���C�̈́����\=���� �ׄ=݂��� ���������ID���V �)��������H
�b�����mJ݂����ID���V �)�������Yl��������ID���V �)�������c���F�����6�#��X����Yl����Yl����Yl����ޠ��ޠ��Yl������)�Yl����Yl��������qq5�=:�g����j@�*�F�=L�ɅV��]`�(_���bj��j@�=p��j@��P��=v�����\=�����\=�t?݂����\=�����\=�j�݂�Z݂�\݂2w��Vm�t?݂Vm|�t?݂�����#��%_���^��Vm�(_���P���F��R��t?݂Vm���]݂�^��Vm��wq���]ąt?݂Vm�t?݂�@���F���_̓um΅�܅��І����>�݂�F���_̓j_̓������>���WD��V��IJ��mP�^X	���΅��+�'��-��_̓�F���=5�+=�����>�݂3l;��\K��\R����>�݂?�X�-�a��\l���������p�݂��݂4�݂n݂�s�4�݂�_��9]���HJ��k���k���k��\eӃ�K݂$�-��K݂�K݂�}��kH������gs���]���n���K݂�K݂�K݂�K݂�K݂�K݂�K݂�K݂�K݂�K݂�K݂�K݂Kr���V��/n�0f�=��%&���C�%&�������}��=��=Ɔ=̆=҆=؆�]���B��=ކ=�=�=�=���v��]��v�]��P��}�ރj�������j������j���5�(�j����.�j�������j�����B�j�������j���5�(�j�������j�������j�������j������j������j���=H����j������j������j���:�N�j�������j����F���?��"D����݂IT��P݂}T�'݂+�X�4mX��e��$�^�!�h���h���h��p��F���&݂[XT�mA��wQt��F���e��!�������~'h��e����݂�P݂����'h��'������j�������j�������j�������j���a�D�j���a�D�j������j���ɒj�j���ɒj�j���ɒj�j����x�j�������j���ɒj�j���		


!#%')!+6-;/<1=3>5?7@9A;G=H=J?KANCOEQGRISKTMUOVQXS]U^WgYhYt[u]v_�a�c�c�e�g�i�k�m�o�q�s�u�w�y�{�}�������������������������������������������������������������������������������������������������	�
���
��������"�-�.�/�0�1�2�3456789:;	<	=>b
cdghijklmn!p#~%'�'�)�+�-�/�1�3�5�7�9�;�=�?�A�C�E�G�I�K�M�O�Q�S�U�W�Y�[�]�_�a�c�e�g�i�k�m�o�q�s�u�w�y�{�}������������������������������������������������������������������������������������������������������������������������������������������������
������"�,�5�8�9�:�;�<�=�>�BCLMN	O{
|
���������������!�!�#�#�%�%�'�'�)�+�-�/�/�1�1�3�3�5�5�7�7�9�9�;�;�=�?�A�C�E�G�G�I�I�K�K�M�M�O�O�Q�S�S�U�U�W�Y�[]
_ace&g'i0k4m5o6q7s=u>wDyE{N}OPQ�n�o�v��������������������������!�"�(�)�0�1�2�3�9�:�;�<�?�@�D�F�J�K�P�Q�R�S�T�\�]�_�`�a�b�i�j�k�l�m�n�v�w�x�{�~����������������������������������������������������	��
�����������!#%%')+-//11233547596;A=B?LAMCNEOGPIQKRM^OcQdQhSlUpWqWrYsYt[u[v]w]x_yazac�e�g�i�k�m�o�q�s�u�w�y�{�}���������
������"�'�,�1�7�>�C�H�M�R�]�^�d�e�k�y�{���������������������:�<�U�W���������������������������������������#�%�)�*+,-.	/0
12345678;<!=#>%?'F)G+H-I/J1K3L5M7N9O;P=`?bAjClEsGuIK�M�O�Q�S�U�W�Y�[�]�_�a�c�e�g�i*	k,	mF	oH	q
X3�3�3�3D3O�j\3�&3�03�H3�V3�T	3�h	3�
3�8
}�L
�P
3��
��'�)�+�-�/�1�3

'
)
7
-
/
9
3
@
'
B
)
F
?
H
-
J
/Z
'\
)b
Ad
-f
/h
Cj
3n
'p
)r
Et
-v
/�
K�
M�
K�
M�
K�
M�
'�
)�
O�
-�
/�
Q�
3�
K�
M�
K�
M!�
K!�
M"�
K"�
M#�
K#�
M$�
K$�
M)�
K)�
M0K0M1K1M3K3M4 K4"M5$K5&M6(K6*M7,K7.M::K:<M;>K;@M<BK<DM?RK?TMB^KB`MCbKCdMDfKDhMEjKElMFp'Fr)FtaFv-Fx/FzcF|3G~KG�MK�KK�ML�KL�MN�'N�)N�eN�-N�/N�gN�3O�KO�MP�KP�MQ�KQ�MR�KR�MS�KS�MV�KV�MW�KW�MX�KX�MY�KY�MZ�KZ�M[�K[�M]�K]�M_K_Ma
'a)aAa-a/aCa3d"Kd$Me&Ke(Mf*Kf,MkD'kF)kHikJ-kL/kNkkP3mX'mZ)m\im^-m`/mbkmd3nh'nj)nlinn-np/nrknt3ox'oz)o|?o~-o�/p�'p�)p�?p�-p�/v�'v�)v�?v�-v�/v�ov�3w�'w�)w�?w�-w�/w�ow�3��'��)�?�-�/�o�3�'�)�q� -�"/�$s�&3�@'�B)�Fe�H-�J/�Lg�N3��'��)��e��-��/��g��3��'��)��i��-��/��k��3��'��)��O��-��/��Q��3��'��)��O�-�/�Q�3�'�)�"y�$-�&/�({�*3�.'�0)�4y�6-�8/�:{�<3�j'�l)�r?�t-�v/�xo�z3�~'��)�����-��/�����3��'��)�����-��/�����3��'��)�����-��/�����3��'��)�����-��/�����3�N'�P)�TO�V-�X/�ZQ�\3��'��)�����-��/�����3$4IPW]go}�����������
 )2;DQct}��������������
"+4=JW_gow�������������+4=FS[cfox�������������
+5?HQ]fv��������)7EO�������7m{~����-M^��s���+	D	Q	m		�	�	�	�	�	�	
~
�
�
�

#@[{�������8M`�
+
�
�
�
�
:MU����7BO^�����M07>������.�'/F����"Lc�����7DPn����+2I��JVi����5���BT��FMT\{����#,B��*HX��ev����#+S����DS^fo��  4 M T [ g � � !]!k!y!�!�!�!�!�!�!"(":"B"r"�"�"�"#5#J#`#�#�#�#�#�#�#�#�#�#2$:$I$P$�$�$�$�$�$�$�$%%=%K%�%�%�%	&%&J&s&�&�&'E'e'o'�'�'�'�'(+(4(i(u(�(�(�(�(
)*)2)�)�)�)�)�)�)H*V*e*�*�*+C+e,t,�,�,�,-�-�-�-�-�-H.V.�.�.�.�./+/</Q/{/�/�/�/�/�/�/�/�/�/80_0t0�0�0�01
1n1�1 2W2d2q2�2�2�2
3!313A3�34�4�4�4�4�4�455!5f5�5�5�5�5�5�56*626y6�6�6�6�6�6�7�7�8�89(92:D:V:h:t:�:�:�:�:�:�;�;�;�;=<�<�<
=p=|=�=�=�=�=�=>>s?�?�?�?�?-A{A�A�A�A�A(B0B8BDBMBVBmB�B�BuC�C�CDD=DmD�D�D�D�D�D]EkEyE�E�E�E�E�E�E�E�E3FSF~F�F�F�F�F�F�G�G�GHH�����d\Hq�AH ;JHO�
SHej[���j
	


 !"#$(%)&)'*(/)/*=+A,B-B.B/L0S1S2U3U4X5X6X7X8X9X:X;X<Y=\>^?^@^A^B_CaDbEbFbGeHgIhJhKhLhMiNlOmPmQmRnSnToUoVoWpXrYsZt[w\w]w^w_w`wawbwcwdwewfwgzh�i�j�k�l�m�n�o�p�q�r�s�t�u�v�w�x�y�z�{�|�}�~�����������������������������������������������������������������������������������������������������ȌY\C#F#0Y\4A#>A#E��E��E�OG��I��K��MA#O��O��O�O�u���Z���A#A#A# A#O�;tA#|A#~A#�A#�A#�A#�����O�A#�A#�A#��;�~c�Y\�A#�A#�A#��O�w���O�w��w���O�w��w���O�w���O�O�O
Ȍ
Y\ȌY\ȌY\C#F#C#F#(A#*A#+A#,A#9�9�P�P�R�R�^�;��Z�A#�A#�A#�A# A#,A#.A#8��8�O:��:�O<��<�O>��>�O@��@�OB��B�OFA#HA#TA#VA#A#UA#[A#a�;�A#%	A#�O�@;������F���??�f#?'�+�-�3O;�L��z
'�
N�N�N�N�N�N�'A�`���'
-!
8>
1u
1�
;�
A�
MM.e�M��y23o�T�'��Az
�����������]1����#�'QMdO�Q�*�-��W�l�����������M�M�M���-�'������'2�rM|����M����M�M�;M�w}MpM|1�M���M�M�M	AA!'��'���#�'���M���M��<'Qz
z
+%<z
���z
'\M�SdQdd#z
Wz
Sz
#�'e�i�d�dMM1d+��d��D� '� �� � '!���!$	�$	�$	2"$	�$	6"+]"��"#�"�#+&#��#�#-�#i�#-,$'�-��+b$�#g�%19&'�&'�&�9&��'i(��(�T)^)Ww)|)�)�)��**"*�(*-*<(*���<�*�*���<
+����+��+��+��+��+��+��W��N,��!�,�~-���-z
i�q�/'D0��'h0�o0��0W�q�0'1��1��1��1��1�2e�1	~2	�2�3	M3+	�3+	�3#�1'4+	47	947	�4*�7	�47	5*�7	*5*7	X5w	�5w	6�	�6�	�6�	7�	N7�	�7�	�7�	"87	l87	z87	�87	�8D�89#9'97	d97	r9�	�9�	�:'�:�	M;�	�;�	�;W
/<+L<��	~<'�<��<7	�<7	=*�7	�=7	�=�
 >�
�>7	�>7	�>7	�>1�?7	�?�	�?7	g@7	�@7	�@7	�@+	A+	oA+	�A+�A�	�A7	_B#{B'�B
�B7	�B�\C��+�C��C'�C+�CJ�C'.D#ND�ND\DF�C'� '�D'�D��D'�D'$EY�#dy�"1�Ea�E#�E�E�E'�"#�Ey�E'�E;�E'F$	(*y���S�E+FFW�#,$q�F��M�1�(�G
((���(�"�#�&F&J)�*�D(F(H(J(M(N�R�a�b�c�d�f(g(l�<.cctor>b__13_10<found>5__10<IsChannelAvailable>d__10<.cctor>b__13_20<.cctor>b__13_30<.cctor>b__13_40<GetChecksCore>d__40<.cctor>b__13_50<.cctor>b__13_60<>9__10_0<get_Count>b__10_0<>c__DisplayClass10_0<>c__DisplayClass20_0<>9__0_0<Consolidate>b__0_0<.ctor>b__0_0<ProcessTableIndexes>b__0_0<GetPermutations>b__0_0<>c__DisplayClass0_0<>9__11_0<get_IncludedColumnsOrdered>b__11_0<>c__DisplayClass11_0<>9__21_0<get_KeyColumnsOrdered>b__21_0<>c__DisplayClass21_0<>9__41_0<get_KeyColumnOrderedTypes>b__41_0<>9__1_0<.ctor>b__1_0<GetCombinations>b__1_0<>9__12_0<FormatVariableValueString>b__12_0<GetAssessmentResults>b__12_0<QueryKey>b__12_0<>c__DisplayClass12_0<>9__22_0<Add>b__22_0<AddRuleset>b__22_0<>c__DisplayClass22_0<TryGetObjectValue>g__TryGetValueFromProperties|22_0<>9__2_0<Duplicates>b__2_0<>c__DisplayClass2_0<.cctor>b__13_0<>9__23_0<get_AllColumnsOrdered>b__23_0<GetAssessmentResultsList>b__23_0<>c__DisplayClass23_0<>9__43_0<get_KeyColsDataLengthBytes>b__43_0<>9__3_0<Transform>b__3_0<Run>b__3_0<>c__DisplayClass3_0<AreEqual>g__NormalizeParams|3_0<>9__14_0<GetEnumerator>b__14_0<>c__DisplayClass24_0<>9__44_0<ProcessRequestAsync>b__44_0<>9__4_0<GetHashCode>b__4_0<Execute>b__4_0<ToWarning>b__4_0<get_Total>b__4_0<Transform>b__4_0<>c__DisplayClass4_0<>9__15_0<get_Failed>b__15_0<GetPermutations>b__15_0<>c__DisplayClass15_0<>c__DisplayClass25_0<>c__DisplayClass45_0<>9__5_0<GetNames>b__5_0<ThrowOnErrors>b__5_0<>c__DisplayClass5_0<>c__DisplayClass16_0<>9__6_0<get_BenefitsFromCache>b__6_0<>c__DisplayClass6_0<>9__17_0<GetHashCode>b__17_0<get_Exceptions>b__17_0<GetContexts>b__17_0<>c__DisplayClass17_0<>9__37_0<get_KeyColumns>b__37_0<>9__7_0<ApplyTo>b__7_0<>c__DisplayClass7_0<>c__DisplayClass28_0<>9__8_0<GetAggregate>b__8_0<ToDebugString>b__8_0<GetDataImpl>b__8_0<GetNames>b__8_0<>9__19_0<get_Data>b__19_0<get_OrderedColumns>b__19_0<>9__39_0<get_IncludedColumns>b__39_0<>9__9_0<GetAggregate>b__9_0<get_IsEmpty>b__9_0<>c__DisplayClass9_0<>9__0<GetData>b__0<Add>b__0<Find>b__0<EvaluateCore>b__0<Substitute>b__0<FindValue>b__0<TryGetRefValue>b__0<TryGetValue>b__0<Remove>b__0<Specialize>b__0<IndexOf>b__0<ToString>b__0<IsMatch>b__0<get_Item>b__0<Transform>b__0<UpdateCharacteristics>b__0<Includes>b__0<Equals>b__0<Contains>b__0<ProcessAssessmentRequest>b__0<GetAssessmentResultsList>b__0<GetProbeContext>b__0<GetData>d__0<ProcessTableIndexes>d__0<GetPermutations>d__0arg0<ReadNamedExpression>g__ReadOperands|0<.cctor>b__13_11<GetData>d__11<Transform>d__11<UpdateCharacteristics>d__11<GetAssessmentResults>d__11<CollectKeys>d__11<.cctor>b__13_21<.cctor>b__13_31<>9__13_41<.cctor>b__13_41<.cctor>b__13_51<.cctor>b__13_61<>9__0_1<ProcessTableIndexes>b__0_1<>9__41_1<get_KeyColumnOrderedTypes>b__41_1<>9__1_1<.ctor>b__1_1<GetCombinations>b__1_1<>9__2_1<Duplicates>b__2_1<.cctor>b__13_1<>9__43_1<get_KeyColsDataLengthBytes>b__43_1<>9__3_1<Transform>b__3_1<AreEqual>g__NormalizeNumericParams|3_1<>9__15_1<get_Failed>b__15_1<>9__25_1<GetData>b__25_1<>9__45_1<ProcessAssessmentRequest>b__45_1<>c__DisplayClass16_1<>9__6_1<UpdateCharacteristics>b__6_1<>9__17_1<get_Exceptions>b__17_1<>9__37_1<get_KeyColumns>b__37_1<>c__DisplayClass28_1<>9__8_1<GetDataImpl>b__8_1<>9__19_1<get_Data>b__19_1<get_OrderedColumns>b__19_1<>9__39_1<get_IncludedColumns>b__39_1<>9__9_1<GetAggregate>b__9_1<>8__1<Transform>b__1<GetPermutations>b__1<GetContexts>b__1<AddRuleset>b__1<QueryKey>b__1<Transform>d__1<IsPresent>d__1<Apply>d__1<>u__1<>c__DisplayClass2_0`1<>c__DisplayClass6_0`1Func`1SingleToolProbe`1Range`1IItemChange`1Nullable`1IComparable`1IEnumerable`1IOrderedEnumerable`1IEquatable`1ConfiguredTaskAwaitable`1Predicate`1Task`1Literal`1DependentTool`1InPlaceTransform`1ChangeTransform`1OverwriteTransform`1UnitTransform`1NonstrictComparisonExpression`1StringBinaryExpression`1ICollection`1IReadOnlyCollection`1IPattern`1CompositePattern`1ConjunctionPattern`1DisjunctionPattern`1ComplementaryPattern`1AsyncTaskMethodBuilder`1IComparer`1ReferenceComparer`1IEqualityComparer`1RangeConverter`1ConcreteConverter`1JsonConverter`1RangeListConverter`1IEnumerator`1ISet`1AtomicSet`1HashSet`1ConcurrentSet`1IList`1RangeList`1PatternList`1IReadOnlyList`1EvaluationContext`1get_WarningCheckSkipped1get_FieldName1fieldName1get_Value1value1arg1obj1get_Item1<>7__wrap1CS$<>8__locals1<>m__Finally1<Transform>g__ParseColumn|1<.cctor>b__13_12<ReadSequence>d__12<GetAssessmentResults>d__12<QueryKey>d__12<.cctor>b__13_22<GetDataAsync>d__22<FilterContexts>d__22<.cctor>b__13_32UInt32<>9__13_42<.cctor>b__13_42<.cctor>b__13_52<.cctor>b__13_62<>9__0_2<ProcessTableIndexes>b__0_2<>9__41_2<get_KeyColumnOrderedTypes>b__41_2<.cctor>b__13_2<>c__DisplayClass16_2<>9__6_2<UpdateCharacteristics>b__6_2<>9__17_2<get_Exceptions>b__17_2<>9__37_2<get_KeyColumns>b__37_2<get_Data>b__19_2<>9__39_2<get_IncludedColumns>b__39_2<command>5__2<semaphore>5__2<i>5__2<total>5__2<connection>5__2<heap>5__2<selector>5__2<confirmedServices>5__2<confirmedRoles>5__2<lines>5__2<items>5__2<confirmedPermissions>5__2<results>5__2<skippedContexts>5__2<keys>5__2<target>5__2<result>5__2<parent>5__2<view>5__2<>9__2<GetCombinations>b__2<ReadRanges>d__2<>u__2<>c__DisplayClass1_0`2<>c__1`2<GetCombinations>d__1`2<>c__3`2<Run>d__3`2Func`2MultipleItemChange`2Tuple`2IGrouping`2KeyValuePair`2IChangeAccessor`2IMultipleChangeAccessor`2SortedList`2IDictionary`2ListBiDictionary`2PatternDictionary`2ConcurrentDictionary`2IReadOnlyDictionary`2get_WarningCheckSkipped2get_FieldName2fieldName2get_Value2value2arg2obj2get_Item2<>7__wrap2ILogicsProvider2AssessmentRequest2<>m__Finally2<Transform>g__ApplyPattern|2<.cctor>b__13_13<QueryName>d__13<.cctor>b__13_23<Invoke>d__23<.cctor>b__13_33<>9__13_43<.cctor>b__13_43<.cctor>b__13_53<>9__0_3<ProcessTableIndexes>b__0_3<.cctor>b__13_3<>c__DisplayClass16_3<command>5__3<tree>5__3<i>5__3<sqlTool>5__3<tool>5__3<connection>5__3<p>5__3<errorGroup>5__3<reader>5__3<contexts>5__3<subKeys>5__3<waitList>5__3<resultList>5__3<row>5__3<GetDataImpl>d__3<ExecuteLines>d__3<>u__3Func`3SingleItemOrArrayConverter`3get_WarningCheckSkipped3obj3<>7__wrap3<Transform>g__MatchToDictionary|3<.cctor>b__13_14<ReadMeasurementsAsync>d__14<GetServices>d__14__StaticArrayInitTypeSize=24<.cctor>b__13_24<GetTags>d__24<.cctor>b__13_34<>9__13_44<.cctor>b__13_44<ProcessRequestAsync>d__44<.cctor>b__13_54UInt649B0C257D89782D17D9AFCD55037CCAF565EE46A3DD0EA068E476FC9D568B0A84<>9__0_4<ProcessTableIndexes>b__0_4<.cctor>b__13_4<>9__16_4<Transform>b__16_4<>c__DisplayClass16_4<runSpace>5__4<cache>5__4<done>5__4<probeRef>5__4<i>5__4<patternTail>5__4<wmiTool>5__4<reader>5__4<keyParameter>5__4<parameter>5__4<services>5__4<checkRequirements>5__4<hiveQuery>5__4<ReadSequence>d__4<Execute>d__4<ToWarning>d__4<ExecuteTextReader>d__4<>u__4Func`4<>7__wrap4<.cctor>b__13_15<GetResultSets>d__15<GetServiceAccount>d__15<.cctor>b__13_25<GetData>d__25<GetChecksAsync>d__25<.cctor>b__13_35<>9__13_45<.cctor>b__13_45<ProcessAssessmentRequest>d__45<.cctor>b__13_55<.cctor>b__13_5<vmId>5__5<command>5__5<instanceName>5__5<i>5__5<column>5__5<valueNameParameter>5__5<calls>5__5<probeContext>5__5<ProcessTableIndexes>b__5<ReadSequence>d__5<GetDataImpl>d__5<Transform>d__5<GetNames>d__5<TransformRows>d__5<>7__wrap5<Transform>g__CapturesToDictionary|5<.cctor>b__13_16<Touch>d__16UInt16<.cctor>b__13_26<GetChecksCore>d__26<InvokeProbeCall>d__26<.cctor>b__13_36<>9__13_46<.cctor>b__13_46<.cctor>b__13_56<>9__0_6<ProcessTableIndexes>b__0_6<.cctor>b__13_6<role>5__6<value>5__6<reader>5__6<pair>5__6<vmIdStr>5__6<probeCalls>5__6<keyList>5__6<prefix>5__6<channelKey>5__6<Transform>b__6<UpdateCharacteristics>d__6<>7__wrap6<.cctor>b__13_17<.cctor>b__13_27<GetChecksAsync>d__27<GetChecksCore>d__27<CollectCharacteristics>d__27<GetNewChecks>d__27<.cctor>b__13_37<GetOpenedConnectionAsync>d__37<.cctor>b__13_47<.cctor>b__13_57<MakeSpecific>d__576B31F522CD735CBC9C722C1616A96DB65290F26857DC090182D85C7F7B981DC7<>9__0_7<ProcessTableIndexes>b__0_7<.cctor>b__13_7<azureTool>5__7<UpdatePresence>d__7<Update>d__7<Execute>d__7<Transform>d__7<GetEnumerator>d__7<UpdateCharacteristics>d__7<GetNames>d__7<.cctor>b__13_18<.cctor>b__13_28<GetDataAsync>d__28<Specialize>d__28<.cctor>b__13_38<GetImplementedChecks>d__38<.cctor>b__13_48<.cctor>b__13_58<SpecifyVmType>d__58<.cctor>b__13_8<c>5__8<command>5__8<serviceKey>5__8<GetDataImpl>d__8<UpdateCharacteristics>d__8<EnumKeys>d__8<.cctor>b__13_19<.cctor>b__13_29<.cctor>b__13_39<.cctor>b__13_49<.cctor>b__13_59<>9<.cctor>b__13_9<svcName>5__9<UpdateNamed>d__9<GetDataImpl>d__9<GetEnumerator>d__9<UpdateCharacteristics>d__9<Module><PrivateImplementationDetails>System.IOTTXTYvalue__System.DataMicrosoft.SqlServer.Management.Assessment.Dataget_Dataget_ExtraDataextraDataget_ErrorFailedObtainProbeDataget_ErrorEvalMissingDataTryGetOwnDataTryGetDataInitDatarawDataGetRowDatadatasb<>caccspecrecMakeSpecificIsNumericSystem.Collections.GenericToolTypesStaticroundFuncIAggregateFuncArrayAggregateFuncMinimumFuncMaximumFuncStringJoinFuncCountFuncfuncGetDataAsyncReadAsyncOpenAsyncGetOpenedConnectionAsyncExecuteScalarAsyncExecuteReaderAsyncGetChecksAsyncReadMeasurementsAsyncWaitAsyncProcessRequestAsyncdoc<>3__src<<ReadNamedExpression>g__ReadOperands|0>dget_Idset_Idget_CurrentManagedThreadId<>l__initialThreadIdprobeIdget_CheckIdget_ErrorInvalidCheckIdget_StringCheckIdcheckIdPowerShellCommandHeadReadheadLoadSystem.Collections.Generic.ICollection<Microsoft.SqlServer.Management.Assessment.Probes.ProbeFamily>.AddGetOrAddTryAddget_IsIncludedisIncludedAddImpliedGetImpliedget_Enabledset_Enabledget_IsDisabledisDisabledget_Failedset_Failedget_ErrorConditionEvaluationFailedUpdateNamedget_IncludedColumnsOrderedget_AllColumnsOrderedget_KeyColumnsOrderedget_ErrorNameFieldIsRequiredget_ErrorVersionFieldIsRequiredget_ErrorCheckModificationSelectorResuiredget_ErrorStringOrObjectExpectedget_ErrorStringArrayOrObjectExpectedexpectedget_ErrorRecursionDetectedAwaitUnsafeOnCompletedget_IsCompleted<>3__unimplementedget_ErrorJsonSerializationNotSupportedNewGuid<FieldName1>k__BackingField<Value1>k__BackingField<FieldName2>k__BackingField<Value2>k__BackingField<Data>k__BackingField<ExtraData>k__BackingField<CheckId>k__BackingField<IsIncluded>k__BackingField<Enabled>k__BackingField<IsDisabled>k__BackingField<Failed>k__BackingField<Instance>k__BackingField<Reference>k__BackingField<CharacteristicProviderSource>k__BackingField<Message>k__BackingField<AssessmentMessage>k__BackingField<Table>k__BackingField<Name>k__BackingField<FieldName>k__BackingField<ProbeName>k__BackingField<TypeName>k__BackingField<OriginName>k__BackingField<ParameterName>k__BackingField<ServerName>k__BackingField<DisplayName>k__BackingField<FamilyName>k__BackingField<Line>k__BackingField<Define>k__BackingField<Type>k__BackingField<MachineType>k__BackingField<ItemType>k__BackingField<ImplementationType>k__BackingField<ObjectType>k__BackingField<TargetType>k__BackingField<UseDatabase>k__BackingField<Predicate>k__BackingField<Template>k__BackingField<Value>k__BackingField<IsUnique>k__BackingField<Size>k__BackingField<Eof>k__BackingField<PresenceFlag>k__BackingField<Morph>k__BackingField<Path>k__BackingField<TargetPath>k__BackingField<CallStack>k__BackingField<Check>k__BackingField<HelpLink>k__BackingField<Original>k__BackingField<KeyOriginal>k__BackingField<Level>k__BackingField<NotNull>k__BackingField<Eol>k__BackingField<BaseTool>k__BackingField<Trim>k__BackingField<Transform>k__BackingField<Platform>k__BackingField<Children>k__BackingField<Flatten>k__BackingField<Join>k__BackingField<Column>k__BackingField<ValueColumn>k__BackingField<KeyColumn>k__BackingField<Version>k__BackingField<SchemaVersion>k__BackingField<OriginVersion>k__BackingField<Configuration>k__BackingField<Implementation>k__BackingField<Connection>k__BackingField<EngineEdition>k__BackingField<Condition>k__BackingField<FilterDefinition>k__BackingField<LinePosition>k__BackingField<Exception>k__BackingField<Description>k__BackingField<StringComparison>k__BackingField<Urn>k__BackingField<Pattern>k__BackingField<NamePattern>k__BackingField<ServerNamePattern>k__BackingField<MachineTypePattern>k__BackingField<GetPattern>k__BackingField<IsDryRun>k__BackingField<ReadsRatio>k__BackingField<Map>k__BackingField<Rep>k__BackingField<Timestamp>k__BackingField<Char>k__BackingField<LineNumber>k__BackingField<Reader>k__BackingField<Scheduler>k__BackingField<Grouper>k__BackingField<ResultGrouper>k__BackingField<Comparer>k__BackingField<Parser>k__BackingField<TargetFilter>k__BackingField<Accessor>k__BackingField<Separator>k__BackingField<FillFactor>k__BackingField<Selector>k__BackingField<CheckSelector>k__BackingField<ProbeNameAlias>k__BackingField<Logics>k__BackingField<FailedCharacteristics>k__BackingField<KnownCharacteristics>k__BackingField<CheckIds>k__BackingField<Methods>k__BackingField<Probes>k__BackingField<Indices>k__BackingField<Ranges>k__BackingField<CheckChanges>k__BackingField<MissingDependencies>k__BackingField<Rules>k__BackingField<Lines>k__BackingField<Types>k__BackingField<Tags>k__BackingField<Checks>k__BackingField<Locals>k__BackingField<Calls>k__BackingField<Items>k__BackingField<Columns>k__BackingField<CheckSpecializations>k__BackingField<CheckDefinitions>k__BackingField<Options>k__BackingField<Exceptions>k__BackingField<InnerProbeExceptions>k__BackingField<InnerExceptions>k__BackingField<Parameters>k__BackingField<Errors>k__BackingField<Rulesets>k__BackingField<CurrentRulesets>k__BackingField<Hits>k__BackingField<ProbeResults>k__BackingField<InnerResults>k__BackingField<Requirements>k__BackingField<Arguments>k__BackingField<Subject>k__BackingField<Distinct>k__BackingField<Target>k__BackingField<Left>k__BackingField<IncludesLeft>k__BackingField<Right>k__BackingField<IncludesRight>k__BackingField<Result>k__BackingField<NullParamResult>k__BackingField<Element>k__BackingField<Document>k__BackingField<SpecList>k__BackingField<ErrorList>k__BackingField<DispatchPost>k__BackingField<CommandText>k__BackingField<ProbeContext>k__BackingField<BaseContext>k__BackingField<EvaluationContext>k__BackingField<GlobalEvaluationContext>k__BackingField<SystemEvaluationContext>k__BackingField<BaseRow>k__BackingField<Index>k__BackingField<IsPrimaryKey>k__BackingField<Query>k__BackingField<Inventory>k__BackingField<Registry>k__BackingField<Severity>k__BackingField<Empty>k__BackingFieldYieldBitAndTrimEndIDbCommandBuildCommandPrepareCommandCreateCommandcommandAppendFindget_ErrorImplementationWasNotFoundget_ErrorKeyNotFoundmethodStandardnetstandardCreateRecordIProbeTProbeDbaProbeReadStandardProbeWmiProbeReadExternalProbeCmdShellProbePowerShellProbeSqlProbeServerVersionProbeKustoProbeReadClrProbeRegistryProbeprobeTToolInterfaceTCollectionInterfaceReplaceget_ErrorValueEndsWithWhiteSpaceget_ErrorValueStartsWithWhiteSpaceget_ErrorValueCannotBeNullOrWhiteSpaceIsNullOrWhiteSpaceIsWhiteSpaceRunSpace<>3__runSpaceXNamespaceserviceget_Instanceset_InstanceManagedInstanceCreateInstanceComposeByInstanceinstanceget_ReferenceProbeReferencereferenceUpdatePresenceReadSequencesequenceget_DataSourcedataSourceget_CharacteristicProviderSource<>3__providerSource<>3__sourceCreateOverrideDividefuncCodemorphCodeGetHashCodeoperationCodeXNodeget_Unicodeget_Messageset_MessageBuildMessageget_UnsupportedTargetCheckMessageGetMessageget_AssessmentMessageset_AssessmentMessageget_NotEnoughPermissionsToRunAssessmentMessagemessageAddRangeget_ErrorIndexOutOfRangeInsertRangeReadChangeCheckChangeReadReplaceItemChange<>3__itemChangeReadTargetChangeget_ErrorCheckTargetChangechangeuseCacheget_BenefitsFromCachecallsCachecacheEndInvokeBeginInvokeget_TableICloneableIsChannelAvailableIsAvailableIsNullableIComparableIEnumerableIDisposableYieldAwaitableConfiguredTaskAwaitableDoubleRuntimeFieldHandleRuntimeTypeHandleGetTypeFromHandleSingleTupleCheckRulecheckDefinitionRuleXNameget_Nameset_NameAzureVmIdNameAzureVmResIdNameAzureSqlOnVmResIdNameget_FieldNameset_FieldNamefieldNameget_ProbeNameprobeNameGetInstanceNameinstanceNameTableNamevariableNametableNameget_TypeNametypeNamedatabaseNameGetCliNameget_FullNamecolNameErrorStreamNameProgressStreamNameGetStreamNameOutputStreamNamedataItemNameget_OriginNameset_OriginNameLineColumnNamelineColumnNameConfigurationNameJsonNameCommaGroupNameGetGroupNameLeftBracketGroupNameRightBracketGroupNameLeftGroupNameRightGroupNamegroupNameget_ParameterNameset_ParameterNameNameParameterNameparameterNameget_ServerNameset_ServerNameattrNameGetNameset_TargetNamerulesetNamedefaultNameelementNameSecurableNameArgumentNameSecurableClassArgumentNameAttributeContextNameIndexNameReadFuncByNameReadMorphByNameget_DisplayNameset_DisplayNameget_UnsupportedTargetCheckDisplayNameGetDisplayNamekeyNameget_FamilyNameset_FamilyNameQueryNameAzureResourceIdPropertyNameAzureVmResourceIdPropertyNameEnabledPropertyNameUuidPropertyNameMessagePropertyNameServerNamePropertyNameDisplayNamePropertyNameVmTypePropertyNameItemTypePropertyNameHelpLinkPropertyNameLevelPropertyNameTransformPropertyNamePlatformPropertyNameVersionPropertyNameImplementationPropertyNameEditionPropertyNameConditionPropertyNameDescriptionPropertyNameTargetFilterPropertyNameAliasPropertyNameProbesPropertyNameTagsPropertyNameLocalsPropertyNameParametersPropertyNameClassPropertyNameTargetPropertyNameAssemblyPropertyNamepropertyNamenameDateTimeget_LineAppendLineCreateLineCombineget_DefinePersonalOrDesktopEngineIAsyncStateMachineSetStateMachinestateMachineNoneGetSqlConnectionCloneCharactersToEscapeget_Typeset_Typeget_NodeTypeXmlNodeTypeChangeTypeIsNullableTypeget_MachineTypeset_MachineTypeget_IsValueTypeOfTypeGetUnderlyingTypechannelTypetoolTypeSpecifyVmTypeget_ItemTypeset_ItemTypeOverrideItemTypeDefinitionItemTypeget_ErrorUnrecognizedChecksItemTypeJTokenTypeget_TokenTypeCheckTokenTypetokenTypeget_ImplementationTypeset_ImplementationTypeget_ObjectTypeSqlObjectTypeobjectTypeGetTypeget_TargetTypetargetTypeget_Unsupported_PowerShell_parameter_typeCompareWhereTryGetDataCoreEvaluateCoreGetChecksCoreGetAssessmentResultsListCoreprocedureCharacteristicFailureget_Cultureset_CultureresourceCultureget_InvariantCultureget_CurrentCultureCaptureAzurevalueInUseget_OrdinalIgnoreCaseChangeDatabaseAzureDatabaseget_UseDatabaseset_UseDatabaseStretchDatabaseReleaseEnterpriseSystem.IDisposable.DisposeTryParseReverseDataWarehouseget_PredicatepredicateConsolidateAddOrUpdateCreateParserDelegateMulticastDelegateGetAggregateget_Templateset_TemplateCommandTemplatemessageTemplateAddMemberTemplatetemplatePopulateget_StateEditorBrowsableStateConnectionState<>1__stateEvaluateget_CanWriteIAssessmentNoteXAttributeCompilerGeneratedAttributeGeneratedCodeAttributeDebuggerNonUserCodeAttributeNeutralResourcesLanguageAttributeDebuggableAttributeEditorBrowsableAttributeAssemblyTitleAttributeAsyncStateMachineAttributeIteratorStateMachineAttributeDefaultValueAttributeAssemblyTrademarkAttributeTargetFrameworkAttributeDebuggerHiddenAttributeExtensionAttributeAssemblyFileVersionAttributeAssemblyInformationalVersionAttributeAssemblyConfigurationAttributeInternalsVisibleToAttributeDefaultMemberAttributeJsonConverterAttributeJsonConstructorAttributeHasAttributeFlagsAttributeCompilationRelaxationsAttributeJsonObjectAttributeAssemblyProductAttributeAssemblyCopyrightAttributeCLSCompliantAttributeDebuggerDisplayAttributeParamArrayAttributeAssemblyCompanyAttributeRuntimeCompatibilityAttributeJsonPropertyAttributeExecuteShouldSubstituteSByteget_ErrorConverterCannotReadJSONValueTValueget_Valueset_ValueFindValuesingleValueget_ErrorConverterCannotWriteValueTryGetRefValuehasExistingValueexistingValueget_ErrorJsonWrongValueTryGetCliValuelocalValueTryGetNilValueget_HasValueTryGetObjectValueTryGetValueSetValuesqlDateTimeDefaultValuenewValueKeyValueGetPropertyValuevalueget_IsUniqueisUniqueHivehiveget_ErrorJsonSingularRangeInclusiveget_ErrorJsonSingularLeftRangeInclusiveget_ErrorJsonSingularRightRangeInclusiveTryRemovexeget_SizecolTypeSizeKeySizeSpecializeSerializeDeserializeget_ErrorProbeInitializeNormalizeSplitIfIsSupersetOfLastIndexOfprobeRefget_Eofset_Eofget_PresenceFlagset_PresenceFlagHasFlagEngineConfigLoadJsonConfigSystem.ThreadingEncodingTypeNameHandlingset_NullValueHandlingset_DefaultValueHandlingset_PreserveReferencesHandlingCeilingSystem.Runtime.VersioningToWarningRequirementsWarningIAssessmentWarningToBase64StringReadStringget_ErrorValueIsAWhiteSpaceStringGetVariableStringFormattableStringEscapePowerShellDoubleQuoteStringEscapePowerShellSingleQuoteStringFormatVariableValueStringGetVariableValueStringToDebugStringToStringReadAsStringGetStringassemblyStringget_ErrorEmtyStringget_ErrorValueIsAnEmptyStringSubstringexistingargMicrosoft.SqlServer.Management.Assessment.Configuration.IPattern<System.String>.IsMatchget_ErrorEvalTypeMismatchTouchget_Morphset_MorphIDataMorphRenameDataMorphCompositeDataMorphFlattenDataMorphNoDataMorphdataMorphRowWiseCachedMorphMultidimensionalCachedMorphAggregateProbeMorphStringFieldParseMorphCreateMorphReadCompositeMorphDefaultValueMorphToStringMorphIMultidimensionalMorphIndexDefinitionMorphDbInfoMorphDuplicateIndexesMorphRedundantIndexesMorphNameValuePairsMorphIRowMorphExtValueRowMorphIndexMorphApplyMorphmorphComputeStringHashfreshPublishMathget_Pathget_TargetPathtargetPathkeyPathpathget_Lengthset_LengthUnionWithEndsWithStartsWithIntersectWithSplitWithExceptWithWmiobjAsyncCallbackcallbackget_CallStackICheckget_CheckCreateCheckWarningCheckIQuasiCheckUnsupportedTargetCheckCreateNewCheckcheckPeekget_HelpLinkset_HelpLinkhelpLinkget_Taskget_CompletedTaskPhysicalCriticalDecimalget_OrdinalCompareOrdinalordinalget_Originalget_KeyOriginaloriginalReadDateLiteralTryConvertToPowerShellLiteralReadNullLiteralReadBooleanLiteralToLiteralReadIntegerLiteralReadFloatLiteralget_TotalSequenceEqualAreEqualop_LessThanOrEqualactualSystem.Collections.ObjectModelSystem.ComponentModelget_Levelset_Levelset_ConformanceLevelminLevelSeverityLeveltailAlgebraicUtilSerializationUtilCollectionUtilDictionaryUtilRemoveAllTrueForAllProvidesAllAddCallInvokeProbeCallGetProbeCallCreateCallcallMicrosoft.SqlServer.Assessment.dllCmdShellPowerShellIsDBNullget_GroupingColumnNameCannotBeNullWriteNullCheckNullget_NotNullset_NotNullallowNullSystem.XmlCliXmlget_Eolset_EolIToolTToolXpRegXToolIAzureToolUnavailableAzureToolget_BaseToolIWmiToolPsWmiToolICmdShellToolXpCmdShellToolIPowerShellToolCmdPowerShellToolISqlToolsqlToolGetToolSetToolIRegistryTooltoolGetDataImplAzureSqlComposeMsSqlGetManifestResourceStreamGetDefaultConfigurationStreaminputStreamDivRemToStringElemObjElemMsElemObjsElemPropsElemTItemget_Itemset_ItemTagItemIsItem<>3__firstItemnewItemitemSystemSemaphoreSlimget_Trimset_TrimnmReadFromLoadFromIsAssignableFromLoadAssemblyFromget_TransformCheckInPlaceTransformtransformget_Platformset_PlatformplatformSumEnumresourceManBooleanTimeSpanJTokenget_ErrorJsonUnexpectedToken<>3__endTokenget_ErrorJsonWrongTokenJsonTokenget_Childrenchildrenget_Flattenset_FlattenWmiProbeTypeSignExternalProbeTypeSignCmdShellProbeTypeSignPowerShellProbeTypeSignSqlProbeTypeSignKustoProbeTypeSignClrProbeTypeSignRegistryProbeTypeSignStringSubstitutionSignRegexSignComplementarySignMinget_Joinset_Joinget_Columnget_ValueColumnset_ValueColumnIndexColumnget_KeyColumnset_KeyColumncolumnUnionget_Versionset_Versionget_SchemaVersionset_SchemaVersionget_OriginVersionset_OriginVersionrulesetVersionComposeByVersionversionUnaryFuncExpressionReadNamedExpressionAndExpressionSequentialCompositeExpressionDecimalAssociativeExpressionMatchExpressionNullLiteralExpressionIntervalExpressionInExpressionColumnExpressionstrictComparisonExpressionOrExpressionGreaterExpressionEqualsExpressionLessExpressionIntersectExpressionNotExpressionArrayExpressionUnaryExpressionDecimalBinaryExpressionexpressionSpecificationspecificationget_ErrorJsonOperatorInstantiationTranslationInformationget_ErrorJsonUnsupportedOperationoperationMicrosoft.SqlServer.Management.Assessment.Configurationget_Configurationset_Configurationconfigurationget_ImplementationIProbeImplementationGetProbeImplementationget_ErrorCheckHasNoImplementationTryGetImplementationimplementationrepresentationSystem.GlobalizationCheckSpecializationSystem.Runtime.SerializationMemberSerializationMicrosoft.SqlServer.Management.Assessment.Configuration.CustomizationSystem.ReflectionTCollectionICharacteristicCollectionProbeCollectionRuleCollectionCaptureCollectionValueCollectionMatchCollectionGroupCollectionIDataParameterCollectionDbParameterCollectionemptyMeasurementCollectionKeyCollectioncollectionMicrosoft.SqlServer.Management.Assessment.Tools.ISqlTool.ConnectionMicrosoft.SqlServer.Management.Assessment.Tools.ISqlTool.get_Connectionset_ConnectionIDbConnectionconnectionsectionroundingFunctionget_EngineEditionset_EngineEditionSqlEngineEditionengineEditionop_Additionget_Conditionset_Conditionget_DefinitionCheckDefinitionget_ErrorTargetFilerInDefinitionget_FilterDefinitionfilterDefinitionget_LinePositionget_ErrorJsonLocationWithLinePositionlinePositionIOExceptionget_Exceptionset_ExceptionInvalidDataExceptionSqlAssessmentMissingDataExceptionDbExceptionFileLoadExceptionCreateAssemblyLoadExceptionNotImplementedExceptionNotSupportedExceptionBuildExceptionProbeNotFoundExceptionFileNotFoundExceptionKeyNotFoundExceptionSqlAssessmentProbeExceptionArgumentOutOfRangeExceptionHandleExceptionAggregateExceptionSqlAssessmentTypeMismatchExceptionArgumentNullExceptionCreateWrongTokenExceptionInvalidOperationExceptionSqlAssessmentEvaluationExceptionJsonSerializationExceptionSqlAssessmentJsonExceptionget_InnerExceptioninnerExceptionSqlAssessmentProbeParameterExceptionProbeRequirementsExceptionBadImageFormatExceptionSqlAssessmentFormatExceptionSetExceptionArgumentExceptionInvalidCastExceptionStackOverflowExceptionSqlAssessmentOverflowExceptionOutOfMemoryExceptionSqlAssessmentArityExceptionSecurityExceptionexceptionget_Descriptionset_Descriptionget_UnsupportedTargetCheckDescriptionSystem.Data.CommonMicrosoft.SqlServer.Management.Assessment.Configuration.JsonNewtonsoft.JsonReadJsonWriteJsonLoadRuleFactoryJsonPushRuleFactoryJsonReasonget_StringComparisonstringComparisoncomparisonMicrosoft.SqlServer.Management.Assessment.config.jsonRequirementsSingletonget_Urnset_Urnget_PatternStaticPatternReadPatternVariablePatternget_NamePatternget_ServerNamePatternserverNamePatternnamePatternget_MachineTypePatternmachineTypePatternExactStringPatternParsingPatternParamPatternSqlObjectLocatorPatternget_GetPatterngetPatternRegexPatternkeyPatternpatternget_IsDryRunisDryRunCompareToIsSimilarToApplyToCopyToIJsonLineInfoHasLineInfolineInfoCultureInfotblInfoSerializationInfoserializationInfoMemberInfoget_TextInfoIndexInfoindexInfoinfoget_ReadsRatioreadsRatioget_Mapset_MapcapheapComposeMsOlapget_ReprepindexToSkipget_TimestampsubGroupFileGroupDataRowGroupAvailabilityGroupSystem.Xml.LinqSystem.LinqNewtonsoft.Json.LinqBitOrClearget_Charset_Charget_IsSingularvarget_LineNumberlineNumberget_Readerset_ReaderDbDataReaderCreateReaderStringReaderXmlReaderStreamReaderget_ErrorJsonReaderLinesReaderExecuteTextReaderJsonTextReadertextReader<>3__readerICharacteristicProviderRoleCharacteristicProviderFeatureCharacteristicProviderPermissionsCharacteristicProviderChannelPresenceProviderIFeatureProviderHadrProviderILogicsProviderServicesProviderSysConfigurationsProviderIFormatProviderTryGetProviderproviderAsyncTaskMethodBuilderRequirementsWarningBuilderStringBuilderCheckModificationBuilder<>t__builderRenderRemainderget_ResourceManagerget_ErrorEvalOtherotherSystem.CodeDom.Compilerget_SchedulerGetFlattenerXContainerToUpperget_Grouperset_GrouperSingleFieldGrouperMultipleFieldGrouperSingularGrouperIResultGrouperget_ResultGrouperset_ResultGrouperDefaultResultGrouperget_ComparerExpressionByReferenceComparerStringComparerProbeCallComparerGroupsComparerSqlLocatorAccessPointComparerIEqualityComparerget_StructuralEqualityComparerCallPriorityComparercomparerget_ParserparserIDataParameterIDbDataParameterDbParameterAddParameterSetCommandParameterget_ErrorEvalWrongProbeParametervalueNameParameterHasSameParameterCreateParameterkeyParameterparameterYieldAwaiterConfiguredTaskAwaiterGetAwaiterJsonWriterwriterget_TargetFilterset_TargetFilterAggregateFuncConverterProbeConverterProbeReferenceConverterAssessmentMessageConverterDataMorphConverterStringEnumConverterExpressionConverterCheckModificationConverterProbeCollectionConverterConditionConverterFlatMeasurementJsonConverterGrouperConverterRegexListConverterExtendedRegexConverterSqlProbeQueryPropertyConverterValueGetterComposeReportServerCreateJsonSerializer<>3__serializergrpairBitXorget_MajorFloorProbeErrorCheckErrorFatalErrorNoChecksErrorProbeRequirementsErrorIAssessmentErrorHypervisorget_AccessorCheckEnabledAccessorCheckMessageAccessorCheckDisplayNameAccessorCheckHelpLinkAccessorCheckConditionAccessorCheckDescriptionAccessorCheckParameterAccessorCheckProbesAccessorCheckTagsAccessorCheckLocalsAccessorCheckTargetAccessorCheckSeverityAccessoraccessorISqlObjectLocatorlocatorcreator<>3__aggregatorget_Separatorset_SeparatorNamespaceSeparatorDefaultSeparatorget_ListSeparatorPropertySeparatorIEnumeratorCharEnumeratorSystem.Collections.Generic.IEnumerable<Microsoft.SqlServer.Management.Assessment.Configuration.Range<T>>.GetEnumeratorSystem.Collections.Generic.IEnumerable<System.Collections.Generic.KeyValuePair<System.String,Microsoft.SqlServer.Management.Assessment.Probes.ProbeFamily>>.GetEnumeratorSystem.Collections.Generic.IEnumerable<System.Int32[]>.GetEnumeratorSystem.Collections.Generic.IEnumerable<System.String>.GetEnumeratorSystem.Collections.Generic.IEnumerable<Microsoft.SqlServer.Management.Assessment.Checks.Check>.GetEnumeratorSystem.Collections.Generic.IEnumerable<Microsoft.SqlServer.Management.Assessment.Checks.ICheck>.GetEnumeratorSystem.Collections.Generic.IEnumerable<Microsoft.SqlServer.Management.Assessment.Expressions.Expression>.GetEnumeratorSystem.Collections.Generic.IEnumerable<Microsoft.SqlServer.Management.Assessment.Data.Morphs.DataRowGroup>.GetEnumeratorSystem.Collections.Generic.IEnumerable<System.Data.Common.DbDataReader>.GetEnumeratorSystem.Collections.Generic.IEnumerable<TBasket>.GetEnumeratorSystem.Collections.Generic.IEnumerable<Microsoft.SqlServer.Management.Assessment.IAssessmentResult>.GetEnumeratorSystem.Collections.Generic.IEnumerable<Microsoft.SqlServer.Management.Assessment.Measurement>.GetEnumeratorSystem.Collections.Generic.IEnumerable<Microsoft.SqlServer.Management.Assessment.IDataRow>.GetEnumeratorSystem.Collections.IEnumerable.GetEnumeratorenumeratorMatchEvaluatorActivator.ctorget_FillFactorfillFactor.cctorget_Selectorset_SelectorCheckByIdSelectorReadSelectorCheckByTagSelectorstringSelectorget_CheckSelectorcheckSelectorselectorconstructorstrictComparisonExprerrstrRefIdAttrNameAttrStreamAttrPassVariableAsIsget_ProbeNameAliasprobeNameAliasaliasMicrosoft.SqlServer.Management.Assessment.Logicsget_Logicsset_LogicsTwoPhaseLogicsMicrosoft.SqlServer.Management.Assessment.Probes.Characteristicsget_FailedCharacteristicsUpdateCharacteristicsget_KnownCharacteristicsCollectCharacteristicsSystem.DiagnosticsMicrosoft.SqlServer.Management.Assessment.Data.AggregateFuncsget_CheckIdscheckIds<>3__suspectIdsidsfieldsget_Methodsset_MethodsmethodsMicrosoft.SqlServer.Management.Assessment.Probesget_Probesprobesget_IndicesindicesSystem.Runtime.CompilerServicesGetServicesreferencesSystem.ResourcesMicrosoft.SqlServer.Management.Assessment.Properties.Resources.resourcesAggregateFuncCodesExpressionTypeCodesDataMorphCodesDebuggingModesIncludesget_RangesReadRangesget_CheckChangeschangesrangesMatchesget_MissingDependenciesset_MissingDependenciesGetMissingDependenciesGetDependenciesMicrosoft.SqlServer.Management.Assessment.Propertiesget_ErrorMultuallyExclusiveJsonPropertiesget_Rulesset_RulesFieldNamesvalueNamesGetGroupNamesgroupNamesGetNamesget_LinesExecuteLineslinesMicrosoft.SqlServer.Assessment.Typesget_Typesget_KeyColumnOrderedTypesget_ToolTypestoolTypestokenTypesKeyColsTypesget_CapturesOnPremisesDuplicatesget_KeyColsDataLengthBytesGetBytesget_ValuesconfirmedValuesGetValuesvaluesMicrosoft.SqlServer.Management.Assessment.Data.Morphs.IndexesProcessTableIndexes<>3__tableIndexesrefsget_TagssuspectedTags<>3__checkIdsOrTagscheckNamesOrTags<>3__suspectTagsGetTagstagsXmlReaderSettingsJsonSerializerSettingsargsMicrosoft.SqlServer.Management.Assessment.Data.Morphs<>4__thisOpeningInclusiveParenthesisClosingInclusiveParenthesisMicrosoft.SqlServer.Management.Assessment.Checksget_Checksset_ChecksGetImplementedChecksbaseChecksGetChecksGetNewCheckschecksSystem.Threading.Tasksget_Localsset_LocalsEqualsIndexDetailsUtilsget_CallscallsIncludedColsKeyColsMicrosoft.SqlServer.Management.Assessment.Toolsget_ItemsitemsContainsget_Columnsset_Columnsget_IncludedColumnsget_OrderedColumnsget_KeyColumns<>3__columnsExtensionsMicrosoft.SqlServer.Management.Assessment.ExpressionsSystem.Text.RegularExpressionsGetRecommendationsGetCombinationsGetPermutationsget_CheckSpecializationsSystem.Collectionscollectionsget_CheckDefinitionsget_OptionsRegexOptionsget_Exceptionsget_InnerProbeExceptionsget_InnerExceptionsinnerExceptionsexceptionsoptionsStructuralComparisonsOverlapsget_Groupsget_CharsInitializeCharacteristicProvidersRuntimeHelpersComposersget_Parametersset_ParametersparametersNewtonsoft.Json.Convertersset_ConvertersStandardConvertersGetConvertersTryGetNameValuePairsget_ErrorsGetProbeErrorsThrowOnErrorsget_SuccessExpresserrorObjectsGetSuspectsGetResultSetsMeetsget_Rulesetsget_CurrentRulesetsset_CurrentRulesetsget_Hitshitsget_ProbeResultsget_InnerResultsinnerResultsGetAssessmentResultsresultsDescendantsCodeSignConstantsElementsget_Requirementsset_RequirementsStaticRequirementsget_ErrorProbeRequirementsadvanceRequirementsCollectRequirementsrequirementsGetEmptyMeasurementsGetNArgumentsGetFirstNArgumentsget_ArgumentsCheckUnexpectedArgumentsargumentsExistsFilterContextsGetContexts<>3__contextsget_WarningCheckSkipped3PlusdataRowsTransformRowsJoinRowsget_HasRowsget_TotalDaysget_KeysEnumKeysCollectKeysPrefixKeysRemoveAtElementAtConcatAppendFormatget_ErrorEvalStringFormatformatSubtractJObjectXObjectReadAggregateFuncObjectReadObjectITargetedObjectPopulateObjectReadMorphObjectToObjectGetPropertyObjectobjectget_Subjectset_SubjectsubjectSelectIsSuspectIntersectdictget_Distinctset_DistinctGetTTargetget_Targetset_Targetget_StringTargetget_ErrorAccessTarget<>3__targetTBasketSystem.Collections.IEnumerator.ResetIRulesetAddRulesetGetRulesetget_DefaultRulesetset_DefaultRulesetdefaultRulesetDateTimeOffsetpathOffsetget_Leftget_IncludesLeftincludesLeftleftget_Rightget_IncludesRightincludesRightrightConfigureAwaitop_Implicitop_ExplicitSplitget_DefaultGetValueOrDefaultFirstOrDefaultTResultget_Resultset_ResultIAsyncResultIProbeResultFailedProbeResultget_NullParamResultnullParamResultFromResultcomparisonResultGetResultSetResultIAssessmentResultNextResult__resultToUpperInvariantComposeSqlAgentXElementget_ElementReadStartElementelementSingleFieldMeasurementTwoFieldMeasurementToMeasurementEnvironmentMicrosoft.SqlServer.AssessmentMicrosoft.SqlServer.Management.AssessmentXDocumentget_Documentget_ErrorJsonUnexpectedEndOfDocumentcliXmlDocumentComponentparentSystem.Collections.Generic.IEnumerator<System.Collections.Generic.KeyValuePair<System.Collections.Generic.HashSet<System.String>,System.Collections.Generic.IReadOnlyList<Microsoft.SqlServer.Management.Assessment.ProbeRequirementsError>>>.CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Configuration.Range<T>>.CurrentSystem.Collections.Generic.IEnumerator<System.Int32[]>.CurrentSystem.Collections.Generic.IEnumerator<System.String>.CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Checks.Check>.CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Checks.ICheck>.CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Expressions.Expression>.CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Data.Morphs.DataRowGroup>.CurrentSystem.Collections.Generic.IEnumerator<System.Data.Common.DbDataReader>.CurrentSystem.Collections.Generic.IEnumerator<TBasket>.CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.IAssessmentResult>.CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Measurement>.CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.IDataRow>.CurrentSystem.Collections.IEnumerator.CurrentSystem.Collections.Generic.IEnumerator<System.Collections.Generic.KeyValuePair<System.Collections.Generic.HashSet<System.String>,System.Collections.Generic.IReadOnlyList<Microsoft.SqlServer.Management.Assessment.ProbeRequirementsError>>>.get_CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Configuration.Range<T>>.get_CurrentSystem.Collections.Generic.IEnumerator<System.Int32[]>.get_CurrentSystem.Collections.Generic.IEnumerator<System.String>.get_CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Checks.Check>.get_CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Checks.ICheck>.get_CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Expressions.Expression>.get_CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Data.Morphs.DataRowGroup>.get_CurrentSystem.Collections.Generic.IEnumerator<System.Data.Common.DbDataReader>.get_CurrentSystem.Collections.Generic.IEnumerator<TBasket>.get_CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.IAssessmentResult>.get_CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.Measurement>.get_CurrentSystem.Collections.Generic.IEnumerator<Microsoft.SqlServer.Management.Assessment.IDataRow>.get_CurrentSystem.Collections.IEnumerator.get_Current<>2__currentSystem.Collections.ConcurrentIsPresentget_Countget_FieldCountactualArgumentsCountGetServiceAccountDotget_RootXpCmdShellScriptscriptStartInsertCanConvertJsonConvertSortCastLastrestTRequestIAssessmentRequestProcessAssessmentRequestrequestIListget_SpecListToListSpecGroupListget_ErrorListGetAssessmentResultsListkeyListEmptyListlistget_DispatchPostFirst<>3__inputMoveNextSystem.TextParameterizedTextget_CommandTextset_CommandTextcommandTextVmIdWmiQueryTextVmAssetWmiQueryTextVmSqlQueryTextSqlOnVmKustoQueryTextExtraDataContextget_ProbeContextGetProbeContextprobeContextget_BaseContextbaseContextStreamingContextstreamingContextBuildCheckContextcheckContextPermutationContextIEvaluationContextget_EvaluationContextDerivedEvaluationContextbaseEvaluationContextAttributeEvaluationContextget_GlobalEvaluationContextget_SystemEvaluationContextevaluationContextcontextvIDataViewConstantDataViewCachedMorphingViewRowMorphingViewCliXmlViewLinesViewProbeResultViewviewget_NowIDataRowCreateDataRowdataRowsourceRowget_BaseRowbaseRowExtValueRowMorphingRowCliXmlRowget_ErrorEvalOverflowrowMaxidxget_IndexFindIndexFindLastIndexarrayIndexindexRegexinstancePrefixVariablePrefixprefixGroupByOrderByReadArrayInitializeArrayToArrayarrayTDependencyTKeyget_KeySqlPublicKeyToolKeyServicesKeyContainsKeyget_IsPrimaryKeyisPrimaryKeyQueryKeykeyget_AssemblyLoadAssemblyget_ErrorLoadingAssemblyGetExecutingAssemblyProbeFamilyget_IsReadOnlyMultiplyApplyIndexOfAnySelectManyCopyParseBoundaryTDictionaryToDictionarydictionaryget_Queryset_QuerycharacteristicQuerySingleValueInstanceQueryEnumKeysInstanceQuerySingleValueQuerykustoQueryEnumKeysQueryqueryPushRuleFactoryFormattableStringFactoryfactoryIInventoryget_InventoryInitializeInventoryinventoryget_Registrycapacityop_Equalityop_InequalityexpectedArityget_ErrorEvalArityget_Severityseverityget_PrioritySystem.Securityget_EmptyIsNullOrEmptyget_IsEmptyget_ErrorJsonMissingPropertyget_ErrorMissingJsonPropertylocator	attr.::index, {0:S\{(?<key>(\w|\.|::)+)(:(?<format>.*?))?\}check: . 
system
global
target!checkNamesOrTags
checksfactorykMicrosoft.SqlServer.Management.Assessment.config.json__NoChecks#Microsoft Rulesetchannel 
<null>'''}Microsoft.SqlServer.Management.Assessment.Properties.ResourcesErrorEmtyString-ErrorCheckTargetChange'ErrorInvalidCheckIdErrorEvalArity)ErrorEvalMissingData#ErrorEvalOverflow+ErrorEvalStringFormat+ErrorEvalTypeMismatch)ErrorIndexOutOfRange1ErrorJsonMissingProperty=ErrorJsonOperatorInstantiationErrorJsonReaderEErrorJsonSerializationNotSupported?ErrorJsonSingularRangeInclusiveAErrorJsonUnexpectedEndOfDocument1ErrorJsonUnexpectedToken;ErrorJsonUnsupportedOperation'ErrorJsonWrongToken'ErrorJsonWrongValue9ErrorValueEndsWithWhiteSpace;ErrorValueIsAWhiteSpaceString3ErrorValueIsAnEmptyString=ErrorValueStartsWithWhiteSpace9ErrorEvalWrongProbeParameter7ErrorStringOrObjectExpected=ErrorConverterCannotWriteValueCErrorConverterCannotReadJSONValue7ErrorVersionFieldIsRequired1ErrorNameFieldIsRequired!ErrorKeyNotFound=ErrorImplementationWasNotFoundGErrorJsonSingularLeftRangeInclusiveIErrorJsonSingularRightRangeInclusive-ErrorRecursionDetectedEErrorValueCannotBeNullOrWhiteSpaceKErrorMultuallyExclusiveJsonProperties1ErrorMissingJsonProperty9ErrorTargetFilerInDefinition?ErrorUnrecognizedChecksItemTypeOError_CheckModificationSelectorResuiredErrorEvalOther;UnsupportedTargetCheckMessageCUnsupportedTargetCheckDescriptionCUnsupportedTargetCheckDisplayName5ErrorFailedObtainProbeData;ErrorCheckHasNoImplementation#ErrorAccessTargetStringCheckIdStringTarget=ErrorConditionEvaluationFailedCErrorJsonLocationWithLinePosition)ErrorProbeInitialize)ErrorLoadingAssemblyUNotEnoughPermissionsToRunAssessmentMessage-ErrorProbeRequirements=GroupingColumnNameCannotBeNullKUnsupported_PowerShell_parameter_type)WarningCheckSkipped1)WarningCheckSkipped2)WarningCheckSkipped31WarningCheckSkipped3Plusvalue	data	path_http://schemas.microsoft.com/powershell/2004/04ToStringPropsMSObj	ObjsSNRefIdRefNilBCDTTSGBAURIVersionXDSBKSSBySBU16I16U32I32U64I64SgDbDprogresstoolTypekeySQLCmdShellPowerShellWMIRegistryAzurelinesaUnavailableAzureTool.Query should not be called.Aobject permission on xp_cmdshellEXECUTE#sys.configurationxp_cmdshell?.InvocationInfo.PositionMessage	    $=;
$({0})��powershell -NoLogo -NoProfile -ExecutionPolicy RemoteSigned -OutputFormat Xml -EncodedCommand 
$false$trueeGet-WmiObject -computername 'localhost' -query {0} | ��Add-Member -MemberType ScriptProperty -Name '{0}' -Value {{$this.{1}()}} -PassThru?object permission on xp_regreadGobject permission on xp_regenumkeysQobject permission on xp_instance_regreadYobject permission on xp_instance_regenumkeys(?<!@)@{(.*)}commandTargetName@ProductVersion%ServerMajorVersion services installedMSSQLServerMSSQLSQLServerAgentSQLAgent-MSSQLServerOLAPService
MSOLAP5SQLServerReportingServices{0}{1}0^service$ReportServerMsDtsServerMSSQLFDLauncherSQLBrowser	name= in sys.configurations set to = in sys.configurations enabledI^sys.configuration(\s+(?<name>.+))?$access to ^channel$	HADR enabled^feature$class
OBJECT permission	 on W^(?<class>.+) permission( on (?<name>.+))?$ role
^role$
source
columnimplementationmorphVALUETableNameIndexNameis_primary_keyIndexTypefill_factoris_disabledis_unique	HitsReads_Ratio#filter_definitionColumnName%is_included_columnkey_ordinalColTypeNameColTypeSizeids	tagsoriginalarguments	itemprobeIdaliasgetPatternarraynewItem	restitemTypeDEFINITIONOVERRIDE5targetFilter, targetFilterCheckRuleidtargetFilterdisplayNamedescriptionmessagehelpLinklevel
probesconditionenabled
locals!string, string[]GrouperQueryPropertyProbeIAggregateFunc	type#ParameterizedTextConditionExpressionIPatternnotProbeCollectionCLRExternalKustoprobe typeassemblyStringassemblyProbeReference
paramstransformIDataMorphRangeleftBracketrightBracket	leftcommaright��^\s*(?<leftBracket>[([])?\s*(?<left>[^,)\] ]+)?\s*(?<comma>,)?\s*(?<right>[^,)\] ]+)?\s*(?<rightBracket>[)\]])?\s*$	 or 	lessgreaterequalltgteqieqiniinorandaddsubmuldivmod
bitandbitor
bitxorgreaterequallessequalnotequalgeleneineintersectceilingfloormatch
imatchindexofiindexofstartswithistartswithendswithiendswithintervalminmaxaggregate
renameindexDefinition!redundantIndexes!duplicateIndexes
dbInfo
noDatanameValuePairsparsetoStringdefaultValue	joincount{}changesparameterNameaccessor
formatgSELECT virtual_machine_type FROM sys.dm_os_sys_infoPhysicalHypervisorOther��Select * FROM Win32_SystemEnclosure WHERE SMBIOSAssetTag = '7783-7084-3265-9085-8269-3286-77'SSELECT * FROM Win32_ComputerSystemProductOutput.UUID��Resources

| where type =~ 'Microsoft.SqlVirtualMachine/sqlVirtualMachines'

| extend vmResId = toupper(tostring(properties.virtualMachineResourceId))

| join (Resources

    | where type =~ 'Microsoft.Compute/virtualMachines'

    | where properties.vmId =~ '{0}'

    | extend vmResId = toupper(tostring(id))) on vmResId

| project name, id, vmResId

| top 1 by namevmResIdazure_vm_id-azure_sql_on_vm_res_idazure_vm_res_idAzureSQLrequestprocedure;EXEC master..xp_cmdshell @cmd	@cmd#< CLIXMLErrorOEXEC xp_regread @hive, @key, @valueNameaEXEC xp_instance_regread @hive, @key, @valueName@hive	@key@valueName\*%HKEY_LOCAL_MACHINEASYSTEM\CurrentControlSet\ControlCurrentUserEEXEC xp_regenumkeys @hive, @parentWEXEC xp_instance_regenumkeys @hive, @parent@parentRegistryKeyName
stdoutrunSpaceserviceaccountCSYSTEM\CurrentControlSet\ServicesESYSTEM\CurrentControlSet\Services\ObjectNamekSELECT [name], [value_in_use] FROM sys.configurations��SELECT [value_in_use] FROM sys.configurations WHERE [name] = @name@nameOSELECT SERVERPROPERTY ('IsHadrEnabled')��SELECT [permission_name] FROM [sys].[fn_my_permissions](@securableName, @securableClass)@securableClass@securableNameDATABASE_SELECT ISNULL(IS_SRVROLEMEMBER('@roleName'), 0)@roleName��SELECT count(*) FROM fn_my_permissions(NULL, 'SERVER') WHERE permission_name = 'VIEW SERVER STATE'��SELECT count(*) FROM fn_my_permissions(NULL, 'DATABASE') WHERE permission_name = 'VIEW DATABASE STATE'{0}:{1})LastKnownDBCCDaysAgo+dbi_dbccLastKnownGoodUpdSysCatalog#dbi_updSysCatalogCreateVersion#dbi_createVersionDBCCFlagsdbi_dbccFlagsField7Do not use the same field ']' for grouping and aggregating simultaneously.TableIndexes,ToDeleteIsPrimaryKeyIsUnique	TypeKeyColumnsIncludedColumnsKeyColumnTypesFullNameKeySizeFillFactorIsDisabledReadsRatio!FilterDefinitionRangeListQDz�k�@�eK=��˚      M m  U m imU|	����
U��|�,Y��U������m��m��U��U����YLm����YL�� �m��U����������  ���$�4�$�@�$�P�|�@����������U�����|��|�P�|��|�X�|�4m��U����������$����m��U��������	����mU�� ���,����	�@��@��m��U������U�����U���� �Em�U��������U���� 
U����U��	���������� �����0�p���p}���p���p���p���p�x�pd�p� �p�,m�,U�,�p��p� �p���p��p���p�$�p�(m�$U�$�������,����� 	����	����������������,�������}�������
�����������������������	�YY] ��  m����
U��
m��	��  
��	 ��}U
}	 ���� 
��	����	 U4}��	��
}��� ��	�  ������ 
 ���$��	�$���� m��}XL��}}��y��Uy
�� ��
 U �q �q �q   }$
U
������y������y$
$UUyy��������UUy
��������
y$U��UUyU
$��UUUy��������y��������"��Uyy
�����������0	 ����������y������Uy
������m��������������U������m����������������������\ ������ ��������\ 	YL����YL��L��YL	��
��	������}L��}L
}��}L
}}L����
 ��`	�� �H ���,�� �� �� �� ��qUq
y
	U��  �� �}h}�� 	�P�Ph���� 	�T�T
 ��	�X�X ����	�� �,	���, ��m����U��m��
y���4
�4
y���@
�@
y���P
�P
y���X
�X
y���
�
y���
��\y�U�`y�
���U��h�Y�	�0
�h	 ���l
�l���� ������ ������0�Y
���p���
�p���q ���x�U�
�x��	
}��y��}��
}����������������U
����������������
�������������|�U��
�|���}��
��������
 �������� �����=
�� �	��
�� ���,	��`�,|`�,
��	��
 �������� ��$����
����y��	
��m�I�I �%y��Uy
�I�� y����y������
������	���� U��m��������
U����
m����	����������}����yM
M���	�����y��
�������Y ��	 �]�a�IM��q�i���mMM	M�� M
����
�q�u �u  �
 ��  ��	
 	 �����@�@�@��	����� �q �q ��&	��m���,���,����p
U���,
m���,	���,}��	���, �����,���,�,	���,&�I�Im���,���,y���,��Uy��
���, ������ �������������� �� U����y��Uy
��	���� ����
��������	��������m������	 U��U��m�� ��
y����
����	U
��UyU 4M M	4M�$
�� ����������My���(
y���(	����
y�� �(�� �%m �- �A�A ����
�}
������8
�� �h�������
��	}��}�������������� ����m����U��m��
 �����-  �1��m��������U��m�� �������}��
�������
�����
����
����
����
����
��
��y��
��
��}��������
���� y�|M	��	����|����	
�
M�
��
�
��m������ �5 �� ���	���
��
�y����� y� ������#���������������������������� ����  �A ���,
�,m�$�$U�$m�$���$�����������0
�0�����$ ��y��
��$m����������m����%m����������	 U��m�h�hU�hm�h��,}�������������� ���<
�<�@���
�@�D�
�D�I�I ����������������	���H
�H�L
�L�X
�X����	 ����M�(�\
�\�`
�`������	�����d
�d���q�h
�h�l
�l�t
�t}��mllm������UlmlU��m����$$m������$�xUUy$
$
	y��
���|
�|��y��
��	y��l
��l
ll#m�,�,�������,�,	 �����	���, ��	���,m�������,���,6
D}}$���,���,m$��$����$��
�������
����
������Mm������MM��MU��m����M	����}�,	����
�,��y�,
�,���q
���q ���q ���qU�, �q���q
  ���q�q
�����������
y����y��y�,U
�,UUm�,�,�I�IUUU
 U�,��
 ����,�,�I�I���,mm�,  
]������ �@���@�
����q�@��	�@
 �@
 �@y��
��U]
 ��
U����U��UUUU������
��������y��

��U$
����m����������y��
��
����}������������m���������� �� ��y��U��
����	U��2	��m�����)}��������
��}��
�%}�� �)
�)}��
 ������}��������]�!�!�!
�!]�!�!�!y��}��}�!
��}��}�!
}�!
�!�!y�!��
�!��0�@��}����}��������m
��}��
��}��}������UU}�!	���x}��y��
���������i���m)����� m������� � ����� 	��� 

}�$y����� U��
����� ��y�0U�9Uy
�0y�9�0
�9�0U�9�0y��
y���0&U�9Uyy	
���0y�9�0U��
�9�0����}�}�	�@�@
 }�
 �y�	
����
 ��m����}��}��}��m��������������
��������������m����������
��U��m�����9y����U
����	U��m����U��m�����	 � U�	�X�X�	�\�\��`������y�������������� y
]������������ ]����������������
��	����}�M�	�}�M�y����M��p�M�	�p �M�y�M�
�M��M� �M� 	�ty�M�
�t �M�y�M�
�M� my�M�
�M��x	�x$���M��M����M��|	�|���M���	�� y�
y��M
����M�	��	������m����	����
����y���$	�$
 �$��}�$�(}�$
 }�$	 ��
���$�����$	����y�$	
�$ ��,	�(���Q�Q �]}�U�H���E��}���a �a	
}��
��


��}�����L
�0	��
���� �����0����
�����������	
��	
}�
� 

���,�a�a
�e�x���e�x�e�x	�i�x�i�Y �Y �Yd�,�,�a
�,�,
����yU�,�,}�,��yU�,�,yU�,�,�i�m��Y�	
��� � �m �YM����
 ��� �UM �]�� MMM	� ��
�i�m	 �q�m ��U�m
��
�d
�t
��
�l
�x�q�u�y�q�q���y���u�m�qM�� M�m�qM��M�m�i���,���a
���,
�e�����e���e��	�i����
���������a��
 ���Y����	 ���� ��U�$�Y�� U�$���Y������ �m �� � ���U�����m �m�m �m
��U
�a����������
 �������H}��}����m���,���,�����, �q�����������������������
����������.��������������������	��
���� ��	 ��	���� ��	��
����
m ��	��
 Um	 ���� ���q
 �	]U]
��Y�	�
YYY	�
���	�}]
�yY	 YyY	
Y	y y

}����	] ]UU]

�PX����YL��\��\yL
L�@\	 ��0xY�U��U��U���
 ��U�	 ��U�
0
�U��h
� ��
�U��l	���!�)�%�-�5�1���% �)
�)�p �1 �5
�5�p
�������t'xU��}���}������}���}���}��
�}���xS
xU�����������9����}���}���}������������������
����|
y����
����U�9����m�9�����9����
�}���|��x}����������U�}����5�1�9��������}���}���}��}���}��������
�����
�5��}�
y���
���
�}����x�5�1��
�5��x%x�������5�1������������������������������
�5������
��� ������
�������������
�������������������
�����	��
��!	���5�1����	��y���Y �Y��
y���Y�Y�5�
�5��
y�������
�����	y��1�L}�u������������
 ��������������
�����  ��
���*�L�8}}�}�}��
��}
�}
�}
�}��5
�T��}}�}�}��������
�}�������� �� ���� ��	����$�`}���5�1���5��}��
�5�����`���5�1�� 
�5��)�`�u�u��������������
�����;�`�������������5�1��
�����
���
�5��1]������U���5�1��}}��
�5��
��]������
����y��	
��y����(
������������
�����
���*�d��}}�}�}��
�}��x�x��]������U����}Y}��}���}���}��������}����}����}��}��}��}��}���}���}��
�}����y����
����
 U�� ��(	�|�������������� ��������	���
����"����������������
 ��
 ����
����#��������������}��	����	���	���
���� #����������������
����y��U��
�����"����������������
�������	 ��}�$�5�1��y�����$
�����$
�$}�$
 ��
�5�,�$�5�1�����$
�5�0���8B
������������������������������
����<����
��<2������������������������
����@ U��>}��}���}���}����
�}���D-
�4������������
����H
��H�4�u����
��Lk�P��M�(�h����y����������������������}����	���(y����
����������
��X�������4����
��\c������������������������������������
��`0�4�u�u������������ ��
����d
��d�4����
��h2��}����}���}���}����
�}���l��$8��}��������ll�5�1�5l�5��
��t}l��l
�5�t
ylU�
l�h���4������ ��
��|��������������$	$����������������U�m�����������������
�����
y��$

��$y��$$
��$$�����5�1��
�5��$	����m�������5�1������
�5�����	�� m���X���� �������
��

�
 ��
 
������y��U�!
���!	
�!���- �-
��y��U�!
���!��]�!���!]�!���!y}��
}��y}��
}��
�!��y�!�!�� ��
�1y�1��
�1��	
��}��	���x�������x��U	���xy��
�����U���U��
��UU����9�0��0
U�9�0
m�9�0y�0
�0	�9�0�y�$
�$y�$
�$y�$
�$y�$	��� ����� �(y��� ��
��� ����}�0�0y�9�0U
�9�0}�0�<�������
������D
����U��m���H
���Py��
]������
�����T
��U���h%
�����U�����l�@�����,�����,�����$�a�$�$

�$	�$	��
 m�$����������������q�� ���q�qU�,���q����
���������{��-�Q��]̀�̑0�O沦�퀠$��$RSA1''6�n_�����1�:�fl/��y�����2}/��R4H�<=\]��Ǽ��(k,Q�\�$+�Au2����I���RmRo����{���l�؂O���1
�ˢ�#V{-��P���b�왹J�|};(��Ȃ�0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8attr::.#fSELECT virtual_machine_type FROM sys.dm_os_sys_info��Select * FROM Win32_SystemEnclosure WHERE SMBIOSAssetTag = '7783-7084-3265-9085-8269-3286-77'RSELECT * FROM Win32_ComputerSystemProductidvmResId��Resources

| where type =~ 'Microsoft.SqlVirtualMachine/sqlVirtualMachines'

| extend vmResId = toupper(tostring(properties.virtualMachineResourceId))

| join (Resources

    | where type =~ 'Microsoft.Compute/virtualMachines'

    | where properties.vmId =~ '{0}'

    | extend vmResId = toupper(tostring(id))) on vmResId

| project name, id, vmResId

| top 1 by nameOutput.UUIDazure_vm_idazure_vm_res_id,azure_sql_on_vm_res_idOutputprogress
ErrorSQLCmdShellPowerShellWMIRegistry
Azure:EXEC master..xp_cmdshell @cmd��powershell -NoLogo -NoProfile -ExecutionPolicy RemoteSigned -OutputFormat Xml -EncodedCommand $({0})dGet-WmiObject -computername 'localhost' -query {0}��Add-Member -MemberType ScriptProperty -Name '{0}' -Value {{$this.{1}()}} -PassThruNEXEC xp_regread @hive, @key, @valueName`EXEC xp_instance_regread @hive, @key, @valueNameDEXEC xp_regenumkeys @hive, @parentVEXEC xp_instance_regenumkeys @hive, @parentstdoutTargetNameservice$HKEY_LOCAL_MACHINEBSYSTEM\CurrentControlSet\ServicesnamechannelHADR
classrolePhysicalAzureSQLHypervisor
Otherintersect@,  @��versionplatformtypeengineEditionserverNamemachineTypetargetdisplayNamedescriptionmessagehelpLink
levelprobesconditionenabledtagstargetFilteritemTypelocalsDEFINITIONOVERRIDE/notimplementationassemblyCLRExternal
Kustoparams
aliastransform[]leftBracketrightBracketleft
right
commaTableNameIndexNameKeyColumnsIncludedColumns FilterDefinitionIsPrimaryKeyIsUniqueTypeKeyColumnTypesFullNameKeySizeIsDisabledFillFactorHitsReadsRatioU��	y�|����U��}$P��������U$�����������Y	��\}��}}Ld��	�������0�D�������E��
���������,}�������Y���������}���� 	���
���,��
���,��������������4M��My���(mm��}������}���0�hM������������
����<���y����U�,}�,�,]�������0�L���`���d�������
}�!��}��
���x��}��U����	����	����	����� ������������}��
����	�(�����
}�����U��yU�,�,���e�����e�x�������������������������]Y�(	y���,y������y$y��������y$U��y��������$m�������������8y�������<yL��X	��\	��\m����YL����YL\�Ly�d	y�y����
�Y�x
�U�	����)U�	���m�
�U�
�}��
�U����}��	���m�9����
�}�����=���4�X���A�����y��y����y��������y���,�}�L��	���	��8�}��y	y���T�}���`}���u��
������
y��U��}}���@�d��y�����x�����}����}��}�}������}��
���
������ y��������(}�$	���$�4y�������������
����y�����T������}����
���(��
����
����
���� �pylU�y$	y��y��$$}lh����l}	����U�l��	��$m��������m����	���	�����
y�,U����8�X�lm����y����
y������	y��������}��������y}��
���x��m���	y��	���������0�	y�0	y�0
�9�0m�9�0��}�$����� �,y����� U���4y�9�0	y��y���0�8y�9�0U	������m���Lm���dy��������	y���@���am�,�,�����q���q����	y�$	y�$	y�$	y�$����
UYUYY] ��|y�	 U��
 U��
 y� | �� �� ���� ��	 `�, ��	 U�� $������������
 ��}�� }$ $	 U$ �, ��������U$
 ������ �� U$ ���� �������� ��� �U������ �� ������
 ������	 m�� ��
 ��Y � �� �� Y L
 ��\ U����������YL
���� }�� }}L ��L m����YLd ������	 ���� �� �����
 ���� �� �0 � �� ��}���� ��}������ ��}����U ��}����U�� ��}����U� U��� ��Y��� U��� ��Y���
0y�� ��}����Uy� �� �� �� �� ���� ���� ����
 ������U��U������ ��U� ��}����y����� ��U���� ��}��
��(�� �	�� �� ���� �� ���� �� �� � D D  �� ��	 �� ����	 ���� ��
���� ������������ ����� �,	 }�� �����,�|0 �(M �h	 UM ���hUM ��
 �����Y0��y�� �� ��	 ���� �� �� �� � �� M	 M�� M�� MM MM��
 ������ ��M�q
�u�A�,��������	 }� �� �� �  � 
 ��� ��� ���, d d �� �� ���, ������ ���,�� ���, �� �������
��
������
���������� �� �� ������ ���� ������ ��}��Y ���������MMMM0��
 �(��M ��My���( My���( �A �� U m m�4��
 ��} ���8 ����@������}���P���� �����������X����� �	�� �	U}���A�u�u�	�A�u}}�� �������@�� ���������	 }��	 U �� �������P�� ����} ����} ���������YY�� UM ��������	 ��
 �� �������X�� �0 �0 �h  �������4��	 U�� �A���� U������ �����AU���� �� �	������ �������� ���� �h ��
 ������ �� ���� �	���� ���$�$��	�$�$�	��}�$ �$���� �$���� 
 ����U�h	�h�h	 U	 �����������������	�����	����	�h�� ���� ��}�� ��� ��}�� �� < <��}����Ul��l}��U��D����
}l l|��l	����	�,��U����}l�������Dl���$���	��lU�h����������h���	��U����	��U���� �� � U  �, �
 �U�,
 ��,
 y���� y����U�, 	 U�, U �	 }�, �
U	m
m � �, �, �  ]������ ]������U�, �q
 �qU�,
 �q�,�,�,���,�,�
�,�0	 �,�, �, ]�������,�L ��	 �`��	 U�� U����	 ��	 �d��	 �d�� ����
 ���� ��	 �� U���� ����	�� �� U��U�� U���� ��}�� ��}�� ��U�� �@ ���x �� ��	 }��
 U��
 ��U�� �� U���9�0	��U�9�0�9�0 ������ U���U�����
 m�����
 U��
 ����
 ����
 ����	 m�� �� �� �� �  �� �������9������
U��U������������ U��U�� U�������� U��U���� ����	 �� �������� �� �� } } �� �� U���U	 ���� �� �� �  	 U
 U    ��
 ���� �� �� ���� �� ���� ���� ���� �� �� m����	 m�� �� �$�$ �� �,) �(���������
 �(�� � �� �0 �YM��
 �]�� �]���� ���YM����
���U �]}���� }���YM}���� �� �� }���� �Y �� �� �]���� ���YM���������Y������(��������Y��������������Y�����Y�� �]���� ���YM���� �]�x�� �x�YM�x��	�x�Y�x�Y�� d�YMd�� �]d�� �]� �� � �YM� �� �]�,�� �,�YM�,��U�,�,�Y���aU�,�Y���a�,�Y��U�,�Y�� �]��� ��YM�����Y�� � �YM� �� �]� �� �]���� ���YM�������Y��	�q�Y���i�Y�����i�Y���i�Y�� �]��� ��YM��� �]���� ���YM�������Y��	���Y �]�$�� �$�YM�$�� �]�(�� �(�YM�(��
 �����Y��
������
���Y�����������Y�����������Y�����m�i���Y�m�Y���m�Y����
�Y�a���Y�a�Y	�Y
�Y�� �����, ���,�� �Y �� ���0U���� �0U����	 ���� �� �0U����	 ������	 ���  � ���� �� ������ ���� U���� ��	 ���, �,�� ����
 ��}� }�����	 ���� �������� �� ���� �����
 ����� ����	  m �� ������ �������� U��$ �������� ������ L ��	 m�� ����YL ��  � � ����	 m�� ���
 ��  ���� ������ ���,
 �� ������ �� �� ����
 �� ���� ��	 m��
 ����� ������ ����	 �$�$	 ��	 m�� ���� U�l $ $��$ �� l�� ��$
 U�,
 ����   ���! }�!��}�� U�!�� U�!�� }�� ���1 }�� �� �� ��	 m�� �0 �0 
����  ��	 }�$ 
 ��   �����  U�������  �� �9�0 �0�� U�9�0 �� ������ ������	 m�	 m�,
 ����	 ��	 �$ �,U�, �q �q �x �$ �$ �$ �$	(U��(
(y�(|(��((��(��(	(`�,(	(U��(}$
(������(��(U$
(������(��(�(��(��(Y
(��\(}��(}}L	(��(��
(����(��(�0(�(��
(��(��(��(��(�(D((��	(��(����(����(�,	(}��
(�����Y����	(}�(��(� 
(���(���,(d(��(���,
������(��(��(((��My���((��(m(m	(}��(����}(UM	(��(�0(�h(M(��
(��������(����(<��(�q(�	��	(U�,	(}�,(�,�0�L(����(��	(��(��(��}��(���x(��	(}��
(}�
(����
(����
(����(� (��	(�(��������(��(}(��(y�(((��
(����(��
(}�$
(�(��(�(��(}����(�Y	(������������������������(��	(��(��	(��(��(����YL(����(��((��	(}�$(U(
(	(�$TWrapNonExceptionThrows
1.0.49.0$Microsoft SQL Assessment EngineReleaseMicrosoft CorporationMicrosoft SQL Server$Microsoft. All rights reserved.MHMicrosoft SQL Server is a registered trademark of Microsoft Corporation.�z�tMicrosoft.SqlServer.AssessmentTests.Core, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8�u�oMicrosoft.SqlServer.AssessmentTests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8�x�rMicrosoft.SqlServer.AssessmentTests.Fx, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8���{Microsoft.SqlServer.Assessment.IntegrationTests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8����Microsoft.SqlServer.Assessment.IntegrationTests.Core, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8���~Microsoft.SqlServer.Assessment.IntegrationTests.Fx, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8�c�]SqlAssessmentTest, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8�l�fSqlAssessmentConnectedTest, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8�c�]Rules.TestAdapter, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8�k�eRules.TestAdapter.Console, PublicKey=0024000004800000940000000602000000240000525341310004000001000100272736ad6e5f9586bac2d531eabc3acc666c2f8ec879fa94f8f7b0327d2ff2ed523448f83c3d5c5dd2dfc7bc99c5286b2c125117bf5cbe242b9d41750732b2bdffe649c6efb8e5526d526fdd130095ecdb7bf210809c6cdad8824faa9ac0310ac3cba2aa0523567b2dfa7fe250b30facbd62d4ec99b94ac47c7d3b28f1f6e4c8
en-US6.NETStandard,Version=v2.0TFrameworkDisplayNameRMMicrosoft.SqlServer.Management.Assessment.AlgebraicUtil+<GetPermutations>d__0TOMicrosoft.SqlServer.Management.Assessment.AlgebraicUtil+<GetCombinations>d__1`2RMMicrosoft.SqlServer.Management.Assessment.ProbeResultView+<GetEnumerator>d__7YTMicrosoft.SqlServer.Management.Assessment.RequirementsWarningBuilder+<ToWarning>d__4PKMicrosoft.SqlServer.Management.Assessment.SpecGroupList+<GetEnumerator>d__7KFMicrosoft.SqlServer.Management.Assessment.Engine+<GetChecksAsync>d__25KFMicrosoft.SqlServer.Management.Assessment.Engine+<GetChecksAsync>d__27UPMicrosoft.SqlServer.Management.Assessment.Engine+<GetOpenedConnectionAsync>d__37QLMicrosoft.SqlServer.Management.Assessment.Engine+<GetImplementedChecks>d__38JEMicrosoft.SqlServer.Management.Assessment.Engine+<GetChecksCore>d__40PKMicrosoft.SqlServer.Management.Assessment.Engine+<ProcessRequestAsync>d__44UPMicrosoft.SqlServer.Management.Assessment.Engine+<ProcessAssessmentRequest>d__45IDMicrosoft.SqlServer.Management.Assessment.Engine+<MakeSpecific>d__57JEMicrosoft.SqlServer.Management.Assessment.Engine+<SpecifyVmType>d__58FAMicrosoft.SqlServer.Management.Assessment.ProbeCall+<Invoke>d__23D?Microsoft.SqlServer.Management.Assessment.Scheduler+<Run>d__3`2VQMicrosoft.SqlServer.Management.Assessment.Tools.XpCmdShellTool+<ExecuteLines>d__3[VMicrosoft.SqlServer.Management.Assessment.Tools.XpCmdShellTool+<ExecuteTextReader>d__4TOMicrosoft.SqlServer.Management.Assessment.Tools.CmdPowerShellTool+<Execute>d__4MHMicrosoft.SqlServer.Management.Assessment.Tools.XpRegXTool+<Execute>d__7NIMicrosoft.SqlServer.Management.Assessment.Tools.XpRegXTool+<EnumKeys>d__8YTMicrosoft.SqlServer.Management.Assessment.Tools.XpRegXTool+<IsChannelAvailable>d__10RMMicrosoft.SqlServer.Management.Assessment.Tools.XpRegXTool+<CollectKeys>d__11OJMicrosoft.SqlServer.Management.Assessment.Tools.XpRegXTool+<QueryKey>d__12PKMicrosoft.SqlServer.Management.Assessment.Tools.XpRegXTool+<QueryName>d__13UPMicrosoft.SqlServer.Management.Assessment.Probes.CmdShellProbe+<GetDataImpl>d__5UPMicrosoft.SqlServer.Management.Assessment.Probes.RegistryProbe+<GetDataImpl>d__8YTMicrosoft.SqlServer.Management.Assessment.Probes.SingleToolProbe`1+<GetDataImpl>d__3WRMicrosoft.SqlServer.Management.Assessment.Probes.ExternalProbe+<GetDataAsync>d__28PKMicrosoft.SqlServer.Management.Assessment.Probes.DbaProbe+<GetDataImpl>d__9[VMicrosoft.SqlServer.Management.Assessment.Probes.DbaProbe+<ReadMeasurementsAsync>d__14SNMicrosoft.SqlServer.Management.Assessment.Probes.DbaProbe+<GetResultSets>d__15OJMicrosoft.SqlServer.Management.Assessment.Probes.Probe+<GetDataAsync>d__22_ZMicrosoft.SqlServer.Management.Assessment.Probes.CharacteristicProviderSource+<Update>d__7a\Microsoft.SqlServer.Management.Assessment.Probes.CharacteristicProviderSource+<GetData>d__11LGMicrosoft.SqlServer.Management.Assessment.Probes.SqlProbe+<GetData>d__0snMicrosoft.SqlServer.Management.Assessment.Probes.Characteristics.ServicesProvider+<UpdateCharacteristics>d__11idMicrosoft.SqlServer.Management.Assessment.Probes.Characteristics.ServicesProvider+<GetServices>d__14ojMicrosoft.SqlServer.Management.Assessment.Probes.Characteristics.ServicesProvider+<GetServiceAccount>d__15toMicrosoft.SqlServer.Management.Assessment.Probes.Characteristics.SysConfigurationsProvider+<UpdatePresence>d__7qlMicrosoft.SqlServer.Management.Assessment.Probes.Characteristics.SysConfigurationsProvider+<UpdateNamed>d__9ytMicrosoft.SqlServer.Management.Assessment.Probes.Characteristics.ChannelPresenceProvider+<UpdateCharacteristics>d__6b]Microsoft.SqlServer.Management.Assessment.Probes.Characteristics.HadrProvider+<IsPresent>d__1zMicrosoft.SqlServer.Management.Assessment.Probes.Characteristics.FeatureCharacteristicProvider+<UpdateCharacteristics>d__9��~Microsoft.SqlServer.Management.Assessment.Probes.Characteristics.PermissionsCharacteristicProvider+<UpdateCharacteristics>d__8|wMicrosoft.SqlServer.Management.Assessment.Probes.Characteristics.RoleCharacteristicProvider+<UpdateCharacteristics>d__7`[Microsoft.SqlServer.Management.Assessment.Logics.TwoPhaseLogics+<GetAssessmentResults>d__11`[Microsoft.SqlServer.Management.Assessment.Logics.TwoPhaseLogics+<GetAssessmentResults>d__12QLMicrosoft.SqlServer.Management.Assessment.Logics.TwoPhaseLogics+<Touch>d__16ZUMicrosoft.SqlServer.Management.Assessment.Logics.TwoPhaseLogics+<FilterContexts>d__22SNMicrosoft.SqlServer.Management.Assessment.Logics.TwoPhaseLogics+<GetData>d__25[VMicrosoft.SqlServer.Management.Assessment.Logics.TwoPhaseLogics+<InvokeProbeCall>d__26b]Microsoft.SqlServer.Management.Assessment.Logics.TwoPhaseLogics+<CollectCharacteristics>d__27ZUMicrosoft.SqlServer.Management.Assessment.Expressions.ColumnExpression+<GetNames>d__5SNMicrosoft.SqlServer.Management.Assessment.Expressions.Literal`1+<GetNames>d__5_ZMicrosoft.SqlServer.Management.Assessment.Expressions.NullLiteralExpression+<GetNames>d__7XSMicrosoft.SqlServer.Management.Assessment.Data.ConstantDataView+<GetEnumerator>d__9WRMicrosoft.SqlServer.Management.Assessment.Data.RowMorphingView+<GetEnumerator>d__7_ZMicrosoft.SqlServer.Management.Assessment.Data.Morphs.NameValuePairsMorph+<Transform>d__11VQMicrosoft.SqlServer.Management.Assessment.Data.Morphs.DbInfoMorph+<Transform>d__1^YMicrosoft.SqlServer.Management.Assessment.Data.Morphs.AggregateProbeMorph+<Transform>d__7]XMicrosoft.SqlServer.Management.Assessment.Data.Morphs.SingleFieldGrouper+<Transform>d__5rmMicrosoft.SqlServer.Management.Assessment.Data.Morphs.Indexes.DuplicateIndexesMorph+<ProcessTableIndexes>d__0rmMicrosoft.SqlServer.Management.Assessment.Data.Morphs.Indexes.RedundantIndexesMorph+<ProcessTableIndexes>d__0SNMicrosoft.SqlServer.Management.Assessment.Configuration.Ruleset+<GetTags>d__24XSMicrosoft.SqlServer.Management.Assessment.Configuration.Ruleset+<GetNewChecks>d__27VQMicrosoft.SqlServer.Management.Assessment.Configuration.Ruleset+<Specialize>d__28^YMicrosoft.SqlServer.Management.Assessment.Configuration.EngineConfig+<GetChecksCore>d__26^YMicrosoft.SqlServer.Management.Assessment.Configuration.EngineConfig+<GetChecksCore>d__27faMicrosoft.SqlServer.Management.Assessment.Configuration.Json.FlattenDataMorph+<TransformRows>d__5hcMicrosoft.SqlServer.Management.Assessment.Configuration.Json.ExpressionConverter+<ReadSequence>d__4hcMicrosoft.SqlServer.Management.Assessment.Configuration.Json.ExpressionConverter+<ReadSequence>d__5idMicrosoft.SqlServer.Management.Assessment.Configuration.Json.ExpressionConverter+<ReadSequence>d__12gbMicrosoft.SqlServer.Management.Assessment.Configuration.Json.RangeListConverter`1+<ReadRanges>d__2b]Microsoft.SqlServer.Management.Assessment.Configuration.Customization.CheckChange+<Apply>d__1����Microsoft.SqlServer.Management.Assessment.Configuration.Json.ExpressionConverter+<>c__DisplayClass15_0+<<ReadNamedExpression>g__ReadOperands|0>d	ItemError {Message}Note for {Check.Id}����Newtonsoft.Json.Converters.StringEnumConverter, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedTarget unsupported warningA3System.Resources.Tools.StronglyTypedResourceBuilder15.0.0.0
Check {Id}{ToDebugString()}{Name}{Version}=8{Provider.GetDisplayName(Key, Arguments, Specification)}	transformcommand
query`[Microsoft.SqlServer.Management.Assessment.Configuration.Json.SqlProbeQueryPropertyConverter��useDatabaseTUyNewtonsoft.Json.DefaultValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedDefaultValueHandlingrunFor����Microsoft.SqlServer.Management.Assessment.Configuration.Json.ConcreteConverter`1[Microsoft.SqlServer.Management.Assessment.Probes.CharacteristicCollection]
requires��distinctTUyNewtonsoft.Json.DefaultValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedDefaultValueHandling��notNullTUyNewtonsoft.Json.DefaultValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedDefaultValueHandling��trimTUyNewtonsoft.Json.DefaultValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedDefaultValueHandling��	separatorTUvNewtonsoft.Json.NullValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedNullValueHandling
group��nameTUmNewtonsoft.Json.Required, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedRequired��versionTUmNewtonsoft.Json.Required, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedRequired��
schemaVersionTUmNewtonsoft.Json.Required, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedRequired��TUuNewtonsoft.Json.TypeNameHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedTypeNameHandling
rules��TUmNewtonsoft.Json.Required, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedRequiredversion
platform	type	name�3
serverNameTUvNewtonsoft.Json.NullValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedNullValueHandlingTUyNewtonsoft.Json.DefaultValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedDefaultValueHandling�4machineTypeTUvNewtonsoft.Json.NullValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedNullValueHandlingTUyNewtonsoft.Json.DefaultValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedDefaultValueHandling��
engineEditionTUmNewtonsoft.Json.Required, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedRequiredTUvNewtonsoft.Json.NullValueHandling, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeedNullValueHandlingTPItemConverterType��Newtonsoft.Json.Converters.StringEnumConverter, Newtonsoft.Json, Version=10.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed�����lSystem.Resources.ResourceReader, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089#System.Resources.RuntimeResourceSet>PADPADP?����$
������č-
�_�۫���;�;�J��3��yd�^�����ЊN��OHٔC�ܧ��hJ'�jJ'�kJ'�
�ହ������8���沭���x���ݤ�#��>J��y4R��G����[0d��kE�TI������Wf@��!��a$	i�/���8w�A=F E���NA�P�1+Qy�S��T}KT���T�V�Z��f[�@a�
�o�6w��7|
m�}���~����
�	�C���A	 S��"�H

`��
p�I
�'�)f�U��	Kj">

�<�S�=���	�u
�
q��N"ErrorAccessTarget:ErrorCheckHasNoImplementationLErrorCheckModificationSelectorResuired:,ErrorCheckTargetChange�<ErrorConditionEvaluationFailed�BErrorConverterCannotReadJSONValue�<ErrorConverterCannotWriteValueErrorEmtyString[ErrorEvalArityy(ErrorEvalMissingData�ErrorEvalOther�"ErrorEvalOverflow�*ErrorEvalStringFormat�*ErrorEvalTypeMismatch8ErrorEvalWrongProbeParameterX4ErrorFailedObtainProbeData�<ErrorImplementationWasNotFound�(ErrorIndexOutOfRange�&ErrorInvalidCheckId�BErrorJsonLocationWithLinePosition0ErrorJsonMissingProperty4<ErrorJsonOperatorInstantiationSErrorJsonReaderxDErrorJsonSerializationNotSupported�FErrorJsonSingularLeftRangeInclusive�>ErrorJsonSingularRangeInclusive�HErrorJsonSingularRightRangeInclusive}@ErrorJsonUnexpectedEndOfDocument�0ErrorJsonUnexpectedToken�:ErrorJsonUnsupportedOperation�&ErrorJsonWrongToken&ErrorJsonWrongValue3 ErrorKeyNotFoundO(ErrorLoadingAssemblyc0ErrorMissingJsonProperty�JErrorMultuallyExclusiveJsonProperties�0ErrorNameFieldIsRequired�(ErrorProbeInitialize�,ErrorProbeRequirements7,ErrorRecursionDetectedY@ErrorStringArrayOrObjectExpectedw6ErrorStringOrObjectExpected�8ErrorTargetFilerInDefinition�>ErrorUnrecognizedChecksItemTypeDErrorValueCannotBeNullOrWhitespace=8ErrorValueEndsWithWhiteSpaceb:ErrorValueIsAWhiteSpaceString�2ErrorValueIsAnEmptyString�<ErrorValueStartsWithWhiteSpace�6ErrorVersionFieldIsRequired�<GroupingColumnNameCannotBeNullTNotEnoughPermissionsToRunAssessmentMessage?StringCheckId�StringTarget�BUnsupportedTargetCheckDescription�BUnsupportedTargetCheckDisplayName�:UnsupportedTargetCheckMessage	JUnsupported_PowerShell_parameter_type6	(WarningCheckSkipped1L	(WarningCheckSkipped2	(WarningCheckSkipped3�	0WarningCheckSkipped3Plus
Cannot access {0} {1}. Check {0} has no implementation.EAn id or a list of tags or ids is required for every check list item.(Check target replacement is not allowed.Condition evaluation failed.NConverter cannot read JSON with the specified existing value. {0} is required.@Converter cannot write specified value to JSON. {0} is required.Empty string is not allowed.){0} parameters required, but {1} present.Missing data item "{0}".Evaluation error.Value does not fit type {0}.-String '{0}' cannot be converted to type {1}.8Value '{0}' of type {1} cannot be converted to type {2}.(Probe {0} does not support parameter {1}/Check {0}: Probe {1} failed to obtain data: {2}1Implementation was not found for given target {0}Index out of range.Valid check ID required.{0} Line: {1}. Position: {2}.Property "{0}" was not found.#Operator "{0}" instantiation error.JSON reading error.)JSON serialization for {0} not supported./Singular range does not include its left bound.�SIngular range must include both left and right boundaries. Use single value without any parenthesis for singular ranges: "{0}" instead of "{1}".0Singular range does not include its right bound. Unecpected end of JSON document.Unexpected token "{0}" in {1}.Unsupported operation "{0}"."Encountered {0}, {1} was expected.Wrong value "{0}" for {1}.Key not found: {0} Error loading assembly {0}: {1}.Missing JSON property {0}.#Only one of ({0}) may be specified.)Name field is required for every ruleset.DProbe implementation cannot be instantiated. Implementing type: {0}. Probe requirements were not met.Infinite recursion detected.+String, array, or object expected. Got {0}.:String or object expected for aggregate func, but got {0}.3Target filter was not expected in check definition.&Checks item type {0} is not supported.#Value cannot be null or whitespace.Value ends with white space..Value is a null, empty, or white space string.Value is an empty string.Value starts with white space.,Version field is required for every ruleset.$Grouping column name cannot be null.XMinimal permissions to run SQL assessment are VIEW SERVER STATE and VIEW DATABASE STATE.Check IDTargetNThis check signals when no other check exists for given target and parameters.No checks for the targetNo check found for this target.unsupported type {0}1'{1}' check has been skipped because it needs {0}>Checks '{1}' and '{2}' have been skipped because they need {0}FChecks '{1}', '{2}', and '{3}' have been skipped because they need {0}PChecks '{1}', '{2}', '{3}', and {4} more have been skipped because they need {0}t3{
  "schemaVersion": "1.0",
  "name": "Microsoft ruleset",
  "version": "1.0.305",
  "rules": [
    {
      "id": "AutoCreateStats",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Statistics",
        "QueryOptimizer"
      ],
      "displayName": "'Auto-Create Statistics' option should be on",
      "description": "The Query Optimizer determines whether an index is useful for a specific query by evaluating the stored statistics. If the statistics become out of date and significant changes have occurred against the underlying data, this can result in less than optimal query performance. In most cases, it's best to let SQL Server maintain the statistics. If you turn 'Auto Create Stats' and 'Auto Update Stats' off, then it is up to you to keep the statistics up-to-date somehow. Failure to do so will lead to poor query performance. Most applications should have these options ON. When the Auto Create statistics setting is ON, the Query Optimizer creates statistics on one or more columns of a table or an indexed view, as necessary, to improve query plans and query performance.",
      "message": "Turn on 'Auto-Create Statistics' option to improve query performance",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/statistics/statistics#CreateStatistics",
      "condition": "@is_auto_create_stats_on",
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "AutoUpdateStats",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Statistics",
        "QueryOptimizer"
      ],
      "displayName": "Auto-Update Statistics should be on",
      "description": "The Query Optimizer determines whether an index is useful for a specific query by evaluating the stored statistics. If the statistics become out of date and significant changes have occurred against the underlying data, this can result in less than optimal query performance. In most cases, it's best to let SQL Server maintain the statistics. If you turn 'Auto Create Stats' and 'Auto Update Stats' off, then it is up to you to keep the statistics up-to-date somehow. Failure to do so will lead to poor query performance. Most applications should have these options ON. When the Auto Update Statistics setting is ON, the Query Optimizer updates statistics when they are used by a query and when they might be out-of-date. Statistics become out-of-date after insert, update, delete, or merge operations change the data distribution in the table or indexed view. The Query Optimizer determines when statistics might be out-of-date by counting the number of data modifications since the last statistics update and comparing the number of modifications to a threshold. The threshold is based on the number of rows in the table or indexed view. The Query Optimizer checks for out-of-date statistics before compiling a query and before executing a cached query plan. Before compiling a query, the Query Optimizer uses the columns, tables, and indexed views in the query predicate to determine which statistics might be out-of-date. Before executing a cached query plan, the Database Engine verifies that the query plan references up-to-date statistics. The AUTO_UPDATE_STATISTICS option applies to statistics created for indexes, single-columns in query predicates, and statistics that are created by using the CREATE STATISTICS statement. This option also applies to filtered statistics.",
      "message": "Turn on 'Auto-Update Statistics' option to improve query performance",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/statistics/statistics#UpdateStatistics",
      "condition": "@is_auto_update_stats_on",
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "QueryStoreOn",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "version": "[13.0,)",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": {
          "not": [
            "master",
            "tempdb",
            "model"
          ]
        }
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "QueryStore",
        "Statistics"
      ],
      "displayName": "Query Store should be active",
      "description": "The Query Store feature provides you with insight on query plan choice and performance. It simplifies performance troubleshooting by helping you quickly find performance differences caused by query plan changes. Query Store automatically captures a history of queries, plans, and runtime statistics, and retains these for your review. It separates data by time windows so you can see database usage patterns and understand when query plan changes happened on the server. While Query Store collects queries, execution plans and statistics, its size in the database grows until this limit is reached. When that happens, Query Store automatically changes the operation mode to read-only and stops collecting new data, which means that your performance analysis is no longer accurate.",
      "message": "Query Store operation mode should be 'Read Write' to keep performance analysis accurate",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/performance/monitoring-performance-by-using-the-query-store",
      "condition": {
        "equal": [
          "@query_store_state",
          2
        ]
      },
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "TF174",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": [
          "[11.0.3368,12.0)",
          "[12.0.2480,13.0)",
          "[13.0,)"
        ],
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Memory",
        "Performance"
      ],
      "displayName": "TF 174 increases plan cache bucket count",
      "description": "Trace Flag 174 increases the SQL Server plan cache bucket count from 40,009 to 160,001 on 64-bit systems. When the SQL Server plan cache reaches its entry limit, plans that have low cost must be evicted in order to insert new plans. This can cause severe contention on the SOS_CACHESTORE spinlock and a high CPU usage occurs in SQL Server. On 64-bit systems, the number of buckets for the SQL Server plan cache is 40,009. Therefore, the maximum number of entries that can fit inside the SQL Server plan cache is 160,036. Enabling trace flag 174 on high performance systems increases the size of the cache and can avoid SOS_CACHESTORE spinlock contention.",
      "message": "Enable trace flag 174 to increase plan cache bucket count",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "level": "Information",
      "condition": {
        "in": [
          174,
          "@TraceFlag"
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF634",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Memory",
        "Performance",
        "ColumnStore"
      ],
      "displayName": "TF 634 disables background columnstore compression",
      "description": "Trace Flag 634 disables the background columnstore compression task. SQL Server periodically runs the Tuple Mover background task that compresses columnstore index rowgroups with uncompressed data, one such rowgroup at a time. Columnstore compression improves query performance but also consumes system resources. You can control the timing of columnstore compression manually, by disabling the background compression task with trace flag 634, and then explicitly invoking ALTER INDEX...REORGANIZE or ALTER INDEX...REBUILD at the time of your choice.",
      "message": "Trace flag 634 disables background columnstore compression task. Check if you need to set non-default trace flag with current system build and configuration",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            634,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF652",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "Memory",
        "Pages"
      ],
      "displayName": "TF 652 disables page pre-fetching scans",
      "description": "Trace Flag 652 disables page pre-fetching for scans. The read-ahead process reads the full extent of a referenced database page into the buffer pool, before those contiguous database pages are consumed by scans. Enabling the trace flag can lead to performance issues on queries that leverage pre-fetching.",
      "message": "Trace flag 652 disables page pre-fetching scans. Check if you need to set non-default trace flag with current system build and configuration",
      "helpLink": "http://support.microsoft.com/kb/920093",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            652,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF661",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 661 disables background ghost cleanup task",
      "description": "Trace Flag 661 disables the ghost record removal process. A ghost record is the result of a delete operation. When you delete a record, the deleted record is kept as a ghost record. Later, the deleted record is purged by the ghost record removal process. When you disable this process, the deleted record is not purged. Therefore, the space that the deleted record consumes is not freed. This behavior affects space consumption and the performance of scan operations. If you turn off this trace Flag, the ghost record removal process works correctly.",
      "message": "Check if you need to set non-default trace flag with current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/920093",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            661,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF834",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "Memory",
        "ColumnStore"
      ],
      "displayName": "TF 834 enables large-page allocations",
      "description": "Trace Flag 834 causes the server to use large-page memory (LPM) model for the buffer pool allocations. Consider enabling TF 834 if you have a server that has a lot of memory, particularly for an analytical or data warehousing workload. Trace flag 834 is NOT recommended on SQL Server instances that use columnstore indexes.",
      "message": "Enable trace flag 834 to use large-page allocations to improve analytical and data warehousing workloads",
      "helpLink": "https://support.microsoft.com/kb/3210239",
      "level": "Information",
      "condition": {
        "in": [
          834,
          "@TraceFlag"
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF845",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Memory",
        "Performance"
      ],
      "displayName": "TF 845 is not needed in SQL Server 2012 and higher",
      "description": "Trace Flag 845 supports locking pages in memory in SQL Server Standard edition, which is needed together with trace flag 834 to use the large-page memory (LPM) model for the buffer pool allocations.  Consider enabling TF 834 if you have a server that has a lot of memory, particularly for an analytical or data warehousing workload. Starting with SQL Server 2012 this behavior is enabled by default for Standard edition, and trace flag 845 must not be used.",
      "message": "Disable trace flag 845 in SQL Server 2012 and higher versions",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "condition": {
        "not": {
          "in": [
            845,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF902",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "UpdateIssues"
      ],
      "displayName": "TF 902 Database Upgrade Bypass should be disabled",
      "description": "Trace Flag 902 bypasses execution of database upgrade script when installing a Cumulative Update or Service Pack. This trace flag is not supported to run it continuously in a production environment. If you encounter an error during script upgrade mode, it is recommended to contact Microsoft SQL Customer Service and Support (CSS) for further guidance.",
      "message": "Disable trace flag 902 which bypasses database upgrade",
      "helpLink": "https://support.microsoft.com/help/2163980",
      "condition": {
        "not": {
          "in": [
            902,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1117",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "DBFileConfiguration",
        "Performance"
      ],
      "displayName": "TF 1117 enables filegroup-level autogrow",
      "description": "Trace Flag 1117 initiates the growth of every file in the filegroup, when a file in the filegroup meets the autogrow threshold, and together with trace flag 1118, can help reduce allocation contention in the SQL Server TempDB database. This trace flag affects all databases and is recommended only if every database is safe to be grow all files in a filegroup by the same amount.",
      "message": "Enable trace flag 1117 to enable filegroup auto-grow",
      "helpLink": "https://support.microsoft.com/help/2154845",
      "level": "Information",
      "condition": {
        "in": [
          1117,
          "@TraceFlag"
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1117",
      "itemType": "override",
      "targetFilter": {
        "version": "[13.0,)"
      },
      "displayName": "TF 1117 has no effect in SQL Server 2016 and higher",
      "description": "Trace Flag 1117 initiates the growth of every file in the filegroup, when a file in the filegroup meets the autogrow threshold, and together with trace flag 1118, can help reduce allocation contention in the SQL Server TempDB database. Starting with SQL Server 2016, this behavior is controlled by the AUTOGROW_SINGLE_FILE and AUTOGROW_ALL_FILES options of ALTER DATABASE syntax.",
      "message": "Disable trace flag 1117 in SQL Server 2016 and higher versions",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/alter-database-transact-sql-file-and-filegroup-options",
      "condition": {
        "not": {
          "in": [
            1117,
            "@TraceFlag"
          ]
        }
      }
    },
    {
      "id": "TF1118",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Memory",
        "Performance",
        "Pages"
      ],
      "displayName": "TF 1118 disables single page allocations",
      "description": "Trace Flag 1118 forces page allocations on uniform extents instead of mixed extents, and together with trace flag 1117, can help reduce allocation contention in the SQL Server TempDB database. When a new object is created, by default, the first eight pages are allocated from different extents (mixed extents). Afterwards, when more pages are needed, those are allocated from that same extent (uniform extent). The SGAM page is used to track these mixed extents, so can quickly become a bottleneck when numerous mixed page allocations are occurring. This trace flag allocates all eight pages from the same extent when creating new objects, minimizing the need to scan the SGAM page and forces uniform extent allocations instead of mixed page allocations.",
      "message": "Enable trace flag 1118 to force page allocations on uniform extents",
      "helpLink": "https://support.microsoft.com/help/328551",
      "level": "Information",
      "condition": {
        "in": [
          1118,
          "@TraceFlag"
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1118",
      "itemType": "override",
      "targetFilter": {
        "version": "[13.0,)"
      },
      "displayName": "TF 1118 has no effect in SQL Server 2016 and higher",
      "description": "Trace Flag 1118 forces page allocations on uniform extents instead of mixed extents, and together with trace flag 1117, can help reduce allocation contention in the SQL Server TempDB database. When a new object is created, by default, the first eight pages are allocated from different extents (mixed extents). Afterwards, when more pages are needed, those are allocated from that same extent (uniform extent). The SGAM page is used to track these mixed extents, so can quickly become a bottleneck when numerous mixed page allocations are occurring. This trace flag allocates all eight pages from the same extent when creating new objects, minimizing the need to scan the SGAM page and forces uniform extent allocations instead of mixed page allocations. Starting with SQL Server 2016, this behavior is controlled by the SET MIXED_PAGE_ALLOCATION option of ALTER DATABASE syntax.",
      "message": "Disable trace flag 1118 in SQL Server 2016 and higher versions",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/alter-database-transact-sql-file-and-filegroup-options",
      "condition": {
        "not": {
          "in": [
            1118,
            "@TraceFlag"
          ]
        }
      }
    },
    {
      "id": "TF1204",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Locks",
        "Performance"
      ],
      "displayName": "TF 1204 returns deadlock information",
      "description": "Trace Flag 1204 returns the resources and types of locks that are participating in a deadlock, including the affected command. The resulting information is recorded in the SQL Server Errorlog.",
      "message": "Disable trace flag 1204 that returns deadlock information",
      "helpLink": "https://support.microsoft.com/help/832524",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            1204,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1211",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Locks",
        "Performance"
      ],
      "displayName": "TF 1211 lock escalation should be disabled",
      "description": "Trace Flag 1211 disables lock escalation based on memory pressure, or based on number of locks. Because SQL Server will not escalate row or page locks to table locks, this can generate an excessive number of locks. If the lock memory grows large enough, attempts to allocate additional locks for any query may fail and cause performance issues. This trace flag should not be used in order to avoid inability to allocate lock resources because of insufficient memory. If lock escalation needs to be disabled, use trace flag 1224 instead.",
      "message": "Disable trace flag 1211 to enable lock escalation",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "condition": {
        "not": {
          "in": [
            1211,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1222",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Locks",
        "Performance"
      ],
      "displayName": "TF 1222 returns deadlock information",
      "description": "Trace Flag 1222 returns the resources and types of locks that are participating in a deadlock, including the affected command. The resulting information is recorded in the SQL Server Errorlog, in XML format that does not comply with any XSD schema.",
      "message": "Disable trace flag 1222 that returns deadlock information",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            1222,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1224",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Locks",
        "Performance"
      ],
      "displayName": "TF 1224 should be disabled",
      "description": "Trace Flag 1224 disables lock escalation based on the number of locks, unless SQL Server is under memory pressure. Because SQL Server will not escalate row or page locks to table locks, this can generate an excessive number of locks.",
      "message": "Disable trace flag 1224 to allow lock escalation",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "condition": {
        "not": {
          "in": [
            1224,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1229",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Locks",
        "Performance",
        "CPU"
      ],
      "displayName": "TF 1229 lock partitioning should be enabled",
      "description": "Trace Flag 1229 disables lock partitioning regardless of the number of CPUs. By default, SQL Server enables lock partitioning when a server has 16 or more CPUs, to improve the scalability characteristics of larger systems. Disabling lock partitioning may cause can cause spinlock contention and poor performance, or unexpected behaviors when switching partitions.",
      "message": "Disable trace flag 1229 to enable lock partitioning",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/sql-server-transaction-locking-and-row-versioning-guide",
      "condition": {
        "not": {
          "in": [
            1229,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1236",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Locks",
        "Performance"
      ],
      "displayName": "TF 1236 database lock partitioning should be enabled",
      "description": "Trace Flag 1236 enables database-level lock partitioning. Lock Partitioning is utilized to improve the scalability characteristics on larger systems.",
      "message": "Enable trace Flag 1236 to enable database lock partitioning",
      "helpLink": "https://support.microsoft.com/help/2926217",
      "condition": {
        "in": [
          1236,
          "@TraceFlag"
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF1236",
      "itemType": "override",
      "targetFilter": {
        "version": [
          "[11.0.6020,12.0)",
          "[12.0.4100,)"
        ]
      },
      "displayName": "TF 1236 is not needed in SQL Server 2012 SP3, SQL Server 2014 SP1 and higher",
      "description": "Trace Flag 1236 enables database-level lock partitioning. Starting with SQL Server 2012 SP3 and SQL Server 2014 SP1, this behavior is controlled by the engine and trace flag 1236 has no effect.",
      "message": "Disable trace flag 1236 in SQL Server 2012 SP3, SQL Server 2014 SP1 and higher versions",
      "condition": {
        "not": {
          "in": [
            1236,
            "@TraceFlag"
          ]
        }
      }
    },
    {
      "id": "TF1462",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "AvailabilityGroups"
      ],
      "displayName": "TF 1462 should be disabled to allow Log Stream Compression",
      "description": "Trace Flag 1462 disables log stream compression for asynchronous availability groups. This feature is enabled by default on asynchronous replicas to optimize network bandwidth.",
      "message": "Disable trace flag 1462 to allow log stream compression",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/availability-groups/windows/tune-compression-for-availability-group",
      "condition": {
        "not": {
          "in": [
            1462,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2312",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "QueryOptimizer",
        "Performance"
      ],
      "displayName": "TF 2312 sets the default cardinality estimation model",
      "description": "Trace Flag 2312 sets the Query Optimizer cardinality estimation model to the default version of the database compability level of SQL Server 2014 and higher versions. If the database compatibility level is lower than 120, enabling trace flag 2312 uses the cardinality estimation model of SQL Server 2014 (120).",
      "message": "Trace Flag 2312 does not apply to this SQL Server version. Check if you need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/2801413",
      "level": "Warning",
      "condition": {
        "not": {
          "in": [
            2312,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2312",
      "itemType": "override",
      "targetFilter": {
        "version": "[12.0, 13.0)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "QueryOptimizer",
        "Performance"
      ],
      "level": "Information"
    },
    {
      "id": "TF2312",
      "itemType": "override",
      "targetFilter": {
        "version": "[13.0, )"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "QueryOptimizer",
        "Performance"
      ],
      "message": "TF2312 enables New CE model to SQL Server 2014 or above versions, dependent of the compatibility level of the database",
      "level": "Information"
    },
    {
      "id": "TF2330",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,)",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "Indexes"
      ],
      "displayName": "TF 2330 disables recording of index usage stats",
      "description": "Trace Flag 2330 disables recording of index usage stats, which could lead to a non-yielding condition in SQL 2005.",
      "message": "Trace Flag 2330 does not apply to this SQL Server version. Check if you need to set non-default trace flag with current system build and configuration",
      "helpLink": "https://blogs.msdn.microsoft.com/ialonso/2012/10/08/faq-around-sys-dm_db_index_usage_stats",
      "level": "Warning",
      "condition": {
        "not": {
          "in": [
            2330,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2340",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "QueryOptimizer",
        "Performance"
      ],
      "displayName": "TF 2340 disables Batch Sorts for optimized nested loops joins",
      "description": "Trace Flag 2340 causes SQL Server not to use a sort operation (batch sort) for optimized nested loops joins when generating a plan. Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Trace Flag 2340 disables Batch Sorts for optimized nested loops joins",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            2340,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2371",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "Statistics"
      ],
      "displayName": "TF 2371 enables a linear recompilation threshold for statistics",
      "description": "Trace Flag 2371 causes SQL Server to change the fixed update statistics threshold to a linear update statistics threshold. This is especially useful to keep statistics updated on large tables.",
      "message": "Enable trace Flag 2371 to allow linear recompilation threshold for statistics",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "level": "Information",
      "condition": {
        "in": [
          2371,
          "@TraceFlag"
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2371",
      "itemType": "override",
      "targetFilter": {
        "version": "[13.0,)"
      },
      "displayName": "TF 2371 has no effect in SQL Server 2016 and higher",
      "description": "Trace Flag 2371 causes SQL Server to change the fixed update statistics threshold to a linear update statistics threshold. This is especially useful to keep statistics updated on large tables. Starting with SQL Server 2016, for databases using compatibility level 130 and above, this behavior is controlled by the engine and trace flag 2371 has no effect.",
      "message": "Disable trace flag 2371 in SQL Server 2016 and higher versions when all databases are at compatibility level 130 and above",
      "condition": {
        "not": {
          "in": [
            2371,
            "@TraceFlag"
          ]
        }
      }
    },
    {
      "id": "TF2389",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Statistics",
        "Performance"
      ],
      "displayName": "TF 2389 enables automatic statistics for ascending keys",
      "description": "Trace Flag 2389 enables automatically generated quick statistics for ascending keys (histogram amendment). This trace flag is recommended to be set in cases where queries access newly inserted ascending key values (such as an IDENTITY column), but the new values are not yet updated in the statistics histogram for the affected columns. In this case the histogram used to estimate cardinality will be adjusted at query compile time. Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Check if you need to set non-default trace flag with current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/2801413",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            2389,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2390",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Statistics",
        "Performance",
        "Indexes"
      ],
      "displayName": "TF 2390 enables automatic statistics for Ascending or Unknown Keys",
      "description": "Trace Flag 2390 enables automatically generated quick statistics for ascending or unknown keys (histogram amendment). This trace flag is recommended to be set in cases where queries access newly inserted ascending key values (such as an IDENTITY column), but the new values are not yet updated in the statistics histogram for the affected columns. In this case the histogram used to estimate cardinality will be adjusted at query compile time. Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Trace Flag 2390 enables automatic statistics for ascending or unknown keys. Check if you need to set non-default trace flag with current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/2801413",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            2390,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2528",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "DataIntegrity",
        "DBCC"
      ],
      "displayName": "TF 2528 disables parallel operations for integrity checking",
      "description": "Trace Flag 2528 disables parallel checking of objects by DBCC CHECKDB, DBCC CHECKFILEGROUP, and DBCC CHECKTABLE. By default, the degree of parallelism is automatically determined by the query processor. The maximum degree of parallelism is configured just like that of parallel queries. When parallel checks are disabled, the DBCC commands will take longer to complete. Starting with SQL Server 2014 SP2, a MAXDOP option is available to override the max degree of parallelism configuration option of sp_configure for the DBCC statements.",
      "message": "Trace Flag 2528 disables parallel operations for integrity checking",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "level": "Warning",
      "condition": {
        "not": {
          "in": [
            2528,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2549",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "DBCC"
      ],
      "displayName": "TF 2549 optimizes PHYSICAL_ONLY option of DBCC CHECKDB",
      "description": "Trace Flag 2549 forces the DBCC CHECKDB command to assume each database file is on a unique disk drive but treating different physical files as one logical file. This trace flag can improve the performance when using the PHYSICAL_ONLY option, but it's not recommended unless it is known that each file is based on a unique physical disk.",
      "message": "Trace Flag 2549 forces DBCC CHECKDB to treat different physical files as one logical file",
      "helpLink": "https://support.microsoft.com/help/2634571",
      "level": "Warning",
      "condition": {
        "not": {
          "in": [
            2549,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2562",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "DBCC",
        "TempDB"
      ],
      "displayName": "TF 2562 forces 'DBCC CHECKDB' command to execute in single batch",
      "description": "Trace Flag 2562 forces the DBCC CHECKDB command to execute in a single batch regardless of the number of indexes in the database. This trace flag can improve the performance when using the PHYSICAL_ONLY option, but space requirements for TempDB may increase.",
      "message": "Disable trace flag 2562 to force 'DBCC CHECKDB' command to execute in single batch",
      "helpLink": "https://support.microsoft.com/help/2634571",
      "level": "Warning",
      "condition": {
        "not": {
          "in": [
            2562,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF2566",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "DBCC",
        "DataIntegrity"
      ],
      "displayName": "TF 2566 disables default data purity check",
      "description": "Trace Flag 2566 forces the DBCC CHECKDB command to execute without data purity check unless the DATA_PURITY option is specified. For databases upgraded from earlier versions of SQL Server, it is recommended to run the DBCC CHECKDB WITH DATA_PURITY command at least once, to enable column-value integrity checks to happen by default.",
      "message": "Disable trace flag 2566 to turn off default data purity check",
      "helpLink": "https://support.microsoft.com/help/945770",
      "level": "Warning",
      "condition": {
        "not": {
          "in": [
            2566,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF3023",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Backup"
      ],
      "displayName": "TF 3023 enables Backup Checksum option by default",
      "description": "Trace Flag 3023 enables the CHECKSUM option of the BACKUP command by default. This trace flag forces the CHECKSUM option for BACKUP command even when not explicitely set. Starting with SQL Server 2014, this behavior is controlled by setting the Backup Checksum Default configuration option.",
      "message": "Disable trace flag 3023 to turn on 'CHECKSUM' option as default for 'BACKUP' command",
      "helpLink": "https://support.microsoft.com/help/2656988",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            3023,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF3042",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Backup"
      ],
      "displayName": "TF 3042 bypasses default backup compression pre-allocation algorithm",
      "description": "Trace Flag 3042 bypasses the default backup compression pre-allocation algorithm to allow the backup file to grow only as needed to reach its final size. This trace flag can achieve space savings by allocating only the actual size required for the compressed backup, but might increase the overall backup operation time.",
      "message": "Disable trace flag 3042 to bypass default backup compression",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/backup-restore/backup-compression-sql-server",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            3042,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF3226",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Backup"
      ],
      "displayName": "TF 3226 disables ErrorLog entries for successful backup operations",
      "description": "Trace Flag 3226 prevents SQL Server from recording an entry to the Errorlog on every successful backup operation. Backup operations are registered in the Errorlog by default. Frequent backup operations can contribute to massive Errorlog files that become unwieldy.",
      "message": "Disable trace flag 3226 to prevent SQL Server from recording ErrorLog entries for each successful backup operation",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/database-console-commands/dbcc-traceon-trace-flags-transact-sql",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            3226,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF4136",
      "itemType": "override",
      "targetFilter": {
        "version": "[11.0.2316,)"
      },
      "description": "Trace Flag 4136 disables parameter sniffing unless OPTION(RECOMPILE), WITH RECOMPILE or OPTIMIZE FOR value is used. Starting with SQL Server 2016, to accomplish this at the database level use the PARAMETER_SNIFFING option in ALTER DATABASE SCOPED CONFIGURATION. Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Disable trace flag 4136 to prevent parameter sniffing. Verify need to set non-default trace flag with current system build and configuration",
      "level": "Information"
    },
    {
      "id": "TF4136",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag"
      ],
      "displayName": "TF 4136 disables parameter sniffing",
      "description": "Trace Flag 4136 disables parameter sniffing unless OPTION(RECOMPILE), WITH RECOMPILE or OPTIMIZE FOR value is used, but does not apply to this SQL Server version. Starting with SQL Server 2016, to accomplish this at the database level use the PARAMETER_SNIFFING option in ALTER DATABASE SCOPED CONFIGURATION. Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Trace Flag 4136 does not apply to this SQL Server version. Verify need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/980653",
      "condition": {
        "not": {
          "in": [
            4136,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF4137",
      "itemType": "override",
      "targetFilter": {
        "version": "[11.0.2316,)"
      },
      "description": "Trace Flag 4137 causes SQL Server to generate a plan using minimum selectivity when estimating AND predicates for filters to account for partial correlation instead of independence, under the query optimizer cardinality estimation model of SQL Server 2012 and earlier versions (CE 70). Does not apply to CE version 120 or above. Use trace flag 9471 instead. Starting with SQL Server 2016 SP1, to accomplish this at the query level use the USE HINT 'ASSUME_MIN_SELECTIVITY_FOR_FILTER_ESTIMATES' query hint. Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Disable trace flag 4137 to instruct SQL Server to generate plan using partial correlation of filters. Verify need to set non-default trace flag with the current system build and configuration",
      "level": "Information"
    },
    {
      "id": "TF4137",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "QueryOptimizer",
        "Performance"
      ],
      "displayName": "TF 4137 causes plans to use partial correlation for filters",
      "description": "Trace Flag 4137 causes SQL Server to generate a plan using minimum selectivity when estimating AND predicates for filters to account for partial correlation instead of independence, under the query optimizer cardinality estimation model of SQL Server 2012 and earlier versions (CE 70). However it does not apply to this SQL Server version. Does not apply to CE version 120 or above. Use trace flag 9471 instead. Starting with SQL Server 2016 SP1, to accomplish this at the query level use the USE HINT 'ASSUME_MIN_SELECTIVITY_FOR_FILTER_ESTIMATES' query hint. Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Trace flag 4137 does not apply to this SQL Server version. Verify need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/2658214",
      "condition": {
        "not": {
          "in": [
            4137,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF4138",
      "itemType": "override",
      "targetFilter": {
        "version": "[11.0.2325,)"
      },
      "description": "Trace Flag 4138 causes SQL Server to generate a plan that does not use row goal adjustments with queries that contain TOP, OPTION (FAST N), IN, or EXISTS keywords. Starting with SQL Server 2016 SP1, to accomplish this at the query level use the USE HINT 'DISABLE_OPTIMIZER_ROWGOAL' query hint. Verify need to set a Non-default trace flag with current system build and configuration.",
      "message": "Trace Flag 4138 enables plan that without row goal adjustments. Verify need to set a non-default trace flag with the current system build and configuration",
      "level": "Information"
    },
    {
      "id": "TF4138",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "QueryOptimizer",
        "Performance"
      ],
      "displayName": "TF 4138 causes plans to not use Row Goal adjustments",
      "description": "Trace Flag 4138 causes SQL Server to generate a plan that does not use row goal adjustments with queries that contain TOP, OPTION (FAST N), IN, or EXISTS keywords. Starting with SQL Server 2016 SP1, to accomplish this at the query level use the USE HINT 'DISABLE_OPTIMIZER_ROWGOAL' query hint. However it does not apply to this SQL Server version. Verify need to set a Non-default trace flag with current system build and configuration.",
      "message": "Trace flag 4138 does not apply to this SQL Server version. Verify need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/2667211",
      "condition": {
        "not": {
          "in": [
            4138,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF4139",
      "itemType": "override",
      "targetFilter": {
        "version": [
          "[11.0.3431,11.0.5058)",
          "[11.0.5532,)"
        ]
      },
      "description": "Trace Flag 4139 enables automatically generated quick statistics (histogram amendment) regardless of key column status. This trace flag is recommended to be set in cases where queries access newly inserted key values that may change plan shape, but the new values are not yet updated in the statistics histogram for the affected columns. In this case, regardless of the leading statistics column status (ascending, descending, or stationary), the histogram used to estimate cardinality will be adjusted at query compile time. This trace flag does not apply to the cardinality estimation model of SQL Server 2012 and earlier versions (CE 70). Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Trace Flag 4139 enables automatic statistics for any key ordering. Verify need to set a non-default trace flag with the current system build and configuration",
      "level": "Information"
    },
    {
      "id": "TF4139",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Statistics"
      ],
      "displayName": "TF 4139 enables automatic statistics for any key ordering",
      "description": "Trace Flag 4139 enables automatically generated quick statistics (histogram amendment) regardless of key column status. However, this trace flag does not apply to this SQL Server version. Verify need to set a non-default trace flag with the current system build and configuration.",
      "message": "Trace flag 4139 does not apply to this SQL Server version. Verify need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/2952101",
      "condition": {
        "not": {
          "in": [
            4139,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF4199",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0, 14.0)",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "QueryOptimizer"
      ],
      "displayName": "TF 4199 enables query optimizer fixes",
      "description": "Trace Flag 4199 enables Query Optimizer fixes released in SQL Server Cumulative Updates and Service Packs.",
      "message": "Trace Flag 4199 enables Query Optimizer fixes. Verify need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "http://support.microsoft.com/help/974006",
      "level": "Information",
      "condition": {
        "not": {
          "in": [
            4199,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF6498",
      "itemType": "override",
      "targetFilter": {
        "version": [
          "[12.0.2474,12.0.2480]",
          "[12.0.4416,12.0.5000)"
        ]
      },
      "message": "Trace Flag 6498 enables concurrent large queries",
      "level": "Information"
    },
    {
      "id": "TF6498",
      "itemType": "override",
      "targetFilter": {
        "version": "[12.0.5000,)"
      },
      "description": "Trace Flag 6498 enables more than one large query compilation to gain access to the big gateway when there is sufficient memory available. This trace flag can be used to keep memory usage for the compilation of incoming queries under control, avoiding compilation waits for concurrent large queries. Starting with SQL Server 2014 SP2 and SQL Server 2016, this behavior is controlled by the engine and trace flag 1236 has no effect.",
      "message": "Disable trace flag 6498 in SQL Server 2014 SP2, SQL Server 2016 and higher versions"
    },
    {
      "id": "TF6498",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "Memory"
      ],
      "displayName": "TF 6498 enables additional concurrent large queries",
      "description": "Trace Flag 6498 enables more than one large query compilation to gain access to the big gateway when there is sufficient memory available. However, this trace flag does not apply to this SQL Server version. This trace flag can be used to keep memory usage for the compilation of incoming queries under control, avoiding compilation waits for concurrent large queries. Starting with SQL Server 2014 SP2 and SQL Server 2016, this behavior is controlled by the engine and trace flag 1236 has no effect.",
      "message": "Trace Flag 6498 does not apply to this SQL Server version. Verify need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/3024815",
      "condition": {
        "not": {
          "in": [
            6498,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF6532",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0.6020,11.0.6518)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 6532 enables performance improvements for spatial data",
      "description": "Trace Flag 6532 enables performance improvements of query operations with spatial data types. The performance gain will vary, depending on the configuration, the types of queries, and the objects.",
      "message": "Enable trace flag 6532 to enable performance improvements for spatial data",
      "helpLink": "https://support.microsoft.com/help/3107399",
      "level": "Information",
      "condition": {
        "in": [
          6532,
          "@TraceFlag"
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF6532.6533",
      "itemType": "override",
      "targetFilter": {
        "version": [
          "[11.0.6518,12.0)",
          "[12.0.5000,13.0)"
        ]
      },
      "description": "Trace Flag 6532 and trace flag 6533 enable performance improvements of query operations with spatial data types. The performance gain will vary, depending on the configuration, the types of queries, and the objects.",
      "message": "Enable trace flag 6532 and trace flag 6533 to enable performance improvements for spatial data",
      "level": "Information",
      "condition": {
        "and": [
          {
            "in": [
              6532,
              "@TraceFlag"
            ]
          },
          {
            "in": [
              6533,
              "@TraceFlag"
            ]
          }
        ]
      }
    },
    {
      "id": "TF6532.6533",
      "itemType": "override",
      "targetFilter": {
        "version": "[13.0,)"
      },
      "message": "Disable trace flag 6532 in SQL Server 2016 and higher versions."
    },
    {
      "id": "TF6532.6533",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 6532 and TF 6533 enable performance improvements for spatial data",
      "description": "Trace flags 6532 and 6533 enable performance improvements of query operations with spatial data types. However, this trace flag does not apply to this SQL Server version. Starting with SQL Server 2016, this behavior is controlled by the engine and trace flags 6532 and 6533 have no effect.",
      "message": "Trace flags 6532 and 6533 do not apply to this SQL Server version. Verify need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/3107399",
      "condition": {
        "and": [
          {
            "not": {
              "in": [
                6532,
                "@TraceFlag"
              ]
            }
          },
          {
            "not": {
              "in": [
                6533,
                "@TraceFlag"
              ]
            }
          }
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF6534",
      "itemType": "override",
      "targetFilter": {
        "version": [
          "[11.0.6020,12.0)",
          "[12.0.5000,13.0)"
        ]
      },
      "description": "Trace Flag 6534 enables performance improvements of query operations with spatial data types. The performance gain will vary, depending on the configuration, the types of queries, and the objects.",
      "message": "Enable trace flag 6534 to enable performance improvement of query operations with spatial data types",
      "level": "Information",
      "condition": {
        "in": [
          6534,
          "@TraceFlag"
        ]
      }
    },
    {
      "id": "TF6534",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 6534 enables performance improvements for spatial data",
      "description": "Trace Flag 6534 enables performance improvement of query operations with spatial data types. However, this trace flag does not apply to this SQL Server version. Verify need to set a Non-default trace flag with current system build and configuration.",
      "message": "Trace flag 6534 does not apply to this SQL Server version. Verify need to set a non-default trace flag with the current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/3107399",
      "condition": {
        "not": {
          "in": [
            6534,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF7412",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[13.0.4001,15.0)",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 7412 enables the lightweight profiling infrastructure",
      "description": "Trace Flag 7412 enables the lightweight profiling infrastructure for live query performance troubleshooting. Consider enabling TF 7412 to have the ability to access runtime information on query execution plans for any session.",
      "message": "Enable trace flag 7412 to enable lightweight profiling infrastructure for live query performance troubleshooting",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/performance/query-profiling-infrastructure",
      "level": "Information",
      "condition": {
        "in": [
          7412,
          "@TraceFlag"
        ]
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF9024",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "NUMA",
        "Memory",
        "CPU"
      ],
      "displayName": "TF 9024 converts global log pool memory object",
      "description": "TF9024 converts a global log pool memory object into NUMA node partitioned memory object.",
      "message": "Verify need to set non-default trace flag with current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/2809338/fix-high-log-write-waits-counter-value-on-a-sql-server-2012-or-sql-ser",
      "level": "Warning",
      "condition": {
        "not": {
          "in": [
            9024,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF9024",
      "itemType": "override",
      "targetFilter": {
        "version": [
          "[11.0.3349, 11.0.6020)",
          "[12.0, 12.0.4100)"
        ]
      },
      "message": "Enable trace flag 9024 to convert global log pool memory objects into NUMA node partitioned memory objects",
      "level": "Information",
      "condition": [
        {
          "in": [
            9024,
            "@TraceFlag"
          ]
        },
        {
          "gt": [
            8,
            {
              "div": [
                "@online_logical_processors",
                "@numa_nodes"
              ]
            }
          ]
        }
      ],
      "probes": [
        "EnabledGlobalTraceFlags",
        "ServerInstanceConfiguration"
      ]
    },
    {
      "id": "TF9024",
      "itemType": "override",
      "targetFilter": {
        "version": [
          "[11.0.6020, 12.0)",
          "[12.0.4100,)"
        ]
      },
      "message": "TF9024 is not needed in SQL Server 2012 SP3, SQL Server 2014 SP1 and above."
    },
    {
      "id": "TF8048",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "NUMA",
        "CPU",
        "Memory"
      ],
      "displayName": "TF 8048 converts NUMA partitioned memory objects into CPU partitioned",
      "description": "TF 8048 converts NUMA partitioned memory objects into CPU partitioned.",
      "message": "Verify need to set a Non-default TF with current system build and configuration",
      "helpLink": "https://support.microsoft.com/help/2809338/fix-high-log-write-waits-counter-value-on-a-sql-server-2012-or-sql-ser",
      "level": "Warning",
      "condition": {
        "not": {
          "in": [
            8048,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF8048",
      "itemType": "override",
      "targetFilter": {
        "version": "[12.0.4100,)"
      },
      "message": "Disable trace flag 8048 in SQL Server 2014 SP2, SQL Server 2016 and above"
    },
    {
      "id": "TF8048",
      "itemType": "override",
      "targetFilter": {
        "version": "[11.0, 12.0.4100)"
      },
      "message": "Enable trace flag 8048 to convert NUMA partitioned memory objects into CPU partitioned",
      "level": "Information",
      "condition": [
        {
          "in": [
            8048,
            "@TraceFlag"
          ]
        },
        {
          "gt": [
            8,
            {
              "div": [
                "@online_logical_processors",
                "@numa_nodes"
              ]
            }
          ]
        }
      ],
      "probes": [
        "EnabledGlobalTraceFlags",
        "ServerInstanceConfiguration"
      ]
    },
    {
      "id": "DeprecatedFeatures",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "tempdb",
            "model",
            "msdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Deprecated",
        "Security",
        "UpdateIssues",
        "Performance"
      ],
      "displayName": "Deprecated or discontinued features should not be used",
      "description": "This check detects deprecated or discontinued features used on target SQL Server instances. Deprecated features may be removed in a future release of SQL Server. Discontinued features have been removed from specific versions of SQL Server.",
      "message": "Replace deprecated or discontinued feature @{DeprecatedFeature} with actual features for SQL Server version @{ProductVersion}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/performance-monitor/sql-server-deprecated-features-object",
      "condition": {
        "equal": [
          "@DeprecatedFeature",
          ""
        ]
      },
      "probes": [
        "DeprecatedFeaturesStats",
        "SQLServerVersion"
      ]
    },
    {
      "id": "SystemHealthSession",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "XEvent",
        "SystemHealth"
      ],
      "displayName": "'system_health' XEvent session is not active",
      "description": "This session starts automatically when the SQL Server Database Engine starts, and runs without any noticeable performance effects. The session collects system data that you can use to help troubleshoot performance issues in the Database Engine. We recommend that you do not stop, alter, or delete the system health session.",
      "message": "Start system health session by using 'ALTER EVENT SESSION' statement or Extended Events node in Object Explorer",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/extended-events/use-the-system-health-session",
      "level": "Warning",
      "condition": "@XEvent.SystemHealthCount",
      "probes": [
        "XEvent.SystemHealth"
      ]
    },
    {
      "id": "SPServerDiagnosticsSession",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "XEvent",
        "SystemHealth"
      ],
      "displayName": "'sp_server_diagnostics' xEvent session is not active",
      "description": "This session starts automatically when the SQL Server Database Engine starts, and runs without any noticeable performance effects. The session collects system data that you can use to help troubleshoot performance issues in the Database Engine. We recommend that you do not stop, alter, or delete the system health session.",
      "message": "Start xEvent session by using 'ALTER EVENT SESSION' statement or Extended Events node in Object Explorer",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/system-stored-procedures/sp-server-diagnostics-transact-sql",
      "level": "Warning",
      "condition": "@XEvent.SPServerDiagnostics",
      "probes": [
        "XEvent.SPServerDiagnostics"
      ]
    },
    {
      "id": "BlackboxTrace",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Traces"
      ],
      "displayName": "Black box trace is running",
      "description": "This trace is designed to behave similarly to an airplane black box, to help you diagnose intermittent server crashes. It consumes more resources than the default trace and should not be running for extended periods of time.",
      "message": "Check that you need black box trace and stop it otherwise",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/system-stored-procedures/sp-trace-create-transact-sql",
      "level": "Warning",
      "condition": {
        "not": "@BlackBoxTraceCount"
      },
      "probes": [
        "CountBlackBoxTraces"
      ]
    },
    {
      "id": "DefaultTrace",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Traces"
      ],
      "displayName": "Default trace was not found or is inactive",
      "description": "Default trace provides troubleshooting assistance to database administrators by ensuring that they have the log data necessary to diagnose problems the first time they occur.",
      "message": "Check if there is enough space on SQL Server to write default trace file, then run default trace by disabling and reenabling it",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/policy-based-management/default-trace-log-files-disabled",
      "level": "Warning",
      "condition": "@DefaultTraceCount",
      "probes": [
        "CountDefaultTraces"
      ]
    },
    {
      "id": "HintsStatistics",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "QueryOptimizer",
        "Performance",
        "Statistics"
      ],
      "displayName": "Hints are used",
      "description": "Hints are options or strategies specified for enforcement by the SQL Server query processor on SELECT, INSERT, UPDATE, or DELETE statements. The hints override any execution plan the Query Optimizer might select for a query. Because the SQL Server Query Optimizer typically selects the best execution plan for a query, we recommend that <join_hint>, <query_hint>, and <table_hint> be used only as a last resort by experienced developers and database administrators.",
      "message": "Use <join_hint>, <query_hint> and <table_hint> in specific cases only since SQL Server Query Optimizer typically selects best execution plan for queries",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/queries/hints-transact-sql",
      "level": "Information",
      "condition": {
        "@HintUsageCount": 0
      },
      "probes": [
        "Hints.InstanceStatistics"
      ]
    },
    {
      "id": "HintsUsageInModules",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "QueryOptimizer",
        "Performance",
        "Statistics"
      ],
      "displayName": "Hints usage in modules",
      "enabled": false,
      "description": "Hints are options or strategies specified for enforcement by the SQL Server query processor on SELECT, INSERT, UPDATE, or DELETE statements. The hints override any execution plan the Query Optimizer might select for a query. Because the SQL Server Query Optimizer typically selects the best execution plan for a query, we recommend that <join_hint>, <query_hint>, and <table_hint> be used only as a last resort by experienced developers and database administrators.",
      "message": "@{Hint} used in @{type_desc} @{Schema_Name}.@{Object_Name}",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/queries/hints-transact-sql",
      "level": "Information",
      "probes": [
        "Hints.ModuleUsage"
      ]
    },
    {
      "id": "PlansUseRatio",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "QueryOptimizer"
      ],
      "displayName": "Amount of single use plans in cache is high",
      "description": "Single use plans waste system resources.",
      "message": "Enable 'Optimize for ad hoc workloads' setting on heavy OLTP ad-hoc workloads to conserve resources. Current amount of single use plans in cache is high (@{SingleUsePlansUseRatio:P0})",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/optimize-for-ad-hoc-workloads-server-configuration-option",
      "level": "Warning",
      "condition": {
        "less": [
          "@SingleUsePlansUseRatio",
          0.5
        ]
      },
      "probes": [
        "CachedPlans.SingleUseRatio"
      ]
    },
    {
      "id": "HypotheticalIndexes",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Hypothetical indexes found",
      "description": "Database has indexes that are marked as hypothetical. Hypothetical indexes are created by the Database Tuning Assistant (DTA) during its tests. If a DTA session was interrupted, these indexes may not be deleted. It is recommended to drop these objects as soon as possible.",
      "message": "Drop hypothetical @{IndexName} index for @{Schema}.@{Object}",
      "helpLink": "https://blogs.technet.microsoft.com/anurag_sharma/2008/04/15/hypothetical-indexes",
      "level": "Warning",
      "probes": [
        "Hypothetical.Indexes"
      ]
    },
    {
      "id": "HypotheticalStatistics",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Statistics"
      ],
      "displayName": "Hypothetical statistics found",
      "description": "Database has statistics that are marked as hypothetical. Hypothetical statistics are created by the Database Tuning Assistant (DTA) during its tests. If a DTA session was interrupted, these statistics may not be deleted. It is recommended to drop these objects as soon as possible.",
      "message": "Drop hypothetical @{StatName} statistics for @{Schema}.@{Object}",
      "helpLink": "https://blogs.technet.microsoft.com/anurag_sharma/2008/04/15/hypothetical-indexes",
      "level": "Warning",
      "probes": [
        "Hypothetical.Statistics"
      ]
    },
    {
      "id": "LatestCU",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Security",
        "UpdateIssues"
      ],
      "displayName": "SQL Server instance is not up to date",
      "description": "On an installed instance of SQL Server, we recommend that you apply the latest security updates and critical updates including general distribution releases (GDRs), service packs (SPs), and cumulative updates (CUs).",
      "message": "Update SQL Server and install Service Packs and Cumulative Updates as they are released. Current product version @{ProductVersion} is not up to date",
      "helpLink": "https://support.microsoft.com/help/321185/how-to-determine-the-version-edition-and-update-level-of-sql-server-an",
      "probes": [
        "SQLServerVersion"
      ]
    },
    {
      "id": "LatestCU",
      "itemType": "override",
      "targetFilter": {
        "version": [
          "[11.0.7507, 12.0)",
          "[12.0.6433, 13.0)",
          "[13.0.5882, 14.0)",
          "[14.0.3370, 15.0)",
          "[15.0.4102,)"
        ]
      },
      "displayName": "SQL Server instance is up to date",
      "message": "Product version @{ProductVersion} is the latest available",
      "helpLink": "https://support.microsoft.com/help/321185/how-to-determine-the-version-edition-and-update-level-of-sql-server-an",
      "condition": true
    },
    {
      "id": "FKNoIndexes",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "engineEdition": "OnPremises, ManagedInstance",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Indexes"
      ],
      "displayName": "Foreign key constraints should have corresponding indexes",
      "description": "Unlike primary key constraints, creating a foreign key constraint does not automatically create a corresponding index. However, manually creating an index on a foreign key is often useful.",
      "message": "Create a corresponding index for each foreign key. There is no index on foreign keys: @{ConstraintName}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/tables/primary-and-foreign-key-constraints",
      "level": "Warning",
      "condition": {
        "@ConstraintName": ""
      },
      "probes": [
        "FKNoIndexes"
      ]
    },
    {
      "id": "MissedIndexes",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Indexes"
      ],
      "displayName": "Potentially missing indexes",
      "description": "Potentially missing indexes were found based on query history. It may be important to revise them.",
      "message": "Create index on @{Table} with key columns @{KeyCols}@{IncludedCols: and included columns: #}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/sql-server-index-design-guide",
      "level": "Information",
      "probes": [
        "MissedIndexes"
      ]
    },
    {
      "id": "FullBackup",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "name": {
          "not": [
            "model",
            "tempdb"
          ]
        },
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Backup"
      ],
      "displayName": "Full backup is missed or outdated",
      "description": "Database doesn't have any full backup or the latest full backup is over 7 days old.",
      "message": "Create full backup. Last full backup is over @{threshold} days old",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/backup-restore/create-a-full-database-backup-sql-server",
      "level": "Warning",
      "condition": {
        "not": {
          "equal": [
            "@LastFullBackup",
            null
          ]
        },
        "less": [
          "@LastFullBackup",
          {
            "mul": [
              "@threshold",
              24
            ]
          }
        ]
      },
      "threshold": 7,
      "probes": [
        "DatabaseBackups"
      ]
    },
    {
      "id": "OutdatedTranLogBackup",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Backup"
      ],
      "displayName": "Transaction Log backup is missed or outdated",
      "description": "Database does not have any transaction Log backup since the latest full or differential backup, or it's older than 24H.",
      "message": "Create transaction log backup. Database recovery model: @{recovery_model_desc}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/backup-restore/back-up-a-transaction-log-sql-server",
      "level": "Warning",
      "condition": {
        "not": {
          "equal": [
            "@LastTLBackup",
            null
          ]
        },
        "less": [
          "@LastTLBackup",
          24
        ]
      },
      "probes": [
        "DatabaseBackups"
      ]
    },
    {
      "id": "DbDiffCollation",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBConfiguration",
        "Collation"
      ],
      "displayName": "Database collation doesn't match master collation",
      "description": "We recommend that the collations of user-defined databases match the collation of master or model. Otherwise, collation conflicts can occur that might prevent code from executing. For example, when a stored procedure joins one table to a temporary table, SQL Server might end the batch and return a collation conflict error if the collations of the user-defined database and the model database are different. This occurs because temporary tables are created in tempdb, which bases its collation on that of model.",
      "message": "Keep database collation the same as master or model collation",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/set-collation-user-defined-databases-match-master-model-databases",
      "level": "Warning",
      "condition": {
        "equal": [
          "@collation_name",
          "@master_collation"
        ]
      },
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "AutoClose",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "name": {
          "not": [
            "master",
            "msdb",
            "tempdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "DBConfiguration"
      ],
      "displayName": "'AUTO_CLOSE' option should be OFF",
      "description": "When AUTO_CLOSE is set ON, this can cause performance degradation on frequently accessed databases because of the increased overhead of opening and closing the database after each connection. AUTO_CLOSE also flushes the procedure cache after each connection.",
      "message": "Set 'AUTO_CLOSE' option to OFF",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/policy-based-management/set-the-auto-close-database-option-to-off",
      "level": "Warning",
      "condition": {
        "not": "@is_auto_close_on"
      },
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "AutoShrink",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": {
          "not": [
            "master",
            "msdb",
            "tempdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBConfiguration",
        "Performance"
      ],
      "displayName": "'AUTO_SHRINK' option should be OFF",
      "description": "Shrinking databases is the fastest way to achieve fragmentation. SQL Server goes to the last page in the database, moves it to the first free available space, and then repeats the process again. This shuffles the deck, putting your pages out of order.",
      "message": "Set 'AUTO_SHRINK' option to OFF",
      "helpLink": "https://blogs.msdn.microsoft.com/buckwoody/2009/07/01/sql-server-best-practices-auto-shrink-should-be-off",
      "level": "Warning",
      "condition": {
        "not": "@is_auto_shrink_on"
      },
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "PageVerify",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "name": {
          "not": [
            "master",
            "msdb",
            "tempdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBConfiguration",
        "DataIntegrity"
      ],
      "displayName": "'PAGE_VERIFY' option should be 'CHECKSUM'",
      "description": "When CHECKSUM is enabled for the PAGE_VERIFY database option, the SQL Server Database Engine calculates a checksum over the contents of the whole page, and stores the value in the page header when a page is written to disk. When the page is read from disk, the checksum is recomputed and compared to the checksum value that is stored in the page header. This helps provide a high level of data-file integrity.",
      "message": "Set 'PAGE_VERIFY' option to 'CHECKSUM'",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/policy-based-management/set-the-page-verify-database-option-to-checksum",
      "level": "Warning",
      "condition": {
        "@page_verify_option": 2
      },
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "DbChaining",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": {
          "not": [
            "master",
            "msdb",
            "tempdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBConfiguration",
        "Security"
      ],
      "displayName": "Cross-Database access should be disabled",
      "description": "Ownership chaining across databases is turned off by default. Microsoft recommends that you disable cross-database ownership chaining because it exposes you to the additional security risks.",
      "message": "Turn off 'DB_CHAINING' option",
      "helpLink": "https://docs.microsoft.com/dotnet/framework/data/adonet/sql/enabling-cross-database-access-in-sql-server",
      "level": "Warning",
      "condition": {
        "not": "@is_db_chaining_on"
      },
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "AutoCreateStatsIncremental",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[12.0,)",
        "name": {
          "not": [
            "master",
            "msdb",
            "tempdb"
          ]
        }
      },
      "tags": [
        "DefaultRuleset",
        "DBConfiguration",
        "Statistics",
        "Performance"
      ],
      "displayName": "Incremental option of auto stats should be ON",
      "description": "Incremental statistics update at partition level is a feature introduced in SQL Server 2014. When the option INCREMENTAL is turn on at the database level, newly auto created column statistics will use incremental statistics on partitioned tables by default.",
      "message": "Turn on 'AUTO_CREATE_STATISTICS' and 'INCREMENTAL' options",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/statistics/statistics",
      "level": "Warning",
      "condition": "@is_auto_create_stats_incremental_on",
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "TrustWorthy",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "name": {
          "not": [
            "master",
            "msdb",
            "tempdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBConfiguration",
        "Security"
      ],
      "displayName": "'TRUSTWORTHY' should be OFF",
      "description": "You can use the TRUSTWORTHY database setting to indicate whether the instance of Microsoft SQL Server trusts the database and the contents within the database. By default, this setting is set to OFF to mitigate certain threats that may be present when a database is attached to the server.",
      "message": "Set 'TRUSTWORTHY' option to OFF",
      "helpLink": "https://support.microsoft.com/help/2183687/guidelines-for-using-the-trustworthy-database-setting-in-sql-server",
      "level": "Warning",
      "condition": {
        "not": "@is_trustworthy_on"
      },
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "ParameterizationNotSimple",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": {
          "not": [
            "master",
            "msdb",
            "tempdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBConfiguration",
        "Performance",
        "QueryOptimizer"
      ],
      "displayName": "'PARAMETERIZATION' should be 'SIMPLE'",
      "description": "When the PARAMETERIZATION database option is set to SIMPLE, the SQL Server query optimizer may choose to parameterize the queries. This means that any literal values that are contained in a query are substituted with parameters. This process is referred to as simple parameterization. When SIMPLE parameterization is in effect, you cannot control which queries are parameterized and which queries are not. However, you can specify that all queries in a database be parameterized by setting the PARAMETERIZATION database option to FORCED. Regardless of whether you have a Plan-Stability or not, SQL Server will always auto parameterize your SQL Statements, and reuse the cached execution plan over and over again. It doesn't matter how terrible the execution plan is. Therefore you have to know in exact detail the shape of your execution plans, and whether they can lead to some performance related problems.",
      "message": "Set 'PARAMETERIZATION' to 'SIMPLE' and use forced parameterization only on certain classes of queries instead of all queries",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/performance/specify-query-parameterization-behavior-by-using-plan-guides",
      "level": "Warning",
      "condition": {
        "not": "@is_parameterization_forced"
      },
      "probes": [
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "TempDBFilesNotSameSize",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TempDB",
        "Performance",
        "DBFileConfiguration"
      ],
      "displayName": "TempDB data files are not the same size",
      "description": "We recommend that you create all TempDB data files at the same size.",
      "message": "Make all TempDB data files the same size",
      "helpLink": "https://support.microsoft.com/kb/2154845",
      "level": "Warning",
      "condition": {
        "@filesizeCount": 1
      },
      "probes": [
        "TempDBFiles"
      ]
    },
    {
      "id": "TempDBFilesMultiple4",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TempDB",
        "Performance",
        "DBFileConfiguration"
      ],
      "displayName": "Number of TempDB data files should be in multiples of 4",
      "description": "Number of TempDB data files should correlate with the number of (logical) processors on the machine. As a general rule, if the number of logical processors is less than or equal to 8, use the same number of data files as logical processors. If the number of logical processors is greater than 8, use 8 data files and then if contention continues, increase the number of data files by multiples of 4 until the contention is reduced to acceptable levels or make changes to the workload/code.",
      "message": "Number of TempDB data files should be in multiples of 4",
      "helpLink": "https://support.microsoft.com/kb/2154845",
      "level": "Warning",
      "condition": [
        {
          "less": [
            "@online_logical_processors",
            8
          ]
        },
        {
          "equal": [
            {
              "mod": [
                "@physical_name",
                4
              ]
            },
            0
          ]
        }
      ],
      "probes": [
        {
          "id": "DatabaseMasterFiles",
          "params": {
            "dbId": 2,
            "type": 0
          },
          "transform": {
            "type": "aggregate",
            "map": {
              "physical_name": "count"
            }
          }
        },
        "ServerInstanceConfiguration"
      ]
    },
    {
      "id": "TempDBFiles1PerCPU",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TempDB",
        "Performance",
        "DBFileConfiguration"
      ],
      "displayName": "Number of TempDB data files should depend on CPU count",
      "description": "Number of TempDB data files should correlate with the number of (logical) processors on the machine. As a general rule, if the number of logical processors is less than or equal to 8, use the same number of data files as logical processors. If the number of logical processors is greater than 8, use 8 data files and then if contention continues, increase the number of data files by multiples of 4 until the contention is reduced to acceptable levels or make changes to the workload/code.",
      "message": "1 data file per logical processor is required (processors count: @{online_logical_processors})",
      "helpLink": "https://support.microsoft.com/kb/2154845",
      "level": "Warning",
      "condition": [
        {
          "greater": [
            "@online_logical_processors",
            8
          ]
        },
        {
          "greaterequal": [
            "@physical_name",
            "@online_logical_processors"
          ]
        }
      ],
      "probes": [
        {
          "id": "DatabaseMasterFiles",
          "params": {
            "dbId": 2,
            "type": 0
          },
          "transform": {
            "type": "aggregate",
            "map": {
              "physical_name": "count"
            }
          }
        },
        "ServerInstanceConfiguration"
      ]
    },
    {
      "id": "TempDBFilesNotLess8",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TempDB",
        "Performance",
        "DBFileConfiguration"
      ],
      "displayName": "Number of TempDB data files should be at least 8",
      "description": "Number of TempDB data files should correlate with the number of (logical) processors on the machine. As a general rule, if the number of logical processors is less than or equal to 8, use the same number of data files as logical processors. If the number of logical processors is greater than 8, use 8 data files and then if contention continues, increase the number of data files by multiples of 4 until the contention is reduced to acceptable levels or make changes to the workload/code.",
      "message": "Add extra data files to TempDB. There are @{physical_name} data files, should be at least 8",
      "helpLink": "https://support.microsoft.com/kb/2154845",
      "level": "Warning",
      "condition": [
        {
          "less": [
            "@online_logical_processors",
            9
          ]
        },
        {
          "greater": [
            "@physical_name",
            7
          ]
        }
      ],
      "probes": [
        {
          "id": "DatabaseMasterFiles",
          "params": {
            "dbId": 2,
            "type": 0
          },
          "transform": {
            "type": "aggregate",
            "map": {
              "physical_name": "count"
            }
          }
        },
        "ServerInstanceConfiguration"
      ]
    },
    {
      "id": "TempDBFilesAutoGrowth",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "TempDB",
        "Performance",
        "DBFileConfiguration"
      ],
      "displayName": "TempDB data files have different auto-growth settings",
      "description": "TempDB data files should be of equal size within each filegroup, as SQL Server uses a proportional-fill algorithm that favors allocations in files with more free space.",
      "message": "Make auto-growth settings the same for each TempDB data file",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/databases/tempdb-database",
      "level": "Warning",
      "condition": {
        "and": [
          {
            "@growth": 1
          },
          {
            "@is_percent_growth": 1
          }
        ]
      },
      "probes": [
        {
          "id": "DatabaseMasterFiles",
          "params": {
            "dbId": 2,
            "type": 0
          },
          "transform": {
            "type": "aggregate",
            "map": {
              "growth": "count",
              "is_percent_growth": "count"
            }
          }
        }
      ]
    },
    {
      "id": "FilesAutogrowth",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "version": "[13.0.4001,)",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "DBFileConfiguration"
      ],
      "displayName": "Database files auto-growth over 1GB",
      "description": "A data or log file will be extended with auto-growth value to prevent the lack of free space in files. This process can perform significant impact on SQL Server performance if auto-growth value gets over 1 GB. By default, SQL Server will put zeros to a newly allocated space. And the more space it takes, the more time it takes to initialize it.",
      "message": "Set file growth to less than 1GB for files: @{FileName}",
      "helpLink": "https://support.microsoft.com/help/315512/considerations-for-the-autogrow-and-autoshrink-settings-in-sql-server",
      "level": "Warning",
      "condition": {
        "@FileName": ""
      },
      "probes": [
        "Autogrow1GB"
      ]
    },
    {
      "id": "DuplicateIndexes",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Indexes"
      ],
      "displayName": "Duplicate indexes",
      "description": "A SQL Server index is an on-disk or in-memory structure associated with a table or view that speeds retrieval of rows from the table or view. An index contains keys built from one or more columns in the table or view. ",
      "message": "Remove duplicate indexes in table @{Table}: @{ToDelete}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/sql-server-index-design-guide",
      "level": "Warning",
      "probes": [
        {
          "id": "IndexesDefinitions",
          "transform": {
            "type": "duplicateIndexes"
          }
        }
      ]
    },
    {
      "id": "RedundantIndexes",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Indexes"
      ],
      "displayName": "Tables with redundant indexes",
      "description": "There are tables with possibly redundant indexes according to the set of key and included columns. We recommended to revise all these objects as soon as possible.",
      "message": "Remove redundant indexes in table @{Table}: @{Indexes}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/sql-server-index-design-guide",
      "level": "Warning",
      "probes": [
        {
          "id": "IndexesDefinitions",
          "transform": {
            "type": "redundantIndexes"
          }
        }
      ]
    },
    {
      "id": "UserObjectsInMaster",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": "master",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "masterDB",
        "Backup"
      ],
      "displayName": "User objects in master database",
      "description": "We highly recommend you not create user objects in the master database. If it's unavoidable for some reason, make sure to back up the database more frequently.",
      "message": "Remove user objects from 'master' database: @{Object_Name}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/databases/master-database",
      "condition": {
        "@Object_Name": ""
      },
      "probes": [
        "UserObjectsCountInMasterDB"
      ]
    },
    {
      "id": "HighCPUUsage",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "CPU"
      ],
      "displayName": "High CPU usage on server",
      "description": "Keeping CPU usage rates within normal ranges is vital for servers hosting SQL Server instances. A continually high rate of CPU usage may indicate the need to upgrade the CPU or add multiple processors. Alternatively, a high CPU usage rate may indicate a poorly tuned or designed application. Optimizing the application can lower CPU utilization.",
      "message": "Investigate high CPU utilization on server hosting this instance. Last 2 hours: total CPU usage is ~@{AVGTotalCPUUsage}%, usage by SQL Server is ~@{AVGSQLCPUUsage}%",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/performance-monitor/monitor-cpu-usage",
      "level": "Warning",
      "threshold": 70,
      "condition": {
        "less": [
          "@AVGTotalCPUUsage",
          "@threshold"
        ]
      },
      "probes": [
        "CpuUsage"
      ]
    },
    {
      "id": "ReplErrors24H",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Replication"
      ],
      "displayName": "Replication errors within last 24 hours",
      "description": "This check searches for errors in distribution database agent's history table for the last 24 hours.",
      "message": "Review '@{publisher_db}' database replication errors for publications: @{publication}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/replication/sql-server-replication",
      "level": "Warning",
      "probes": [
        {
          "id": "ReplicationErrors",
          "transform": {
            "type": "aggregate",
            "group": "publisher_db",
            "map": {
              "publication": "join"
            }
          }
        }
      ]
    },
    {
      "id": "AgentAlertsSeverity10",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 10",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        825,
        833,
        855,
        856,
        3452,
        3619,
        17179,
        17883,
        17884,
        17887,
        17888,
        17890,
        28036
      ],
      "severityN": 10,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "AgentAlertsSeverity16",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 16",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        2508,
        2511,
        3271,
        5228,
        5229,
        5242,
        5243,
        5250,
        5901,
        17130,
        17300
      ],
      "severityN": 16,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "AgentAlertsSeverity17",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 17",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        802,
        845,
        1101,
        1105,
        1121,
        1214,
        8642,
        9002
      ],
      "severityN": 17,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "AgentAlertsSeverity19",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 19",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        701
      ],
      "severityN": 19,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "AgentAlertsSeverity20",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 20",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        3624
      ],
      "severityN": 20,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "AgentAlertsSeverity21",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 21",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        605
      ],
      "severityN": 21,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "AgentAlertsSeverity22",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 22",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        5180,
        8966
      ],
      "severityN": 22,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "AgentAlertsSeverity23",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 23",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        5572,
        9100
      ],
      "severityN": 23,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "AgentAlertsSeverity24",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Agent"
      ],
      "displayName": "Agent doesn't rise alerts for errors with severity 24",
      "description": "Events are generated by SQL Server and entered into the Microsoft Windows application log. SQL Server Agent reads the application log and compares events written there to alerts that you have defined. When SQL Server Agent finds a match, it fires an alert, which is an automated response to an event. In addition to monitoring SQL Server events, SQL Server Agent can also monitor performance conditions and Windows Management Instrumentation (WMI) events.",
      "message": "Create alerts for errors: @{error_ids}",
      "helpLink": "https://docs.microsoft.com/sql/ssms/agent/alerts",
      "level": "Warning",
      "condition": [
        {
          "in": [
            "@severityN",
            "@severity"
          ]
        },
        {
          "intersect": [
            "@error_ids",
            "@message_id"
          ]
        }
      ],
      "error_ids": [
        823,
        824,
        832
      ],
      "severityN": 24,
      "probes": [
        "SysAlerts"
      ]
    },
    {
      "id": "WeakPassword",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Security",
        "WeakPassword"
      ],
      "displayName": "Weak password",
      "description": "Some user logins have weak passwords.",
      "message": "Set strong passwords for logins: @{PasswordData}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/security/strong-passwords",
      "probes": [
        "WeakPassword"
      ]
    },
    {
      "id": "VLFCount",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Backup",
        "Performance"
      ],
      "displayName": "VLF count",
      "description": "The SQL Server Database Engine divides each physical log file internally into a number of virtual log files (VLFs). Virtual log files have no fixed size, and there is no fixed number of virtual log files for a physical log file. The Database Engine chooses the size of the virtual log files dynamically while it is creating or extending log files. The Database Engine tries to maintain a small number of virtual files. The size of the virtual files after a log file has been extended is the sum of the size of the existing log and the size of the new file increment. The size or number of virtual log files cannot be configured or set by administrators. If the log files grow to a large size in many small increments, they will have many virtual log files. This can slow down database startup and also log backup and restore operations. Conversely, if the log files are set to a large size with few or just one increment, they will have few very large virtual log files. We recommend that you assign log files a size value close to the final size required, using the required increments to achieve optimal VLF distribution, and also have a relatively large growth_increment value.",
      "message": "Update transaction log settings to reduce number of VLFs. Current number is: @{RecoveryUnitId}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/sql-server-transaction-log-architecture-and-management-guide",
      "condition": {
        "less": [
          "@RecoveryUnitId",
          "@threshold"
        ]
      },
      "threshold": 50,
      "probes": [
        {
          "id": "VLF",
          "transform": {
            "type": "aggregate",
            "map": {
              "RecoveryUnitId": {
                "type": "count",
                "distinct": false
              }
            }
          }
        }
      ]
    },
    {
      "id": "TF8015",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,11.0.3349)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "CPU",
        "NUMA"
      ],
      "displayName": "TF 8015 disables auto-detection and NUMA setup",
      "description": "SQL Server allows you to group CPUs into nodes referred to as soft-NUMA. You usually configure soft-NUMA when you have many CPUs and do not have hardware NUMA, but you can also use soft-NUMA to subdivide hardware NUMA nodes into smaller groups.",
      "message": "Disable trace flag 8015 for this SQL Server instance. This trace flag does not apply to this SQL Server version",
      "helpLink": "https://techcommunity.microsoft.com/t5/SQL-Server-Support/How-It-Works-Soft-NUMA-I-O-Completion-Thread-Lazy-Writer-Workers/ba-p/316044",
      "condition": {
        "not": {
          "in": [
            8015,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF8032",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 8032 reverts cache limit parameters to SQL Server 2005 RTM",
      "description": "Trace Flag 8032 reverts the cache limit parameters to the SQL Server 2005 RTM setting but can cause poor performance if large caches make less memory available for other memory consumers like BP.",
      "message": "Disable trace flag 8032",
      "condition": {
        "not": {
          "in": [
            8032,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF8744",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,12.0)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 8744 disables pre-fetching for Nested Loop operator",
      "description": "Trace flag 8744 disables pre-fetching for the Nested Loops operator. Incorrect use of this trace flag may cause additional physical reads when SQL Server executes plans that contain the Nested Loops operator.",
      "message": "Disable trace flag 8744 for this SQL Server instance. This trace flag does not apply to this SQL Server version",
      "helpLink": "https://support.microsoft.com/help/920093/tuning-options-for-sql-server-when-running-in-high-performance-workloa",
      "condition": {
        "not": {
          "in": [
            8744,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF9347",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,13.0)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 9347 disables batch mode for sort operator",
      "description": "Trace flag 9347 disables batch mode for sort operator. SQL Server 2016 (13.x) introduced a new batch mode sort operator that boosts performance for many analytical queries.",
      "message": "Disable trace flag 9347 for this SQL Server instance. This trace flag does not apply to this SQL Server version",
      "condition": {
        "not": {
          "in": [
            9347,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF9349",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,13.0)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance"
      ],
      "displayName": "TF 9349 disables batch mode for top N sort operator",
      "description": "Trace flag 9349 disables batch mode for top N sort operator. SQL Server 2016 (13.x) introduced a new batch mode top sort operator that boosts performance for many analytical queries.",
      "message": "Disable trace flag 9349 for this SQL Server instance. This trace flag does not apply to this SQL Server version",
      "condition": {
        "not": {
          "in": [
            9349,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF9389",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,13.0)",
        "platform": "Windows",
        "engineEdition": "OnPremises, ManagedInstance"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "TempDB"
      ],
      "displayName": "TF 9389 enables dynamic memory grant for batch mode operators",
      "description": "Trace flag 9389 enables additional dynamic memory grant for batch mode operators. If a query does not get all the memory it needs, it spills data to TempDB, incurring additional I/O and potentially impacting query performance. If the dynamic memory grant trace flag is enabled, a batch mode operator may ask for additional memory and avoid spilling to TempDB if additional memory is available.",
      "message": "Disable trace flag 9389 for this SQL Server instance. The trace flag does not apply to this SQL Server version",
      "condition": {
        "not": {
          "in": [
            9389,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF9476",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,13.0)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "QueryOptimizer"
      ],
      "displayName": "TF 9476 causes SQL Server to generate plan using Simple Containment assumption",
      "description": "Trace flag 9476 causes SQL Server to generate a plan using the Simple Containment assumption instead of the default Base Containment assumption, under the query optimizer cardinality estimation model of SQL Server 2014 (12.x) through SQL Server 2017 versions.",
      "message": "Disable trace flag 9476 for this SQL Server instance. The trace flag does not apply to this SQL Server version",
      "condition": {
        "not": {
          "in": [
            9476,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF9481",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,12.0)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "QueryOptimizer",
        "Performance"
      ],
      "displayName": "TF 9481 enables Legacy CE model",
      "description": "Trace flag 9481 enables you to set the query optimizer cardinality estimation model to the SQL Server 2012 (11.x) and earlier versions, irrespective of the compatibility level of the database.",
      "message": "Disable trace flag 9481 for this SQL Server instance. The trace flag does not apply to this SQL Server version",
      "condition": {
        "not": {
          "in": [
            9481,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "TF10204",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "version": "[11.0,13.0)",
        "platform": "Windows",
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "ColumnStore"
      ],
      "displayName": "TF 10204 disables merge/recompress",
      "description": "Trace flag 10204 disables merge/recompress during columnstore index reorganization. In SQL Server 2016 (13.x), when a columnstore index is reorganized, there is new functionality to automatically merge any small compressed rowgroups into larger compressed rowgroups, as well as recompressing any rowgroups that have a large number of deleted rows.",
      "message": "Disable trace flag 10204. The trace flag does not apply to this SQL Server version",
      "condition": {
        "not": {
          "in": [
            10204,
            "@TraceFlag"
          ]
        }
      },
      "probes": [
        "EnabledGlobalTraceFlags"
      ]
    },
    {
      "id": "SPNaming",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "level": "Warning",
      "tags": [
        "DefaultRuleset",
        "Naming"
      ],
      "displayName": "Stored procedure naming",
      "description": "In SQL Server, the sp_ prefix designates system stored procedures. If you use that prefix for your stored procedures, the name of your procedure might conflict with the name of a system stored procedure that will be created in the future. If such a conflict occurs, your application might break if your application refers to the procedure without qualifying the reference by schema. In this situation, the name will bind to the system procedure instead of to your procedure.",
      "message": "Rename the following stored procedures to eliminate 'sp_' prefix: @{ObjectName}",
      "helpLink": "https://docs.microsoft.com/previous-versions/visualstudio/visual-studio-2010/dd172115(v=vs.100)",
      "condition": {
        "not": "@ObjectName"
      },
      "probes": [
        "BadNamingSP"
      ]
    },
    {
      "id": "ObjectNamingSpecialChar",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "level": "Warning",
      "tags": [
        "DefaultRuleset",
        "Naming"
      ],
      "displayName": "Special characters in object names",
      "description": "If you name a database object by using any character in the following table, you make it more difficult not only to reference that object but also to read code that contains the name of that object.",
      "message": "Rename the following objects to eliminate special characters: @{ObjectName}",
      "helpLink": "https://docs.microsoft.com/previous-versions/visualstudio/visual-studio-2010/dd172134(v=vs.100)",
      "condition": {
        "not": "@ObjectName"
      },
      "probes": [
        "BadNamingSpecialChars"
      ]
    },
    {
      "id": "ColumnNamingSpecialChar",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "level": "Warning",
      "tags": [
        "DefaultRuleset",
        "Naming"
      ],
      "displayName": "Special characters in column names",
      "description": "Using whitespaces, left and right square brackets, single and double quotation marks in database object names makes it more difficult not only to reference that object, but also to read code that contains the name of that object.",
      "message": "Remove whitespaces, left and right square brackets, single and double quotation marks from column names: @{ObjectName}",
      "helpLink": "https://docs.microsoft.com/previous-versions/visualstudio/visual-studio-2010/dd172134(v=vs.100)",
      "condition": {
        "not": "@ObjectName"
      },
      "probes": [
        "BadNamingSpecialCharsColumns"
      ]
    },
    {
      "id": "FnNaming",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "level": "Warning",
      "tags": [
        "DefaultRuleset",
        "Naming"
      ],
      "displayName": "User function naming",
      "description": "In SQL Server, the fn_ prefix designates system functions. If you use that prefix for your functions, the name of your function might conflict with the name of a system function that will be created in the future. If such a conflict occurs, your application might break if your application refers to the function without qualifying the reference by schema. In this situation, the name will bind to the system function instead of to your function.",
      "message": "Rename the following functions to eliminate 'fn_ prefix': @{ObjectName}",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/create-function-transact-sql",
      "condition": {
        "not": "@ObjectName"
      },
      "probes": [
        "BadNamingUserFunctions"
      ]
    },
    {
      "id": "ObjectNamingResKeywords",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "level": "Warning",
      "tags": [
        "DefaultRuleset",
        "Naming"
      ],
      "displayName": "Object names contain reserved keywords",
      "description": "Microsoft SQL Server uses reserved keywords for defining, manipulating, and accessing databases. Reserved keywords are part of the grammar of the Transact-SQL language that is used by SQL Server to parse and understand Transact-SQL statements and batches. Although it is syntactically possible to use SQL Server reserved keywords as identifiers and object names in Transact-SQL scripts, you can do this only by using delimited identifiers.",
      "message": "Rename the following objects to eliminate reserved keywords: @{ObjectName}",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/language-elements/reserved-keywords-transact-sql",
      "condition": {
        "not": "@ObjectName"
      },
      "probes": [
        "BadNamingKeywords"
      ]
    },
    {
      "id": "DeprFeaturesInModules",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "tempdb",
            "model",
            "msdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Security",
        "Deprecated",
        "LongRunningChecks",
        "UpdateIssues"
      ],
      "displayName": "Deprecated or discontinued features in modules",
      "description": "Deprecated features are scheduled to be removed in a future release of SQL Server. Discontinued features have been removed from specific versions of SQL Server.",
      "message": "Remove deprecated or discontinued features in @{ObjectName}: @{Keyword}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/performance-monitor/sql-server-deprecated-features-object",
      "level": "Warning",
      "probes": [
        "DeprecatedFeaturesSQLModules"
      ]
    },
    {
      "id": "DeprFeaturesInJobs",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Security",
        "Deprecated",
        "Agent",
        "Jobs",
        "LongRunningChecks",
        "UpdateIssues"
      ],
      "displayName": "Deprecated or discontinued features in modules",
      "description": "Deprecated features are scheduled to be removed in a future release of SQL Server. Discontinued features have been removed from specific versions of SQL Server.",
      "message": "Remove deprecated or discontinued features in @{ObjectName}: @{Keyword}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/performance-monitor/sql-server-deprecated-features-object",
      "level": "Warning",
      "probes": [
        "DeprecatedFeaturesJobs"
      ]
    },
    {
      "id": "NUMANodeSingleCPU",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "NUMA",
        "CPU",
        "Memory",
        "Performance"
      ],
      "displayName": "Single CPU assigned to NUMA node",
      "description": "Microsoft SQL Server is non-uniform memory access (NUMA) aware. NUMA architecture provides a scalable solution to performance problem. Computers with hardware NUMA have more than one system bus, each serving a small set of processors. Each group of processors has its own memory and possibly its own I/O channels, but each CPU can access memory associated with other groups in a coherent way. Each group is called a NUMA node. The number of CPUs within a NUMA node depends on the hardware vendor. Your hardware manufacturer can tell you if your computer supports hardware NUMA.",
      "message": "Assign additional CPUs to NUMA nodes with only one CPU",
      "helpLink": "https://docs.microsoft.com/previous-versions/sql/sql-server-2008-r2/ms178144(v=sql.105)",
      "level": "Warning",
      "condition": {
        "not": "@nodes_single_cpu"
      },
      "probes": [
        "ServerInstanceConfiguration"
      ]
    },
    {
      "id": "NUMANodeNoCPU",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "NUMA",
        "Performance",
        "CPU",
        "Memory"
      ],
      "displayName": "NUMA nodes without CPUs",
      "description": "Microsoft SQL Server is non-uniform memory access (NUMA) aware. NUMA architecture provides a scalable solution to performance problem. Computers with hardware NUMA have more than one system bus, each serving a small set of processors. Each group of processors has its own memory and possibly its own I/O channels, but each CPU can access memory associated with other groups in a coherent way. Each group is called a NUMA node. The number of CPUs within a NUMA node depends on the hardware vendor. Your hardware manufacturer can tell you if your computer supports hardware NUMA.",
      "message": "Assign CPUs to each NUMA node",
      "helpLink": "https://docs.microsoft.com/previous-versions/sql/sql-server-2008-r2/ms178144(v=sql.105)",
      "level": "Warning",
      "condition": {
        "not": "@NodeCnt"
      },
      "probes": [
        "AffinityNUMANodeNoAssignedCPUs"
      ]
    },
    {
      "id": "IndexKeyGuid",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": {
          "not": [
            "master",
            "tempdb",
            "model",
            "msdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Guid in clustered index key column",
      "description": "A big reason for a clustered index is when you often want to retrieve rows for a range of values for a given column. Because the data is physically arranged in that order, the rows can be extracted very efficiently. Something like a GUID, while excellent for a primary key, could be positively detrimental to performance, as there will be additional cost for inserts and no perceptible benefit on selects.",
      "message": "Remove GUIDs in clustered indexes keys: @{IndexName}",
      "helpLink": "https://azure.microsoft.com/blog/uniqueidentifier-and-clustered-indexes/",
      "level": "Warning",
      "probes": [
        "IndexesGuidKeyColumns"
      ]
    },
    {
      "id": "IndexesLargeKeys",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,13.0)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Indexes keys with more than 900 bytes",
      "description": "When you design an index that contains many key columns, or large-size columns, calculate the size of the index key to make sure that you do not exceed the maximum index key size. SQL Server retains the 900-byte limit for the maximum total size of all index key columns. This excludes nonkey columns that are included in the definition of nonclustered indexes.",
      "message": "Remove keys larger than 900 bytes in @{FullName} index",
      "helpLink": "http://msdn.microsoft.com/library/ms191241.aspx",
      "level": "Warning",
      "condition": {
        "le": [
          "@KeySize",
          900
        ]
      },
      "probes": [
        "IndexesDefinitions"
      ]
    },
    {
      "id": "IndexesLargeKeysNonClust",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[13.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "NonClustered indexes keys with more than 1700 bytes",
      "description": "When you design an index that contains many key columns, or large-size columns, calculate the size of the index key to make sure that you do not exceed the maximum index key size. SQL Server retains the 1700-byte limit for the maximum total size of all non-clustered index key columns. This excludes nonkey columns that are included in the definition of nonclustered indexes.",
      "message": "Remove keys larger than 1700 bytes in @{FullName} index",
      "helpLink": "http://msdn.microsoft.com/library/ms191241.aspx",
      "level": "Warning",
      "condition": [
        {
          "le": [
            "@KeySize",
            1700
          ]
        },
        {
          "not": {
            "in": [
              "@Type",
              [
                2,
                6
              ]
            ]
          }
        }
      ],
      "probes": [
        "IndexesDefinitions"
      ]
    },
    {
      "id": "IndexesLargeKeysClust",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[13.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Clustered indexes keys with more than 900 bytes",
      "description": "When you design an index that contains many key columns, or large-size columns, calculate the size of the index key to make sure that you do not exceed the maximum index key size. SQL Server retains the 900-byte limit for the maximum total size of all clustered index key columns. This excludes nonkey columns that are included in the definition of nonclustered indexes.",
      "message": "Remove keys larger than 900 bytes in @{FullName} index",
      "helpLink": "http://msdn.microsoft.com/library/ms191241.aspx",
      "level": "Warning",
      "condition": [
        {
          "le": [
            "@KeySize",
            900
          ]
        },
        {
          "not": {
            "in": [
              "@Type",
              [
                1,
                5
              ]
            ]
          }
        }
      ],
      "probes": [
        "IndexesDefinitions"
      ]
    },
    {
      "id": "DisabledIndexes",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Disabled indexes exist",
      "description": "If you need to load a lot of data quickly, you can disable nonclustered indexes in order to improve performance. After the data load finishes, enable the nonclustered indexes again by rebuilding them. This technique works best in large data warehouse environments where entire dimension tables might be reloaded from scratch every night. Disabling nonclustered indexes is safer than dropping and recreating them because scripting indexes is hard. Unfortunately, sometimes our load processes crash before enabling the indexes again, or sometimes we manually load data and we forget to rebuild them.",
      "message": "Remove or enable disabled index: @{FullName}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/indexes/disable-indexes-and-constraints",
      "level": "Warning",
      "condition": {
        "@IsDisabled": false
      },
      "probes": [
        "IndexesDefinitions"
      ]
    },
    {
      "id": "IndexesFillFactor",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Index fill factor is below 80%",
      "description": "The fill-factor option is provided for fine-tuning index data storage and performance. When an index is created or rebuilt, the fill-factor value determines the percentage of space on each leaf-level page to be filled with data, reserving the remainder on each page as free space for future growth. For example, specifying a fill-factor value of 80 means that 20 percent of each leaf-level page will be left empty, providing space for index expansion as data is added to the underlying table. The empty space is reserved between the index rows rather than at the end of the index.",
      "message": "Review index @{FullName} as its fill factor @{FillFactor} is lower than 80 percent",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/indexes/specify-fill-factor-for-an-index",
      "level": "Warning",
      "condition": [
        {
          "less": [
            "@FillFactor",
            1
          ]
        },
        {
          "ge": [
            "@FillFactor",
            80
          ]
        }
      ],
      "probes": [
        "IndexesDefinitions"
      ]
    },
    {
      "id": "NonUniqueClusterIndex",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Non-unique clustered indexes",
      "description": "Index uniqueness is highly desirable attribute of a clustering key, and goes hand-in-hand with index narrowness. SQL Server does not require a clustered index to be unique, but yet it must have some means of uniquely identifying every row. That’s why, for non-unique clustered indexes, SQL Server adds to every duplicate instance of a clustering key value a 4-byte integer value called a uniqueifier. This uniqueifier is added everywhere the clustering key is stored. That means the uniqueifier is stored in both clustered and non-clustered indexes. As you can imagine, if there are many rows using the same clustering key value, this can become quite expensive.",
      "message": "Review non-unique @{FullName} clustered index",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/indexes/clustered-and-nonclustered-indexes-described",
      "level": "Warning",
      "condition": [
        {
          "gt": [
            "@Type",
            1
          ]
        },
        {
          "@IsUnique": true
        }
      ],
      "probes": [
        "IndexesDefinitions"
      ]
    },
    {
      "id": "SuspectPages",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleSet",
        "Pages",
        "DataIntegrity"
      ],
      "displayName": "Suspect pages found",
      "description": "The suspect_pages table is used for maintaining information about suspect pages, and is relevant in helping to decide whether a restore is necessary.",
      "message": "Run 'DBCC CHECKDB' to verify affected database. Suspect pages were found: @{EventType}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/backup-restore/manage-the-suspect-pages-table-sql-server",
      "level": "Warning",
      "probes": [
        "SuspectPagesValidation"
      ]
    },
    {
      "id": "SparseFiles",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleSet",
        "Snapshots",
        "Backup",
        "DataIntegrity"
      ],
      "displayName": "Sparse files",
      "description": "If the file is sparse or compressed, the NTFS file system may deallocate disk space in the file. This sets the range of bytes to zeroes (0) without extending the file size.",
      "message": "Remove sparse files: @{SparseFiles}",
      "helpLink": "https://blogs.msdn.microsoft.com/jorgepc/2010/11/25/what-are-sparse-files-and-why-should-i-care-as-sql-server-dba/",
      "level": "Warning",
      "probes": [
        "SparseFilesValidation"
      ]
    },
    {
      "id": "TableNoIndex",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": {
          "not": [
            "master",
            "tempdb",
            "model",
            "msdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Tables without indexes",
      "description": "Each table in the database has one or more pages. To keep track of those pages, SQL Server uses a special set of pages, called IAM (for Index Allocation Map) pages. In spite of the word “Index” in the name, IAMs are used for non-indexed tables as well. These are called heaps. All the data is there, but the only way to find anything is to read it starting at the beginning. For a very large table, this will be terribly inefficient.",
      "message": "Review @{TableName} table and create reasonable indexes",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/indexes/heaps-tables-without-clustered-indexes",
      "level": "Warning",
      "condition": [
        {
          "gt": [
            "@IndexCount",
            1
          ]
        },
        {
          "gt": [
            "@MaxIndexId",
            0
          ]
        }
      ],
      "probes": [
        "TableIndexes"
      ]
    },
    {
      "id": "TableNoClusteredIndex",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": {
          "not": [
            "master",
            "tempdb",
            "model",
            "msdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Tables without clustered indexes",
      "description": "Tables without clustered indexes are called heaps. They’re scattered on disk anywhere that SQL Server can find a spot, and they’re not stored in any order whatsoever. This can make for really fast inserts – SQL Server can just throw the data down – but slow selects, updates, and deletes.",
      "message": "Review @{TableName} table and create clustered index",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/indexes/heaps-tables-without-clustered-indexes",
      "level": "Warning",
      "condition": [
        {
          "le": [
            "@IndexCount",
            1
          ]
        },
        {
          "gt": [
            "@MinIndexId",
            0
          ]
        }
      ],
      "probes": [
        "TableIndexes"
      ]
    },
    {
      "id": "TablePSAlign",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "name": {
          "not": [
            "master",
            "tempdb",
            "model",
            "msdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Table index not aligned with PS",
      "description": "Table partitioning is a complex way to break out your large tables into smaller, more manageable chunks, but it comes with a lot of management heartache. One of the challenges is making sure that your indexes are partitioned and aligned the same way as your clustered index.",
      "message": "Re-create @{IndexName} index in @{TableName} table to have it aligned with current schema",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/partitions/partitioned-tables-and-indexes",
      "level": "Warning",
      "probes": [
        "TableIndexesPartitioned"
      ]
    },
    {
      "id": "LoginNoPassword",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Security",
        "WeakPassword"
      ],
      "displayName": "Logins with no passwords",
      "description": "Password complexity policies are designed to deter brute force attacks by increasing the number of possible passwords.",
      "message": "Set strong passwords for logins: @{PasswordData}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/security/password-policy",
      "probes": [
        "NullPassword"
      ]
    },
    {
      "id": "LoginEqPassword",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Security",
        "WeakPassword"
      ],
      "displayName": "Logins with passwords that are same as login names",
      "enabled": false,
      "description": "Password complexity policies are designed to deter brute force attacks by increasing the number of possible passwords.",
      "message": "Review logins with password equals to login: @{PasswordData}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/security/password-policy",
      "probes": [
        "NamePassword"
      ]
    },
    {
      "id": "SystemHealth",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "XEvent",
        "SystemHealth",
        "Performance"
      ],
      "displayName": "System Health important messages",
      "description": "The system_health session is an Extended Events session that is included by default with SQL Server. This session starts automatically when the SQL Server Database Engine starts, and runs without any noticeable performance effects. The session collects system data that you can use to help troubleshoot performance issues in the Database Engine",
      "message": "Error @{Error_Number} occured @{Error_Count} times. Last time was @{Last_Logged_Days_Ago} days ago",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/extended-events/use-the-system-health-session",
      "level": "Warning",
      "probes": [
        "SystemHealth"
      ]
    },
    {
      "id": "RarelyUsedIndex",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Indexes",
        "Performance"
      ],
      "displayName": "Rarely used index",
      "description": "Rarely used indexes can slow down database's performance. Time of write operations is increased because of index maintenance, but index is not used quite often. It makes sense to compare impact of writing operations versus rare reading speedup.",
      "message": "Revise rarely used index @{IndexName}",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/drop-index-transact-sql",
      "level": "Warning",
      "condition": [
        {
          "@Hits": 0
        },
        {
          "ge": [
            "@ReadsRatio",
            "@ReadsThreshold"
          ]
        },
        {
          "@IsPrimaryKey": true
        }
      ],
      "ReadsThreshold": 5,
      "probes": [
        "IndexesDefinitions"
      ]
    },
    {
      "id": "UnusedIndex",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Index",
        "Performance"
      ],
      "displayName": "Unused index",
      "description": "Unused indexes can slow down database's performance. Time of write operations is increased because of index maintenance, but index is not used anywhere.",
      "message": "Revise unused @{IndexName} index",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/drop-index-transact-sql",
      "level": "Warning",
      "condition": [
        {
          "and": [
            {
              "ne": [
                "@Type",
                2
              ]
            },
            {
              "ne": [
                "@Type",
                6
              ]
            }
          ]
        },
        {
          "@IsPrimaryKey": true
        },
        {
          "gt": [
            "@Hits",
            0
          ]
        }
      ],
      "probes": [
        "IndexesDefinitions"
      ]
    },
    {
      "id": "SkewedCompatibilityLevel",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "CompatibilityLevel",
        "Security",
        "Performance",
        "UpdateIssues"
      ],
      "displayName": "Database with skewed compatibility level",
      "description": "Some databases may have a compatibility level lower than the allowed level by the Database Engine.",
      "message": "Update database compatibility level. Current level is @{CompatibilityLevel}",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/alter-database-transact-sql-compatibility-level",
      "level": "Warning",
      "condition": {
        "ge": [
          {
            "div": [
              "@CompatibilityLevel",
              10
            ]
          },
          "@ServerMajorVersion"
        ]
      },
      "probes": [
        "CompatibilityLevel",
        "SQLServerVersion"
      ]
    },
    {
      "id": [
        "DefaultRuleset"
      ],
      "itemType": "override",
      "targetFilter": {
        "type": "Database",
        "name": [
          "virtualmanagerdb",
          "scspfdb",
          "semanticsdb",
          "servicemanager",
          "service manager",
          "dwstagingandconfig",
          "dwrepository",
          "dwdatamart",
          "dwasdatabase",
          "omdwdatamart",
          "cmdwdatamart",
          "ssodb",
          "bamanalysis",
          "bamarchive",
          "bamalertsapplication",
          "bamalertsnsmain",
          "bamprimaryimport",
          "bamstarschema",
          "biztalkmgmtdb",
          "biztalkmsgboxdb",
          "biztalkdtadb",
          "biztalkruleenginedb",
          "bamprimaryimport",
          "biztalkedidb",
          "biztalkhwsdb",
          "tpm",
          "biztalkanalysisdb",
          "bamprimaryimportsuccessfully",
          "aspstate",
          "aspnet",
          "mscrm_config",
          "cpsdyn",
          "lcslog",
          "lcscdr",
          "lis",
          "lyss",
          "mgc",
          "qoemetrics",
          "rgsconfig",
          "rgsdyn",
          "rtc",
          "rtcab",
          "rtcab1",
          "rtcdyn",
          "rtcshared",
          "rtcxds",
          "xds",
          "activitylog",
          "branchdb",
          "clienttracelog",
          "eventlog",
          "listingssettings",
          "servicegroupdb",
          "tservercontroller",
          "vodbackend",
          "operationsmanager",
          "operationsmanagerdw",
          "operationsmanagerac",
          "orchestrator",
          "sso",
          "wss_search",
          "wss_search_config",
          "sharedservices_db",
          "sharedservices_search_db",
          "wss_content",
          "profiledb",
          "social db",
          "sync db",
          "susdb",
          "projectserver_archive",
          "projectserver_draft",
          "projectserver_published",
          "projectserver_reporting",
          "reportserver",
          "reportservertempdb",
          "rsdb",
          "rstempdb",
          "fastsearchadmindatabase",
          "ppsmonitoring",
          "ppsplanningservice",
          "ppsplanningsystem",
          "dynamics",
          "microsoftdynamicsax",
          "microsoftdynamicsaxbaseline",
          "fimservice",
          "fimsynchronizationservice",
          "sbgatewaydatabase",
          "sbmanagementdb",
          "wfinstancemanagementdb",
          "wfmanagementdb",
          "wfresourcemanagementdb"
        ]
      },
      "enabled": false
    },
    {
      "id": "PendingDiskIORequests",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "IO",
        "Performance"
      ],
      "displayName": "Pending disk I/O requests",
      "description": "A database management system (DBMS), such as SQL Server, relies on the timeliness of file input and output (I/O) operations. The proper configuration and maintenance of the I/O subsystem is critical to a successful SQL Server deployment.",
      "message": "Solve I/O related issues to get rid of pending requests",
      "helpLink": "https://support.microsoft.com/en-sg/help/897284/diagnostics-in-sql-server-help-detect-stalled-and-stuck-i-o-operations",
      "level": "Warning",
      "probes": [
        {
          "id": "PendingIORequests",
          "params": {
            "io_type": "disk"
          }
        }
      ]
    },
    {
      "id": "MaxDOP",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "engineEdition": "OnPremises",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "MaxDOP",
        "Performance",
        "Configuration",
        "NUMA",
        "CPU"
      ],
      "displayName": "MaxDOP should be less or equal to number of CPUs",
      "description": "The Microsoft SQL Server max degree of parallelism (MAXDOP) configuration option controls the number of processors that are used for the execution of a query in a parallel plan. This option determines the number of threads that are used for the query plan operators that perform the work in parallel. Depending on whether SQL Server is set up on a symmetric multiprocessing (SMP) computer, a non-uniform memory access (NUMA) computer, or hyperthreading-enabled processors, the max degree of parallelism option should be configured appropriately.",
      "message": "Update MaxDOP configuration option value: @{max_dop}. It shouldn't exceed @{online_logical_processors} - number of processors used by SQL Server",
      "helpLink": "https://support.microsoft.com/kb/2806535",
      "level": "Warning",
      "condition": {
        "le": [
          "@max_dop",
          "@online_logical_processors"
        ]
      },
      "probes": [
        "ServerInstanceConfiguration",
        "SysConfiguration"
      ]
    },
    {
      "id": "MaxDOPFewNUMA",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "engineEdition": "OnPremises",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[11.0, 13.0)"
      },
      "tags": [
        "DefaultRuleset",
        "MaxDOP",
        "Performance",
        "Configuration",
        "NUMA",
        "CPU"
      ],
      "displayName": "MAXDOP set in accordance with CPU count",
      "description": "The Microsoft SQL Server max degree of parallelism (MAXDOP) configuration option controls the number of processors that are used for the execution of a query in a parallel plan. This option determines the number of threads that are used for the query plan operators that perform the work in parallel. Depending on whether SQL Server is set up on a symmetric multiprocessing (SMP) computer, a non-uniform memory access (NUMA) computer, or hyperthreading-enabled processors, the max degree of parallelism option should be configured appropriately.",
      "message": "Update MAXDOP configuration option value: @{max_dop}. It should not exceed the number of logical processors per NUMA node",
      "helpLink": "https://support.microsoft.com/kb/2806535",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "le": [
              "@numa_nodes",
              1
            ]
          },
          {
            "or": [
              {
                "gt": [
                  {
                    "ceiling": {
                      "div": [
                        "@total_logical_processors",
                        "@numa_nodes"
                      ]
                    }
                  },
                  8
                ]
              },
              {
                "and": [
                  {
                    "gt": [
                      "@max_dop",
                      0
                    ]
                  },
                  {
                    "le": [
                      "@max_dop",
                      {
                        "ceiling": {
                          "div": [
                            "@total_logical_processors",
                            "@numa_nodes"
                          ]
                        }
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ]
      },
      "probes": [
        "ServerInstanceConfiguration",
        "SysConfiguration"
      ]
    },
    {
      "id": "DbIntegrity",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": "tempdb"
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBCC",
        "Performance",
        "DataIntegrity"
      ],
      "displayName": "Database Integrity Checks",
      "description": "The DBCC CHECKDB command checks the integrity of the objects in a database and should be run on a regular basis. This statement is used to perform different operations in your database and can be broken down into four categories: Maintenance, Miscellaneous, Informational, and Validation.",
      "message": "Run 'DBCC CHECKDB' command checks",
      "helpLink": "https://msdn.microsoft.com/library/ms176064.aspx",
      "level": "Warning",
      "condition": [
        {
          "@IsReadOnly": true
        },
        {
          "ne": [
            "@DbState",
            0
          ]
        },
        {
          "le": [
            "@LastKnownDBCCDaysAgo",
            7
          ]
        }
      ],
      "probes": [
        "DBMetaInfo",
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "DirectCatalogUpdates",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": "tempdb"
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBCC",
        "Deprecated"
      ],
      "displayName": "Direct Catalog Updates",
      "description": "The 'allow updates' option is still present in the sp_configure stored procedure, although its functionality is unavailable in SQL Server. The setting has no effect. Starting with SQL Server 2005, direct updates to the system tables are not supported.",
      "message": "Avoid using direct catalog update feature",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/allow-updates-server-configuration-option",
      "level": "Warning",
      "condition": [
        {
          "@IsReadOnly": true
        },
        {
          "ne": [
            "@DbState",
            0
          ]
        },
        {
          "@UpdSysCatalog": 0
        }
      ],
      "probes": [
        "DBMetaInfo",
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "DataPurityCheck",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "DBCC",
        "DataIntegrity"
      ],
      "displayName": "Data Purity Check",
      "description": "The DBCC CHECKDB command checks the integrity of the objects in a database and should be run on a regular basis. One thing that this command does not check in databases created in versions prior to SQL Server 2005 is the integrity of the data in the columns until it has been run once with the DATA_PURITY option. Adding the DATA_PURITY option causes the CHECKDB command to look for column values that are invalid or out of range. Any database that was created in SQL Server 2005 or later will include the DATA_PURITY check by default; but if the database is being upgraded from an earlier version, you must run the command with the DATA_PURITY option at least once using the following command and then fix any data issues.",
      "message": "Enable data purity validation with  'DBCC CHECKDB ([DatabaseName]) WITH DATA_PURITY' command",
      "helpLink": "http://support.microsoft.com/kb/923247",
      "level": "Warning",
      "condition": [
        {
          "@IsReadOnly": true
        },
        {
          "ne": [
            "@DbState",
            0
          ]
        },
        {
          "gt": [
            "@CreateVersion",
            611
          ]
        },
        {
          "ne": [
            "@DBCCFlags",
            0
          ]
        }
      ],
      "probes": [
        "DBMetaInfo",
        "DatabaseConfiguration"
      ]
    },
    {
      "id": "StatSamplingRate",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Statistics"
      ],
      "displayName": "Statistics sampling rate",
      "description": "For most queries, the Query Optimizer already generates the necessary statistics for a high quality query plan; in some cases, you need to create additional statistics or modify the query design for best results.",
      "message": "Some statistics have sampling rates less than @{threshold:P}. Update with a larger sample or full scan if key is not uniformly distributed. Affected tables: @{FullName}",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/update-statistics-transact-sql",
      "level": "Warning",
      "threshold": 0.25,
      "probes": [
        {
          "id": "StatSamplingRate",
          "params": {
            "threshold": "@threshold"
          },
          "transform": {
            "type": "aggregate",
            "map": {
              "FullName": "join"
            }
          }
        }
      ]
    },
    {
      "id": "IndexFragmentation",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Index",
        "Performance"
      ],
      "displayName": "Index Fragmentation",
      "description": "The SQL Server Database Engine automatically modifies indexes whenever insert, update, or delete operations are made to the underlying data. Over time these modifications can cause the information in the index to become scattered in the database (fragmented). Fragmentation exists when indexes have pages in which the logical ordering, based on the key value, does not match the physical ordering inside the data file. Heavily fragmented indexes can degrade query performance and cause your application to respond slowly, especially scan operations.",
      "message": "Remove fragmentation of @{IndexFullName} index. Current fragmentation level is @{fragmentation:#0.##}%",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/indexes/reorganize-and-rebuild-indexes",
      "level": "Warning",
      "condition": [
        {
          "le": [
            "@fragmentation",
            "@threshold"
          ]
        },
        {
          "le": [
            "@page_count",
            8
          ]
        }
      ],
      "threshold": 5,
      "probes": [
        "IndexStatistics"
      ]
    },
    {
      "id": "IndexFragmentation",
      "itemType": "override",
      "targetFilter": {
        "version": "[12.0,)"
      },
      "condition": {
        "and": [
          {
            "or": [
              {
                "le": [
                  "@fragmentation",
                  "@threshold"
                ]
              },
              {
                "le": [
                  "@page_count",
                  8
                ]
              }
            ]
          },
          {
            "or": [
              {
                "not": {
                  "in": [
                    "@IndexType",
                    [
                      5,
                      6
                    ]
                  ]
                }
              },
              {
                "le": [
                  "@fragmentation_CI",
                  "@threshold"
                ]
              },
              {
                "ne": [
                  "@state",
                  3
                ]
              }
            ]
          }
        ]
      }
    },
    {
      "id": "XTPHashAvgChainBuckets",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[12.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Index",
        "Performance",
        "XTP"
      ],
      "displayName": "High avg chain length and empty buckets",
      "description": "Memory-optimized HASH indexes behave different from NONCLUSTERED indexes. They are optimized for point-lookup operations, and do not support ordered scans or inequality seek operations. You should specify a value for the BUCKET_COUNT parameter when you create a memory-optimized table.",
      "message": "Index @{IndexFullName} has @{avg_chain_length} average chain length and @{EmptyBucketPct}% empty buckets count. Verify if there are many rows with duplicate index key values or there is a skew in key values",
      "helpLink": "https://techcommunity.microsoft.com/t5/sql-server/in-memory-oltp-indexes-part-2-performance-troubleshooting-guide/ba-p/385725",
      "level": "Warning",
      "condition": [
        {
          "le": [
            "@EmptyBucketPct",
            "@EmptyBucketsPctThreshold"
          ]
        },
        {
          "le": [
            "@avg_chain_length",
            5
          ]
        }
      ],
      "EmptyBucketsPctThreshold": 50,
      "probes": [
        "XTPIndexHashStatistics"
      ]
    },
    {
      "id": "XTPTooManyBuckets",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[12.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Index",
        "Performance",
        "XTP"
      ],
      "displayName": "Too many buckets",
      "description": "Memory-optimized HASH indexes behave different from NONCLUSTERED indexes. They are optimized for point-lookup operations, and do not support ordered scans or inequality seek operations. You must specify a value for the BUCKET_COUNT parameter when you create the memory-optimized table.",
      "message": "Make number of buckets of @{IndexFullName} index equal to distinct rows. It has @{total_bucket_count} buckets and there are @{DistinctCnt} in table, which wastes memory and marginally slows down full table scans",
      "helpLink": "https://techcommunity.microsoft.com/t5/sql-server/in-memory-oltp-indexes-part-2-performance-troubleshooting-guide/ba-p/385725",
      "level": "Warning",
      "condition": [
        {
          "le": [
            "@total_bucket_count",
            "@DistinctCnt"
          ]
        }
      ],
      "probes": [
        "XTPIndexHashStatistics"
      ]
    },
    {
      "id": "XTPTooFewBuckets",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[12.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Index",
        "Performance",
        "XTP"
      ],
      "displayName": "Too few buckets",
      "description": "Memory-optimized HASH indexes behave different from NONCLUSTERED indexes. They are optimized for point-lookup operations, and do not support ordered scans or inequality seek operations. You must specify a value for the BUCKET_COUNT parameter when you create the memory-optimized table.",
      "message": "Make number of buckets of @{IndexFullName} index equal to distinct rows. It has @{total_bucket_count} buckets and there are @{DistinctCnt} in table, which leads to chaining records",
      "helpLink": "https://techcommunity.microsoft.com/t5/sql-server/in-memory-oltp-indexes-part-2-performance-troubleshooting-guide/ba-p/385725",
      "level": "Warning",
      "condition": [
        {
          "ge": [
            "@total_bucket_count",
            "@DistinctCnt"
          ]
        }
      ],
      "probes": [
        "XTPIndexHashStatistics"
      ]
    },
    {
      "id": "XTPRangeIXHealth",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[12.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Index",
        "Performance",
        "XTP"
      ],
      "displayName": "NonClustered index retry amount",
      "description": "When a database with a memory-optimized table is restarted, the index is built by inserting one row at a time into memory. The count of page splits, merges, and consolidation can help you understand the work done to build the index when a database is brought online. Large numbers of retries are indicative of concurrency issues.",
      "message": "Review @{IndexFullName} index as its retry count is over @{RetryCountPct}% of total, which indicates possible concurrency issues",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/system-dynamic-management-views/sys-dm-db-xtp-nonclustered-index-stats-transact-sql",
      "level": "Warning",
      "condition": {
        "and": [
          {
            "le": [
              "@page_update_count_pct",
              "@RetryCountPct"
            ]
          },
          {
            "le": [
              "@page_consolidation_count_pct",
              "@RetryCountPct"
            ]
          },
          {
            "le": [
              "@page_split_count_pct",
              "@RetryCountPct"
            ]
          },
          {
            "le": [
              "@key_split_count_pct",
              "@RetryCountPct"
            ]
          },
          {
            "le": [
              "@page_merge_count_pct",
              "@RetryCountPct"
            ]
          },
          {
            "le": [
              "@key_merge_count_pct",
              "@RetryCountPct"
            ]
          }
        ]
      },
      "RetryCountPct": 5,
      "probes": [
        "XTPNonClusteredIndexHashStatistics"
      ]
    },
    {
      "id": "TF6533Misuse",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "version": "[11.0.6020, 11.0.6518)",
        "platform": "Windows",
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises"
      },
      "tags": [
        "DefaultRuleset",
        "TraceFlag",
        "Performance",
        "TF6533"
      ],
      "displayName": "'STRelate' and 'STAsBinary' functions unexpected results due to TF 6533",
      "description": "The STRelate and STAsBinary functions may return unexpected results when trace flag 6533 is enabled. Do not use this trace flag if your workload involves either of these functions.",
      "message": "Disable trace flag 6533 to avoid unexpected results of 'STRelate' and 'STAsBinary' functions",
      "helpLink": "https://support.microsoft.com/help/3107399",
      "level": "Warning",
      "condition": [
        {
          "not": {
            "in": [
              6533,
              "@TraceFlag"
            ]
          }
        },
        {
          "@InUse": 0
        }
      ],
      "probes": [
        "EnabledGlobalTraceFlags",
        "TF6533SpatialFunctionsUsage"
      ]
    },
    {
      "id": "UntrustedConstraints",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "DataIntegrity"
      ],
      "displayName": "Untrusted constraints",
      "description": "If you need to load a lot of data quickly, you can disable keys and constraints in order to improve performance. After the data load finishes, enable them again, and SQL Server will check them behind the scenes. This technique works best in large data warehouse environments where entire dimension tables might be reloaded from scratch every night. Disabling constraints is usually safer and easier than dropping and recreating them.",
      "message": "Execute 'ALTER TABLE <table name> WITH CHECK CHECK CONSTRAINT <constraint name>' statement to avoid possible performance issues: @{constraint_name} constraints are not trusted for referential integrity",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/alter-table-transact-sql",
      "level": "Warning",
      "probes": [
        "FKNotTrusted"
      ]
    },
    {
      "id": "PercentAutogrows",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "name": {
          "not": [
            "master",
            "model",
            "msdb",
            "tempdb"
          ]
        },
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "DBFileConfiguration",
        "DBConfiguration"
      ],
      "displayName": "Database files have growth ratio in percentage",
      "description": "Some database files have a growth ratio set in percentage. Over time, this could lead to uncontrolled disk space allocation and extended time to perform these growths",
      "message": "Do not use \"File Growth In Percent\" for Autogrowth setting. Affected files: @{fileName} have growth ratio set in percentage",
      "helpLink": "https://docs.microsoft.com/sql/t-sql/statements/alter-database-transact-sql-file-and-filegroup-options",
      "level": "Warning",
      "probes": [
        {
          "id": "DatabaseMasterFiles",
          "params": {
            "type": null,
            "is_percent_growth": 1
          },
          "transform": {
            "type": "aggregate",
            "map": {
              "fileName": "join"
            }
          }
        }
      ]
    },
    {
      "id": "StatsUpdate",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Statistics",
        "QueryOptimizer"
      ],
      "displayName": "Statistics need to be updated",
      "description": "The Query Optimizer determines whether an index is useful for a specific query by evaluating the stored statistics. If the statistics become out of date and significant changes have occurred against the underlying data, this can result in less than optimal query performance. In most cases, it's best to let SQL Server maintain the statistics. If you turn 'Auto Create Stats' and 'Auto Update Stats' off, then it is up to you to keep the statistics up-to-date somehow. Failure to do so will lead to poor query performance. Most applications should have these options ON. When the Auto Update Statistics setting is ON, the Query Optimizer updates statistics when they are used by a query and when they might be out-of-date. Statistics become out-of-date after insert, update, delete, or merge operations change the data distribution in the table or indexed view. The Query Optimizer determines when statistics might be out-of-date by counting the number of data modifications since the last statistics update and comparing the number of modifications to a threshold. The threshold is based on the number of rows in the table or indexed view. The Query Optimizer checks for out-of-date statistics before compiling a query and before executing a cached query plan. Before compiling a query, the Query Optimizer uses the columns, tables, and indexed views in the query predicate to determine which statistics might be out-of-date. Before executing a cached query plan, the Database Engine verifies that the query plan references up-to-date statistics. The AUTO_UPDATE_STATISTICS option applies to statistics created for indexes, single-columns in query predicates, and statistics that are created by using the CREATE STATISTICS statement. This option also applies to filtered statistics.",
      "message": "Update stats in @{TableName} table to improve query performance",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/statistics/statistics#UpdateStatistics",
      "condition": [
        "@is_auto_update_stats_on",
        {
          "and": [
            {
              "or": [
                {
                  "gt": [
                    "@rows",
                    "@threshold"
                  ]
                },
                {
                  "lt": [
                    "@modification_counter",
                    "@threshold"
                  ]
                }
              ]
            },
            {
              "or": [
                {
                  "le": [
                    "@rows",
                    "@threshold"
                  ]
                },
                {
                  "lt": [
                    "@modification_counter",
                    {
                      "add": [
                        "@threshold",
                        {
                          "mul": [
                            "@rows",
                            0.2
                          ]
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        }
      ],
      "threshold": 500,
      "probes": [
        "DatabaseConfiguration",
        "ObjectStatistics"
      ]
    },
    {
      "id": "AdHocQueriesOff",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Security"
      ],
      "displayName": "Option 'ad hoc distributed queries' should be disabled",
      "description": "Ad Hoc Distributed Queries use the OPENROWSET and OPENDATASOURCE functions to connect to remote data sources that use OLE DB. OPENROWSET and OPENDATASOURCE should be used only to reference OLE DB data sources that are accessed infrequently. For any data sources that will be accessed more than several times, define a linked server. Enabling the use of ad hoc names means that any authenticated login to SQL Server can access the provider. SQL Server administrators should enable this feature for providers that are safe to be accessed by any local login.",
      "message": "Disable 'ad hoc distributed queries' option",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/ad-hoc-distributed-queries-server-configuration-option",
      "level": "Warning",
      "condition": {
        "not": "@ad_hoc_distributed_queries"
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "AffinityMasksOverlap",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance"
      ],
      "displayName": "Affinity Mask and Affinity I/O Mask overlapping",
      "description": "Enabling a CPU with both the affinity mask and the affinity I/O mask can slow performance by forcing the processor to be overused. When specified either the affinity mask or the affinity I/O mask options they must both be specified, but only enables each CPU no more than once. The same CPU should not be enabled in both the affinity mask option and the affinity I/O mask option. The bits that correspond to each CPU should be in one of the following states.",
      "message": "Correct Affinity Mask and Affinity IO Mask overlap. AffinityMask = @{affinity_mask}, Affinity64Mask = @{affinity64_mask}, AffinityIOMask = @{affinity_io_mask}, Affinity64IOMask = @{affinity64_io_mask}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/policy-based-management/correct-affinity-mask-and-affinity-input-and-output-mask-overlap",
      "level": "Warning",
      "condition": {
        "and": [
          {
            "eq": [
              {
                "bitand": [
                  "@affinity_mask",
                  "@affinity_io_mask"
                ]
              },
              0
            ]
          },
          {
            "eq": [
              {
                "bitand": [
                  "@affinity64_mask",
                  "@affinity64_io_mask"
                ]
              },
              0
            ]
          }
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "AgentSvcAccNotRecommended",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'SQL Server Agent' service uses non-recommended account",
      "description": "Running the 'SQL Server Agent' service under 'NT AUTHORITY\\SYSTEM' or 'NT AUTHORITY\\NETWORKSERVICE' accounts is not recommended for security reasons.",
      "message": "Use another account to run 'SQL Server Agent' service. Current account '@{attr::service::SQLAgent.account}' is not recommended",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "unrecommendedAccounts": [
        "NT AUTHORITY\\SYSTEM",
        "LOCALSYSTEM",
        "NT AUTHORITY\\NETWORKSERVICE"
      ],
      "condition": {
        "or": [
          {
            "or": [
              {
                "not": "@attr::service::SQLAgent"
              },
              "@is_clustered_server"
            ]
          },
          {
            "not": {
              "iin": [
                "@attr::service::SQLAgent.account",
                "@unrecommendedAccounts"
              ]
            }
          }
        ]
      },
      "probes": [
        "IsClusteredServer"
      ]
    },
    {
      "id": "AgentSvcAccNotRecommended",
      "itemType": "override",
      "targetFilter": {
        "engineEdition": "Express"
      },
      "enabled": false
    },
    {
      "id": "AgentSvcAccNotSupported",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'SQL Server Agent' service uses not supported account",
      "description": "Running the 'SQL Server Agent' service under 'NT AUTHORITY\\LOCALSERVICE', 'NT AUTHORITY\\SYSTEM' or 'NT AUTHORITY\\NETWORKSERVICE' accounts is not supported.",
      "message": "Use another account to run 'SQL Server Agent' service. Current account '@{attr::service::SQLAgent.account}' is not supported",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "localServiceAccount": "NT AUTHORITY\\LOCALSERVICE",
      "unsupportedAccounts": [
        "NT AUTHORITY\\SYSTEM",
        "LOCALSYSTEM",
        "NT AUTHORITY\\NETWORKSERVICE"
      ],
      "condition": {
        "or": [
          {
            "not": "@attr::service::SQLAgent"
          },
          {
            "and": [
              {
                "ine": [
                  "@attr::service::SQLAgent.account",
                  "@localServiceAccount"
                ]
              },
              {
                "or": [
                  {
                    "not": "@is_clustered_server"
                  },
                  {
                    "not": {
                      "iin": [
                        "@attr::service::SQLAgent.account",
                        "@unsupportedAccounts"
                      ]
                    }
                  }
                ]
              }
            ]
          }
        ]
      },
      "probes": [
        "IsClusteredServer"
      ]
    },
    {
      "id": "AgentSvcAccNotSupported",
      "itemType": "override",
      "targetFilter": {
        "engineEdition": "Express"
      },
      "enabled": false
    },
    {
      "id": "AgentSvcAccSame",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'SQL Server Agent' and 'SQL Server Database Engine' use same account",
      "description": "Running the 'SQL Server Agent' service under the same account as the 'SQL Server Database Engine' service is not recommended.",
      "message": "Use different accounts for 'SQL Server Agent' service and 'SQL Server Database Engine' service. Now both services use '@{attr::service::SQLAgent.account}' account",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::SQLAgent"
          },
          {
            "ine": [
              "@attr::service::MSSQL.account",
              "@attr::service::SQLAgent.account"
            ]
          }
        ]
      }
    },
    {
      "id": "AgentSvcAccSame",
      "itemType": "override",
      "targetFilter": {
        "engineEdition": "Express"
      },
      "enabled": false
    },
    {
      "id": "AgentSvcStoped",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'SQL Server Agent' service is stopped",
      "description": "The 'SQL Server Agent' service executes jobs, monitors SQL Servers, fires alerts and enables automation for some administrative tasks.",
      "message": "Run 'SQL Server Agent' service",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/manage-the-database-engine-services",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::SQLAgent"
          },
          {
            "imatch": [
              "@Output.Status",
              "^Running\\.*$"
            ]
          }
        ]
      },
      "probes": [
        {
          "id": "ServiceControl",
          "params": {
            "ServiceName": "@attr::service::SQLAgent.name"
          }
        }
      ]
    },
    {
      "id": "AgentSvcStoped",
      "itemType": "override",
      "targetFilter": {
        "engineEdition": "Express"
      },
      "enabled": false
    },
    {
      "id": "AutoSoftNUMAOn",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[13.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "NUMA"
      ],
      "displayName": "Auto Soft NUMA should be enabled",
      "description": "Modern processors have multiple cores per socket. Each socket is represented, usually, as a single NUMA node. The SQL Server database engine partitions various internal structures and partitions service threads per NUMA node. With processors containing 10 or more cores per socket, using software NUMA to split hardware NUMA nodes generally increases scalability and performance. Prior to SQL Server 2014 (12.x) SP2, software-based NUMA (soft-NUMA) has required to edit the registry to add a node configuration affinity mask, and was configured at the host level, rather than per instance. Soft-NUMA has configured automatically at the database-instance level when the SQL Server Database Engine service starts.",
      "message": "Turn 'automatic soft-NUMA disabled' option on to avoid inefficient allocation of cores between NUMA nodes",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/soft-numa-sql-server",
      "level": "Warning",
      "condition": {
        "not": "@automatic_soft_NUMA_disabled"
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "AzSqlVmSize",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "machineType": "AzureSQL"
      },
      "tags": [
        "DefaultRuleset",
        "SqlOnVm",
        "Azure",
        "Performance"
      ],
      "displayName": "VM size is not memory-optimized",
      "description": "Memory optimized VM sizes offer a high memory-to-CPU ratio that is great for relational database servers. The DSv2 11-15, Edsv4 series, the M-, and the Mv2- series offer the optimal memory-to-vCore ratio required for OLTP workloads. Both M series VMs offer the highest memory-to-vCore ratio required for mission critical workloads and is also ideal for data warehouse workloads.",
      "message": "Use memory optimized virtual machine sizes for the best performance of SQL Server workloads",
      "helpLink": "https://docs.microsoft.com/azure/azure-sql/virtual-machines/windows/performance-guidelines-best-practices",
      "level": "Warning",
      "condition": {
        "imatch": [
          "@vmSize",
          "(^Standard_DS?1[1-5](-\\d+)?_v2$)|(^Standard_E\\d+[asi]*(-\\d+[sad]+)?_v[3-4]$)|(^Standard_M\\d+[ltms]*(-\\d+[ms]+)?(_v21?)?$)|(^Standard_GS\\d+-\\d+$)"
        ]
      },
      "probes": [
        {
          "id": "AzVmProps",
          "params": {
            "resId": "@azure_vm_res_id"
          }
        }
      ]
    },
    {
      "id": "BlockingChains",
      "itemType": "definition",
      "target": {
        "type": "Database",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Statistics"
      ],
      "displayName": "Blocking chains",
      "description": "Blocking chains of sessions can cause poor performance when the duration of locks is too long on the resource.",
      "message": "Review locking strategy. @{blocked_spid} process(es) have been blocked@{block_time_min: for more than #0 min;;''}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/system-dynamic-management-views/sys-dm-os-waiting-tasks-transact-sql",
      "level": "Warning",
      "condition": {
        "not": "@blocked_spid"
      },
      "probes": [
        {
          "id": "ProcessBlockingChains",
          "params": {
            "waitThreshold": 5
          },
          "transform": {
            "type": "aggregate",
            "map": {
              "blocked_spid": "count",
              "block_time_min": "min"
            }
          }
        }
      ]
    },
    {
      "id": "BlockProcThreshNotRecommend",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Blocked process threshold is set to recommended value",
      "description": "This rule checks that the blocked process threshold option is set to 0 (disabled) or set to a value higher than or equal to 5 (seconds). Setting the blocked process threshold option to a value from 1 to 4 can cause the deadlock monitor to run constantly. Values 1 to 4 should only be used for troubleshooting, and never long term or in a production environment without the assistance of Microsoft Customer Service and Support.",
      "message": "Increase or disable blocked process threshold option. Current value is @{block_threshold}",
      "helpLink": "https://docs.microsoft.com/sql/relational-databases/policy-based-management/increase-or-disable-blocked-process-threshold",
      "level": "Warning",
      "threshold": 5,
      "condition": {
        "or": [
          {
            "le": [
              "@block_threshold",
              0
            ]
          },
          {
            "ge": [
              "@block_threshold",
              "@threshold"
            ]
          }
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "BrowserSvcAccSame",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'SQL Server Browser' and 'SQL Server Database Engine' use same account",
      "description": "Running the 'SQL Server Browser' service under the same account as the 'SQL Server Database Engine' service is not recommended.",
      "message": "Use different accounts for 'SQL Server Browser' and 'SQL Server Database Engine'. Now both services use '@{attr::service::SQLBrowser.account}' account",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::SQLBrowser"
          },
          {
            "ine": [
              "@attr::service::MSSQL.account",
              "@attr::service::SQLBrowser.account"
            ]
          }
        ]
      }
    },
    {
      "id": "BrowserSvcStoped",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'SQL Server Browser' service is stopped",
      "description": "The 'SQL Server Browser' service is a name resolution service that provides SQL Server connection information to client computers.",
      "message": "Run 'SQL Server Browser' service",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/manage-the-database-engine-services",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::SQLBrowser"
          },
          {
            "imatch": [
              "@Output.Status",
              "^Running\\.*$"
            ]
          }
        ]
      },
      "probes": [
        {
          "id": "ServiceControl",
          "params": {
            "ServiceName": "@attr::service::SQLBrowser.name"
          }
        }
      ]
    },
    {
      "id": "CrossDBOwnershipOff",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Security"
      ],
      "displayName": "Option 'cross db ownership chaining' should be disabled",
      "description": "Cross-database ownership chaining occurs when a procedure in one database depends on objects in another database. A cross-database ownership chain works in the same way as ownership chaining within a single database, except that an unbroken ownership chain requires that all the object owners are mapped to the same login account. If the source object in the source database and the target objects in the target databases are owned by the same login account, SQL Server does not check permissions on the target objects. Ownership chaining across databases is turned off by default. Microsoft recommends that you disable cross-database ownership chaining because it exposes you to some security risks.",
      "message": "Disable 'cross db ownership chaining' option",
      "helpLink": "https://docs.microsoft.com/dotnet/framework/data/adonet/sql/enabling-cross-database-access-in-sql-server",
      "level": "Warning",
      "condition": {
        "not": "@cross_db_ownership_chaining"
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "DefaultTraceOff",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Default trace is enabled",
      "description": "Use the 'default trace enabled' option to enable or disable the default trace log files. The default trace functionality provides a rich, persistent log of activity and changes primarily related to the configuration options. ",
      "message": "Enable 'default trace enabled' option to get troubleshooting assistance",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/default-trace-enabled-server-configuration-option",
      "level": "Warning",
      "condition": "@default_trace_enabled",
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "DiskFragmentationAnalysis",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Disk fragmentation analysis",
      "description": "If you do not defragment your hard disk, the operating system may have to go to several physical locations on the disk to retrieve the database file, making file access slower. To get information about the fragmentation level, this check requires the destination SQL Server to be running under the sysadmin account.",
      "message": "Defragment volume '@{Output.Name}' with physical fragmentation",
      "helpLink": "https://support.microsoft.com/help/3195161/defragmenting-sql-server-database-disk-drives",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "ne": [
              "@Output.da.ReturnValue",
              0
            ]
          },
          {
            "not": "@Output.da.DefragRecommended"
          }
        ]
      },
      "probes": [
        "DiskFragmentationAnalysis"
      ]
    },
    {
      "id": "DiskPartitionAlignment",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Storage"
      ],
      "displayName": "Disk Partition alignment",
      "description": "Noncompliance with storage configuration best practices for the Microsoft SQL Server database software is a common root cause of support cases. The reason is often shown to be misalignment between Windows, storage, disk controllers, and cache segment lines. 64 KB is a common, valid starting partition offset because it correlates well with fundamental physical boundaries in disks, controllers, and cache. Other valid starting partition offsets exist.",
      "message": "Increase disk partition alignment on @{Output.Name} to make it 64 KB at least. Current volume offset is @{Output.StartingOffset}",
      "helpLink": "https://docs.microsoft.com/previous-versions/sql/sql-server-2008/dd758814(v=sql.100)",
      "level": "Warning",
      "Threshold": 65536,
      "probes": [
        {
          "id": "MisalignedDiskPartition",
          "params": {
            "threshold": "@Threshold"
          }
        }
      ]
    },
    {
      "id": "DtsSvcAccSame",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Integration Services' and 'SQL Server Database Engine' use same account",
      "description": "Running the 'Integration Services' service under the same account as the 'SQL Server Database Engine' service is not recommended.",
      "message": "Use different accounts for 'Integration Services' service and 'SQL Server Database Engine' service. Now both services use '@{attr::service::MsDtsServer.account}' account",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::MsDtsServer"
          },
          {
            "ine": [
              "@attr::service::MSSQL.account",
              "@attr::service::MsDtsServer.account"
            ]
          }
        ]
      }
    },
    {
      "id": "DtsSvcStoped",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Integration Services' service is stopped",
      "description": "The 'Integration Services' service provides management support for Integration Services package storage and execution.",
      "message": "Run 'Integration Services' service",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/manage-the-database-engine-services",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::MsDtsServer"
          },
          {
            "imatch": [
              "@Output.Status",
              "^Running\\.*$"
            ]
          }
        ]
      },
      "probes": [
        {
          "id": "ServiceControl",
          "params": {
            "ServiceName": "@attr::service::MsDtsServer.name"
          }
        }
      ]
    },
    {
      "id": "ErrorLogSize",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance"
      ],
      "displayName": "Error log file size is too big",
      "description": "Cycling error log files makes it easier to read the error log.",
      "message": "Cycle error log files or revise error log settings. Current error log file size is more than @{threshold} MB.",
      "helpLink": "https://docs.microsoft.com/sql/tools/configuration-manager/viewing-the-sql-server-error-log",
      "level": "Warning",
      "threshold": 50,
      "condition": {
        "or": [
          {
            "ne": [
              "@id",
              0
            ]
          },
          {
            "lt": [
              "@size",
              {
                "mul": [
                  "@threshold",
                  1024,
                  1024
                ]
              }
            ]
          }
        ]
      },
      "probes": [
        "ErrorLogInfo"
      ]
    },
    {
      "id": "FullTextServiceLoadOSResources",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Full-text search option 'load_os_resources' set to default",
      "description": "The full-text search option 'load_os_resources' indicates whether operating system word breakers, stemmers, and filters are registered and used with this instance of SQL Server. By default, this property is disabled to prevent inadvertent behavior changes by updates made to the operating system. Enabling use of operating system resources provides access to resources for languages and document types registered with Microsoft Indexing Service that do not have an instance-specific resource installed. If you enable the loading of operating system resources, ensure that the operating system resources are trusted signed binaries; otherwise, they cannot be loaded when verify_signature (see below) is set to 1.",
      "message": "Set full-text search option 'load_os_resources' to @{defaultLoadOSResources}",
      "level": "Warning",
      "defaultLoadOSResources": 0,
      "condition": {
        "or": [
          {
            "eq": [
              "@IsFulltextInstalled",
              0
            ]
          },
          {
            "eq": [
              "@LoadOSResources",
              "@defaultLoadOSResources"
            ]
          }
        ]
      },
      "probes": [
        "FullTextServiceInfo"
      ]
    },
    {
      "id": "FullTextServiceVerifySignature",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Security"
      ],
      "displayName": "Full-text search option 'verify_signature' set to default",
      "description": "The full-text search option 'verify_signature' indicates whether only signed binaries are loaded by the Full-Text Engine. By default, only trusted, signed binaries are loaded.",
      "message": "Set full-text search option 'load_os_resources' to @{defaultVerifySignature}",
      "level": "Warning",
      "defaultVerifySignature": 1,
      "condition": {
        "or": [
          {
            "eq": [
              "@IsFulltextInstalled",
              0
            ]
          },
          {
            "eq": [
              "@VerifySignature",
              "@defaultVerifySignature"
            ]
          }
        ]
      },
      "probes": [
        "FullTextServiceInfo"
      ]
    },
    {
      "id": "FullTextSvcAccNotRecommended",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Full-text search' service uses non-recommended account",
      "description": "Running the 'Full-text search' service under the 'NT AUTHORITY\\SYSTEM' account is not recommended for security reasons.",
      "message": "Use another account to run 'Full-text search' service. Current account '@{attr::service::MSSQLFDLauncher.account}' is not recommended",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "unrecommendedAccounts": [
        "NT AUTHORITY\\SYSTEM",
        "LOCALSYSTEM"
      ],
      "condition": {
        "or": [
          {
            "not": "@attr::service::MSSQLFDLauncher"
          },
          {
            "not": {
              "iin": [
                "@attr::service::MSSQLFDLauncher.account",
                "@unrecommendedAccounts"
              ]
            }
          }
        ]
      }
    },
    {
      "id": "FullTextSvcAccSame",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Full-text search' and 'SQL Server Database Engine' use same account",
      "description": "Running the 'Full-text search' service under the same account as the 'SQL Server Database Engine' service is not recommended.",
      "message": "Use different accounts for the 'Full-text search' service and the 'SQL Server Database Engine' service. Now both services use '@{attr::service::MSSQLFDLauncher.account}' account",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::MSSQLFDLauncher"
          },
          {
            "ine": [
              "@attr::service::MSSQL.account",
              "@attr::service::MSSQLFDLauncher.account"
            ]
          }
        ]
      }
    },
    {
      "id": "FullTextSvcStoped",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Full-text search' service is stopped",
      "description": "The 'Full-text search' service quickly creates full-text indexes on content and properties of structured and semistructured data to provide document filtering and word-breaking for SQL Server.",
      "message": "Run 'Full-text search' service",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/manage-the-database-engine-services",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::MSSQLFDLauncher"
          },
          {
            "imatch": [
              "@Output.Status",
              "^Running\\.*$"
            ]
          }
        ]
      },
      "probes": [
        {
          "id": "ServiceControl",
          "params": {
            "ServiceName": "@attr::service::MSSQLFDLauncher.name"
          }
        }
      ]
    },
    {
      "id": "HPLogicalProcessor",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance"
      ],
      "displayName": "HP Logical Processor issue",
      "description": "HP ProLiant Gen9 servers configured with Intel Xeon E5 2600 v3 processors can be configured to support processor configurations that exceed 64 logical processors. Windows Operating Systems divide the logical processors into groups (Kgroups). On HP ProLiant Gen9 servers, the System Firmware, by default, reports the maximum number of possible logical processors to reflect the highest core count processor available. The result is that Windows Operating Systems will group the available logical processors into more than one Kgroup in a two-socket populated configuration. Applications that rely on older kernel APIs for affnitizing threads inside a process to a specific logical processor will only be able to address one Kgroup. The result is that the process will run on fewer logical processors than are presented to the OS for use. Workloads that utilize multiple processes (in lieu of a single process with multiple threads), or are leveraging the APIs that allow beyond single Kgroup addressing, will have full access to all the logical processors presented to the OS for use.",
      "message": "Update server BIOS to the latest version. It may be affected by the HP Logical Processor issue ",
      "helpLink": "https://support.hpe.com/hpesc/public/docDisplay?docId=emr_na-c04650594",
      "level": "Warning",
      "condition": {
        "gt": [
          "@virtual_machine_type",
          0
        ]
      },
      "probes": [
        "SysDmOsSysInfo",
        {
          "id": "ServerBIOSInfo",
          "transform": {
            "type": "parse",
            "map": {
              "BIOSVendor": "/^(HP|Hewlett-Packard)$/ix"
            }
          }
        },
        {
          "id": "ServerCPUInfo",
          "transform": [
            {
              "type": "parse",
              "map": {
                "ProcessorNameString": "/.*XEON.*E5.*/ix"
              }
            },
            {
              "type": "aggregate",
              "map": {
                "ProcessorNameString": "count"
              }
            }
          ]
        }
      ]
    },
    {
      "id": "IndexCreateMemory",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "IndexCreateMemory"
      ],
      "displayName": "'index create memory' should be greater than 'min memory per query'",
      "description": "The 'index create memory' option controls the maximum amount of memory initially allocated for sort operations when creating indexes. The default value for this option is 0 (self-configuring). If more memory is later needed for index creation and the memory is available, the server will use it; thereby, exceeding the setting of this option. If additional memory is not available, the index creation will continue using the memory already allocated. However, if you experience difficulties creating indexes, consider increasing the value of this option from its run value.",
      "message": "Set 'index create memory' to 0 or make it greater than 'min memory per query'. Current 'index create memory' is @{index_create_memory} KB. Current 'min memory per query' is @{min_memory_per_query} KB",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-index-create-memory-server-configuration-option",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@index_create_memory"
          },
          {
            "ge": [
              "@index_create_memory",
              "@min_memory_per_query"
            ]
          }
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "LightweightPoolingOn",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance"
      ],
      "displayName": "Lightweight pooling option disabled",
      "description": "The 'lightweight pooling' option is used to configure SQL Server to use simplified flows (or 'fibers'). Fiber mode is intended for certain situations in which the context switching of the UMS workers are the critical bottleneck in performance. Because this is rare, fiber mode rarely enhances performance or scalability on the typical system. Improved context switching in Microsoft Windows Server 2003 has also reduced the need for fiber mode. We do not recommend that you use fiber mode scheduling for routine operation. This is because it can decrease performance by inhibiting the regular benefits of context switching, and because some components of SQL Server that use Thread Local Storage (TLS) or thread-owned objects, such as mutexes (a type of Win32 kernel object), cannot function correctly in fiber mode.",
      "message": "Disable 'lightweight pooling' option as fiber mode scheduling can decrease performance",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/lightweight-pooling-server-configuration-option",
      "level": "Warning",
      "condition": {
        "not": "@lightweight_pooling"
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "LocksOptionNotDefault",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance"
      ],
      "displayName": "Option 'locks' should be set to default",
      "description": "The 'locks' option sets the maximum number of available locks, thereby limiting the amount of memory the SQL Server Database Engine uses for them. The default setting is 0, which allows the Database Engine to allocate and deallocate lock structures dynamically, based on changing system requirements.",
      "message": "Set 'locks' option to @{recommended_max_lock_number}. Current value is @{locks}",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-locks-server-configuration-option",
      "level": "Warning",
      "recommended_max_lock_number": 0,
      "condition": {
        "eq": [
          "@locks",
          "@recommended_max_lock_number"
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "MaxDOP1NUMA",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "engineEdition": "OnPremises",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "MaxDOP",
        "Performance",
        "Configuration",
        "NUMA",
        "CPU"
      ],
      "displayName": "MAXDOP set in accordance with CPU count",
      "description": "The Microsoft SQL Server max degree of parallelism (MAXDOP) configuration option controls the number of processors that are used for the execution of a query in a parallel plan. This option determines the number of threads that are used for the query plan operators that perform the work in parallel. Depending on whether SQL Server is set up on a symmetric multiprocessing (SMP) computer, a non-uniform memory access (NUMA) computer, or hyperthreading-enabled processors, the max degree of parallelism option should be configured appropriately.",
      "message": "Update MAXDOP option according to guideline (see help link). Current MAXDOP value is @{max_dop}, CPU count is @{online_logical_processors}",
      "helpLink": "https://support.microsoft.com/kb/2806535",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "ne": [
              "@numa_nodes",
              1
            ]
          },
          {
            "and": [
              {
                "or": [
                  {
                    "le": [
                      "@online_logical_processors",
                      8
                    ]
                  },
                  {
                    "eq": [
                      "@max_dop",
                      8
                    ]
                  }
                ]
              },
              {
                "or": [
                  {
                    "gt": [
                      "@online_logical_processors",
                      8
                    ]
                  },
                  {
                    "le": [
                      "@max_dop",
                      "@online_logical_processors"
                    ]
                  }
                ]
              }
            ]
          }
        ]
      },
      "probes": [
        "ServerInstanceConfiguration",
        "SysConfiguration"
      ]
    },
    {
      "id": "MaxDopFewNumaLess16",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "engineEdition": "OnPremises",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[13.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "MaxDOP",
        "Performance",
        "Configuration",
        "NUMA",
        "CPU"
      ],
      "displayName": "MAXDOP set in accordance with CPU count",
      "description": "The Microsoft SQL Server max degree of parallelism (MAXDOP) configuration option controls the number of processors that are used for the execution of a query in a parallel plan. This option determines the number of threads that are used for the query plan operators that perform the work in parallel. Depending on whether SQL Server is set up on a symmetric multiprocessing (SMP) computer, a non-uniform memory access (NUMA) computer, or hyperthreading-enabled processors, the max degree of parallelism option should be configured appropriately.",
      "message": "Update MAXDOP configuration option value: @{max_dop}. It should not exceed the number of logical processors per NUMA node",
      "helpLink": "https://support.microsoft.com/kb/2806535",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "le": [
              "@numa_nodes",
              1
            ]
          },
          {
            "or": [
              {
                "gt": [
                  {
                    "ceiling": {
                      "div": [
                        "@total_logical_processors",
                        "@numa_nodes"
                      ]
                    }
                  },
                  16
                ]
              },
              {
                "and": [
                  {
                    "gt": [
                      "@max_dop",
                      0
                    ]
                  },
                  {
                    "le": [
                      "@max_dop",
                      {
                        "ceiling": {
                          "div": [
                            "@total_logical_processors",
                            "@numa_nodes"
                          ]
                        }
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ]
      },
      "probes": [
        "ServerInstanceConfiguration",
        "SysConfiguration"
      ]
    },
    {
      "id": "MaxDopFewNumaOver16",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "engineEdition": "OnPremises",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[13.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "MaxDOP",
        "Performance",
        "Configuration",
        "NUMA",
        "CPU"
      ],
      "displayName": "MAXDOP set in accordance to CPU count",
      "description": "The Microsoft SQL Server max degree of parallelism (MAXDOP) configuration option controls the number of processors that are used for the execution of a query in a parallel plan. This option determines the number of threads that are used for the query plan operators that perform the work in parallel. Depending on whether SQL Server is set up on a symmetric multiprocessing (SMP) computer, a non-uniform memory access (NUMA) computer, or hyperthreading-enabled processors, the max degree of parallelism option should be configured appropriately.",
      "message": "Update MAXDOP configuration option value: @{max_dop}. It should be half the number of logical processors per NUMA node with maximum value of 16",
      "helpLink": "https://support.microsoft.com/kb/2806535",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "le": [
              "@numa_nodes",
              1
            ]
          },
          {
            "or": [
              {
                "le": [
                  {
                    "ceiling": {
                      "div": [
                        "@total_logical_processors",
                        "@numa_nodes"
                      ]
                    }
                  },
                  16
                ]
              },
              {
                "and": [
                  {
                    "eq": [
                      "@max_dop",
                      {
                        "ceiling": {
                          "div": [
                            {
                              "div": [
                                "@total_logical_processors",
                                "@numa_nodes"
                              ]
                            },
                            2
                          ]
                        }
                      }
                    ]
                  },
                  {
                    "le": [
                      "@max_dop",
                      16
                    ]
                  }
                ]
              }
            ]
          }
        ]
      },
      "probes": [
        "ServerInstanceConfiguration",
        "SysConfiguration"
      ]
    },
    {
      "id": "MaxDopFewNumaOver8",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "engineEdition": "OnPremises",
        "platform": [
          "Windows",
          "Linux"
        ],
        "version": "[11.0, 13.0)"
      },
      "tags": [
        "DefaultRuleset",
        "MaxDOP",
        "Performance",
        "Configuration",
        "NUMA",
        "CPU"
      ],
      "displayName": "MAXDOP set in accordance with CPU count",
      "description": "The Microsoft SQL Server max degree of parallelism (MAXDOP) configuration option controls the number of processors that are used for the execution of a query in a parallel plan. This option determines the number of threads that are used for the query plan operators that perform the work in parallel. Depending on whether SQL Server is set up on a symmetric multiprocessing (SMP) computer, a non-uniform memory access (NUMA) computer, or hyperthreading-enabled processors, the max degree of parallelism option should be configured appropriately.",
      "message": "Update MAXDOP configuration option value: @{max_dop}. It should be equal to 8",
      "helpLink": "https://support.microsoft.com/kb/2806535",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "le": [
              "@numa_nodes",
              1
            ]
          },
          {
            "or": [
              {
                "le": [
                  {
                    "ceiling": {
                      "div": [
                        "@total_logical_processors",
                        "@numa_nodes"
                      ]
                    }
                  },
                  8
                ]
              },
              {
                "eq": [
                  "@max_dop",
                  8
                ]
              }
            ]
          }
        ]
      },
      "probes": [
        "ServerInstanceConfiguration",
        "SysConfiguration"
      ]
    },
    {
      "id": "MaxMemory",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Memory",
        "Performance",
        "MaxMemory"
      ],
      "displayName": "Max allowed memory ",
      "description": "Setting the 'max server memory' value too high can cause a single instance of SQL Server to compete for memory with other SQL Server instances hosted on the same machine. However, setting this value too low could cause significant memory pressure and performance problems.",
      "message": "Set 'max server memory' value to @{recommended:N0} MB or less to avoid detrimental memory pressure. Current 'max server memory' value is @{max_server_memory:N0}, which is greater than recommended",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/server-memory-server-configuration-options",
      "level": "Warning",
      "limit": 2147483647,
      "condition": {
        "or": [
          {
            "gt": [
              "@max_server_memory",
              {
                "div": [
                  "@total_physical_memory_kb",
                  1024
                ]
              }
            ]
          },
          {
            "le": [
              "@max_server_memory",
              "@recommended"
            ]
          }
        ]
      },
      "probes": [
        "OsSysMemory",
        "SysConfiguration",
        "SysDmOsSysInfo",
        "SysDmOsHostInfo"
      ],
      "locals": {
        "recommended": {
          "floor": {
            "min": [
              "@limit",
              {
                "sub": [
                  {
                    "sub": [
                      {
                        "div": [
                          "@total_physical_memory_kb",
                          1024
                        ]
                      },
                      {
                        "interval": [
                          {
                            "div": [
                              "@total_physical_memory_kb",
                              1024
                            ]
                          },
                          512,
                          2048,
                          819,
                          4096,
                          1228,
                          8192,
                          2048,
                          12288,
                          2560,
                          24576,
                          3072,
                          32768,
                          4096
                        ]
                      }
                    ]
                  },
                  {
                    "mul": [
                      "@max_workers_count",
                      {
                        "interval": [
                          "@host_architecture",
                          0.5,
                          32,
                          2,
                          64,
                          4
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        }
      }
    },
    {
      "id": "MaxMemory",
      "itemType": "override",
      "targetFilter": {
        "engineEdition": "Express"
      },
      "limit": 1410
    },
    {
      "id": "MaxMemory",
      "itemType": "override",
      "targetFilter": {
        "engineEdition": "Standard"
      },
      "limit": 131072
    },
    {
      "id": "MaxMemorySystem",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises, ManagedInstance",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Memory",
        "Performance",
        "MaxMemory"
      ],
      "displayName": "Max server memory exceeds system memory",
      "description": "Setting the 'max server memory' value higher than system memory can cause SQL Server to compete for memory with the operating system and processes running on the same machine.",
      "message": "Set 'max server memory' to @{recommended:N0} MB or less to avoid detrimental memory pressure. System memory of @{sysmem:N0} MB is not sufficient for current 'max server memory' setting of @{max_server_memory:N0} MB",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/server-memory-server-configuration-options",
      "level": "Warning",
      "limit": 2147483647,
      "condition": {
        "lt": [
          "@max_server_memory",
          "@sysmem"
        ]
      },
      "probes": [
        "OsSysMemory",
        "SysConfiguration",
        "SysDmOsSysInfo",
        "SysDmOsHostInfo"
      ],
      "locals": {
        "sysmem": {
          "div": [
            "@total_physical_memory_kb",
            1024
          ]
        },
        "recommended": {
          "floor": {
            "min": [
              "@limit",
              {
                "sub": [
                  {
                    "sub": [
                      {
                        "div": [
                          "@total_physical_memory_kb",
                          1024
                        ]
                      },
                      {
                        "interval": [
                          {
                            "div": [
                              "@total_physical_memory_kb",
                              1024
                            ]
                          },
                          512,
                          2048,
                          819,
                          4096,
                          1228,
                          8192,
                          2048,
                          12288,
                          2560,
                          24576,
                          3072,
                          32768,
                          4096
                        ]
                      }
                    ]
                  },
                  {
                    "mul": [
                      "@max_workers_count",
                      {
                        "interval": [
                          "@host_architecture",
                          0.5,
                          32,
                          2,
                          64,
                          4
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        }
      }
    },
    {
      "id": "MaxMemorySystem",
      "itemType": "override",
      "targetFilter": {
        "engineEdition": "Express"
      },
      "limit": 1410
    },
    {
      "id": "MaxMemorySystem",
      "itemType": "override",
      "targetFilter": {
        "engineEdition": "Standard"
      },
      "limit": 131072
    },
    {
      "id": "MinMemoryPerQuery",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Memory",
        "Performance"
      ],
      "displayName": "Option 'min memory per query' set to default",
      "description": "The min memory per query option specifies the minimum amount of memory (in kilobytes) that will be allocated for the execution of a query. This is also known as the minimum memory grant. The default value is 1,024 KB. Do not set the min memory per query server configuration option too high, especially on very busy systems, because the query has to wait1 until it can secure the minimum memory requested, or until the value specified in the query wait server configuration option is exceeded. If more memory is available than the specified minimum value required to execute the query, the query is allowed to make use of the additional memory, provided that the memory can be used effectively by the query.",
      "message": "Set 'min memory per query' option to @{recommended_min_memory_per_query} KB. Current value is '@{min_memory_per_query}'",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-min-memory-per-query-server-configuration-option",
      "level": "Warning",
      "recommended_min_memory_per_query": 1024,
      "condition": {
        "eq": [
          "@min_memory_per_query",
          "@recommended_min_memory_per_query"
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "NetworkPacketSize",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Network"
      ],
      "displayName": "Option 'network packet size' set to default",
      "description": "The 'network packet size' option sets the packet size (in bytes) that is used across the whole network. Packets are the fixed-size chunks of data that transfer requests and results between clients and servers. The default packet size is 4096 bytes.",
      "message": "Set 'network packet size' option to @{recommended_network_packet_size} bytes. Current value is @{network_packet_size}",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-network-packet-size-server-configuration-option",
      "level": "Warning",
      "recommended_network_packet_size": 4096,
      "condition": {
        "eq": [
          "@network_packet_size",
          "@recommended_network_packet_size"
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "NtfsBlockSizeNotFormatted",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Configuration",
        "NTFS"
      ],
      "displayName": "NTFS block size in volumes with database files <> 64KB",
      "description": "A drive can be formatted with different sizes ranging from 512 bytes to 64K sizes with the default being 4KB (4096 bytes). This setting is also called as “Bytes Per Cluster”. The atomic unit of storage in SQL Server is a page which is 8KB in size. Extents are groups of eight 8 KB pages that are physically contiguous to each other for a total of 64 KB. SQL Server uses extents to store data. Hence, on a SQL Server machine the NTFS Allocation unit size hosting SQL database files (Including tempdb files) should be 64 KB.",
      "message": "Set allocation unit size on volume '@{masterFilesVolumeName}' to 64 KB. Current size is @{Output.BlockSize} bytes",
      "helpLink": "https://docs.microsoft.com/archive/blogs/docast/operating-system-best-practice-configurations-for-sql-server",
      "level": "Warning",
      "BlockSize": 65536,
      "condition": {
        "or": [
          {
            "ne": [
              "@masterFilesVolumeName",
              "@Output.Name"
            ]
          },
          {
            "eq": [
              "@Output.BlockSize",
              "@BlockSize"
            ]
          }
        ]
      },
      "probes": [
        "NtfsBlockSize",
        "Win32Volume"
      ]
    },
    {
      "id": "OlapSvcAccSame",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Analysis Services' and 'SQL Server Database Engine' use same account",
      "description": "Running the 'Analysis Services' service under the same account as the 'SQL Server Database Engine' service is not recommended.",
      "message": "Use different accounts for the 'Analysis Services' service and the 'SQL Server Database Engine' service. Now both services use '@{attr::service::MSOLAP.account}' account",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::MSOLAP"
          },
          {
            "ine": [
              "@attr::service::MSSQL.account",
              "@attr::service::MSOLAP.account"
            ]
          }
        ]
      }
    },
    {
      "id": "OlapSvcStoped",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Analysis Services' service is stopped",
      "description": "The 'Analysis Services' service provides online analytical processing (OLAP) and data mining functionality for business intelligence applications.",
      "message": "Run 'Analysis Services' service",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/manage-the-database-engine-services",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::MSOLAP"
          },
          {
            "imatch": [
              "@Output.Status",
              "^Running\\.*$"
            ]
          }
        ]
      },
      "probes": [
        {
          "id": "ServiceControl",
          "params": {
            "ServiceName": "@attr::service::MSOLAP.name"
          }
        }
      ]
    },
    {
      "id": "OleAutomationProceduresOn",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Security"
      ],
      "displayName": "Option 'Ole Automation Procedures' set to default",
      "description": "Use the 'Ole Automation Procedures' option to specify whether OLE Automation objects can be instantiated within Transact-SQL batches. When OLE Automation Procedures are enabled, a call to 'sp_OACreate' will start the OLE shared execution environment. The 'Ole Automation Procedures' option can be set to the following values: 1 Enabled, 0 Disabled (default value).",
      "message": "Disable 'Ole Automation Procedures' option to avoid security risks",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/ole-automation-procedures-server-configuration-option",
      "level": "Warning",
      "condition": {
        "not": "@ole_automation_procedures"
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "PageFileAutoManaged",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Memory",
        "PageFile",
        "SysAdminReq"
      ],
      "displayName": "Page file is not automatically managed",
      "description": "Memory allocation failures can occur due to latencies that are associated with growing the size of a page file to support additional memory requirements in the system. A potential cause of these failures is when the page file size is configured as “automatic.” Automatic page-file size starts with a small page file and grows automatically as needed. The IO system consists of many components, including file system filters, file systems, volume filters, storage filters, and so on. The specific components on a given system can cause variability in page file growth.",
      "message": "Avoid automatic management of page files. Set custom size for page file on drives: '@{PagingFiles.Drive}'",
      "helpLink": "https://support.microsoft.com/help/4055223/memory-allocation-errors-can-be-caused-by-slow-page-file-growth",
      "level": "Warning",
      "probes": [
        {
          "id": "PageFileManagement",
          "transform": [
            {
              "type": "parse",
              "map": {
                "PagingFiles": "/^(?<Drive>\\w:)\\\\pagefile.sys 0 0$/x"
              }
            },
            {
              "type": "aggregate",
              "map": {
                "PagingFiles.Drive": "join"
              }
            }
          ]
        }
      ]
    },
    {
      "id": "PageFileAutoManagedAllDrives",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Memory",
        "PageFile",
        "SysAdminReq"
      ],
      "displayName": "Page file is not automatically managed",
      "description": "Memory allocation failures can occur due to latencies that are associated with growing the size of a page file to support additional memory requirements in the system. A potential cause of these failures is when the page file size is configured as “automatic.” Automatic page-file size starts with a small page file and grows automatically as needed. The IO system consists of many components, including file system filters, file systems, volume filters, storage filters, and so on. The specific components on a given system can cause variability in page file growth. ",
      "message": "Disable 'Automatically manage paging file size for all drives' option",
      "helpLink": "https://support.microsoft.com/help/4055223/memory-allocation-errors-can-be-caused-by-slow-page-file-growth",
      "level": "Warning",
      "condition": {
        "ne": [
          "@PagingFiles",
          "?:\\pagefile.sys"
        ]
      },
      "probes": [
        "PageFileManagement"
      ]
    },
    {
      "id": "PageFileLess10FreeSpace",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Memory",
        "PageFile",
        "SysAdminReq"
      ],
      "displayName": "Insufficient page file free space",
      "description": "Page file sizing depends on the system crash dump setting requirements and the peak usage or expected peak usage of the system commit charge. Both considerations are unique to each system, even for systems that are identical. This means that page file sizing is also unique to each system and cannot be generalized.",
      "message": "Revise page file settings. Less than 10% of page file is available",
      "helpLink": "https://docs.microsoft.com/windows/client-management/determine-appropriate-page-file-size",
      "level": "Warning",
      "threshold": 0.1,
      "condition": {
        "or": [
          {
            "eq": [
              {
                "sub": [
                  "@total_page_file_kb",
                  "@total_physical_memory_kb"
                ]
              },
              0
            ]
          },
          {
            "gt": [
              {
                "div": [
                  {
                    "sub": [
                      "@available_page_file_kb",
                      "@available_physical_memory_kb"
                    ]
                  },
                  {
                    "sub": [
                      "@total_page_file_kb",
                      "@total_physical_memory_kb"
                    ]
                  }
                ]
              },
              "@threshold"
            ]
          }
        ]
      },
      "probes": [
        "OsSysMemory"
      ]
    },
    {
      "id": "PageFileNotConfigured",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Memory",
        "PageFile",
        "SysAdminReq"
      ],
      "displayName": "Page file not configured",
      "description": "Page file sizing depends on the system crash dump setting requirements and the peak usage or expected peak usage of the system commit charge. Both considerations are unique to each system, even for systems that are identical. This means that page file sizing is also unique to each system and cannot be generalized.",
      "message": "Create page file on server",
      "helpLink": "https://docs.microsoft.com/windows/client-management/determine-appropriate-page-file-size",
      "level": "Warning",
      "condition": "@PagingFiles",
      "probes": [
        "PageFileManagement"
      ]
    },
    {
      "id": "PageFileOut",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance",
        "Memory",
        "PageFile",
        "SysAdminReq"
      ],
      "displayName": "Memory paged out",
      "description": "Microsoft SQL Server performs dynamic memory management based on the memory requirements of the current load and activities on the system. On Windows, SQL Server can use the memory notification mechanisms that are provided by the QueryMemoryResourceNotification Windows API. Based on this information from the QueryMemoryResourceNotification Windows API or from the memory calculation, SQL Server responds to the current memory situation on a specific system. This provides the following benefits: 1. The system does not page out the working set of the SQL Server process; 2. The necessary database pages are available in memory to reduce physical I/O needs. For more information, see the \"Dynamic memory management\" topic and the \"Server memory options\" topic in SQL Server Books Online.",
      "message": "Revise LPIM settings. Part of SQL Server process memory has been paged out",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/enable-the-lock-pages-in-memory-option-windows",
      "level": "Warning",
      "condition": {
        "gt": [
          "@available_page_file_kb",
          0
        ]
      },
      "probes": [
        "OsSysMemory"
      ]
    },
    {
      "id": "PowerPlanSchemeNotRecommended",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance"
      ],
      "displayName": "Power plan is High Performance",
      "description": "In some cases you may experience degraded overall performance on a Windows Server 2008 R2 or later machine when running with the default (Balanced) power plan. The issue may occur irrespective of platform and may be exhibited on both native and virtual environments. The degraded performance may increase the average response time for some tasks and cause performance issues with CPU-intensive applications. Please note that you may not notice performance issues while performing simple operations. However, applications or scripts that intensively use resources (primarily processor and memory) may exhibit the problem. To work around the performance degradation issue, you can switch to the High Performance power plan.  However, this will disable dynamic performance scaling on the platform. Depending on the environment, if the platform is always under a heavy load, then this is a viable solution.",
      "message": "Switch server to High Performance power plan",
      "helpLink": "https://support.microsoft.com/help/2207548/slow-performance-on-windows-server-when-using-the-balanced-power-plan",
      "level": "Warning",
      "powerplanid": "8c5e7fda-e8bf-4a96-9a85-a6e23a8c635c",
      "condition": {
        "or": [
          {
            "eq": [
              "@ActivePowerScheme",
              0
            ]
          },
          {
            "eq": [
              "@ActivePowerScheme",
              "@powerplanid"
            ]
          }
        ]
      },
      "probes": [
        "PowerPlan"
      ]
    },
    {
      "id": "PriorityBoostOn",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance"
      ],
      "displayName": "Option 'priority boost' set to default",
      "description": "The 'priority boost' option used to specify whether Microsoft SQL Server should run at a higher scheduling priority than other processes on the same computer. If this option is set to 1, SQL Server runs at a priority base of '13' scheduler. The default is '0', which is a priority base of '7'.",
      "message": "Set 'priority boost' option to default value",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-priority-boost-server-configuration-option",
      "level": "Critical",
      "condition": {
        "not": "@priority_boost"
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "QueryWaitNotDefault",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Option 'query wait' set to default",
      "description": "Memory-intensive queries (such as those involving sorting and hashing) are queued when there is not enough memory available to run the query. The query wait option specifies the time, in seconds (from 0 through 2147483647), that a query waits for resources before it times out. The default value for this option is -1. This means the time-out is calculated as 25 times the estimated query cost.",
      "message": "Set 'query wait' option to @{default_query_wait}. Current value is @{query_wait}. Increasing maximum wait time may increase amount of time to terminate queries",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-query-wait-server-configuration-option",
      "level": "Critical",
      "default_query_wait": -1,
      "condition": {
        "eq": [
          "@query_wait",
          "@default_query_wait"
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "RecoveryIntervalOn",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance"
      ],
      "displayName": "Option 'recovery interval' set to default",
      "description": "The 'recovery interval' option defines an upper limit on the time recovering a database should take. The default recovery-interval value is 0, which allows the Database Engine to automatically configure the recovery interval. Higher values indicate the approximate maximum recovery time, in minutes.",
      "message": "Set 'recovery interval' option to @{default_recovery_interval}. Current value is @{recovery_interval}",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-recovery-interval-server-configuration-option",
      "level": "Warning",
      "default_recovery_interval": 0,
      "condition": {
        "eq": [
          "@recovery_interval",
          "@default_recovery_interval"
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "RemoteDacClusterOn",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Remote admin connections enabled on cluster (DAC)",
      "description": "SQL Server provides a dedicated administrator connection (DAC). The DAC lets an administrator access a running server to execute diagnostic functions or Transact-SQL statements, or to troubleshoot problems on the server, even when the server is locked or running in an abnormal state and not responding to a SQL Server Database Engine connection. On cluster configurations, the DAC will be off by default. Users can execute the remote admin connection option of sp_configure to enable the DAC listener to access a remote connection. If SQL Server is unresponsive and the DAC listener is not enabled, you might have to restart SQL Server to connect with the DAC. Therefore, we recommend that you enable the remote admin connections configuration option on clustered systems.",
      "message": "Enable 'remote admin connections' option",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/diagnostic-connection-for-database-administrators",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@is_clustered_server"
          },
          "@remote_admin_connections"
        ]
      },
      "probes": [
        "SysConfiguration",
        "IsClusteredServer"
      ]
    },
    {
      "id": "RemoteQueryTimeout",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Option 'remote query timeout' set to default",
      "description": "The 'remote query timeout' option specifies how long, in seconds, a remote operation can take before SQL Server times out. The default value for this option is 600, which allows a 10-minute wait. This value applies to an outgoing connection initiated by the Database Engine as a remote query.",
      "message": "Set 'remote query timeout' option to @{recommended_remote_query_timeout}. Current value is @{remote_query_timeout}",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-remote-query-timeout-server-configuration-option",
      "level": "Warning",
      "recommended_remote_query_timeout": 600,
      "condition": {
        "eq": [
          "@remote_query_timeout",
          "@recommended_remote_query_timeout"
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "RsSvcAccSame",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Reporting Services' and 'SQL Server Database Engine' use same account",
      "description": "Running the 'Reporting Services' service under the same account as the 'SQL Server Database Engine' service is not recommended.",
      "message": "Use different accounts for 'Reporting Services' service and the 'SQL Server Database Engine' service. Now both services use '@{attr::service::ReportServer.account}' account",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::ReportServer"
          },
          {
            "ine": [
              "@attr::service::MSSQL.account",
              "@attr::service::ReportServer.account"
            ]
          }
        ]
      }
    },
    {
      "id": "RsSvcStoped",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'Reporting Services' service is stopped",
      "description": "'The Reporting Services' service manages, executes, creates, schedules and delivers reports.",
      "message": "Run 'Reporting Services' service",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/manage-the-database-engine-services",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@attr::service::ReportServer"
          },
          {
            "imatch": [
              "@Output.Status",
              "^Running\\.*$"
            ]
          }
        ]
      },
      "probes": [
        {
          "id": "ServiceControl",
          "params": {
            "ServiceName": "@attr::service::ReportServer.name"
          }
        }
      ]
    },
    {
      "id": "ScanStartupProcs",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Option 'scan for startup procs' disabled on replication servers",
      "description": "Use the scan for startup procs option to scan for automatic execution of stored procedures at SQL Server startup time. If this option is set to 1, SQL Server scans for and runs all automatically run stored procedures that are defined on the server. The default value for scan for startup procs is 0 (do not scan). This option shouldn't be enabled on a SQL Server participating in replication.",
      "message": "Disable 'scan for startup procs' option for servers that participate in replication",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-scan-for-startup-procs-server-configuration-option",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "not": "@ReplicationInfo::IsInstalled"
          },
          {
            "not": "@startup_stored_procedures"
          }
        ]
      },
      "probes": [
        "ReplicationInfo",
        "SysConfiguration"
      ]
    },
    {
      "id": "SqlSvcAccNotRecommended",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'SQL Server Database Engine' service uses non-recommended account",
      "description": "Running the 'SQL Server Database Engine' service under 'NT AUTHORITY\\SYSTEM' or 'NT AUTHORITY\\NETWORKSERVICE' accounts is not recommended for security reasons.",
      "message": "Use another account to run 'SQL Server Database Engine' service. Current account '@{attr::service::MSSQL.account}' is not recommended",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "unrecommendedAccounts": [
        "NT AUTHORITY\\SYSTEM",
        "LOCALSYSTEM",
        "NT AUTHORITY\\NETWORKSERVICE"
      ],
      "condition": {
        "or": [
          "@is_clustered_server",
          {
            "not": {
              "iin": [
                "@attr::service::MSSQL.account",
                "@unrecommendedAccounts"
              ]
            }
          }
        ]
      },
      "probes": [
        "IsClusteredServer"
      ]
    },
    {
      "id": "SqlSvcAccNotSupported",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "'SQL Server Database Engine' service uses not supported account",
      "description": "Running the 'SQL Server Database Engine' service under 'NT AUTHORITY\\LOCALSERVICE', 'NT AUTHORITY\\SYSTEM' or 'NT AUTHORITY\\NETWORKSERVICE' accounts is not supported.",
      "message": "Use another account to run 'SQL Server Database Engine' service. Current account '@{attr::service::MSSQL.account}' is not supported",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-windows-service-accounts-and-permissions",
      "level": "Warning",
      "localServiceAccount": "NT AUTHORITY\\LOCALSERVICE",
      "unsupportedAccounts": [
        "NT AUTHORITY\\SYSTEM",
        "LOCALSYSTEM",
        "NT AUTHORITY\\NETWORKSERVICE"
      ],
      "condition": {
        "and": [
          {
            "ine": [
              "@attr::service::MSSQL.account",
              "@localServiceAccount"
            ]
          },
          {
            "or": [
              {
                "not": "@is_clustered_server"
              },
              {
                "not": {
                  "iin": [
                    "@attr::service::MSSQL.account",
                    "@unsupportedAccounts"
                  ]
                }
              }
            ]
          }
        ]
      },
      "probes": [
        "IsClusteredServer"
      ]
    },
    {
      "id": "ThreadExhaustionCPUBound",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance"
      ],
      "displayName": "Worker thread exhaustion on CPU-bound system",
      "description": "Consider overall runnable tasks count and schedulers work queue count.",
      "message": "Possible worker thread exhaustion (schedulers work queue count is '@{schedulers_work_queue_count}'). Overall runnable tasks count is '@{overall_runnable_tasks_count}' (> 2), indicating the server might be CPU-bound. Configured workers is '@{max_workers_count}'",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-max-worker-threads-server-configuration-option",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "le": [
              "@schedulers_work_queue_count",
              1
            ]
          },
          {
            "le": [
              "@overall_runnable_tasks_count",
              2
            ]
          }
        ]
      },
      "probes": [
        "WorkerThreads",
        "SysDmOsSysInfo"
      ]
    },
    {
      "id": "ThreadExhaustionNotCPUBound",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Performance"
      ],
      "displayName": "Possible worker thread exhaustion on non-CPU-bound system",
      "description": "Consider overall runnable tasks count and schedulers work queue count.",
      "message": "Possible worker thread exhaustion (schedulers work queue count is '@{schedulers_work_queue_count}'). Because overall runnable tasks count is '@{overall_runnable_tasks_count}' (<= 2), indicating the server might not be CPU bound, there might be room to increase max_worker_threads (configured workers is '@{max_workers_count}')",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-max-worker-threads-server-configuration-option",
      "level": "Warning",
      "condition": {
        "or": [
          {
            "le": [
              "@schedulers_work_queue_count",
              1
            ]
          },
          {
            "gt": [
              "@overall_runnable_tasks_count",
              2
            ]
          }
        ]
      },
      "probes": [
        "WorkerThreads",
        "SysDmOsSysInfo"
      ]
    },
    {
      "id": "ThresholdForParallelism",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance"
      ],
      "displayName": "Option 'cost threshold for parallelism' set to default",
      "description": "The 'cost threshold for parallelism' option specifies the threshold at which SQL Server creates and runs parallel plans for queries. SQL Server creates and runs a parallel plan for a query only when the estimated cost to run a serial plan for the same query is higher than the value set in the cost threshold for parallelism. The cost refers to an estimated cost required to run the serial plan on a specific hardware configuration and is not a unit of time. The 'cost threshold for parallelism' option can be set to any value from 0 through 32767. The default value is 5.",
      "message": "Set 'cost threshold for parallelism' option to @{default_cost_parallel}. Current value is @{cost_threshold_for_parallelism}",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-cost-threshold-for-parallelism-server-configuration-option",
      "level": "Warning",
      "default_cost_parallel": 5,
      "condition": {
        "eq": [
          "@cost_threshold_for_parallelism",
          "@default_cost_parallel"
        ]
      },
      "probes": [
        "SysConfiguration"
      ]
    },
    {
      "id": "WorkerThreadsLargeX64",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance",
        "CPU"
      ],
      "displayName": "Option 'max worker threads' set to recommended value on x64 system",
      "description": "The max worker threads option configures the number of worker threads that are available to SQL Server processes. The default value for max worker threads is 0. This enables SQL Server to automatically configure the number of worker threads at startup.",
      "message": "Reconfigure 'max worker threads' option parameter. Current value (@{max_worker_threads}) is higher than recommended for x64 system (@{recommended_max_worker_threads})",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-max-worker-threads-server-configuration-option",
      "level": "Warning",
      "recommended_max_worker_threads": 2048,
      "condition": {
        "or": [
          {
            "ne": [
              "@host_architecture",
              64
            ]
          },
          {
            "lt": [
              "@max_worker_threads",
              "@recommended_max_worker_threads"
            ]
          }
        ]
      },
      "probes": [
        "SysDmOsHostInfo",
        "SysConfiguration"
      ]
    },
    {
      "id": "WorkerThreadsLargeX86",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": "Windows",
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration",
        "Performance",
        "CPU"
      ],
      "displayName": "Option 'max worker threads' set to recommended value on x86 system",
      "description": "The max worker threads option configures the number of worker threads that are available to SQL Server processes. The default value for max worker threads is 0. This enables SQL Server to automatically configure the number of worker threads at startup.",
      "message": "Reconfigure 'max worker threads' option. Current value (@{max_worker_threads}) is higher than recommended for x86 system (@{recommended_max_worker_threads})",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/configure-the-max-worker-threads-server-configuration-option",
      "level": "Warning",
      "recommended_max_worker_threads": 1024,
      "condition": {
        "or": [
          {
            "ne": [
              "@host_architecture",
              32
            ]
          },
          {
            "lt": [
              "@max_worker_threads",
              "@recommended_max_worker_threads"
            ]
          }
        ]
      },
      "probes": [
        "SysDmOsHostInfo",
        "SysConfiguration"
      ]
    },
    {
      "id": "XpCmdShellOn",
      "itemType": "definition",
      "target": {
        "type": "Server",
        "platform": [
          "Windows",
          "Linux"
        ],
        "engineEdition": "OnPremises",
        "version": "[11.0,)"
      },
      "tags": [
        "DefaultRuleset",
        "Configuration"
      ],
      "displayName": "Option 'xp_cmdshell' is disabled",
      "description": "The xp_cmdshell option is a SQL Server configuration option that enables system administrators to control whether the xp_cmdshell extended stored procedure can be executed on a system. By default, the xp_cmdshell option is disabled on new installations. ",
      "message": "Disable 'xp_cmdshell' as it exposes to security risks",
      "helpLink": "https://docs.microsoft.com/sql/database-engine/configure-windows/xp-cmdshell-server-configuration-option",
      "level": "Warning",
      "condition": {
        "not": "@xp_cmdshell"
      },
      "probes": [
        "SysConfiguration"
      ]
    }
  ],
  "probes": {
    "EnabledGlobalTraceFlags": [
      {
        "type": "SQL",
        "target": {
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DECLARE @tracestatus TABLE (TraceFlag NVARCHAR(40), [Status] tinyint, [Global] tinyint, [Session] tinyint); INSERT INTO @tracestatus EXEC ('DBCC TRACESTATUS WITH NO_INFOMSGS'); IF NOT EXISTS(SELECT * FROM @tracestatus WHERE Global=1) SELECT 0 AS [TraceFlag], 0 AS [Status] ELSE SELECT [TraceFlag], [Status] FROM @tracestatus WHERE Global=1",
          "transform": {
            "type": "aggregate",
            "map": {
              "TraceFlag": "array"
            }
          }
        }
      }
    ],
    "CountBlackBoxTraces": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT COUNT(id) AS [BlackBoxTraceCount] FROM [sys].[traces] WHERE [path] LIKE '%blackbox%.trc' AND status=1;"
        }
      }
    ],
    "CountDefaultTraces": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT COUNT(id) AS [DefaultTraceCount] FROM [sys].[traces] WHERE is_default = 1 AND status = 1;"
        }
      }
    ],
    "XEvent.SystemHealth": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT COUNT(name) AS [XEvent.SystemHealthCount] FROM [sys].[dm_xe_sessions] WHERE [name] = 'system_health';"
        }
      }
    ],
    "XEvent.SPServerDiagnostics": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT COUNT(name) AS [XEvent.SPServerDiagnostics] FROM sys.dm_xe_sessions WHERE [name] = 'sp_server_diagnostics session';"
        }
      }
    ],
    "DeprecatedFeaturesStats": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT [instance_name] AS [DeprecatedFeature] FROM [sys].[dm_os_performance_counters] WHERE ([object_name] LIKE '%Deprecated Features%') AND ([cntr_value] > 0);",
          "transform": {
            "type": "aggregate",
            "map": {
              "DeprecatedFeature": "join"
            }
          }
        }
      }
    ],
    "DatabaseConfiguration": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "version": "[11.0,12.0)",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance"
        },
        "implementation": {
          "query": "SELECT db.is_auto_create_stats_on, db.is_auto_update_stats_on, 0 AS query_store_state, db.collation_name, (SELECT collation_name FROM master.sys.databases (NOLOCK) WHERE database_id = 1) AS master_collation, db.is_auto_close_on, db.is_auto_shrink_on, db.page_verify_option, db.is_db_chaining_on, NULL AS is_auto_create_stats_incremental_on, db.is_trustworthy_on, db.is_parameterization_forced,db.is_read_only AS IsReadOnly,db.[state] AS DbState FROM [sys].[databases] (NOLOCK) AS db WHERE db.[name]=@TargetName"
        }
      },
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "version": "[12.0, 13.0)",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance"
        },
        "implementation": {
          "query": "SELECT db.is_auto_create_stats_on, db.is_auto_update_stats_on, 0 AS query_store_state, db.collation_name, (SELECT collation_name FROM master.sys.databases (NOLOCK) WHERE database_id = 1) AS master_collation, db.is_auto_close_on, db.is_auto_shrink_on, db.page_verify_option, db.is_db_chaining_on, db.is_auto_create_stats_incremental_on, db.is_trustworthy_on, db.is_parameterization_forced,db.is_read_only AS IsReadOnly,db.[state] AS DbState FROM [sys].[databases] (NOLOCK) AS db WHERE db.[name]=@TargetName"
        }
      },
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "version": "[13.0,)",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT db.is_auto_create_stats_on, db.is_auto_update_stats_on, (SELECT CAST(actual_state AS DECIMAL) FROM [sys].[database_query_store_options]) AS query_store_state, db.collation_name, (SELECT collation_name FROM master.sys.databases (NOLOCK) WHERE database_id = 1) AS master_collation, db.is_auto_close_on, db.is_auto_shrink_on, db.page_verify_option, db.is_db_chaining_on, db.is_auto_create_stats_incremental_on, db.is_trustworthy_on, db.is_parameterization_forced,db.is_read_only AS IsReadOnly,db.[state] AS DbState FROM [sys].[databases] (NOLOCK) AS db WHERE db.[name]=@TargetName"
        }
      }
    ],
    "FKNoIndexes": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT QUOTENAME(fk.parent_schema_name)+ '.' + QUOTENAME(fk.parent_table_name) + '.' + QUOTENAME(fk.constraint_name) AS ConstraintName FROM ( SELECT t.name AS [parent_schema_name], OBJECT_NAME(FKC.parent_object_id) [parent_table_name], OBJECT_NAME(constraint_object_id) AS [constraint_name], SUBSTRING((SELECT ',' + RTRIM(COL_NAME(k.parent_object_id,parent_column_id)) AS [data()] FROM sys.foreign_key_columns k (NOLOCK) INNER JOIN sys.foreign_keys (NOLOCK) ON k.constraint_object_id = [object_id] AND k.constraint_object_id = FKC.constraint_object_id ORDER BY constraint_column_id FOR XML PATH('')), 2, 8000) AS [parent_columns] FROM sys.foreign_key_columns FKC (NOLOCK) INNER JOIN sys.objects o (NOLOCK) ON FKC.parent_object_id = o.[object_id] INNER JOIN sys.tables mst (NOLOCK) ON mst.[object_id] = o.[object_id] INNER JOIN sys.schemas t (NOLOCK) ON t.[schema_id] = mst.[schema_id] INNER JOIN sys.objects so (NOLOCK) ON FKC.referenced_object_id = so.[object_id] WHERE o.type = 'U' AND so.type = 'U' GROUP BY o.[schema_id],so.[schema_id],FKC.parent_object_id,constraint_object_id,referenced_object_id,t.name ) fk WHERE NOT EXISTS (SELECT 1 FROM ( SELECT t.name AS schemaName, OBJECT_NAME(mst.[object_id]) AS objectName, SUBSTRING(( SELECT ',' + RTRIM(ac.name) FROM sys.tables AS st INNER JOIN sys.indexes AS mi ON st.[object_id] = mi.[object_id] INNER JOIN sys.index_columns AS ic ON mi.[object_id] = ic.[object_id] AND mi.[index_id] = ic.[index_id] INNER JOIN sys.all_columns AS ac ON st.[object_id] = ac.[object_id] AND ic.[column_id] = ac.[column_id] WHERE i.[object_id] = mi.[object_id] AND i.index_id = mi.index_id AND ic.is_included_column = 0 ORDER BY ac.column_id FOR XML PATH('')), 2, 8000) AS KeyCols FROM sys.indexes AS i INNER JOIN sys.tables AS mst ON mst.[object_id] = i.[object_id] INNER JOIN sys.schemas AS t ON t.[schema_id] = mst.[schema_id] WHERE i.[type] IN (1,2,5,6) AND i.is_unique_constraint = 0 AND mst.is_ms_shipped = 0 ) ict WHERE fk.parent_schema_name = ict.schemaName AND fk.parent_table_name = ict.objectName AND REPLACE(fk.parent_columns,' ,',',') = ict.KeyCols);",
          "transform": {
            "type": "aggregate",
            "map": {
              "ConstraintName": "join"
            }
          }
        }
      }
    ],
    "Hints.InstanceStatistics": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT COUNT([counter]) AS [HintUsageCount] FROM [sys].[dm_exec_query_optimizer_info] WHERE ([counter] = 'order hint' OR [counter] = 'join hint') AND occurrence > 1;"
        }
      }
    ],
    "Hints.ModuleUsage": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT ss.name AS [Schema_Name], so.name AS [Object_Name], so.type_desc, CASE WHEN sm.[definition] LIKE '%FORCE ORDER%' THEN '[FORCE ORDER Hint]' WHEN sm.[definition] LIKE '%MERGE JOIN%' OR sm.[definition] LIKE '%LOOP JOIN%' OR sm.[definition] LIKE '%HASH JOIN%' THEN '[JOIN Hint]' END AS Hint FROM [sys].[sql_modules] AS sm INNER JOIN [sys].[objects] AS so ON sm.[object_id] = so.[object_id] INNER JOIN [sys].[schemas] AS ss ON so.[schema_id] = ss.[schema_id] WHERE (sm.[definition] LIKE '%FORCE ORDER%' OR sm.[definition] LIKE '%MERGE JOIN%' OR sm.[definition] LIKE '%LOOP JOIN%' OR sm.[definition] LIKE '%HASH JOIN%') AND OBJECTPROPERTY(sm.[object_id],'IsMSShipped') = 0;"
        }
      }
    ],
    "CachedPlans.SingleUseRatio": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DECLARE @Size1 AS REAL, @Size2 AS REAL; SET @Size1=COALESCE((SELECT SUM(CAST(size_in_bytes AS bigint)) AS Size1 FROM [sys].[dm_exec_cached_plans] (NOLOCK) WHERE cacheobjtype LIKE '%Plan%' AND usecounts = 1),0);SET @Size2=COALESCE((SELECT SUM(CAST(size_in_bytes AS bigint)) AS Size2 FROM [sys].[dm_exec_cached_plans] (NOLOCK) WHERE cacheobjtype LIKE '%Plan%' AND usecounts > 1),0);SELECT @Size1/(@Size1+@Size2) AS [SingleUsePlansUseRatio];"
        }
      }
    ],
    "Hypothetical.Indexes": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT QUOTENAME(t.name) AS [Schema], QUOTENAME(o.[name]) AS [Object], i.name AS [IndexName] FROM [sys].[indexes] i INNER JOIN [sys].[objects] AS o ON o.[object_id] = i.[object_id] INNER JOIN [sys].[tables] AS mst ON mst.[object_id] = i.[object_id] INNER JOIN [sys].[schemas] AS t ON t.[schema_id] = mst.[schema_id] WHERE i.is_hypothetical = 1;"
        }
      }
    ],
    "Hypothetical.Statistics": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT QUOTENAME(t.name) AS [Schema], QUOTENAME(o.[name]) AS [Object], s.name AS [StatName] FROM [sys].[stats] s INNER JOIN [sys].[objects] AS o (NOLOCK) ON o.[object_id] = s.[object_id] INNER JOIN [sys].[tables] AS mst (NOLOCK) ON mst.[object_id] = s.[object_id] INNER JOIN [sys].[schemas] AS t (NOLOCK) ON t.[schema_id] = mst.[schema_id] WHERE (s.name LIKE 'hind_%' OR s.name LIKE '_dta_stat%') AND auto_created = 0 AND s.name NOT IN (SELECT name FROM sys.indexes);"
        }
      }
    ],
    "SQLServerVersion": [
      {
        "type": "SQL",
        "type": "CLR",
        "name": "SQLServerVersion",
        "implementation": {
          "class": "Microsoft.SqlServer.Management.Assessment.Probes.ServerVersionProbe"
        }
      }
    ],
    "MissedIndexes": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT RIGHT(i.[statement],LEN(i.[statement])-(LEN(m.[name])+3)) AS [Table], CASE WHEN (i.equality_columns IS NOT NULL AND i.inequality_columns IS NULL) THEN i.equality_columns WHEN (i.equality_columns IS NULL AND i.inequality_columns IS NOT NULL) THEN i.inequality_columns ELSE i.equality_columns+','+i.inequality_columns END AS [KeyCols], ISNULL(i.included_columns,'') AS [IncludedCols],(CONVERT(NUMERIC(19,3),s.user_seeks)+CONVERT(NUMERIC(19,3),s.user_scans))*CONVERT(NUMERIC(19,3),s.avg_total_user_cost)*CONVERT(NUMERIC(19,3),s.avg_user_impact) AS [Score] FROM [sys].[dm_db_missing_index_details] i INNER JOIN [master].[sys].[databases] m ON i.database_id=m.database_id INNER JOIN [sys].[dm_db_missing_index_groups] g ON i.index_handle=g.index_handle INNER JOIN [sys].[dm_db_missing_index_group_stats] s ON s.group_handle=g.index_group_handle WHERE m.[name]=@TargetName"
        }
      }
    ],
    "DatabaseBackups": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT db.recovery_model, db.recovery_model_desc, fb.LastFullBackup, tl.LastTLBackup FROM [master].[sys].[databases] db (NOLOCK) LEFT JOIN (SELECT b.database_name, DATEDIFF(HH, MAX(b.backup_finish_date),GETDATE()) AS LastFullBackup FROM [msdb].[dbo].[backupset] b WHERE b.is_copy_only=0 AND b.type='D' GROUP BY b.database_name) fb ON fb.database_name=db.name LEFT JOIN (SELECT b.database_name, DATEDIFF(HH, MAX(b.backup_finish_date), GETDATE()) AS LastTLBackup FROM [msdb].[dbo].[backupset] b WHERE b.is_copy_only=0 AND b.type='L' GROUP BY b.database_name HAVING MAX(b.backup_finish_date)>=(SELECT MAX(f.backup_finish_date) FROM [msdb].[dbo].[backupset] f WHERE f.is_copy_only=0 AND f.type IN ('D','I') AND f.database_name=b.database_name GROUP BY f.database_name )) tl ON fb.database_name=tl.database_name WHERE db.name=@TargetName;"
        }
      }
    ],
    "TempDBFiles": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT COUNT(DISTINCT size) AS filesizeCount FROM tempdb.sys.database_files WHERE [type] = 0"
        }
      }
    ],
    "ServerInstanceConfiguration": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT ( SELECT COUNT(cpu_id) FROM sys.dm_os_schedulers WHERE is_online = 1 AND scheduler_id < 255 AND parent_node_id < 64 ) AS online_logical_processors, ( SELECT COUNT(DISTINCT parent_node_id) FROM sys.dm_os_schedulers WHERE scheduler_id < 255 AND parent_node_id < 64 ) AS numa_nodes, ( SELECT COUNT(*) FROM ( SELECT COUNT(cpu_id) CpuNodeCnt FROM sys.dm_os_schedulers WHERE is_online = 1 AND scheduler_id < 255 AND parent_node_id < 64 GROUP BY parent_node_id, is_online HAVING COUNT(cpu_id) = 1 ) AS Node_CPU ) AS nodes_single_cpu, ( SELECT COUNT(cpu_id) FROM sys.dm_os_schedulers WHERE scheduler_id < 255 AND parent_node_id < 64 ) AS total_logical_processors"
        }
      }
    ],
    "DatabaseMasterFiles": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT mf.database_id,dbs.name AS databaseName,[type],physical_name,mf.name AS fileName,size,growth,is_percent_growth FROM [sys].[master_files] AS mf INNER JOIN [sys].databases AS dbs ON mf.database_id=dbs.database_id WHERE mf.database_id=ISNULL(@dbId,mf.database_id) AND [type]=ISNULL(@type,[type])"
        }
      },
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT [type],physical_name,mf.name AS fileName,size,growth,is_percent_growth FROM [sys].[master_files] AS mf INNER JOIN [sys].databases AS dbs ON mf.database_id=dbs.database_id WHERE dbs.name=@TargetName AND [type]=ISNULL(@type,[type]) AND is_percent_growth=ISNULL(@is_percent_growth,is_percent_growth)"
        }
      }
    ],
    "InstantFileInitialization": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "version": "[13.0.4001,)",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises"
        },
        "implementation": {
          "query": "SELECT instant_file_initialization_enabled FROM [sys].[dm_server_services] WHERE servicename LIKE 'SQL Server%' AND servicename NOT LIKE 'SQL Server Agent%' AND servicename NOT LIKE 'SQL Server Launchpad%'"
        }
      },
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT 'N' AS instant_file_initialization_enabled"
        }
      }
    ],
    "IndexesDefinitions": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "version": "[11.0,)",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT i.object_id,QUOTENAME(t.name)+'.'+QUOTENAME(st.name) AS TableName,QUOTENAME(i.name) AS IndexName,QUOTENAME(ac.Name) AS ColumnName,ic.is_included_column,i.is_primary_key,i.filter_definition,i.is_unique,ic.key_ordinal,sty.name AS ColTypeName,CASE sty.name WHEN 'nvarchar' THEN ac.max_length/2 ELSE ac.max_length END AS ColTypeSize,i.fill_factor,i.is_disabled,i.type AS IndexType,index_stat.Hits,index_stat.Reads_Ratio,index_stat.last_user_update FROM [sys].[tables] AS st INNER JOIN [sys].[schemas] AS t ON t.[schema_id]=st.[schema_id] INNER JOIN [sys].[indexes] AS i ON st.[object_id]=i.[object_id] INNER JOIN [sys].[index_columns] AS ic ON i.[object_id]=ic.[object_id] AND i.[index_id]=ic.[index_id] INNER JOIN [sys].[all_columns] AS ac ON st.[object_id]=ac.[object_id] AND ic.[column_id]=ac.[column_id] INNER JOIN [sys].[types] AS sty ON ac.user_type_id=sty.user_type_id LEFT JOIN(SELECT s.object_id,s.index_id,(stat.user_seeks+stat.user_scans+stat.user_lookups) AS [Hits],RTRIM(CONVERT(NVARCHAR(10),CAST(CASE WHEN (stat.user_seeks+stat.user_scans+stat.user_lookups) = 0 THEN 0 ELSE CONVERT(REAL,(stat.user_seeks+stat.user_scans+stat.user_lookups)) * 100/CASE (stat.user_seeks+stat.user_scans+stat.user_lookups+stat.user_updates) WHEN 0 THEN 1 ELSE CONVERT(REAL,(stat.user_seeks+stat.user_scans+stat.user_lookups+stat.user_updates)) END END AS DECIMAL(18,2)))) AS [Reads_Ratio],MAX(stat.last_user_update) AS last_user_update FROM sys.indexes s INNER JOIN sys.dm_db_index_usage_stats stat on stat.object_id = s.object_id and stat.index_id = s.index_id WHERE s.type IN (2,6) AND s.is_primary_key=0 AND s.is_unique_constraint=0 GROUP BY s.object_id,s.index_id,stat.user_seeks,stat.user_scans,stat.user_lookups,stat.user_updates ) index_stat ON index_stat.object_id = i.object_id AND index_stat.index_id = i.index_id WHERE i.type IN (1,2,5,6) AND st.is_ms_shipped=0 AND i.is_unique_constraint=0",
          "transform": {
            "type": "indexDefinition"
          }
        }
      }
    ],
    "UserObjectsCountInMasterDB": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "name": "master",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT sao.name AS [Object_Name] FROM master.sys.all_objects sao INNER JOIN master.sys.schemas ss ON sao.[schema_id] = ss.[schema_id] WHERE sao.is_ms_shipped = 0 AND sao.[type] IN ('AF','FN','P','IF','PC','TF','TR','T','V') ORDER BY sao.name, sao.type_desc;",
          "transform": {
            "type": "aggregate",
            "map": {
              "Object_Name": "join"
            }
          }
        }
      }
    ],
    "Autogrow1GB": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "version": "[13.0.4001,)",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance"
        },
        "implementation": {
          "query": "DECLARE @ifi bit IF ( SELECT instant_file_initialization_enabled FROM sys.dm_server_services WHERE servicename LIKE 'SQL Server%' AND servicename NOT LIKE 'SQL Server Agent%' AND servicename NOT LIKE 'SQL Server Launchpad%' ) = 'Y' SET @ifi = 1; ELSE SET @ifi = 0; SELECT mf.[name] AS FileName FROM [sys].[master_files] AS mf (NOLOCK) INNER JOIN [sys].[databases] as dbs (NOLOCK) ON mf.database_id = dbs.database_id WHERE [type] >= CASE WHEN @ifi = 1 THEN 1 ELSE 0 END AND [type] < 2 AND ((is_percent_growth = 1 AND ((CONVERT(bigint,size)*8)*growth)/100 > 1048576) OR (is_percent_growth = 0 AND growth*8 > 1048576)) AND dbs.name = @TargetName",
          "transform": {
            "type": "aggregate",
            "map": {
              "FileName": "join"
            }
          }
        }
      }
    ],
    "CpuIdle": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DECLARE @ts_now bigint; SELECT @ts_now=ms_ticks FROM sys.dm_os_sys_info (NOLOCK); SELECT ISNULL(MIN(SystemIdle),100) AS MinIdle FROM (SELECT AVG(SystemIdle) AS SystemIdle FROM (SELECT record.value('(./Record/SchedulerMonitorEvent/SystemHealth/SystemIdle)[1]', 'int') AS SystemIdle, [TIMESTAMP] FROM (SELECT [TIMESTAMP], CONVERT(xml, record) AS record FROM sys.dm_os_ring_buffers (NOLOCK) WHERE ring_buffer_type = N'RING_BUFFER_SCHEDULER_MONITOR' AND record LIKE '%<SystemHealth>%' AND @ts_now-[TIMESTAMP]<=7200000) AS xrb) AS si GROUP BY (@ts_now-[TIMESTAMP])/600000) AS avg;"
        }
      }
    ],
    "ReplicationErrors": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DECLARE @cmd NVARCHAR(max) = N''; SELECT @cmd = @cmd + N' USE ' + QUOTENAME([name]) + N'; SELECT msa.publisher_db ,msa.publication FROM dbo.MSdistribution_history AS msh INNER JOIN dbo.MSrepl_errors AS mse ON mse.id = msh.error_id INNER JOIN dbo.MSdistribution_agents AS msa ON msh.agent_id = msa.id WHERE mse.time >= DATEADD(hh, - 24, GETDATE()) GROUP BY msa.publisher_db ,msa.publication;' FROM [master].sys.databases WHERE is_distributor = 1; EXEC (@cmd);"
        }
      }
    ],
    "SysAlerts": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT DISTINCT severity, message_id FROM [msdb].[dbo].[sysalerts]",
          "transform": {
            "type": "aggregate",
            "map": {
              "severity": "array",
              "message_id": "array"
            }
          }
        }
      }
    ],
    "WeakPassword": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DECLARE @word TABLE (word NVARCHAR(50)); INSERT INTO @word values ('0'),('012'),('0123'),('01234'),('012345'),('0123456'),('01234567'),('012345678'),('0123456789'),('01234567890'),('11111'),('111111'),('1111111'),('11111111'),('21'),('321'),('4321'),('54321'),('654321'),('7654321'),('87654321'),('987654321'),('0987654321'),('pwd'),('Password'),('password'),('P@ssw0rd'),('p@ssw0rd'),('Teste'),('teste'),('Test'),('test'),(''),('p@wd'),('Qwerty'),('qwerty'),('Password1'),('password1'); SELECT DISTINCT RTRIM(s.name) AS [PasswordData] FROM @word d INNER JOIN master.sys.sql_logins s ON PWDCOMPARE(d.word, s.[password_hash]) = 1",
          "transform": {
            "type": "aggregate",
            "map": {
              "PasswordData": "join"
            }
          }
        }
      }
    ],
    "VLF": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DBCC LOGINFO (@TargetName) WITH NO_INFOMSGS"
        }
      }
    ],
    "BadNamingSP": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT s.[name]+'.'+so.[name] AS ObjectName FROM sys.objects so INNER JOIN sys.schemas s ON so.schema_id = s.schema_id WHERE so.is_ms_shipped = 0 AND [type] = 'P' AND so.[name] LIKE 'sp[_]%' AND so.[name] NOT IN ('sp_alterdiagram','sp_creatediagram','sp_dropdiagram','sp_helpdiagramdefinition','sp_helpdiagrams','sp_renamediagram','sp_upgraddiagrams');",
          "transform": {
            "type": "aggregate",
            "map": {
              "ObjectName": "join"
            }
          }
        }
      }
    ],
    "BadNamingSpecialChars": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT s.[name] +'.'+so.[name] as ObjectName FROM sys.objects so INNER JOIN sys.schemas s ON so.schema_id = s.schema_id WHERE so.is_ms_shipped = 0 AND [type] <> 'S' AND (so.[name] LIKE '% %' OR so.[name] LIKE '%[[]%' OR so.[name] LIKE '%]%' OR so.[name] LIKE '%-%' OR so.[name] LIKE '%.%' OR so.[name] LIKE '%,%' OR so.[name] LIKE '%;%' OR so.[name] LIKE '%' + CHAR(34) + '%' OR so.[name] LIKE '%' + CHAR(39) + '%');",
          "transform": {
            "type": "aggregate",
            "map": {
              "ObjectName": "join"
            }
          }
        }
      }
    ],
    "BadNamingSpecialCharsColumns": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT s.name +'.'+ so.name + '.'+sc.name AS ObjectName FROM sys.columns sc INNER JOIN sys.objects so ON sc.object_id = so.object_id INNER JOIN sys.schemas s ON so.schema_id = s.schema_id WHERE so.is_ms_shipped = 0 AND (sc.[name] LIKE '% %' OR sc.[name] LIKE '%[[]%' OR sc.[name] LIKE '%]%' OR sc.[name] LIKE '%-%' OR sc.[name] LIKE '%.%' OR sc.[name] LIKE '%,%' OR sc.[name] LIKE '%;%' OR sc.[name] LIKE '%' + CHAR(34) + '%' OR sc.[name] LIKE '%' + CHAR(39) + '%') ORDER BY 1;",
          "transform": {
            "type": "aggregate",
            "map": {
              "ObjectName": "join"
            }
          }
        }
      }
    ],
    "BadNamingUserFunctions": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT s.name+'.'+so.name AS ObjectName FROM sys.objects so INNER JOIN sys.schemas s ON so.schema_id = s.schema_id WHERE so.is_ms_shipped = 0 AND [type] IN ('FN','FS','TF','IF') AND so.[name] LIKE 'fn[_]%' AND so.[name] NOT IN ('fn_diagram_objects')",
          "transform": {
            "type": "aggregate",
            "map": {
              "ObjectName": "join"
            }
          }
        }
      }
    ],
    "BadNamingKeywords": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": [
            "DECLARE @KeywordTbl AS TABLE(Keyword VARCHAR(255)) INSERT INTO @KeywordTbl VALUES ('ABSOLUTE'),('ACTION'),('ADA'),('ADD'),('ADMIN'),('AFTER'),('AGGREGATE'),('ALIAS'),('ALL'),('ALLOCATE'),('ALTER'),('AND'),('ANY'),('ARE'),('ARRAY'),('AS'),('ASC'),('ASSERTION'),('AT'),('AUTHORIZATION'),('AVG'),('BACKUP'),('BEFORE'),('BEGIN'),('BETWEEN'),('BINARY'),('BIT'),('BIT_LENGTH'),('BLOB'),('BOOLEAN'),('BOTH'),('BREADTH'),('BREAK'),('BROWSE'),('BULK'),('BY'),('CALL'),('CASCADE'),('CASCADED'),('CASE'),('CAST'),('CATALOG'),('CHAR'),('CHAR_LENGTH'),('CHARACTER'),('CHARACTER_LENGTH'),('CHECK'),('CHECKPOINT'),('CLASS'),('CLOB'),('CLOSE'),('CLUSTERED'),('COALESCE'),('COLLATE'),('COLLATION'),('COLUMN'),('COMMIT'),('COMPLETION'),('COMPUTE'),('CONNECT'),('CONNECTION'),('CONSTRAINT'),('CONSTRAINTS'),('CONSTRUCTOR'),('CONTAINS'),('CONTAINSTABLE'),('CONTINUE'),('CONVERT'),('CORRESPONDING'),('COUNT'),('CREATE'),('CROSS'),('CUBE'),('CURRENT'),('CURRENT_DATE'),('CURRENT_PATH'),('CURRENT_ROLE'),('CURRENT_TIME'),('CURRENT_TIMESTAMP'),('CURRENT_USER'),('CURSOR'),('CYCLE'),('DATA'),('DATABASE'),('DATE'),('DAY'),('DBCC'),('DEALLOCATE'),('DEC'),('DECIMAL'),('DECLARE'),('DEFAULT'),('DEFERRABLE'),('DEFERRED'),('DELETE'),('DENY'),('DEPTH'),('DEREF'),('DESC'),('DESCRIBE'),('DESCRIPTOR'),('DESTROY'),('DESTRUCTOR'),('DETERMINISTIC'),('DIAGNOSTICS'),('DICTIONARY'),('DISCONNECT'),('DISK'),('DISTINCT'),('DISTRIBUTED'),('DOMAIN'),('DOUBLE'),('DROP'),('DUMMY'),('DUMP'),('DYNAMIC') SELECT [schema]+'.'+[ObjName] AS ObjectName FROM ( SELECT s.name [schema],so.name [ObjName],type,type_desc FROM sys.objects so INNER JOIN sys.schemas s ON so.schema_id = s.schema_id WHERE so.is_ms_shipped = 0 AND [type] <> 'S') AS ObjNames CROSS JOIN @KeywordTbl WHERE ObjName like '% '+Keyword+' %' OR ObjName like '% '+Keyword OR ObjName=Keyword",
            "DECLARE @KeywordTbl AS TABLE(Keyword VARCHAR(255)) INSERT INTO @KeywordTbl VALUES ('EACH'),('ELSE'),('END'),('END-EXEC'),('EQUALS'),('ERRLVL'),('ESCAPE'),('EVERY'),('EXCEPT'),('EXCEPTION'),('EXEC'),('EXECUTE'),('EXISTS'),('EXIT'),('EXTERNAL'),('EXTRACT'),('FALSE'),('FETCH'),('FILE'),('FILLFACTOR'),('FIRST'),('FLOAT'),('FOR'),('FOREIGN'),('FORTRAN'),('FOUND'),('FREE'),('FREETEXT'),('FREETEXTTABLE'),('FROM'),('FULL'),('FULLTEXTTABLE'),('FUNCTION'),('GENERAL'),('GET'),('GLOBAL'),('GO'),('GOTO'),('GRANT'),('GROUP'),('GROUPING'),('HAVING'),('HOLDLOCK'),('HOST'),('HOUR'),('IDENTITY'),('IDENTITY_INSERT'),('IDENTITYCOL'),('IF'),('IGNORE'),('IMMEDIATE'),('IN'),('INCLUDE'),('INDEX'),('INDICATOR'),('INITIALIZE'),('INITIALLY'),('INNER'),('INOUT'),('INPUT'),('INSENSITIVE'),('INSERT'),('INT'),('INTEGER'),('INTERSECT'),('INTERVAL'),('INTO'),('IS'),('ISOLATION'),('ITERATE'),('JOIN'),('KEY'),('KILL'),('LANGUAGE'),('LARGE'),('LAST'),('LATERAL'),('LEADING'),('LEFT'),('LESS'),('LEVEL'),('LIKE'),('LIMIT'),('LINENO'),('LOAD'),('LOCAL'),('LOCALTIME'),('LOCALTIMESTAMP'),('LOCATOR'),('LOWER'),('MAP'),('MATCH'),('MAX'),('MIN'),('MINUTE'),('MODIFIES'),('MODIFY'),('MODULE'),('MONTH') SELECT [schema]+'.'+[ObjName] AS ObjectName FROM ( SELECT s.name [schema],so.name [ObjName],type,type_desc FROM sys.objects so INNER JOIN sys.schemas s ON so.schema_id = s.schema_id WHERE so.is_ms_shipped = 0 AND [type] <> 'S') AS ObjNames CROSS JOIN @KeywordTbl WHERE ObjName like '% '+Keyword+' %' OR ObjName like '% '+Keyword OR ObjName=Keyword",
            "DECLARE @KeywordTbl AS TABLE(Keyword VARCHAR(255)) INSERT INTO @KeywordTbl VALUES ('NAMES'),('NATIONAL'),('NATURAL'),('NCHAR'),('NCLOB'),('NEW'),('NEXT'),('NO'),('NOCHECK'),('NONCLUSTERED'),('NONE'),('NOT'),('NULL'),('NULLIF'),('NUMERIC'),('OBJECT'),('OCTET_LENGTH'),('OF'),('OFF'),('OFFSETS'),('OLD'),('ON'),('ONLY'),('OPEN'),('OPENDATASOURCE'),('OPENQUERY'),('OPENROWSET'),('OPENXML'),('OPERATION'),('OPTION'),('OR'),('ORDER'),('ORDINALITY'),('OUT'),('OUTER'),('OUTPUT'),('OVER'),('OVERLAPS'),('PAD'),('PARAMETER'),('PARAMETERS'),('PARTIAL'),('PASCAL'),('PATH'),('PERCENT'),('PLAN'),('POSITION'),('POSTFIX'),('PRECISION'),('PREFIX'),('PREORDER'),('PREPARE'),('PRESERVE'),('PRIMARY'),('PRINT'),('PRIOR'),('PRIVILEGES'),('PROC'),('PROCEDURE'),('PUBLIC'),('RAISERROR'),('READ'),('READS'),('READTEXT'),('REAL'),('RECONFIGURE'),('RECURSIVE'),('REF'),('REFERENCES'),('REFERENCING'),('RELATIVE'),('REPLICATION'),('RESTORE'),('RESTRICT'),('RESULT'),('RETURN'),('RETURNS'),('REVOKE'),('RIGHT'),('ROLE'),('ROLLBACK'),('ROLLUP'),('ROUTINE'),('ROW'),('ROWCOUNT'),('ROWGUIDCOL'),('ROWS'),('RULE') SELECT [schema]+'.'+[ObjName] AS ObjectName FROM ( SELECT s.name [schema],so.name [ObjName],type,type_desc FROM sys.objects so INNER JOIN sys.schemas s ON so.schema_id = s.schema_id WHERE so.is_ms_shipped = 0 AND [type] <> 'S') AS ObjNames CROSS JOIN @KeywordTbl WHERE ObjName like '% '+Keyword+' %' OR ObjName like '% '+Keyword OR ObjName=Keyword",
            "DECLARE @KeywordTbl AS TABLE(Keyword VARCHAR(255)) INSERT INTO @KeywordTbl VALUES ('SAVE'),('SAVEPOINT'),('SCHEMA'),('SCOPE'),('SCROLL'),('SEARCH'),('SECOND'),('SECTION'),('SELECT'),('SEQUENCE'),('SESSION'),('SESSION_USER'),('SET'),('SETS'),('SETUSER'),('SHUTDOWN'),('SIZE'),('SMALLINT'),('SOME'),('SPACE'),('SPECIFIC'),('SPECIFICTYPE'),('SQL'),('SQLCA'),('SQLCODE'),('SQLERROR'),('SQLEXCEPTION'),('SQLSTATE'),('SQLWARNING'),('START'),('STATE'),('STATEMENT'),('STATIC'),('STATISTICS'),('STRUCTURE'),('SUBSTRING'),('SUM'),('SYSTEM_USER'),('TABLE'),('TEMPORARY'),('TERMINATE'),('TEXTSIZE'),('THAN'),('THEN'),('TIME'),('TIMESTAMP'),('TIMEZONE_HOUR'),('TIMEZONE_MINUTE'),('TO'),('TOP'),('TRAILING'),('TRAN'),('TRANSACTION'),('TRANSLATE'),('TRANSLATION'),('TREAT'),('TRIGGER'),('TRIM'),('TRUE'),('TRUNCATE'),('UNDER'),('UNION'),('UNIQUE'),('UNKNOWN'),('UNNEST'),('UPDATE'),('UPDATETEXT'),('UPPER'),('USAGE'),('USE'),('USER'),('USING'),('VALUE'),('VALUES'),('VARCHAR'),('VARIABLE'),('VARYING'),('VIEW'),('WAITFOR'),('WHEN'),('WHENEVER'),('WHERE'),('WHILE'),('WITH'),('WITHOUT'),('WORK'),('WRITE'),('WRITETEXT'),('YEAR'),('ZONE') SELECT [schema]+'.'+[ObjName] AS ObjectName FROM ( SELECT s.name [schema],so.name [ObjName],type,type_desc FROM sys.objects so INNER JOIN sys.schemas s ON so.schema_id = s.schema_id WHERE so.is_ms_shipped = 0 AND [type] <> 'S') AS ObjNames CROSS JOIN @KeywordTbl WHERE ObjName like '% '+Keyword+' %' OR ObjName like '% '+Keyword OR ObjName=Keyword"
          ],
          "transform": {
            "type": "aggregate",
            "map": {
              "ObjectName": "join"
            }
          }
        }
      }
    ],
    "DeprecatedFeaturesSQLModules": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": [
            "IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion/0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('disk init',NULL,9),('disk resize',NULL,9),('for load',NULL,9),('dbcc dbrepair',NULL,9),('dbcc newalloc',NULL,9),('dbcc pintable',NULL,9),('dbcc unpintable',NULL,9),('dbcc rowlock',NULL,9),('dbcc textall',NULL,9),('dbcc textalloc',NULL,9),('*=',NULL,9),('=*',NULL,9),('setuser',9,NULL),('sp_helpdevice',9,NULL),('sp_addtype',9,NULL),('sp_attach_db',9,NULL),('sp_attach_single_file_db',9,NULL),('sp_bindefault',9,NULL),('sp_unbindefault',9,NULL),('sp_bindrule',9,NULL),('sp_unbindrule',9,NULL),('create default',9,NULL),('drop default',9,NULL),('create rule',9,NULL),('drop rule',9,NULL),('sp_renamedb',9,NULL),('sp_resetstatus',9,NULL),('dbcc dbreindex',9,NULL),('dbcc indexdefrag',9,NULL),('dbcc showcontig',9,NULL),('sp_addextendedproc',9,NULL),('sp_dropextendedproc',9,NULL),('sp_helpextendedproc',9,NULL),('xp_loginconfig',1,NULL),('sp_fulltext_catalog',9,NULL),('sp_fulltext_table',9,NULL),('sp_fulltext_column',9,NULL),('sp_fulltext_database',9,NULL),('sp_help_fulltext_tables',9,NULL),('sp_help_fulltext_columns',9,NULL),('sp_help_fulltext_catalogs',9,NULL),('sp_help_fulltext_tables_cursor',9,NULL),('sp_help_fulltext_columns_cursor',9,NULL) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT QUOTENAME(ss.name)+'.'+QUOTENAME(so.name) AS [ObjectName],tk.Keyword FROM sys.sql_modules sm (NOLOCK) INNER JOIN sys.objects so (NOLOCK) ON sm.[object_id]=so.[object_id] INNER JOIN sys.schemas ss (NOLOCK) ON so.[schema_id]=ss.[schema_id] CROSS JOIN @tblKeywords tk WHERE PATINDEX('%' + tk.Keyword + '%',LOWER(sm.[definition]) COLLATE DATABASE_DEFAULT)>1 AND OBJECTPROPERTY(sm.[object_id],'IsMSShipped')=0 END",
            "IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion/0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('sp_help_fulltext_catalogs_cursor',9,NULL),('fn_get_sql',9,NULL),('sp_indexoption',9,NULL),('sp_lock',9,NULL),('indexkey_property',9,NULL),('file_id',9,NULL),('sp_certify_removable',9,NULL),('sp_create_removable',9,NULL),('sp_dbremove',9,NULL),('sp_addapprole',9,NULL),('sp_dropapprole',9,NULL),('sp_addlogin',9,NULL),('sp_droplogin',9,NULL),('sp_adduser',9,NULL),('sp_dropuser',9,NULL),('sp_grantdbaccess',9,NULL),('sp_revokedbaccess',9,NULL),('sp_addrole',9,NULL),('sp_droprole',9,NULL),('sp_approlepassword',9,NULL),('sp_password',9,NULL),('sp_changeobjectowner',9,NULL),('sp_defaultdb',9,NULL),('sp_defaultlanguage',9,NULL),('sp_denylogin',9,NULL),('sp_grantlogin',9,NULL),('sp_revokelogin',9,NULL),('user_id',9,NULL),('sp_srvrolepermission',9,NULL),('sp_dbfixedrolepermission',9,NULL),('text',9,NULL),('ntext',9,NULL),('image',9,NULL),('textptr',9,NULL),('textvalid',9,NULL),('sp_addalias',9,10),('no_log',9,10),('truncate_only',9,10),('backup transaction',9,10),('dbcc concurrencyviolation',9,10),('sp_addgroup',9,10),('sp_changegroup',9,10),('sp_dropgroup',9,10),('sp_helpgroup',9,10),('sp_makewebtask',NULL,10),('sp_dropwebtask',NULL,10),('sp_runwebtask',NULL,10),('sp_enumcodepages',NULL,10),('dump',9,10),('load',9,10),('sp_articlesynctranprocs',NULL,10),('sp_diskdefault',NULL,10),('sp_eventlog',NULL,10) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT QUOTENAME(ss.name)+'.'+QUOTENAME(so.name) AS [ObjectName],tk.Keyword FROM sys.sql_modules sm (NOLOCK) INNER JOIN sys.objects so (NOLOCK) ON sm.[object_id]=so.[object_id] INNER JOIN sys.schemas ss (NOLOCK) ON so.[schema_id]=ss.[schema_id] CROSS JOIN @tblKeywords tk WHERE PATINDEX('%' + tk.Keyword + '%',LOWER(sm.[definition]) COLLATE DATABASE_DEFAULT)>1 AND OBJECTPROPERTY(sm.[object_id],'IsMSShipped')=0 END",
            "IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion/0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('sp_getmbcscharlen',NULL,10),('sp_helplog',NULL,10),('sp_helpsql',NULL,10),('sp_ismbcsleadbyte',NULL,10),('sp_lock2',NULL,10),('sp_msget_current_activity',NULL,10),('sp_msset_current_activity',NULL,10),('sp_msobjessearch',NULL,10),('xp_enum_activescriptengines',NULL,10),('xp_eventlog',NULL,10),('xp_getadmingroupname',NULL,10),('xp_getfiledetails',NULL,10),('xp_getlocalsystemaccountname',NULL,10),('xp_isntadmin',NULL,10),('xp_mslocalsystem',NULL,10),('xp_msnt2000',NULL,10),('xp_msplatform',NULL,10) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT QUOTENAME(ss.name)+'.'+QUOTENAME(so.name) AS [ObjectName],tk.Keyword FROM sys.sql_modules sm (NOLOCK) INNER JOIN sys.objects so (NOLOCK) ON sm.[object_id]=so.[object_id] INNER JOIN sys.schemas ss (NOLOCK) ON so.[schema_id]=ss.[schema_id] CROSS JOIN @tblKeywords tk WHERE PATINDEX('%' + tk.Keyword + '%',LOWER(sm.[definition]) COLLATE DATABASE_DEFAULT)>1 AND OBJECTPROPERTY(sm.[object_id],'IsMSShipped')=0 END",
            "IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion/0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('xp_setsecurity',NULL,10),('xp_varbintohexstr',NULL,10),('spt_datatype_info',NULL,10),('spt_datatype_info_ext',NULL,10),('spt_provider_types',NULL,10),('spt_server_info',NULL,10),('spt_values',NULL,10),('sysfulltextnotify ',NULL,10),('syslocks',NULL,10),('sysproperties',NULL,10),('sysprotects_aux',NULL,10),('sysprotects_view',NULL,10),('sysremote_catalogs',NULL,10),('sysremote_column_privileges',NULL,10),('sysremote_columns',NULL,10),('sysremote_foreign_keys',NULL,10) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT QUOTENAME(ss.name)+'.'+QUOTENAME(so.name) AS [ObjectName],tk.Keyword FROM sys.sql_modules sm (NOLOCK) INNER JOIN sys.objects so (NOLOCK) ON sm.[object_id]=so.[object_id] INNER JOIN sys.schemas ss (NOLOCK) ON so.[schema_id]=ss.[schema_id] CROSS JOIN @tblKeywords tk WHERE PATINDEX('%' + tk.Keyword + '%',LOWER(sm.[definition]) COLLATE DATABASE_DEFAULT)>1 AND OBJECTPROPERTY(sm.[object_id],'IsMSShipped')=0 END",
            "IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion/0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('sysremote_indexes',NULL,10),('sysremote_primary_keys',NULL,10),('sysremote_provider_types',NULL,10),('sysremote_schemata',NULL,10),('sysremote_statistics',NULL,10),('sysremote_table_privileges',NULL,10),('sysremote_tables',NULL,10),('sysremote_views',NULL,10),('syssegments',NULL,10),('sysxlogins',NULL,10),('sp_droptype',10,NULL),('@@remserver',10,NULL),('remote_proc_transactions',10,NULL),('sp_addumpdevice',10,NULL),('xp_grantlogin',10,NULL),('xp_revokelogin',10,NULL),('grant all',10,NULL),('deny all',10,NULL),('revoke all',10,NULL),('fn_virtualservernodes',10,NULL),('fn_servershareddrives',10,NULL),('writetext',10,NULL),('updatetext',10,NULL),('readtext',10,NULL),('torn_page_detection',10,NULL),('set rowcount',10,NULL),('dbo_only',9,11) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT QUOTENAME(ss.name)+'.'+QUOTENAME(so.name) AS [ObjectName],tk.Keyword FROM sys.sql_modules sm (NOLOCK) INNER JOIN sys.objects so (NOLOCK) ON sm.[object_id]=so.[object_id] INNER JOIN sys.schemas ss (NOLOCK) ON so.[schema_id]=ss.[schema_id] CROSS JOIN @tblKeywords tk WHERE PATINDEX('%' + tk.Keyword + '%',LOWER(sm.[definition]) COLLATE DATABASE_DEFAULT)>1 AND OBJECTPROPERTY(sm.[object_id],'IsMSShipped')=0 END",
            "IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion/0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('mediapassword',9,11 ),('password',9,11 ),('with append',10,11),('sp_dboption',9,11),('databaseproperty',9,11),('fastfirstrow',10,11),('sp_addserver',10,11 ),('sp_dropalias',9,11),('disable_def_cnst_chk',10,11),('sp_activedirectory_obj',NULL,11),('sp_activedirectory_scp',NULL,11),('sp_activedirectory_start',NULL,11),('sys.database_principal_aliases',NULL,11),('compute',10,11),('compute by',10,11),('sp_change_users_login',11,NULL),('sp_depends',11,NULL),('sp_getbindtoken',11,NULL),('sp_bindsession',11,NULL),('fmtonly',11,NULL),('raiserror',11,NULL),('sp_db_increased_partitions',11,NULL),('databasepropertyex(''isfulltextenabled'')',11,NULL),('sp_dbcmptlevel',11,NULL),('set ansi_nulls off',11,NULL),('set ansi_padding off',11,NULL),('set concat_null_yields_null off',11,NULL),('set offsets',11,NULL),('sys.numbered_procedures',12,NULL),('sys.numbered_procedure_parameters',12,NULL),('sys.sql_dependencies',12,NULL),('sp_db_vardecimal_storage_format',12,NULL),('sp_estimated_rowsize_reduction_for_vardecimal',12,NULL),('sp_trace_create',12,NULL),('sp_trace_setevent',12,NULL),('sp_trace_setstatus',12,NULL),('fn_trace_geteventinfo',12,NULL),('fn_trace_getfilterinfo',12,NULL),('fn_trace_gettable',12,NULL),('sys.traces',12,NULL),('sys.trace_events',12,NULL),('sys.trace_event_bindings',12,NULL),('sys.trace_categories',12,NULL),('sys.trace_columns',12,NULL),('sys.trace_subclass_values',12,NULL),('disable_interleaved_execution_tvf',10,15),('disable_batch_mode_memory_grant_feedback',10,15),('disable_batch_mode_adaptive_joins',10,15) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT QUOTENAME(ss.name)+'.'+QUOTENAME(so.name) AS [ObjectName],tk.Keyword FROM sys.sql_modules sm (NOLOCK) INNER JOIN sys.objects so (NOLOCK) ON sm.[object_id]=so.[object_id] INNER JOIN sys.schemas ss (NOLOCK) ON so.[schema_id]=ss.[schema_id] CROSS JOIN @tblKeywords tk WHERE PATINDEX('%' + tk.Keyword + '%',LOWER(sm.[definition]) COLLATE DATABASE_DEFAULT)>1 AND OBJECTPROPERTY(sm.[object_id],'IsMSShipped')=0 END"
          ],
          "transform": {
            "type": "aggregate",
            "group": "ObjectName",
            "map": {
              "Keyword": "join"
            }
          }
        }
      }
    ],
    "DeprecatedFeaturesJobs": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": [
            "USE [msdb]; IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion / 0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('disk init',NULL,9),('disk resize',NULL,9),('for load',NULL,9),('dbcc dbrepair',NULL,9),('dbcc newalloc',NULL,9),('dbcc pintable',NULL,9),('dbcc unpintable',NULL,9),('dbcc rowlock',NULL,9),('dbcc textall',NULL,9),('dbcc textalloc',NULL,9),('*=',NULL,9),('=*',NULL,9),('setuser',9,NULL),('sp_helpdevice',9,NULL),('sp_addtype',9,NULL),('sp_attach_db',9,NULL),('sp_attach_single_file_db',9,NULL),('sp_bindefault',9,NULL),('sp_unbindefault',9,NULL),('sp_bindrule',9,NULL),('sp_unbindrule',9,NULL),('create default',9,NULL),('drop default',9,NULL),('create rule',9,NULL),('drop rule',9,NULL),('sp_renamedb',9,NULL),('sp_resetstatus',9,NULL),('dbcc dbreindex',9,NULL),('dbcc indexdefrag',9,NULL),('dbcc showcontig',9,NULL),('sp_addextendedproc',9,NULL),('sp_dropextendedproc',9,NULL),('sp_helpextendedproc',9,NULL),('xp_loginconfig',1,NULL),('sp_fulltext_catalog',9,NULL),('sp_fulltext_table',9,NULL),('sp_fulltext_column',9,NULL),('sp_fulltext_database',9,NULL),('sp_help_fulltext_tables',9,NULL),('sp_help_fulltext_columns',9,NULL),('sp_help_fulltext_catalogs',9,NULL),('sp_help_fulltext_tables_cursor',9,NULL),('sp_help_fulltext_columns_cursor',9,NULL) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT 'Job: '+sj.[name]+' Step: '+sjs.step_name AS ObjectName,Keyword FROM msdb.dbo.sysjobsteps sjs (NOLOCK) INNER JOIN msdb.dbo.sysjobs sj (NOLOCK) ON sjs.job_id=sj.job_id CROSS JOIN @tblKeywords tk WHERE PATINDEX('%'+tk.Keyword+'%',LOWER(sjs.[command]) COLLATE DATABASE_DEFAULT)>1 AND sjs.[subsystem] IN ('TSQL','PowerShell'); END",
            "USE [msdb]; IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion / 0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('sp_help_fulltext_catalogs_cursor',9,NULL),('fn_get_sql',9,NULL),('sp_indexoption',9,NULL),('sp_lock',9,NULL),('indexkey_property',9,NULL),('file_id',9,NULL),('sp_certify_removable',9,NULL),('sp_create_removable',9,NULL),('sp_dbremove',9,NULL),('sp_addapprole',9,NULL),('sp_dropapprole',9,NULL),('sp_addlogin',9,NULL),('sp_droplogin',9,NULL),('sp_adduser',9,NULL),('sp_dropuser',9,NULL),('sp_grantdbaccess',9,NULL),('sp_revokedbaccess',9,NULL),('sp_addrole',9,NULL),('sp_droprole',9,NULL),('sp_approlepassword',9,NULL),('sp_password',9,NULL),('sp_changeobjectowner',9,NULL),('sp_defaultdb',9,NULL),('sp_defaultlanguage',9,NULL),('sp_denylogin',9,NULL),('sp_grantlogin',9,NULL),('sp_revokelogin',9,NULL),('user_id',9,NULL),('sp_srvrolepermission',9,NULL),('sp_dbfixedrolepermission',9,NULL),('text',9,NULL),('ntext',9,NULL),('image',9,NULL),('textptr',9,NULL),('textvalid',9,NULL),('sp_addalias',9,10),('no_log',9,10),('truncate_only',9,10),('backup transaction',9,10),('dbcc concurrencyviolation',9,10),('sp_addgroup',9,10),('sp_changegroup',9,10),('sp_dropgroup',9,10),('sp_helpgroup',9,10),('sp_makewebtask',NULL,10),('sp_dropwebtask',NULL,10),('sp_runwebtask',NULL,10),('sp_enumcodepages',NULL,10),('dump',9,10),('load',9,10),('sp_articlesynctranprocs',NULL,10),('sp_diskdefault',NULL,10),('sp_eventlog',NULL,10) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT 'Job: '+sj.[name]+' Step: '+sjs.step_name AS ObjectName,Keyword FROM msdb.dbo.sysjobsteps sjs (NOLOCK) INNER JOIN msdb.dbo.sysjobs sj (NOLOCK) ON sjs.job_id=sj.job_id CROSS JOIN @tblKeywords tk WHERE PATINDEX('%'+tk.Keyword+'%',LOWER(sjs.[command]) COLLATE DATABASE_DEFAULT)>1 AND sjs.[subsystem] IN ('TSQL','PowerShell'); END",
            "USE [msdb]; IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion / 0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('sp_getmbcscharlen',NULL,10),('sp_helplog',NULL,10),('sp_helpsql',NULL,10),('sp_ismbcsleadbyte',NULL,10),('sp_lock2',NULL,10),('sp_msget_current_activity',NULL,10),('sp_msset_current_activity',NULL,10),('sp_msobjessearch',NULL,10),('xp_enum_activescriptengines',NULL,10),('xp_eventlog',NULL,10),('xp_getadmingroupname',NULL,10),('xp_getfiledetails',NULL,10),('xp_getlocalsystemaccountname',NULL,10),('xp_isntadmin',NULL,10),('xp_mslocalsystem',NULL,10),('xp_msnt2000',NULL,10),('xp_msplatform',NULL,10) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT 'Job: '+sj.[name]+' Step: '+sjs.step_name AS ObjectName,Keyword FROM msdb.dbo.sysjobsteps sjs (NOLOCK) INNER JOIN msdb.dbo.sysjobs sj (NOLOCK) ON sjs.job_id=sj.job_id CROSS JOIN @tblKeywords tk WHERE PATINDEX('%'+tk.Keyword+'%',LOWER(sjs.[command]) COLLATE DATABASE_DEFAULT)>1 AND sjs.[subsystem] IN ('TSQL','PowerShell'); END",
            "USE [msdb]; IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion / 0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('xp_setsecurity',NULL,10),('xp_varbintohexstr',NULL,10),('spt_datatype_info',NULL,10),('spt_datatype_info_ext',NULL,10),('spt_provider_types',NULL,10),('spt_server_info',NULL,10),('spt_values',NULL,10),('sysfulltextnotify ',NULL,10),('syslocks',NULL,10),('sysproperties',NULL,10),('sysprotects_aux',NULL,10),('sysprotects_view',NULL,10),('sysremote_catalogs',NULL,10),('sysremote_column_privileges',NULL,10),('sysremote_columns',NULL,10),('sysremote_foreign_keys',NULL,10) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT 'Job: '+sj.[name]+' Step: '+sjs.step_name AS ObjectName,Keyword FROM msdb.dbo.sysjobsteps sjs (NOLOCK) INNER JOIN msdb.dbo.sysjobs sj (NOLOCK) ON sjs.job_id=sj.job_id CROSS JOIN @tblKeywords tk WHERE PATINDEX('%'+tk.Keyword+'%',LOWER(sjs.[command]) COLLATE DATABASE_DEFAULT)>1 AND sjs.[subsystem] IN ('TSQL','PowerShell'); END",
            "USE [msdb]; IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion / 0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('sysremote_indexes',NULL,10),('sysremote_primary_keys',NULL,10),('sysremote_provider_types',NULL,10),('sysremote_schemata',NULL,10),('sysremote_statistics',NULL,10),('sysremote_table_privileges',NULL,10),('sysremote_tables',NULL,10),('sysremote_views',NULL,10),('syssegments',NULL,10),('sysxlogins',NULL,10),('sp_droptype',10,NULL),('@@remserver',10,NULL),('remote_proc_transactions',10,NULL),('sp_addumpdevice',10,NULL),('xp_grantlogin',10,NULL),('xp_revokelogin',10,NULL),('grant all',10,NULL),('deny all',10,NULL),('revoke all',10,NULL),('fn_virtualservernodes',10,NULL),('fn_servershareddrives',10,NULL),('writetext',10,NULL),('updatetext',10,NULL),('readtext',10,NULL),('torn_page_detection',10,NULL),('set rowcount',10,NULL),('dbo_only',9,11 ) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT 'Job: '+sj.[name]+' Step: '+sjs.step_name AS ObjectName,Keyword FROM msdb.dbo.sysjobsteps sjs (NOLOCK) INNER JOIN msdb.dbo.sysjobs sj (NOLOCK) ON sjs.job_id=sj.job_id CROSS JOIN @tblKeywords tk WHERE PATINDEX('%'+tk.Keyword+'%',LOWER(sjs.[command]) COLLATE DATABASE_DEFAULT)>1 AND sjs.[subsystem] IN ('TSQL','PowerShell'); END",
            "USE [msdb]; IF (SELECT COUNT(instance_name) FROM sys.dm_os_performance_counters WHERE [object_name] LIKE '%Deprecated Features%' AND cntr_value>0)>0 BEGIN DECLARE @sqlmajorver INT; SELECT @sqlmajorver=CONVERT(int,(@@microsoftversion / 0x1000000) & 0xff); DECLARE @tblKeywords as TABLE (KeywordID int IDENTITY(1,1) PRIMARY KEY, Keyword VARCHAR(64), DeprecatedIn tinyint, DiscontinuedIn tinyint) INSERT INTO @tblKeywords VALUES ('mediapassword',9,11 ),('password',9,11 ),('with append',10,11),('sp_dboption',9,11),('databaseproperty',9,11),('fastfirstrow',10,11),('sp_addserver',10,11 ),('sp_dropalias',9,11),('disable_def_cnst_chk',10,11),('sp_activedirectory_obj',NULL,11),('sp_activedirectory_scp',NULL,11),('sp_activedirectory_start',NULL,11),('sys.database_principal_aliases',NULL,11),('compute',10,11),('compute by',10,11),('sp_change_users_login',11,NULL),('sp_depends',11,NULL),('sp_getbindtoken',11,NULL),('sp_bindsession',11,NULL),('fmtonly',11,NULL),('raiserror',11,NULL),('sp_db_increased_partitions',11,NULL),('databasepropertyex(''isfulltextenabled'')',11,NULL),('sp_dbcmptlevel',11,NULL),('set ansi_nulls off',11,NULL),('set ansi_padding off',11,NULL),('set concat_null_yields_null off',11,NULL),('set offsets',11,NULL),('sys.numbered_procedures',12,NULL),('sys.numbered_procedure_parameters',12,NULL),('sys.sql_dependencies',12,NULL),('sp_db_vardecimal_storage_format',12,NULL),('sp_estimated_rowsize_reduction_for_vardecimal',12,NULL),('sp_trace_create',12,NULL),('sp_trace_setevent',12,NULL),('sp_trace_setstatus',12,NULL),('fn_trace_geteventinfo',12,NULL),('fn_trace_getfilterinfo',12,NULL),('fn_trace_gettable',12,NULL),('sys.traces',12,NULL),('sys.trace_events',12,NULL),('sys.trace_event_bindings',12,NULL),('sys.trace_categories',12,NULL),('sys.trace_columns',12,NULL),('sys.trace_subclass_values',12,NULL),('sp_addremotelogin',10,14),('sp_dropremotelogin',10,14),('sp_helpremotelogin',10,14),('sp_remoteoption',10,14) DELETE FROM @tblKeywords WHERE DeprecatedIn>@sqlmajorver OR DiscontinuedIn>@sqlmajorver SELECT 'Job: '+sj.[name]+' Step: '+sjs.step_name AS ObjectName,Keyword FROM msdb.dbo.sysjobsteps sjs (NOLOCK) INNER JOIN msdb.dbo.sysjobs sj (NOLOCK) ON sjs.job_id=sj.job_id CROSS JOIN @tblKeywords tk WHERE PATINDEX('%'+tk.Keyword+'%',LOWER(sjs.[command]) COLLATE DATABASE_DEFAULT)>1 AND sjs.[subsystem] IN ('TSQL','PowerShell'); END"
          ],
          "transform": {
            "type": "aggregate",
            "group": "ObjectName",
            "map": {
              "Keyword": "join"
            }
          }
        }
      }
    ],
    "AffinityNUMANodeNoAssignedCPUs": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": "Windows",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "WITH cpuCTE (node, afin) AS (SELECT DISTINCT(parent_node_id), is_online FROM sys.dm_os_schedulers WHERE scheduler_id < 255 AND parent_node_id < 64 GROUP BY parent_node_id, is_online) SELECT COUNT(DISTINCT(node)) AS NodeCnt FROM cpuCTE WHERE afin = 0 AND node NOT IN ( SELECT DISTINCT(node) FROM cpuCTE WHERE afin = 1)"
        }
      }
    ],
    "IndexesGuidKeyColumns": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT ss.[name]+'.'+t.[name]+'.'+i.[name] as IndexName FROM [sys].[indexes] AS i INNER JOIN [sys].[tables] AS t ON t.[object_id]=i.[object_id] INNER JOIN [sys].[schemas] ss ON ss.[schema_id]=t.[schema_id] INNER JOIN [sys].[index_columns] AS sic ON sic.[object_id]=t.[object_id] AND sic.index_id=i.index_id INNER JOIN [sys].[columns] AS sc ON sc.[object_id]=t.[object_id] AND sc.column_id=sic.column_id INNER JOIN [sys].[types] AS sty ON sc.user_type_id=sty.user_type_id WHERE sic.is_included_column=0 AND sty.name='uniqueidentifier' and i.type=1 AND i.is_unique_constraint=0 AND t.is_ms_shipped=0 GROUP BY ss.name,t.[name],i.name HAVING COUNT(sty.name)>0",
          "transform": {
            "type": "aggregate",
            "map": {
              "IndexName": "join"
            }
          }
        }
      }
    ],
    "SuspectPagesValidation": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "IF (SELECT COUNT(*) FROM msdb.dbo.suspect_pages WHERE (event_type = 1 OR event_type = 2 OR event_type = 3)) > 0 BEGIN SELECT CASE event_type WHEN 1 THEN 'Error 823 or unspecified Error 824' WHEN 2 THEN 'Bad Checksum' WHEN 3 THEN 'Torn Page' ELSE NULL END AS [EventType] FROM msdb.dbo.suspect_pages (NOLOCK) WHERE (event_type = 1 OR event_type = 2 OR event_type = 3) AND DB_NAME(database_id)=(@TargetName) END;"
        }
      }
    ],
    "SparseFilesValidation": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "IF (SELECT COUNT(sd.database_id) FROM sys.databases sd INNER JOIN sys.master_files smf ON sd.database_id = smf.database_id WHERE sd.source_database_id IS NULL AND smf.is_sparse = 1) > 0 BEGIN SELECT 'Database_checks' AS [Category], 'DB_nonSnap_Sparse' AS [Information], DB_NAME(sd.database_id) AS database_name, smf.name AS [SparseFiles], smf.physical_name FROM sys.databases sd INNER JOIN sys.master_files smf ON sd.database_id = smf.database_id WHERE sd.source_database_id IS NULL AND smf.is_sparse = 1 AND DB_NAME(sd.database_id)=@TargetName END;"
        }
      }
    ],
    "TableIndexes": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT s.name+'.'+t.name AS TableName, COUNT(si.index_id) AS IndexCount, MIN(si.index_id) AS MinIndexId, MAX(si.index_id) AS MaxIndexId FROM sys.indexes AS si (NOLOCK) INNER JOIN sys.tables AS t (NOLOCK) ON si.[object_id]=t.[object_id] INNER JOIN sys.schemas AS s (NOLOCK) ON s.[schema_id]=t.[schema_id] WHERE si.is_hypothetical=0 GROUP BY s.name,t.name"
        }
      }
    ],
    "TableIndexesPartitioned": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT DISTINCT s.name+'.'+t.name AS TableName, i.name AS IndexName FROM sys.tables AS t (NOLOCK) INNER JOIN sys.indexes AS i (NOLOCK) ON t.[object_id]=i.[object_id] INNER JOIN sys.data_spaces AS ds (NOLOCK) ON ds.data_space_id=i.data_space_id INNER JOIN sys.schemas AS s (NOLOCK) ON s.[schema_id]=t.[schema_id] WHERE t.[type]='U' AND i.[type] IN (1,2) AND i.is_hypothetical=0 AND t.name IN(SELECT ob.name FROM sys.tables AS ob (NOLOCK) INNER JOIN sys.indexes AS ind (NOLOCK) ON ind.[object_id]=ob.[object_id] INNER JOIN sys.data_spaces AS sds (NOLOCK) ON sds.data_space_id=ind.data_space_id WHERE sds.[type]='PS' GROUP BY ob.name) AND ds.[type]<>'PS'"
        }
      }
    ],
    "NullPassword": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT RTRIM(name) AS [PasswordData] FROM master.sys.sql_logins WHERE [password_hash] IS NULL AND name NOT IN ('MSCRMSqlClrLogin','##MS_SmoExtendedSigningCertificate##','##MS_PolicySigningCertificate##','##MS_SQLResourceSigningCertificate##','##MS_SQLReplicationSigningCertificate##','##MS_SQLAuthenticatorCertificate##','##MS_AgentSigningCertificate##','##MS_SQLEnableSystemAssemblyLoadingUser##')",
          "transform": {
            "type": "aggregate",
            "map": {
              "PasswordData": "join"
            }
          }
        }
      }
    ],
    "NamePassword": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises, ManagedInstance",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT DISTINCT RTRIM(s.name) AS [PasswordData] FROM master.sys.sql_logins s WHERE PWDCOMPARE(RTRIM(RTRIM(s.name)), s.[password_hash]) = 1",
          "transform": {
            "type": "aggregate",
            "map": {
              "PasswordData": "join"
            }
          }
        }
      }
    ],
    "SystemHealth": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "IF EXISTS (SELECT [object_id] FROM tempdb.sys.objects (NOLOCK) WHERE [object_id]=OBJECT_ID('tempdb.dbo.#SystemHealthSessionData')) DROP TABLE #SystemHealthSessionData; IF NOT EXISTS (SELECT [object_id] FROM tempdb.sys.objects (NOLOCK) WHERE [object_id]=OBJECT_ID('tempdb.dbo.#SystemHealthSessionData')) CREATE TABLE #SystemHealthSessionData (target_data XML); INSERT INTO #SystemHealthSessionData SELECT CAST(xet.target_data AS XML) FROM sys.dm_xe_session_targets xet INNER JOIN sys.dm_xe_sessions xe ON xe.address=xet.event_session_address WHERE xe.name='system_health' IF (SELECT COUNT(*) FROM #SystemHealthSessionData a WHERE CONVERT(VARCHAR(max), target_data) LIKE '%error_reported%')>0 BEGIN ;WITH cteHealthSession (EventXML) AS (SELECT C.query('.') EventXML FROM #SystemHealthSessionData a CROSS APPLY a.target_data.nodes('/RingBufferTarget/event') AS T(C)),cteErrorReported (EventTime, ErrorNumber) AS (SELECT EventXML.value('(/event/@timestamp)[1]','datetime') AS EventTime,EventXML.value('(/event/data[@name=''error_number'']/value)[1]','int') AS ErrorNumber FROM cteHealthSession WHERE EventXML.value('(/event/@name)[1]','VARCHAR(500)')='error_reported') SELECT ErrorNumber AS [Error_Number], DATEDIFF(hour,MAX(EventTime),GETUTCDATE()) AS [Last_Logged_Days_Ago],COUNT(ErrorNumber) AS Error_Count FROM cteErrorReported a INNER JOIN sys.messages b ON a.ErrorNumber=b.message_id WHERE b.language_id=1033 GROUP BY a.ErrorNumber, b.[text] END"
        }
      }
    ],
    "CompatibilityLevel": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT compatibility_level as [CompatibilityLevel] FROM sys.databases where name=@TargetName"
        }
      }
    ],
    "PendingIORequests": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DECLARE @IOCnt INT SET @IOCnt=1 WHILE @IOCnt<5 BEGIN IF EXISTS(SELECT * FROM sys.dm_io_pending_io_requests WHERE io_type=@io_type) BREAK; WAITFOR DELAY '00:00:01' SET @IOCnt=@IOCnt+1 END; IF @IOCnt<5 SELECT 1"
        }
      }
    ],
    "DBMetaInfo": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DBCC DBINFO(@TargetName) WITH TABLERESULTS,NO_INFOMSGS",
          "transform": {
            "type": "dbInfo"
          }
        }
      }
    ],
    "StatSamplingRate": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT CONCAT( sh.[name], '.', o.[name] ) AS FullName, CAST(sp.rows_sampled/(sp.[rows]*1.00) AS DECIMAL(5,2)) AS stat_sampling_rate FROM sys.objects AS o INNER JOIN sys.tables AS mst ON mst.[object_id] = o.[object_id] INNER JOIN sys.stats AS ss ON ss.[object_id] = o.[object_id] INNER JOIN sys.schemas AS sh ON sh.[schema_id] = o.[schema_id] CROSS APPLY sys.dm_db_stats_properties(o.[object_id], ss.[stats_id]) AS sp WHERE sp.[rows] > 0 AND sp.rows_sampled/(sp.[rows]*1.00) < @threshold"
        }
      }
    ],
    "IndexStatistics": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,12.0)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT CASE si.type WHEN 0 THEN CONCAT(t.[name],'.',mst.[name],' (HEAP)') ELSE CONCAT(t.[name],'.',mst.[name],'.',si.name) END AS IndexFullName,index_stat.fragmentation,index_stat.page_count,si.type AS IndexType FROM sys.indexes si INNER JOIN sys.partitions sp ON si.[object_id]=sp.[object_id] AND si.index_id=sp.index_id INNER JOIN sys.tables AS mst ON mst.[object_id]=si.[object_id] INNER JOIN sys.schemas AS t ON t.[schema_id]=mst.[schema_id] LEFT JOIN (SELECT ps.database_id,ps.[object_id],ps.index_id,ps.partition_number,SUM(ps.avg_fragmentation_in_percent) AS fragmentation,SUM(ps.page_count) [page_count] FROM sys.dm_db_index_physical_stats(DB_ID(@TargetName),NULL,NULL,NULL,NULL) ps WHERE ps.index_level=0 AND ps.alloc_unit_type_desc='IN_ROW_DATA' GROUP BY ps.database_id,ps.[object_id],ps.index_id,ps.partition_number,ps.record_count,ps.forwarded_record_count) index_stat on index_stat.[object_id]=si.[object_id] AND index_stat.index_id=si.index_id AND index_stat.[partition_number]=sp.partition_number WHERE mst.is_ms_shipped=0 AND si.[type] IN (0,1,2)"
        }
      },
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[12.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT CASE si.type WHEN 0 THEN CONCAT(t.[name],'.',mst.[name],' (HEAP)') ELSE CONCAT(t.[name],'.',mst.[name],'.',si.name) END AS IndexFullName,ISNULL(index_stat.fragmentation,0) AS fragmentation, ISNULL(index_stat.page_count,0) AS page_count,index_stat_ci.fragmentation_CI,index_stat_ci.state,si.type AS IndexType FROM sys.indexes si INNER JOIN sys.partitions sp ON si.[object_id]=sp.[object_id] AND si.index_id=sp.index_id INNER JOIN sys.tables AS mst ON mst.[object_id]=si.[object_id] INNER JOIN sys.schemas AS t ON t.[schema_id]=mst.[schema_id] LEFT JOIN (SELECT ps.database_id,ps.[object_id],ps.index_id,ps.partition_number,SUM(ps.avg_fragmentation_in_percent) AS fragmentation,SUM(ps.page_count) [page_count] FROM sys.dm_db_index_physical_stats(DB_ID(@TargetName),NULL,NULL,NULL,NULL) ps WHERE ps.index_level=0 AND ps.alloc_unit_type_desc='IN_ROW_DATA' GROUP BY ps.database_id,ps.[object_id],ps.index_id,ps.partition_number,ps.record_count,ps.forwarded_record_count) index_stat on index_stat.[object_id]=si.[object_id] AND index_stat.index_id=si.index_id AND index_stat.[partition_number]=sp.partition_number LEFT JOIN (SELECT rg.object_id,rg.index_id,rg.partition_number,SUM((ISNULL(rg.deleted_rows,1)*100)/CASE WHEN rg.total_rows=0 THEN 1 ELSE rg.total_rows END) AS [fragmentation_CI],rg.[state] FROM sys.column_store_row_groups rg GROUP BY rg.object_id,rg.index_id,rg.partition_number,rg.total_rows,rg.delta_store_hobt_id,rg.row_group_id,rg.state) index_stat_ci on index_stat_ci.[object_id]=si.[object_id] AND index_stat_ci.index_id=si.index_id AND index_stat_ci.[partition_number]=sp.[partition_number] WHERE mst.is_ms_shipped=0 AND si.[type] IN (0,1,2,5,6,7)"
        }
      }
    ],
    "XTPIndexHashStatistics": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[12.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "IF NOT EXISTS(SELECT * FROM sys.filegroups where [type]='FX') RETURN; DECLARE @tmpXIS TABLE([object_id] int,[schema_name] VARCHAR(100) COLLATE database_default,[table_name] VARCHAR(300) COLLATE database_default,[index_id] int,[index_name] VARCHAR(300) COLLATE database_default,total_bucket_count bigint,empty_bucket_count bigint,avg_chain_length bigint,max_chain_length bigint, KeyCols VARCHAR(4000) COLLATE database_default,DistinctCnt bigint NULL,isdone bit) INSERT INTO @tmpXIS SELECT xis.[object_id],t.name,o.name,xis.index_id,si.name,xhis.total_bucket_count,xhis.empty_bucket_count,xhis.avg_chain_length,xhis.max_chain_length,SUBSTRING((SELECT ','+ac.name FROM sys.tables AS st INNER JOIN sys.indexes AS i ON st.[object_id]=i.[object_id] INNER JOIN sys.index_columns AS ic ON i.[object_id]=ic.[object_id] AND i.[index_id]=ic.[index_id] INNER JOIN sys.all_columns AS ac ON st.[object_id]=ac.[object_id] AND ic.[column_id]=ac.[column_id] WHERE si.[object_id]=i.[object_id] AND si.index_id=i.index_id AND ic.is_included_column=0 ORDER BY ic.key_ordinal FOR XML PATH('')),2,8000) AS KeyCols,NULL distinctCntOUT,0 FROM sys.dm_db_xtp_hash_index_stats AS xhis INNER JOIN sys.dm_db_xtp_index_stats AS xis ON xis.[object_id]=xhis.[object_id] AND xis.[index_id]=xhis.[index_id] INNER JOIN sys.indexes AS si (NOLOCK) ON xis.[object_id]=si.[object_id] AND xis.[index_id]=si.[index_id] INNER JOIN sys.objects AS o (NOLOCK) ON si.[object_id]=o.[object_id] INNER JOIN sys.tables AS mst (NOLOCK) ON mst.[object_id]=o.[object_id] INNER JOIN sys.schemas AS t (NOLOCK) ON t.[schema_id]=mst.[schema_id] WHERE o.[type]='U' DECLARE @objectid int,@indexid int,@sqlcmd NVARCHAR(4000),@params NVARCHAR(500),@schema_name VARCHAR(100),@table_name VARCHAR(300),@KeyCols VARCHAR(4000),@distinctCnt bigint IF EXISTS (SELECT TOP 1 [object_id] FROM @tmpXIS WHERE isdone=0) BEGIN WHILE (SELECT COUNT([object_id]) FROM @tmpXIS WHERE isdone=0)>0 BEGIN SELECT TOP 1 @objectid=[object_id],@indexid=[index_id],@schema_name=[schema_name],@table_name=[table_name],@KeyCols=KeyCols FROM @tmpXIS WHERE isdone=0 SELECT @sqlcmd='SELECT @distinctCntOUT=COUNT(*) FROM (SELECT DISTINCT '+@KeyCols+' FROM '+@schema_name+'.'+@table_name+') t1;' EXECUTE sp_executesql @sqlcmd,N'@distinctCntOUT bigint OUTPUT',@distinctCntOUT=@distinctCnt OUTPUT UPDATE @tmpXIS SET DistinctCnt=@distinctCnt,isdone=1 WHERE [object_id]=@objectid AND [index_id]=@indexid; END; END; SELECT CONCAT([schema_name],'.',table_name,'.',index_name) AS IndexFullName,FLOOR((CAST(empty_bucket_count AS FLOAT)/total_bucket_count)*100) EmptyBucketPct,total_bucket_count,avg_chain_length,DistinctCnt FROM @tmpXIS"
        }
      }
    ],
    "XTPNonClusteredIndexHashStatistics": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[12.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT DISTINCT CONCAT(t.name,'.',o.name,'.',si.name) AS IndexFullName,FLOOR((CAST(page_update_retry_count AS FLOAT)/CASE WHEN page_update_count=0 THEN 1 ELSE page_update_count END)*100) AS page_update_count_pct,FLOOR((CAST(page_consolidation_retry_count AS FLOAT)/CASE WHEN page_consolidation_count=0 THEN 1 ELSE page_consolidation_count END)*100) AS page_consolidation_count_pct,FLOOR((CAST(page_split_retry_count AS FLOAT)/CASE WHEN page_split_count=0 THEN 1 ELSE page_split_count END)*100) AS page_split_count_pct,FLOOR((CAST(key_split_retry_count AS FLOAT)/CASE WHEN key_split_count=0 THEN 1 ELSE key_split_count END)*100) AS key_split_count_pct,FLOOR((CAST(page_merge_retry_count AS FLOAT)/CASE WHEN page_merge_count=0 THEN 1 ELSE page_merge_count END)*100) AS page_merge_count_pct,FLOOR((CAST(key_merge_retry_count AS FLOAT)/CASE WHEN key_merge_count=0 THEN 1 ELSE key_merge_count END)*100) AS key_merge_count_pct FROM sys.dm_db_xtp_nonclustered_index_stats AS xnis (NOLOCK) INNER JOIN sys.dm_db_xtp_index_stats AS xis (NOLOCK) ON xis.[object_id]=xnis.[object_id] AND xis.[index_id]=xnis.[index_id] INNER JOIN sys.indexes AS si (NOLOCK) ON xis.[object_id]=si.[object_id] AND xis.[index_id]=si.[index_id] INNER JOIN sys.objects AS o (NOLOCK) ON si.[object_id]=o.[object_id] INNER JOIN sys.tables AS mst (NOLOCK) ON mst.[object_id]=o.[object_id] INNER JOIN sys.schemas AS t (NOLOCK) ON t.[schema_id]=mst.[schema_id] WHERE o.[type]='U'"
        }
      }
    ],
    "CpuUsage": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "DECLARE @ts_now bigint;SELECT @ts_now=ms_ticks FROM sys.dm_os_sys_info (NOLOCK);SELECT 100-ISNULL(SystemIdle,0) AS AVGTotalCPUUsage,AVGSQLCPUUsage,100-ISNULL(SystemIdle,0)-AVGSQLCPUUsage AS AVGCPUUsageByOther FROM(SELECT AVG(SystemIdle) AS SystemIdle,AVG(SQLProcessUtilization) AS AVGSQLCPUUsage FROM(SELECT record.value('(./Record/SchedulerMonitorEvent/SystemHealth/SystemIdle)[1]','int') AS SystemIdle,record.value('(./Record/SchedulerMonitorEvent/SystemHealth/ProcessUtilization)[1]','int') AS SQLProcessUtilization,[TIMESTAMP] FROM (SELECT [TIMESTAMP],CONVERT(xml,record) AS record FROM sys.dm_os_ring_buffers (NOLOCK) WHERE ring_buffer_type=N'RING_BUFFER_SCHEDULER_MONITOR' AND record LIKE '%<SystemHealth>%' AND @ts_now-[TIMESTAMP]<=7200000) AS xrb ) AS si) AS a"
        }
      }
    ],
    "TF6533SpatialFunctionsUsage": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT DISTINCT 1 AS InUse FROM sys.sql_modules (NOLOCK) WHERE OBJECTPROPERTY([object_id],'IsMSShipped')=0 AND (PATINDEX('%.strelate(%',LOWER([definition]) COLLATE DATABASE_DEFAULT)>1 OR PATINDEX('%.stasbinary(%',LOWER([definition]) COLLATE DATABASE_DEFAULT)>1)",
          "transform": {
            "type": "noData",
            "define": {
              "InUse": 0
            }
          }
        }
      }
    ],
    "FKNotTrusted": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT CONCAT(QUOTENAME(t.name),'.',QUOTENAME(mst.name),'.',QUOTENAME(FKC.name)) AS [constraint_name] FROM sys.foreign_keys FKC (NOLOCK) INNER JOIN sys.objects o (NOLOCK) ON FKC.parent_object_id=o.[object_id] INNER JOIN sys.tables mst (NOLOCK) ON mst.[object_id]=o.[object_id] INNER JOIN sys.schemas t (NOLOCK) ON t.[schema_id]=mst.[schema_id] WHERE o.type='U' AND FKC.is_not_trusted=1 AND FKC.is_not_for_replication=0 GROUP BY o.[schema_id],mst.[object_id],FKC.name,t.name,mst.name UNION ALL SELECT CONCAT(QUOTENAME(t.name),'.',QUOTENAME(mst.name),'.',QUOTENAME(CC.name)) FROM sys.check_constraints CC (NOLOCK) INNER JOIN sys.objects o (NOLOCK) ON CC.parent_object_id=o.[object_id] INNER JOIN sys.tables mst (NOLOCK) ON mst.[object_id]=o.[object_id] INNER JOIN sys.schemas t (NOLOCK) ON t.[schema_id]=mst.[schema_id] WHERE o.type='U' AND CC.is_not_trusted=1 AND CC.is_not_for_replication=0 AND CC.is_disabled=0 GROUP BY t.[schema_id],mst.[object_id],CC.name,t.name,mst.name",
          "transform": {
            "type": "aggregate",
            "map": {
              "constraint_name": "join"
            }
          }
        }
      }
    ],
    "ObjectStatistics": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0.3000,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT DISTINCT CONCAT(t.name,'.',OBJECT_NAME(mst.[object_id])) AS [TableName],ss.name AS [StatName],sp.[rows],sp.modification_counter,sp.rows_sampled FROM sys.objects AS o INNER JOIN sys.tables AS mst ON mst.[object_id]=o.[object_id] INNER JOIN sys.schemas AS t ON t.[schema_id]=mst.[schema_id] INNER JOIN sys.stats AS ss ON ss.[object_id]=mst.[object_id] CROSS APPLY sys.dm_db_stats_properties(ss.[object_id],ss.[stats_id]) AS sp WHERE sp.[rows]>0"
        }
      },
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0, 11.0.3000)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT DISTINCT CONCAT(t.name,'.',OBJECT_NAME(mst.[object_id])) AS [TableName],ss.name AS [StatName],SUM(p.[rows]) AS [rows],si.rowmodctr AS modification_counter,0 AS rows_sampled AS FROM sys.sysindexes AS si INNER JOIN sys.objects AS o ON si.id=o.[object_id] INNER JOIN sys.tables AS mst ON mst.[object_id]=o.[object_id] INNER JOIN sys.schemas AS t ON t.[schema_id]=mst.[schema_id] INNER JOIN sys.stats AS ss ON ss.[object_id]=o.[object_id] INNER JOIN sys.partitions AS p ON p.[object_id]=ss.[object_id] LEFT JOIN sys.indexes i ON si.id=i.[object_id] AND si.indid=i.index_id WHERE o.type<>'S' AND i.name IS NOT NULL GROUP BY mst.[object_id],t.name,rowmodctr,ss.name HAVING SUM(p.[rows])>0"
        }
      }
    ],
    "AzVmProps": [
      {
        "type": "Kusto",
        "target": {
          "type": "Server",
          "machineType": "AzureSQL"
        },
        "implementation": {
          "query": "Resources | where id =~ @resId | project vmSize = properties.hardwareProfile.vmSize"
        }
      }
    ],
    "DiskFragmentationAnalysis": [
      {
        "type": "WMI",
        "target": {
          "type": "Server",
          "platform": "Windows",
          "engineEdition": "OnPremises",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT DeviceID, Name FROM Win32_Volume WHERE DriveType=3 AND Name LIKE '_:\\\\'",
          "methods": {
            "da": "DefragAnalysis"
          }
        }
      }
    ],
    "ErrorLogInfo": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises",
          "version": "[11.0,)"
        },
        "requires": {
          "object permission on xp_enumerrorlogs": [
            "EXECUTE"
          ]
        },
        "implementation": {
          "query": "EXEC xp_enumerrorlogs",
          "transform": {
            "type": "rename",
            "map": {
              "id": "Archive #",
              "size": "Log File Size (Byte)",
              "date": "Date"
            }
          }
        }
      }
    ],
    "FullTextServiceInfo": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT ISNULL(FULLTEXTSERVICEPROPERTY('IsFulltextInstalled'), 0) AS [IsFulltextInstalled] ,FULLTEXTSERVICEPROPERTY('VerifySignature') AS [VerifySignature] ,FULLTEXTSERVICEPROPERTY('LoadOSResources') AS [LoadOSResources];"
        }
      }
    ],
    "IsClusteredServer": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT SERVERPROPERTY('IsClustered') AS is_clustered_server"
        }
      }
    ],
    "MisalignedDiskPartition": [
      {
        "type": "WMI",
        "target": {
          "type": "Server",
          "platform": "Windows",
          "engineEdition": "OnPremises",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT Name, StartingOffset FROM Win32_DiskPartition WHERE StartingOffset < $threshold"
        }
      }
    ],
    "NtfsBlockSize": [
      {
        "type": "WMI",
        "target": {
          "type": "Server",
          "platform": "Windows",
          "engineEdition": "OnPremises",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT name, blocksize FROM Win32_Volume WHERE Capacity <> NULL"
        }
      }
    ],
    "OsSysMemory": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT * FROM sys.dm_os_sys_memory(NOLOCK)"
        }
      }
    ],
    "PageFileManagement": [
      {
        "type": "Registry",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": "Windows",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": {
            "HKEY_LOCAL_MACHINE": {
              "System\\CurrentControlSet\\Control\\Session Manager\\Memory Management": [
                "PagingFiles"
              ]
            }
          }
        }
      }
    ],
    "PowerPlan": [
      {
        "type": "Registry",
        "target": {
          "type": "Server",
          "platform": "Windows",
          "engineEdition": "OnPremises",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": {
            "HKEY_LOCAL_MACHINE": {
              "SOFTWARE\\Policies\\Microsoft\\Power\\PowerSettings": [
                "ActivePowerScheme"
              ],
              "SYSTEM\\CurrentControlSet\\Control\\Power\\User\\PowerSchemes": [
                "ActivePowerScheme"
              ]
            }
          }
        }
      }
    ],
    "ProcessBlockingChains": [
      {
        "type": "SQL",
        "target": {
          "type": "Database",
          "version": "[11.0,)",
          "platform": [
            "Windows",
            "Linux"
          ],
          "engineEdition": "OnPremises"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT es.[session_id] AS [blocked_spid], es.[status] AS [blocked_spid_status], ot.task_state AS [blocked_task_status], COALESCE ( owt.wait_duration_ms, ABS(CONVERT(BIGINT,(DATEDIFF(ms, es.last_request_start_time, GETDATE())))) ) / 60000 AS [block_time_min] FROM sys.dm_exec_sessions es LEFT OUTER JOIN sys.dm_exec_requests er ON es.session_id = er.session_id LEFT OUTER JOIN sys.dm_exec_connections ec ON es.session_id = ec.session_id LEFT OUTER JOIN sys.dm_os_waiting_tasks wt ON es.session_id = wt.session_id LEFT OUTER JOIN sys.dm_os_tasks ot ON er.session_id = ot.session_id AND er.request_id = ot.request_id LEFT OUTER JOIN ( SELECT waiting_task_address, wait_duration_ms, ROW_NUMBER() OVER (PARTITION BY waiting_task_address ORDER BY wait_duration_ms DESC) AS row_num FROM sys.dm_os_waiting_tasks WHERE wait_type <> 'SP_SERVER_DIAGNOSTICS_SLEEP' ) owt ON ot.task_address = owt.waiting_task_address AND owt.row_num = 1 OUTER APPLY sys.dm_exec_sql_text(COALESCE(er.sql_handle, ec.most_recent_sql_handle)) AS query WHERE CONVERT(VARCHAR(max), query.text) not like '%sp_server_diagnostics%' AND (es.session_id <> @@SPID AND es.is_user_process = 1) AND (es.session_id IN (SELECT er3.blocking_session_id FROM sys.dm_exec_requests er3) OR er.blocking_session_id IS NOT NULL) AND ((owt.wait_duration_ms/1000) > @waitThreshold OR (er.total_elapsed_time/1000) > @waitThreshold OR er.total_elapsed_time IS NULL) AND er.database_id = DB_ID(@TargetName)"
        }
      }
    ],
    "ReplicationInfo": [
      {
        "type": "Registry",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": "Windows",
          "version": "[11.0,)"
        },
        "implementation": {
          "instance": true,
          "query": {
            "HKEY_LOCAL_MACHINE": {
              "SOFTWARE\\Microsoft\\MSSQLServer\\Replication": [
                "IsInstalled"
              ]
            }
          }
        }
      }
    ],
    "ServerBIOSInfo": [
      {
        "type": "Registry",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": "Windows",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": {
            "HKEY_LOCAL_MACHINE": {
              "HARDWARE\\DESCRIPTION\\System\\BIOS": [
                "BIOSVendor"
              ]
            }
          }
        }
      }
    ],
    "ServerCPUInfo": [
      {
        "type": "Registry",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": "Windows",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": {
            "HKEY_LOCAL_MACHINE": {
              "HARDWARE\\DESCRIPTION\\System\\CentralProcessor\\*": [
                "ProcessorNameString"
              ]
            }
          },
          "transform": {
            "type": "rename",
            "map": {
              "CPUid": "RegistryKeyName"
            }
          }
        }
      }
    ],
    "ServiceControl": [
      {
        "type": "PowerShell",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": "Windows",
          "version": "[11.0,)"
        },
        "implementation": {
          "command": "Get-Service -Name $ServiceName | Select-Object -Property Status, Name"
        }
      }
    ],
    "SysConfiguration": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "useDatabase": true,
          "query": "SELECT [name], [value] FROM sys.configurations",
          "transform": [
            {
              "type": "nameValuePairs",
              "keyColumn": "name",
              "valueColumn": "value",
              "map": {
                "allow updates": "allow_updates",
                "Ad Hoc Distributed Queries": "ad_hoc_distributed_queries",
                "affinity mask": "affinity_mask",
                "affinity I/O mask": "affinity_io_mask",
                "affinity64 mask": "affinity64_mask",
                "affinity64 I/O mask": "affinity64_io_mask",
                "automatic soft-NUMA disabled": "automatic_soft_NUMA_disabled",
                "backup compression default": "backup_compression",
                "blocked process threshold (s)": "block_threshold",
                "clr enabled": "clr_enabled",
                "cost threshold for parallelism": "cost_threshold_for_parallelism",
                "cross db ownership chaining": "cross_db_ownership_chaining",
                "default trace enabled": "default_trace_enabled",
                "index create memory (KB)": "index_create_memory",
                "lightweight pooling": "lightweight_pooling",
                "locks": "locks",
                "max worker threads": "max_worker_threads",
                "max degree of parallelism": "max_dop",
                "max server memory (MB)": "max_server_memory",
                "min memory per query (KB)": "min_memory_per_query",
                "min server memory (MB)": "min_server_memory",
                "network packet size (B)": "network_packet_size",
                "Ole Automation Procedures": "ole_automation_procedures",
                "optimize for ad hoc workloads": "optimize_for_ad_hoc_workloads",
                "priority boost": "priority_boost",
                "query wait (s)": "query_wait",
                "recovery interval (min)": "recovery_interval",
                "remote admin connections": "remote_admin_connections",
                "remote query timeout (s)": "remote_query_timeout",
                "scan for startup procs": "startup_stored_procedures",
                "xp_cmdshell": "xp_cmdshell"
              }
            },
            {
              "type": "defaultValue",
              "map": {
                "automatic_soft_NUMA_disabled": 0
              }
            }
          ]
        }
      }
    ],
    "SysDmOsHostInfo": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": "Windows",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT N'Windows' AS [host_platform] ,CASE WHEN [windows_release] IN ( '6.3' ,'10.0' ) AND ( @@VERSION LIKE N'%Build 10586%' OR @@VERSION LIKE N'%Build 14393%' ) THEN N'10.0' ELSE [windows_release] END AS [host_release] ,CASE WHEN @@VERSION LIKE '%<X64>%' THEN 64 ELSE 32 END AS [host_architecture] FROM sys.dm_os_windows_info(NOLOCK)",
          "transform": {
            "type": "parse",
            "map": {
              "host_release": "/^(?<major>\\d+)\\.(?<minor>\\d+)(?:\\.(?<build>\\d+))?(?:\\.(?<revision>\\d+))?$/x"
            }
          }
        }
      },
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": "Linux",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT [host_platform] AS [host_platform] ,[host_release] AS [host_release] ,64 AS [host_architecture] FROM sys.dm_os_host_info(NOLOCK)",
          "transform": {
            "type": "parse",
            "map": {
              "host_release": "/^(?<major>\\d+)\\.(?<minor>\\d+)(?:\\.(?<build>\\d+))?(?:\\.(?<revision>\\d+))?$/x"
            }
          }
        }
      }
    ],
    "SysDmOsProcessMemory": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT locked_page_allocations_kb FROM sys.dm_os_process_memory (NOLOCK)"
        }
      }
    ],
    "SysDmOsSysInfo": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises, ManagedInstance",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT max_workers_count, virtual_machine_type FROM sys.dm_os_sys_info (NOLOCK)"
        }
      }
    ],
    "Win32Volume": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "platform": "Windows",
          "engineEdition": "OnPremises",
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT DISTINCT CASE WHEN LEFT(physical_name, 1)= '\\' THEN LEFT(physical_name, charindex('\\',physical_name,5)) ELSE LEFT(physical_name,3) END AS [masterFilesVolumeName] FROM sys.master_files WHERE [database_id] <> 32767;"
        }
      }
    ],
    "WorkerThreads": [
      {
        "type": "SQL",
        "target": {
          "type": "Server",
          "engineEdition": "OnPremises",
          "platform": [
            "Windows",
            "Linux"
          ],
          "version": "[11.0,)"
        },
        "implementation": {
          "query": "SELECT (SUM(runnable_tasks_count) / COUNT(scheduler_id)) AS [overall_runnable_tasks_count], SUM(work_queue_count) AS [schedulers_work_queue_count] FROM sys.dm_os_schedulers WHERE parent_node_id < 64 AND scheduler_id < 255"
        }
      }
    ]
  }
}��d���l�P��^_;k۔��Wn��ȟ�>0��J��󲘖������)�W���_�I�-��>+�uI�f�Ю~7���ˆ��q���
b�Uʃۭ�]m\{$��H�b�6N$Px�*�˚�&�����MP}���
'!!�
RSDSD�{��I�Vm2�*C:\agent-release\_work\10\s\Engine\Std\obj\Release\netstandard2.0\Microsoft.SqlServer.Assessment.pdbSHA256D�{����Vm2�*����Yl~�K�8�Mp� |_CorDllMainmscoree.dll�% 0abfnrtv`#'"

	`#'"�0�HX ||4VS_VERSION_INFO��11?DVarFileInfo$Translation��StringFileInfo�000004b0LCompanyNameMicrosoft Corporationh FileDescriptionMicrosoft SQL Assessment Engine2	FileVersion1.0.49.0f#InternalNameMicrosoft.SqlServer.Assessment.dlld LegalCopyrightMicrosoft. All rights reserved.�ILegalTrademarksMicrosoft SQL Server is a registered trademark of Microsoft Corporation.n#OriginalFilenameMicrosoft.SqlServer.Assessment.dllJProductNameMicrosoft SQL Server6	ProductVersion1.0.49.0<
Assembly Version1.100.0.0�5�#0�#r	*�H��
��#c0�#_10
	`�He0\
+�7�N0L0
+�70	���010
	`�He 9����_ჭ�T׍%Q�_dr8n!��-����
�0��0��3�k�.��J���0
	*�H��
0~10	UUS10U
Washington10URedmond10U
Microsoft Corporation1(0&UMicrosoft Code Signing PCA 20110
201215213145Z
211202213145Z0t10	UUS10U
Washington10URedmond10U
Microsoft Corporation10UMicrosoft Corporation0�"0
	*�H��
�0�
���Y����\��ۚ#��X�x�H�$8�c��K��	�P�'�����C���8�?̐'���1
�{b�u��H��]u���u�#����cp>5�Ԗb�vU�Vԯ�c�����z�*w���t��G�ݠ1-�%,��@fSג��R�
��uV�IS�t����8鎥���zo�|�/��uGp�?�b��EH/��Lo>�7�8�S�5��9Y�����6f�T��'��Y7!�	������FTR@����~0�z0U%0
+�7L+0U8��/��ѭ	�&T�o#�Y��0PUI0G�E0C1)0'U Microsoft Operations Puerto Rico10U
230012+4630090U#0�Hnd�Pӂ�77"�m��u�0TUM0K0I�G�E�Chttp://www.microsoft.com/pkiops/crl/MicCodSigPCA2011_2011-07-08.crl0a+U0S0Q+0�Ehttp://www.microsoft.com/pkiops/certs/MicCodSigPCA2011_2011-07-08.crt0U�00
	*�H��
��z��<�PV�K�+G���ᠿyI�.��g�]C�PG������W�q�@y��т�0��f���=�XC�t����G��]�DF��DLYwh�x*�hc����L��h�6=z1S��B�"���!
�E�����7����L�A��,&�$��*��j�,�e�0�"|�a�ܛ�5f�RT�q�L���G
d��<Hbx�o]l�4@���
3#֋^��YE9�"���ol,�4j
܆��3����標R-	�\% r�KGcAq$�ԫ��!��dߩBW��֐�(��5 �g���s��v�z�H�6���;
&�%x;�8��˩��ۣ2��&���mU(|���J��Yr'���aqi�X8���`���5�}��l�i�dž�~�	=���w�H��=�ηҫ�!t��R�����&}IǴj�ɁC.t�>-��Z�E��tmJ��Fӛ
��0�n�b*�� S=�#B��������6���bf&!D�m��K�a��돒I��Bh\0�z0�b�
a��0
	*�H��
0��10	UUS10U
Washington10URedmond10U
Microsoft Corporation1200U)Microsoft Root Certificate Authority 20110
110708205909Z
260708210909Z0~10	UUS10U
Washington10URedmond10U
Microsoft Corporation1(0&UMicrosoft Code Signing PCA 20110�"0
	*�H��
�0�
���r.��n��M4��X!�B*k�ZP��8I���7k���8™��9�1BӉ
yd�~�`$l��I��h^�ߛS�
,ï٩+�z	�זY�`�fv�2R&/�PϳD�]��.u�h��m�:\��F��8d�nd5x��c-�@����
�\y�I)�
��w��=��+ZMV(�zr�:�I^���C���{�{��>��]�O��/Y�;-�3Xŷ>�2ӳ=����8~ҝ�,�NV�!5%�9ndS���#������_��R������!t%_(��'(8%�9J6�|���#��f�aj�(I�_��%]�!K>RĵW?$��z[/�#�p]QFw��Ἤ�_����UK�9��#I��D|E��rz�r�$߿F����Wۃ��MI0�����[���ݰf��{���K�I)�(��}g��bx_�/��W�\�w((��m�(�,�@7O��D��	L�ԥC/t��n�x X,]`��>O3�ڰ�ޞN�F�l���ֈ����0��0	+�70UHnd�Pӂ�77"�m��u�0	+�7
SubCA0U�0U�0�0U#0�r-:1�C�N���1�#�40ZUS0Q0O�M�K�Ihttp://crl.microsoft.com/pki/crl/products/MicRooCerAut2011_2011_03_22.crl0^+R0P0N+0�Bhttp://www.microsoft.com/pki/certs/MicRooCerAut2011_2011_03_22.crt0��U ��0��0��	+�7.0��0?+3http://www.microsoft.com/pkiops/docs/primarycps.htm0@+042 Legal_policy_statement. 0
	*�H��
�g򆥘�Ty.��tg"���c��B�}�y��e_.,>��r�m���?�
�;�G���i�c�"5��]e��}�FPU��|�K�<B�Rа�k�>.)��=�Եw�9��d�D=xz#�}��t����&F*Š�����h�h.��*?*kXIc	inZ�����F+�;н5�n%��'������(��M=����2���-�[��I9
�
�ƭ�����QEX82q'��'��,: i��Y�hno��t�@�*(>�?Mf��M��o}E�v�@*e��]Rb��c6��������'�ͥ���]cA�[��>w��u�aa������A�(��e/��\��֡F�Y�	KH���)ű��?Ew5�Ң��zz"�H���G#�����k�K���ux��7�yK�ֳ#hu������i;��0�L���umc�=ѝVNO��W"�x2!z�A
�?��̤]����WqVNHE�Bɛv[
�Hk�y���mmj�Rs
zP�1�d0�`0��0~10	UUS10U
Washington10URedmond10U
Microsoft Corporation1(0&UMicrosoft Code Signing PCA 20113�k�.��J���0
	`�He���0	*�H��
	1
+�70
+�710
+�70/	*�H��
	1" J{�����K�^UyN[XD�Lr4��}O��y�0B
+�71402��Microsoft��http://www.microsoft.com0
	*�H��
�2�P0�D*�H#���[��Ky��ϣ@����B]�(!����bY�oU��>�y.��Ӟ����|ze������:՜�,%����'�	ٕ�]�[$��&��W<W�M��9Y��0.�k�r����^�CKL�h[d��(1ۈ<,��;��ݗ	
�e�h�c���ܙ���Z��ӂ�a4@��I6>K:�h�����S�2��ɽ~j��D�a������}=�;k�2U��� �I%�h�sL݀��9r���0��
+�71��0��	*�H��
���0��10
	`�He0�U*�H��
	��D�@0�<
+�Y
010
	`�He �.b@�*X������
����aŠ3Y�=`=9��20210310123547.793Z0��Ԥ��0��10	UUS10U
Washington10URedmond10U
Microsoft Corporation1)0'U Microsoft Operations Puerto Rico1&0$UThales TSS ESN:897A-E356-17011%0#UMicrosoft Time-Stamp Service��A0��0�ݠ3` �Hھ�`0
	*�H��
0|10	UUS10U
Washington10URedmond10U
Microsoft Corporation1&0$UMicrosoft Time-Stamp PCA 20100
210114190220Z
220411190220Z0��10	UUS10U
Washington10URedmond10U
Microsoft Corporation1)0'U Microsoft Operations Puerto Rico1&0$UThales TSS ESN:897A-E356-17011%0#UMicrosoft Time-Stamp Service0�"0
	*�H��
�0�
��1������R3>	��5�Zͤ�-BeL��ċ̵�ן+e���^���O�D��%^��V��,����!��Q��#�ˋ<ժ�T�s�L�m2�n�;r�*a�����*t8��@�4t��&��
`!�Hia�/����mK"�yP|0̑I���b�4�k�h�]	L�����`2Dk\��\��;q����F�mƯ�ɂL����8��F����o�꛿5���3�䃍�����ӽV��ƍs�P��A��8���0�0U�������u2	u|��c0U#0��c:\�1��C{|F�3hZ�mU0VUO0M0K�I�G�Ehttp://crl.microsoft.com/pki/crl/products/MicTimStaPCA_2010-07-01.crl0Z+N0L0J+0�>http://www.microsoft.com/pki/certs/MicTimStaPCA_2010-07-01.crt0U�00U%0
+0
	*�H��
�4��:��PuO'a��$�(C��ڠ�����>]U~���)�A�8c�6"cN"܍ck�7��q����p����+�ϕo[��-������&��&n�KD���#�7�J�?�.m�'���[cJ�[��݀�������""f�>mˉ���)�g�-�kX3�_	�*�c��?���&��Πn���
`1���o��S��w�q��4���7���O5Tf&���_	�F�L$m�i҃sDL����0�q0�Y�
a	�*0
	*�H��
0��10	UUS10U
Washington10URedmond10U
Microsoft Corporation1200U)Microsoft Root Certificate Authority 20100
100701213655Z
250701214655Z0|10	UUS10U
Washington10URedmond10U
Microsoft Corporation1&0$UMicrosoft Time-Stamp PCA 20100�"0
	*�H��
�0�
��
�w�: ����i�ktTե
����|hK,_���a�v�>f+[�S'1A��	�|a0Y�0D�`��TC�M�8�Bݓ��s0W&��E
��G�Ϳ$`2X`F�XG�2�tag�_�T�ϓL��Ħ]�an(������a�F�'$gr!��Kd�Pb�]�w=�Wu���BM@Q��>g�f��D~��K�n�ʱ��z*
1��N���5�x���<�/D����d��� 	�x����D]^�O"M���0��0	+�70U�c:\�1��C{|F�3hZ�mU0	+�7
SubCA0U�0U�0�0U#0��Vˏ�\bh�=��[�Κ�0VUO0M0K�I�G�Ehttp://crl.microsoft.com/pki/crl/products/MicRooCerAut_2010-06-23.crl0Z+N0L0J+0�>http://www.microsoft.com/pki/certs/MicRooCerAut_2010-06-23.crt0��U ���0��0��	+�7.0��0=+1http://www.microsoft.com/PKI/docs/CPS/default.htm0@+042 Legal_Policy_Statement. 0
	*�H��
��Q
���?�q=���!o���1����Wm0���f�j���x�Ǩ�%��kTW+Q�D��S���`�v�@@A��\�\�^5�$VKt�Bȯ���7}Z?�yJ�R�8�/y�e٩�k����zoK0D$"<�����Y)����p�2J'�U�/���3�b_��W@��Ιf���jb��J�&�9�Jqc�{!mÜ��<�}�j�x�m���8ؔ�ƥ
������B�����"8 �%�d��~cY%z.9Wv�q����a�˚�G����ͧ��}���;q	�]t�"aڰPo�����1��:�eGx�H���r~akow��˧	�9����؂�r�����*T9�[��
U�z�s;�-��3.)��/T'!�ȬN�(���ۖ��B���AM�*��f0ӻt2K�c{���/�!�Y���D<�Pqס��U�i�W���0����M�
�]O�8/��X.�
�P5��	'ճ~5��6��_��t�I���0�80����Ԥ��0��10	UUS10U
Washington10URedmond10U
Microsoft Corporation1)0'U Microsoft Operations Puerto Rico1&0$UThales TSS ESN:897A-E356-17011%0#UMicrosoft Time-Stamp Service�#
0+�2�tu�D�ȗ*�Wـ��Т���0���~0|10	UUS10U
Washington10URedmond10U
Microsoft Corporation1&0$UMicrosoft Time-Stamp PCA 20100
	*�H��
��g0"20210310070719Z20210311070719Z0t0:
+�Y
1,0*0
��g0
�0�0
���06
+�Y
1(0&0
+�Y
�
0� �
0��0
	*�H��
��.��J9�6*��AC��A��0Q�핡�n��D$�h�d��h�����~"���;���J�"��m�<�L�Nښ�^]�wRO2m_rޱ�@�c�Z�dx]�ݟ�
���V ���M�1�
0�	0��0|10	UUS10U
Washington10URedmond10U
Microsoft Corporation1&0$UMicrosoft Time-Stamp PCA 20103` �Hھ�`0
	`�He��J0	*�H��
	1
*�H��
	0/	*�H��
	1" z�3�:Ћ��?F]�SL��KM[�T��0��*�H��
	/1��0��0��0�� ���s.�[E���+�~���\	�^H���e�0��0���~0|10	UUS10U
Washington10URedmond10U
Microsoft Corporation1&0$UMicrosoft Time-Stamp PCA 20103` �Hھ�`0" �g^s_��:�m�$C[:�"8杪��ľ��&F0
	*�H��
�w[���P�(�}W�Zm~�L�l�?-3s�{���xR�<�D��U���<�X��gP4��v��iY~�-��LjC��P��R'pz�%F�$��:�v#���nj8�R�?o'nG�$_t��x��8?���‰��~�p�5ic%?I>��n��jf�͠tT<�����\In����(��D���0��#��S��Z�3؝
-�si��O����R#�'�k��BQ�yp55��y�@��^���B��Nť%-�j�/w$ۖʦ�