GeneralCatalog
5.0.14
OTRS AG
http://otrs.org/
GNU AFFERO GENERAL PUBLIC LICENSE Version 3, November 2007
Build for OTRS::ITSM 5 patch level 14.
Build for OTRS::ITSM 5 patch level 13.
Build for OTRS::ITSM 5 patch level 12.
Build for OTRS::ITSM 5 patch level 11.
Build for OTRS::ITSM 5 patch level 10.
Build for OTRS::ITSM 5 patch level 9.
Build for OTRS::ITSM 5 patch level 8.
Build for OTRS::ITSM 5 patch level 7.
Build for OTRS::ITSM 5 patch level 6.
Build for OTRS::ITSM 5 patch level 4.
Build for OTRS::ITSM 5 patch level 4.
Build for OTRS::ITSM 5 patch level 3.
Build for OTRS::ITSM 5 patch level 2.
Build for OTRS::ITSM 5.
Build for OTRS::ITSM 5 rc1.
Build for OTRS::ITSM 5 beta3.
Build for OTRS::ITSM 5 beta2.
Build for OTRS::ITSM 5 beta1.
The General Catalog package.
Das General Catalog Paket.
El paquete General Catalog.
Az általános katalógus csomag.
5.0.x
<br/>
<strong>ATTENTION</strong>
<br/>
<br/>
If you uninstall this package, all database tables that were created during installation will be deleted.
All data from this table will be irrevocably lost.
<br/>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>ACHTUNG</strong>
<br/>
<br/>
Bei der Deinstallation werden die von diesem Paket angelegten Datenbank-Tabellen gelöscht.
Alle darin enthaltenen Daten gehen unwiderruflich verloren!
<br/>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>ATENCIÓN</strong>
<br/>
<br/>
Si usted desinstala este paquete, todas las tablas de la base de datos creadas durante la instalación serán borradas.
¡Todos los datos de esas tablas serán irrevocablemente perdidos!.
<br/>
<br/>
((enjoy))<br/>
<br/>
<br/>
<strong>FIGYELEM</strong>
<br/>
<br/>
Ha eltávolítja ezt a csomagot, akkor a telepítés során létrehozott összes adatbázistábla törlésre kerül.
Az ezekben a táblákban lévő összes adat visszavonhatatlanul el fog veszni!
<br/>
<br/>
((enjoy))<br/>
<br/>
# create the package name
my $CodeModule = 'var::packagesetup::' . $Param{Structure}->{Name}->{Content};
# discard internally stored object, so that the next access to object creates them newly
$Kernel::OM->ObjectsDiscard(
Objects => [$CodeModule],
ForcePackageReload => 1,
);
$Kernel::OM->Get($CodeModule)->CodeUpgrade();
# create the package name
my $CodeModule = 'var::packagesetup::' . $Param{Structure}->{Name}->{Content};
$Kernel::OM->Get($CodeModule)->CodeUpgradeFromLowerThan_4_0_91();
2016-10-26 20:17:32
opms.otrs.com
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AOBPYrFYSUlJPB5Og7b8CACILPPXGGq+973vZf4LAL1SUVFRUVER1ujl5eUhplcAMMhOl2u306XOUy1aH1Da2tpeffXVd955p76+/sSJE8OHD6+srDznnHMuueSS7GUI8n/bvve973U6uKSkZMyYMbNnz7788su7fkBMJpPV1dVvvPHGgQMHWltbhw0bVllZedZZZ33oQx+aOHFib8/l7rvvPnLkSP4F5zjMTyoADHmVlZVhlwBAJJw4caK6unr79u319fXHjx8fNmzYuHHj5syZc/HFFw8fPjzs6k65jo6O119//Z133qmrq2tpaSkuLh47duycOXMWLlw4YsSIsKsrXBHKj3bt2vX4448fO3Yss6W5ubm5uXnXrl1r16793Oc+N3369P6P0t7eXl9fX19f/8c//vH2228/44wzMrva2tpWrFixZ8+ezJbjx4/v2bNnz549a9as6W2C8/vf/76pqan/BQMAAFA4tm3btmrVquPHj2e2tLS07Nq1a9euXWvWrLnmmmvmz58fYnmn2nvvvff444+nWzHSOjo66urq6urq1q9ff80111x44YW9ekLdQwMlKvnRnj17HnzwwUQiUVVVdfnll0+fPr2srOz48eO7d+9eu3bt3r17H3zwwVtvvXXKlCnByd74Hn8gMruam5v37Nnz7LPPNjY2vvDCC5/97Gczx7z44ot79uwZMWLExz/+8bPPPruioqK9vb2hoWHHjh1vvPFGb09n48aNF1988auvvtqrB+Y+CwAAAIaw7du3P/zww6lUasaMGQsXLpwyZUp5eXlbW1tDQ8PWrVurq6tXrVo1hPOj995772c/+1lHR0dVVdWll146ffr0ioqKjo6OQ4cOvfPOOxs3bvzVr37V2/yIgRKJ/CiRSPzyl79MJBIXXnjhX/zFXxQV/WlV74qKirlz55577rlPPvnkpk2bfvGLX9x5553FxcX9GWvEiBHnnntueXn5Aw888O6772bvevPNN4MguP7662fNmpXeUlxcPGXKlClTpixevLhXp/Pkk0+OGDHiz/7sz/qQHwEAAFCA2tvbn3jiiVQq9dGPfvTjH/94ZntZWdnUqVOnTp16xRVXPPXUUyFWeEolEolf/OIXHR0dl1xyyTXXXJNJBuLxeFVVVVVV1aJFi4bw6UdfJPKjzZs3Hz58eNy4cddee23mRySjqKjo2muv3bt3b3rS2YBkjenFjFpbW7M3Hj16NAiCqVOn9vPJ16xZU19ff8MNN5yKianp7qR/+Id/qK6ufu211xoaGtrb2//hH/4hCIK9e/du2rRp586djY2NsVhs9OjR55xzzhVXXFFWVtb1Gb73ve9t2rRp48aN9fX1RUVFU6dOXbJkSfplef3119PbU6nU1KlTP/GJT3Rd+6mxsXHdunU1NTVNTU3xeHzSpEmXXnrpueeemzng//yf/3P48OE77rhj0qRJ6S1PPPHE66+/HgTBBRdccN1116U31tXVLV++/Iwzzvjbv/3bzGP37Nmzbt26PXv2HD9+vKysbNq0aYsWLUq3nuXzOnTV2tq6atWqrVu3FhUVXX311QsWLOjlqw4AAHDKbdq0qbm5edq0adnhUbbhw4dff/31Xbf3eIEWZF0Jvv766y+//HL6SnDatGmZK8G+PWF/Lk47SScDEydOzA6PspWWli5dujRzN59RMvN7sif6ZG73rc60fK5bgyDYtm3b2rVr6+rqUqlUZWXlxRdffPHFF5+mU+oikR9t3bo1CIL/9J/+U3e9RcXFxZdeeulvfvObrVu3Dkh+VFdXFwTBqFGjsjeOHDnyyJEj27dvnzt3bp+fub6+fs2aNbNnzz7//PP7W2X3fvvb33btbLr33nuz7zY0NDQ0NGzZsmXZsmXl5eWdDn766adffvnlzN1t27bt2rVr2bJlGzdufOWVVzLba2pq3nvvvTvuuGPs2LHZG1euXNnW1pa+29HRsWPHjh07dnzkIx+58sor0xtnzpz52muv7dixI5Mf7dixo9ONIAjSLWAzZszIbNm4ceNTTz2V/gLjIAiOHTu2ZcuWt95668///M8vvvjifF6HThobGx955JEDBw6Ul5ffeOON2WMBAABEx7Zt24Ig6O0fvPO5QMt49tln169fnz3irl277rjjjjPPPLNvT9j/i9OMTDJw0vCoq76NMiDPkOd164YNG5555pnM3dra2tra2n379uVTWwRFIj+qra0NPhgidJXemz6yP9ILjz377LNBEMybNy971/z589esWbNq1aqamppzzjln8uTJvV3aPZVKPfnkk0VFRZ/+9Kf7WWdu1dXVixYtuuiii8aOHZv51TrrrLMuvvjiadOmVVRUtLW11dbWvvDCC3v37l2zZs2nPvWpTs+wcePGyy+//KKLLho1atT+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P2bMmE7fmNZns2fPrqqqam5u3rRpU48Hv/fee8HJ1jDr5Hsnk72rv0XnlI6BO2Vh69atG/CB5syZEwTB2rVrezxy+PDhkyZNSiQSGzZsCLL6jNJB0oYNGxKJxKRJk4YPH555SDpL6vrkf/jDH4Je9vOXlJTcfPPNs2fPbm1t/fnPf/7OO+/k/1gAClaI+VEsFhs2bJhvewAoZPPnzx81alRdXV36i4DyeUj+F2h56v8T9vniNJ0M7Nu3r7vTb2tr+9WvftXbUdLHtLa2DlSdeV63pm90fcL169f3OEQ0RSI/Ki4uTq9OvWnTpvvuu+/NN988duxYIpFIL0t+//33b9q0KXPMQA16+eWXB0Gwfv36zJTOu++++/nnn9++ffuRI0c6Ojra29sPHTq0bt26xx9/PAiCuXPnDtTQp0J6zabVq1fX19e3t7cfOHBg9erVr7/++oAPtGjRovLy8tdee+2RRx6pqak5evRoMpk8ceJEbW3tunXrli9fnn1wOio6ceJELBbL/BbNmDEjFoulf3s7TV679NJLi4qKtm7d+utf//rQoUOJROLQoUOrV6/etm1bcXFx1yXccovH45///OfnzJnT0dHx6KOP/vGPf+zPiQNQCNKfVn3rAgChiMfjN954Y3Fx8auvvvrTn/70tddeO3jwYHt7ezKZbGlpeffdd1evXt3pIb26QMtH/5+wzxenxcXFN9xwQzwef/XVV++7777NmzcfOXIkkUi0trbW1dX9x3/8x//9v/830wKS/yijR48OguD//b//l71Cdn/qzPO6deHChUVFRVu2bHnqqacaGxsTiURjY+NTTz11mi6eHURk/loQBFOnTv0v/+W/PPbYY7W1tem8JtuIESNuvPHGqVOnDuCI55133hlnnHHw4MGtW7eee+65QRDU19fX19evWbPmpOV97GMfG8DRB9zHPvaxhx9+ePv27enV8tMWLlz4yiuvDOxAI0eOvPnmm1euXLl169b0xLQcZs6cmY5gJ0yYkFmLdMSIEePHj9+/f3/wwcWzgyCYOHHi1Vdf/dRTT1VXV1dXV2e2x2Kxa665Jv3r3SvxePymm256/PHH33777VWrVrW2tub4yjYACLH/CACCIJg6deoXv/jFX/ziF/v27XvyySe7HjBy5Mhrrrkm+27+F2j56P8T9ufidMqUKV/84hcff/zx2traVatW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fOELP/rRj2pqambNmjUwJwCnjP4jAGAoS6VSw4cPHz58eNiFdEv/EUEQ3HfffTNmzKioqPjc5z535MiRTvN0nnzyyUsvvbS8vHzu3LmrVq3KfmD6yGPHji1durS0tLTr3Jkcjw2yJgStWLHivPPOGzVq1F133ZXZe88999x+++1VVVWTJ09etmzZjh07Bup8169ff/XVV48ePbqsrGzx4sXPP//8nDlzehx39uzZ6WpjWTo9c39qfvTRRz/84Q+PGDHioosueuyxxzrtzf0e9ed8c8txRk888URpaWksFisrK7vkkktWrVp1/vnn57k3beHChQsXLsyzkoxOL37X9yL3u5D7p67H12rbtm2LFi2Kx+Ndf9r7M27G8uXLb7/99l69IAcOHOjz3iAIbr311uXLl/dqRAhHCgCAUL3zzjvvvPNOR0dH2IUwwGbMmLF58+bsLSf9+P3YY49dccUV27dvb2tre+ONN77xjW9kH/boo4/efPPN7777bmtr6xtvvLFkyZJnnnmm03P+zd/8zUsvvZRMJletWlVSUpL/Y9MPv+mmm66//vrq6uq2trann346s2v79u3pGw0NDd/97ndnzpzZtfg+XFA8++yz8+bNe+aZZw4ePNjW1rZr166777577NixeY6be8Q+1/zII4/ccMMNzc3NqVSqubn5hhtuWLlyZWZv7veon+eb+7xynFFJScmqVatSqVQikThw4MCKFSvGjRuX5960Sy655JJLLsnzRLItXrx47dq16dtr1679yEc+kmfNad391PX4WgVB8Od//udvvPFG15/2/oybbd68eW+++WZ3J37StykWi+U4puvev/u7v8ve8sc//vH888/vbkSIDvkRAEDIEolEIpEIuwoGXiY/6rpkT1VVVeawCy64IDtmevnll7OvP+fOnfvee+9l7r7zzjuXX3559ihBEDz22GPZd/N/bPr43/72tz2eS0dHx0mvnPuQH82fP3/Dhg15Htx13PxH7FXN55133ttvv525+/bbb5933nmZu7nfo9zyPN98nrDTGZWXl99zzz2HDx8+6cG59/bTgw8+eOutt6Zvf/GLX1yxYkV3R570Xejup67H1yoIgrq6uuy7AzJutrKysnSM2F0BPW7s8W6n/OjYsWPDhw/PXRVEQSylUxoAAE6BmTNnrl69et68eZkt6U6ETodVVFTU19eX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fvvtvXpBDhw40Oe9QRDceuuty5cv79WIAINMfgQADE3mr3G6SM/J+uY3v/n1r3+9tbV15cqVN910U/YBn/rUp+6///7a2trNmzdPmDDhz/7sz7IfuH///gceeOC666577LHH7rvvvuzHrly5cuXKlY8++ujhw4cff/zxe+6559lnn+06eh8mhaVSqcWLF69duzZ9d+3atR/5yEeyn6e7mrMr//znP/+rX/3qoYceOnjw4IIFC9K7nnvuuTvuuOOrX/3qjh07mpqaHnrooa1bt3ZaHuhrX/vavffe297env9r1eO42Z555pmuix/l1tjY2Oe9QRB84hOfePrpp3s1IsAgiw3aFGIAgMFUU1OTTCanT59eWloadi0UqJkzZ65evXrevHmTJ0+ura3N3lVVVbV3797M3Vgs9thjj914442Zu919Sk8kEvF4PLM3Fou1t7fH4/FYLNbS0lJWVpb92A996EPPPffc5MmT03e3bdt26623/uEPfxiQs1uxYsW///u/p2d13XrrrUuWLPnP//k/51NzpvLf/va311xzTaeDL7jggp/+9KeXXnppd+PGYrG6urqJEydm7ub5WuUeN1t5eXlDQ0N5eXl3BXQdsdPGXt0NgqC5ubmysvL48eM5qmJouOuuuxobG//pn/4p7EKg1/QfAQBDUCKRSCaTwWnSf3T8+PFt27bt3Lkz7EI4Vfbu3Ztp80nfyA6P0jLhUScHDhz4xje+MXfu3PLy8srKyk996lOdDshM0iwrK+u0q6amZsqUKZnJZXPmzHnttdcG4HyCIAiCG2644bnnnmtqampqavrd7353ww035F9z2klDnLfffvv888/PPXQmPOqkP+NmG5A/sed+kpMmUP0fFODUkR8BAENQevJacXHxaXFJVlRUFARBOvCCTpYuXXrttddu2bKlpaVl7969P/vZz/J/7Ny5c996661UlpaWloEqrKysbOnSpQ8//PBDDz103XXXDR8+fEBqnjFjxqZNm/pWUn/GzTZr1qz+57mJRCL/vTt27Jg9e3Y/RwQ4peRHAMAQdHotfpTOj6wqwEnt3LmzsbGxtbW1vr5+3bp1P/7xj/N/7A9+8INly5a98sorx48fb25ufu211z772c92OqZv62enLVu27N57773vvvuWLVs2UDV///vf/8pXvrJ9+/YgCJqbm996663ly5ffeuut+Ty2P+Nmu+qqq1544YVePaSsrGzdunXp2xs3bhw1alT2b3TuvUEQ/P73v7/66qv7Vi3A4JAfAQBD0OmYH+k/KgTTpk3rujHdJZf9XWbZdx955JG77rprzJgx8+fPX7ly5be+9a1Ox3R6YPaNa6655rvf/e5/+2//bcyYMbNmzbr77rv/+Z//udPoiUSiz9nlBRdcUFxcXFxcPH/+/OztOWrudI6dvrUtCILPfe5z//Iv/3LHHXdUVVVNmTLlr/7qr9rb2+++++5+vlY9jpvtb/7mb+6///5OG7Mf1fUZHnrooY997GOxWGzcuHFLly799a9/nf3vT+69QRD87Gc/u+OOO7qrByAKrJ8NAAxB+/fvb2pqGjt27Jlnnhl2LT1LJpM1NTVBEMyaNSudJTE0ZNbPDrsQem3ZsmVLliz5/Oc/PwhjPfLIIy+++OLy5csHYSxCZ/1sTl8+oAAAQ9Dp2H8UaEGCyPjHf/zHf/3Xfx2cse69994f/vCHgzMWQJ/Fwy4AAGDgnV75URAERUVFyWRSYzhERGVl5R/+8IfBGau3ay0BhEL/EQAwZJ1G+VF6IRX9RwBANOk/AgCGoBkzZqRSqRzr40ZNUVFRIpGQHwEA0aT/CAAYmk6j8CjwFWwAQLTJjwAAwpfOj6x/BABEk/wIACB81j8CAKJMfgQAED7z1wCAKJMfAQCET35EZEVzKbFoVlWA2tvbwy4BGCTyIwCA8Fn/iCeeeKK0tDQWi40cOXLWrFmf+cxnwq4oNJs3b47FYhKiHg3aq1RfX79kyZJOG6urq7/2ta9VVVV1Pf6ll1666qqrrrzyylgsVlpa+sQTT+S/94orrjh48OCAnwLQf/IjAIDwWf+oQEyfPr27XTfddNPKlStTqdTRo0drampWr149CPWc9OK/k8GPNefPn9/joN0dkM8ZDRmD9tZ8+9vf/tKXvpS5W1tbe9ttt61fv/5b3/pWQ0ND1+OXLVu2YsWKF154IZVKvfjii7fcckv+e7/85S9/5zvfOUUnAvRHPOwCAAAwf61Q7N69u7td7e3t11133WAWEwRBXV3dII94qg29MwpdTU1NdXX1/fffn9lSVVX1wAMP5HhIUVHRuHHj0rcXLVrU3Nyc/94vfOELP/rRj2pqambNmjUwJwAMEP1HAMCQ0tzcvHfv3sbGxrAL6R35USGbPn16ugEtliWzN5+7x44dW7p0aWlpadfZQOvXr7/66qtHjx5dVla2ePHi559/fs6cOUEQzJ49O8egadu2bcsxQ+rRRx/98Ic/PGLEiIsuuuixxx7L3tVjVffcc8/tt99eVVU1efLkZcuW7dixI/+Xq7uqcp9Rd1vOPvvs7CdZuHDhwoUL8y/mpE/edazc55s5eMWKFeedd96oUaPuuuuuzN7u3sHsF2TRokXxeLy3r3PucTOWL19+++239+oFOXDgQJ/3BkFw6623Ll++vFcjAoNAfgQADCmtra0tLS1tbW1hF9I76as46x8Vpl27dqXf+lSWzN5OPxUnvfvNb37z61//emtr68qVwqCFcQAAIABJREFUK2+66abM3ueee+6OO+746v/H3v3HNXXfix8/JySBBATb4lWDQqHgKEp1VqBztfdOXf2xuUL92R+uRcvDzrWdtdr1UTv2mLq11s7e6couap29+At1WKzVVquzXsVWW6fUK1p+2wKKUARJYhKSfP84d/lmAUL4eZLwev6Vcz7n8/m8z+fQGt58Pp+zZEl5eXlTU9P27duvXLkibS5TUlLiplNJXFxcez+Tu3bt+tvf/nbq1Cm9Xn/y5Mk9e/Y4p5DcRyUIwpQpU959993q6urCwsLBgwdPnjzZ8+FqLyr3d3Tr1q0RI0Y4Zy6ampri4+M///xz50baHIcO2e32CRMmnDp1Sjo8derUQw895NyO+/uVrpw3b97777+/ffv2+vr6pKQkqcjNE3RYunTppk2bLBZLZ8fZTb/OPvroo9abH7nnPoPfYX7/xz/+8aFDhzrVI4A+IPI1BQAA+BOz2Xz79m2VSqXRaOSOpRNu3bp17do1jUYzbNgwuWNBj4mJicnPz09MTIyIiKiurnYu0ul0VVVVzmdEsd1v5i5FrQ937949e/bs1qWjR4/euHFjSkpKexG66dT9NQkJCfv27fve974nHV65ciUtLe3SpUueROXCarUqlcrWpe5ja6/UTa1NmzadO3fuL3/5i3T46quvhoeHL126tL0uOiUnJ+fvf/+7tKorPT190qRJTz75ZJtXtnm/oih++OGH06dPd7nYkydYU1MzZMgQx2Gnxrm9fp1ptdq6ujqtVtteAB0+u04dCoKg1+vDw8ONRqObqHzXqlWrGhoa1q1bJ3cgQKcx/wgAAPgVtVodGhrqW8kjQRAUCgVvm/JjVVVVjokt0geX5FE3OdI0Li5fvjxq1Kge7MihpKQkMjLScRgZGVlaWuphVLW1tcuWLUtISNBqteHh4VOmTOmNCFtbsGDBZ599JiW5vvnmmw8++OC5557rqcZnzZp1+PDhpqampqamI0eOzJo1y1Hk4f22mcTx5Ak6kkcuutOvsx6ZcOC+kTYzUN3vFEDPIn8EAAAgv+Dg4NjYWCYfoUNtvu6qPdHR0efPn/f8epPJ5OGVsbGxlZWVjsPKykrPdztOTU2dMWPGpUuXDAZDVVXV1q1bPY+ws5zvKCAgYM2aNcuXLxcEYcWKFZmZmWq1uqc60mg0qampO3bs2L59e1paWlBQkKOoO/fb2SforKfG+Z577qmoqOhaXQer1ep5aXl5eWxsbDd7BNDjyB8BAAAAXk2lUu3bt89kMn388cdPP/205xVXrly5ePHikpISQRD0en1RUVF2dnZ6erpLy4Ig1NTUbNiwYfz48R62nJmZuWzZMimZVVdXt2zZsszMTA/rVlRUNDQ0mEymGzduFBQUrF271vM76pD7O3r44YdtNtuaNWvKysranB7Vtf2zJRkZGZs2bdq8eXNGRobz+e7cb4dP0I2eGuepU6ceO3asU1U0Gk1BQYH0+ezZs6Ghoc4zjNyXCoLwySefTJs2rWvRAuhFdgAAAAC9IDo6urCw0PlMZGRkm1e6/4qel5enUqkGDBjw5JNPXr9+3fkalyqtWzh+/PjEiROHDh06cODApKSkDRs26PV6l5ZFURw+fPgLL7xQXV3dXkitA9uxY0d8fLxKpYqPj9+xY0ebt9Pm4fHjx8eOHRsUFDRkyJBFixY5lvJ50m+HUbm5I8nFixdFUTx9+nSbD2Ls2LHjxo1rs8gTSUlJSUlJLifd32/rm2pdvb0n2J1x7rBfh+Li4jFjxricdP8gpKcgCEJ4eLhOp/v000+d67ovtdvto0ePLi0tbS8eX7dy5coXX3xR7iiArmD/bAAAAKBXOPbPljsQ/H/5+fk7duzIzc2VOxBfkpGRMWnSpHnz5vVBXzt37jx+/Hh2dnYf9CUL9s+G71LKHQAAAAAA9IWWlpbMzMz3339f7kB8zOuvv56amto3+aNNmzbt3r27DzoC0FnkjwAAAAD4Oef3ecXExLAIo1PCw8NPnjzZN311dq8lAH2G/BEAAAAAP0fCCAC6ifevAQAA/3Hr1i2j0cgvigAAAD2L/BEAAPATVqv12rVr3377rdyBAAAA+BvWrwEAAD9hNpsFQZBe3S13LF3R2NhoNBpDQ0O1Wq3csQAAAPwL5h8BAAA/4cgfyR1IFxmNxlu3bplMJrkDAQAAcMX8IwAA4CcsFosgCGq1Wu5Auig0NDQoKEij0cgdCAAAgCvyRwAAwE/4+vwjrVbLyjX0ElEUe2lf+d5r2RcxGgD8GOvXAACAn/D1+UdA1xQWFoqi2P1tv3qkkT5uuWe5H8meGmcA8FHkjwAAgD+w2+3kj+D9oqKierzN++67r8M5L55MiunaxJnea7nvuR/Jnhrn1nQ6XRdqAUAfI38EAAD8QUtLi91uF0VRqWR5PrzX1atX5Q4BXqempkbuEACgY+SPAACAP5A2P2LyEXyR+E9tHgqCkJWVtXDhQp1OFxERkZGRUV5e7nnjxcXFblZdbdmyJS4uLiQkZNasWXV1dZ0Ku5stJycnJycnd6pHQRD27dunVqtFUdRoNOPGjcvLyxs1apRUJAWzfv36AQMGFBQU5Ofnh4WF7du3z7l6d0bSPTejIZ1vbm5OTU1Vq9VqtdoRVWxsrFRFdNJTIQFAzyJ/BAAA/IGvb56N/sxut0+YMOHUqVPS4alTpx566CHnlVBTpkx59913q6urCwsLBw8ePHnyZM8bj4uLa29RVU5OzrZt244cOVJfX//yyy+/9tprnQq7my3b7fYurPaaO3dubm6u3W7X6/WHDh0yGAy1tbWOBgVBuH79+pYtW9LS0nbv3r158+a5c+c6V+/OSLrnZjSk88uXL3/ppZdMJlNubq4jqpKSEqnU7qSnQgKAnsULAgAAgD+ora1tbGy8884777rrLrljAf5PTExMfn5+YmJiREREdXW1c5FOp6uqqnIc5uTk/P3vf9+yZYsgCOnp6ZMmTXryySfbbNNqtSqVytbf4d2/+avN0lGjRuXm5o4cOVI6PHfu3P3339/Z3w56r+U2BQcHv/XWW48//nhYWFibwVgsFqVSKYqiwWDQaDRuhqUHR7LDUlEUd+/ePXv27DYv461t/cqqVasaGhrWrVsndyBApzH/CAAA+APmH8GbVVVVOaaWSB+ck0eCIMyaNevw4cNNTU1NTU1HjhyZNWuWo6i2tnbZsmUJCQlarTY8PHzKlCk9FVVJSUlMTIzjMD4+3vtb3rt3769+9auBAwcGBgYOHz48ISHh7Nmzzhc4dkDTaDQudXtvJD3hSB4BgI8ifwQAAPyBf7x8zWazWSwWZiL0QxqNJjU1dceOHdu3b09LSwsKCnIUpaamzpgx49KlSwaDoaqqauvWrT3VaWxsbFlZmePwypUr3t/ytGnTzGaz2Wyuqqo6ceLE/PnzH374YQ/r9t5I9iyTySR3CADQBvJHAADA59lstpaWFsH35x+VlZVVVFRI94L+JiMjY9OmTZs3b87IyHA+X1FR0dDQYDKZbty4UVBQsHbt2p7qcfny5c8//3xlZaXZbP7iiy82b97cly13bf/sQYMGnThxwmKxhIeHR0dHx8fH6/V6D+v23kh2k0qlknbUrqmp2bBhw/jx4+WOCADaQP4IAAD4PGnyUUBAQEBAgNyxdIsUv81mkzsQ9JbIyMj2ikaPHi39DN93333O53fu3Llq1aqBAwfed999ubm5v/71rwVBaPNlba1f4OW+9Kmnnpo3b97EiRPvuOOO119//Xe/+51zy+51v2Wr1dqFqXbR0dHXrl174IEHVCqVKIrSdtqOkFxGxuVD741kh6Wt43G+QNpRW6FQpKSklJSUHDhwoLPDAgB9gK3aAACAz2tqarp+/bpGoxk2bJjcsXTL1atXTSZTRESEVquVOxb0AMf+2XIHAsBbsH82fBfzjwAAgM+TNs/29c2PhH/OP7JarXIHAgAA8C/IHwEAAJ/nN/kjhUIhkD8CAADeh/wRAADweVL+KDAwUO5Auov5R/ASUVFRYjuioqLkjg4AIAOl3AEAAAB0i/TOe8Ev5h+RP4KXqKyslDsEAIB3IX8EAAB8myiKQ4cONZvNvv7yNYH8EQAA8FbkjwAAgG8TRTEkJETuKHqGlD+y2WxyBwIAAPAv2P8IAADAWzD/CAAAeCfyRwAAAN6C/BEAAPBO5I8AAAC8BfkjAADgncgfAQAAeAuFQiEIgt1uZwskwKuIoiiKYh90dOPGjUmTJjkOd+7cGRAQIP6TWq3et2+f8/UnTpyYOnXqxIkTu1D64IMP1tfX9+rtAPAn5I8AAAC8hUKhkH5HZQqSv4qKipI7hB6j0+nkDqHv2O32vunolVdeeeaZZxyHTz311IEDB+z/lJubO3fuXOfrMzIycnJyjh07Zrfbjx8/Pn/+fM9Lf/GLX7z66qu9ejsA/An5IwAAAC/CEjb/dvXqVblD6DE1NTVyh+BvSktLv/zyy8cee8xxRqfTTZs2zXGYlpbW0tLiXEWhUAwaNEj6PH78eL1e73npE088cfr06dLS0p69CwD+ivwRAACAF5HyR6xf629Onz49bdq0sLAwjUYzYcKEo0ePjhgxwlG6a9eu73//+8HBwWPHjt29e7fjvLSmaf369QMGDCgoKMjPzw8LC3OsUXJfKtm/f39KSopWq01ISMjLy3Mukqo3Nzenpqaq1Wrn1U+xsbHSRDnRiXPdffv2qdVqURQ1Gs24cePy8vJGjRrlcsvJycnJycmdHSiX7lr3npWVtXDhQp1OFxERkZGRUV5e3rq6IAg5OTn33ntvaGjoqlWrHKXun4IgCMXFxePHj1cqla3XgnWnX4fs7OyFCxc6n6moqHA+LCsre/HFF53P1NbWtjNUHZcKgpCenp6dne3+GgCQkD8CAAA+zGAwGI1Gf8q2MP+oHzp8+PCiRYuWLFlSXl7e1NS0ffv2K1euODam2bVr19/+9rdTp07p9fqTJ0/u2bPHkUKSFlVdv359y5YtaWlpu3fv3rx5s2N9k/tSQRByc3Nzc3N37dp18+bNPXv2ZGVlffzxx45Sqfry5ctfeuklk8nkvHKqpKREKrU7cb6juXPn5ubm2u12vV5/6NAhg8HQOpHRupYn7Hb7hAkTTp06JR2eOnXqoYcecm5nypQp7777bnV1dWFh4eDBgydPnuxSXRCEefPmvf/++9u3b6+vr09KSpKK3D8FydKlSzdt2mSxWFqvI+tyv84++ugj582PXDQ3NxcVFf3xj390PtnQ0NDuYHVUKgjCj3/840OHDrm/BgAkYp8t5QUAAOhxFRUVFotl2LBhGo1G7lh6Rk1NTXNz86BBgwYOHCh3LOiumJiY/Pz8xMTEiIiI6upq5yKdTldVVSV9Hj169MaNG1NSUtpsJCEhYd++fd/73vekwytXrqSlpV26dEk6FEXRYrEolUpRFA0Gg0ajEcX//w3ffenIkSMPHz4cEREhHRYXF6enp588edLRtSiKu3fvnj17tuPQ+XcHl0NnwcHBb7311uOPPx4WFubpYHksJyfn73//+5YtWwRBSE9PnzRp0pNPPtnmlVarValUugQpiuKHH344ffp0l4vdPwWpYk1NzZAhQxyH7d1+p/p1ptVq6+rqtFpt66La2torV65MmDChdVRuHkqHj0yv14eHhxuNRjdRoWetWrWqoaFh3bp1cgcCdBrzjwAAgA9TqVTSWhK5A+kxzD/yS1VVVY7pNtIHR/JIEITLly+3Xt7lUFJSEhkZ6TiMjIx02bBGqVRKH9rMoropLS0tHTZsmGMJ2IgRI86dO+dyjSN51Cl79+791a9+NXDgwMDAwOHDhyckJJw9e7YL7bRp1qxZhw8fbmpqampqOnLkyKxZsxxFtbW1y5YtS0hI0Gq14eHhU6ZMabOFNpM47p+CxJE8ctGdfp21l5C6ePHixYsXWyePOtVIe6V98145AH6A/BEAAPBhERER0dHRUs7FP5A/6oeio6PPnz/fXmlsbGxlZaXjsLKy8p577umRfhMSEoqKipzXoBkMhi63ZjKZHJ+nTZtmNpvNZnNVVdWJEyfmz5//8MMP90TIgiAIGo0mNTV1x44d27dvT0tLCwoKchSlpqbOmDHj0qVLBoOhqqpq69atnjfr/im4151+nd1zzz0uGx4JgnDmzJna2tqJEyd62Ij7/3u4lJaXl8fGxnYmRgD9F/kjAAAAL6JWq4OCghxzRtAfrFy5cvHixSUlJYIg6PX6oqKi7Ozs9PR0qTQzM3PZsmV1dXWCINTV1S1btiwzM7NH+l29enVGRsaZM2eMRqNerz937tzMmTM9r65SqaQ9pGtqajZs2DB+/HhH0aBBg06cOGGxWMLDw6Ojo+Pj413e/CV0df9sSUZGxqZNmzZv3pyRkeF8vqKioqGhwWQy3bhxo6CgYO3atZ636f4puNedfp1NnTr12LFjzmdOnDgRFBTknDxymS6k0WgKCgqkz2fPng0NDXWeYeS+VBCETz75xPn9bgDgjh0AAABAL4iOji4sLHQ+ExkZ2eaVx48fnzhx4tChQwcOHJiUlLRhwwa9Xu8o3bFjR3x8vEqlio+P37Fjh+O881f69j60Vyo5dOhQUlKSWq0ePHjwggULKisr22y89aHdbs/Ly1OpVKIoDh8+/IUXXqiurnYUJSUl5ebmJiYmSplQlUqVl5fncstjx44dN26cR+PYlqSkpKSkJJeTx48fHzt2bFBQ0JAhQxYtWuRYJNj6ptr8VcjNU3A/Gt3s16G4uHjMmDHOZ0JCQtz/Bic9BUEQwsPDdTrdp59+6nmp3W4fPXp0aWlpe/GgN6xcufLFF1+UOwqgK9g/GwAAAOgVjv2z5Q4EPiMjI2PSpEnz5s3rg7527tx5/Pjx7OzsPugLDuyfDd/F+jUAAAAA8Aqvv/76n//8577pa9OmTb///e/7pi8AfoCl9QAAAADgFcLDw0+ePNk3fbnstQQA7jH/CAAAAAAAAO6QPwIAAAAAAIA75I8AAIBP4h0gAAAAfYb9jwAAgE/65ptvWlpahg4dqtFo5I4FAADAz5E/AgAAvsdut5vNZrvdrlKp5I4FAADA/7F+DUD/9Yc//OGnP/2p+2tEUZQ+TJ8+/Y033uj9oAB4REoeBQQEKJV++MewxsbGioqKuro6uQMBAAD4P+SPAPRTer3+7bfffvvtt6VDR56oPevWrVu3bp3RaOz90AB0zGQyCYKgVqvlDqRX2O12i8VisVjkDgToXR3+4wsA8B7kjwD0U3l5eePHj4+Li5MOO9yINz4+fty4cfn5+b0fGoCOSfmjwMBAuQPpFSEhITqd7q677pI7EKD/EkWR9BYAOCN/BKCf+uCDD2bPnt2pKnPmzNm/f3+P9H769OnDhw/3SFNA/+Tf+SOlUhkcHOyvs6v6uaioKLlD+Bc6nU7Glr35LYqdja33RhIAvAT5IwDyc/n7nuPw6NGjY8eO1Wg0d9999+bNm6WTNptt9erV0dHRd95554IFC/R6vaPW22+/PXz4cIVC0V5dZ1988cUPfvCD1p2azeZf/vKXd91115AhQ9auXetc5Yc//OGZM2e6ebOnT59+6KGHJk2aNHbs2G42BfRn/p0/gh+7evWq3CH8i5qaGp9r2Tv1t/sF0A+RPwLgvebPn79ixYqbN2+eOHHis88+k07+53/+5/Hjx48dO1ZaWmqxWDIzMx3Xf/rpp59//rnNZmuvrrNr164NHTq09fk//OEPX3/9dWFh4RdffHHo0CHnIp1OV11d3eXbKSgo+MEPfvCjH/3o1KlTv/zlL8PDw7vcFNDPtbS02Gw2URSZoQO/cfr06WnTpoWFhWk0mgkTJhw9enTEiBGOUsdaqpycnHvvvTc0NHTVqlWO0v3796ekpGi12oSEhLy8PJeWs7KyFi5cqNPpIiIiMjIyysvLpfOxsbFSm6ITl7ruW26PJy0XFxe3eV46uX79+gEDBhQUFOTn54eFhe3bt69TUSUnJycnJ3sYrbMtW7bExcWFhITMmjWr9Qb2fT+SAOBV/PCVJQD8hlKprK6urq2tjYyMdMwh2rRp0/vvvx8dHS0IwltvvZWSkvLHP/5RKvrTn/7kmD3eZl1n7c1L37Zt2/79+yMiIgRBWL9+fWJiYvdv5OTJky+//PL58+dNJpPNZlMqlbW1tYsWLZJKv/rqq6KiIjfVhwwZwhYMgDObzdbS0iKKokqlkjsWeIXJkyevX79e7ii67vDhw8uWLVu7du327dsHDBhQU1Nz4MCB+vp6xwV2u10UxXnz5lkslu3btycmJh49elQqys3N3b9//65duyIiIoqLi3/1q18FBwdPmTLFUXfKlCmLFy8WBKG+vv7tt9+ePHlyaWmpIAglJSWCIIii2N4/iB223J4OWxYEIS4uTropl/PSyevXr2/ZsiUtLW3y5MmbN2+eO3eu2Wz2PKquLYvLycnZtm3bkSNHhg4deuHChddee83lgr4fSQDwKu7+tw4AfcPlK5fj8Ny5c6tWrfqf//mfO++8809/+tO0adMEQdBqtc4vQVMoFFarVaolzUeQzrdZ11lMTMzhw4djY2NdOtVoNA0NDUFBQYIg3L59W6PROGIrLi6eOnWq9GWxUy5evPjqq69+8sknLS0tFotFpVK98sorwcHBUuk//vGP8+fPu6l+9913S4vyAEjMZrPFYlEqlaxfgyAIZ8+e1el0Fy5ckDuQNsTExOTn5ycmJkZERLjMYNXpdFVVVdLn0aNHb9y4MSUlxU1Toih++OGH06dPdzk/cuTIw4cPS3/2EAShuLg4PT395MmTbTZitVqVSmWb/+a21qmW2wy4w1802rxGFEXpP3BRFA0Gg0ajcb6sm1G5MWrUqNzc3JEjR0qH586du//++9u7hb4cSfiZVatWNTQ0rFu3Tu5AgE5j/hEA+QUFBRkMBq1WKwjCtWvXHOfHjh27b98+u91+8ODBBQsWSDsLREZGfvTRR3fffXfrdpz/jNlmXWfjxo07deqUI3/kEBERUVZWlpCQIAiCS6ro1KlTXZsPP2rUqP3791+4cOGVV145ceLE7du3m5ubV65c2YWmAAiCUFNT09zcHB4efscdd8gdC+Q3depU7996xpEqajPLcPny5VGjRnXYSOvkkSAIpaWlw4YNcz6j0Wgcn2tra998882DBw9WVFRotdoxY8Z4HrP7lnuVUqlsr8fei6qkpCQmJsZxGB8f71zqoyMJAD2IP2gDkN/999//1ltv6fX68vJyx6ouQRAee+yxS5cuWSwWQRAcE3B+8YtfZGRkFBUVmc3mr776at68eW222WZdZzNmzNi7d2/r848//viLL75YVVVVVVW1ZMkS56K9e/fOmDGjq3cpjB49+tChQydOnPj3f//37OzsGzdudLkpoJ9j82z4mejoaPcTUd1ISEgoKiqyOzEYDI7S1NTUGTNmXLp0yWAwVFVVbd261X1r0n9cnrTcWc4td0fPRuUsNja2rKzMcXjlyhXnUu8ZSQCQC/kjAPL7r//6r0OHDoWHh//oRz+aOnWq4/wjjzzy6KOPhoWF/eY3v9m2bZt08vnnn//Zz3726KOPhoaGPvHEE4899libbbZZ19nMmTM/++yzr7/+2uX8ihUrYmJiEhMTx44d+/DDDzvOX7ly5cyZM2lpad282fvvv//YsWPHjx//6quvutkU0D/ZbDYpNUz+CH5j5cqVixcvlrbR0ev1RUVF2dnZ6enpntRdvXp1RkbGmTNnjEajXq8/d+7czJkzHaUVFRUNDQ0mk+nGjRsFBQUu7xUVBEGlUkm7U9fU1GzYsGH8+PEettwhNy13hydRdW3/7OXLlz///POVlZVms/mLL75w2TxRxpEEAG9hB4D+6g9/+MP06dM9vHj69Omvv/56r8YDwBMGg+Hrr78uKyuTO5DeZTKZGhsbm5ub5Q7EB0yZMuW+++6TO4q2RUdHFxYWOp+JjIxs88rjx49PnDhx6NChAwcOTEpK2rBhg16vd5S6/wJ/6NChpKQktVo9ePDgBQsWVFZWOjc7duzYoKCgIUOGLFq0yLGMznFBXl6eSqUSRXH48OEvvPBCdXW1hy13yE3Lbn4rcT5s/cHDqMaOHTtu3DjPQ3XIzs6OiYnRarWPPvqoY5qwVCTjSMLPrFy58sUXX5Q7CqAr2D8bAAD4ksbGxtra2uDgYMf7Fv1SU1PT9evXtVqtY89dtEfa/8jL98+WOxAA3oL9s+G7WL8GAAB8ye3btwVBUKvVcgfSu6T9g1taWuQOBAAAQBDIHwEAAN8i5Y+CgoLkDqR3kT8CAABehfwRAADwGTabzWw2C/0mf2Sz2Ww2m9yxAK6ioqLEdkRFRckdHQCgVyjlDgAAAMBT0iuxlUqllF7xYwqFQqFQSC+b401z8DaVlZVyhwAA6GvMPwIAAD5Dyh/1k3wKS9gAAID3IH8EAAB8hkqlGjBgQHBwsNyB9AWVSiWQPwIAAN7Bz+d+AwAAfxIcHNxPkkcC848AAIA3Yf4RAACANyJ/BAAAvAf5IwAAAG9E/gjoMlEU5Q4BAPwN+SMAAABvJOWPLBaL3IEAnSaKIhkcAPAz5I8AAAC8EfOP/FJUVJTcIfwLnU7XG83a7fbeaLa3A+il0QAA/0D+CAAAwBtJ71+z2+1Wq1XuWNBjrl69KncI/6KmpkbuELwIowEAbpA/AgAA8EaiKAYEBAhMQeofTp8+PW3atLCwMI1GM2HChKNHj44YMcJR6lgOlpOTc++994aGhq5atcpRun///pSUFK1Wm5CQkJeX59JyVlbWwoULdTpdRERERkZGeXm5dD42NlZqU3TiUtd9yx0yGo1PP/10SEjI3XffnZ2d7Xwvzn1Jh3Fxcc51k5OTk5OTO9ujIAjFxcXtrZ6Tzjc3N6empqrVarVavW/fPqnIk9EAgH6O/BEAAICXYglbP3H48OFFixYtWbKkvLy8qalp+/aKPipDAAAgAElEQVTtV65cqa+vd1wgrcaaN2/e+++/v3379vr6+qSkJKkoNzc3Nzd3165dN2/e3LNnT1ZW1scff+zc+JQpU959993q6urCwsLBgwdPnjxZOl9SUiI1a3fiXLHDljv0m9/85oknnrh+/XpeXt5f//rXXbt2CYJw69atESNG1NbWOi5ramqKj4///PPPneu2jsdDcXFx7VWUzi9fvvyll14ymUy5ublz586VijocDQCAyP8ZAQCA9zObzaIoSku6+o/q6mq9Xj9o0KCBAwfKHYv3mjp1amfzGn0mJCSkoKAgMTExIiKiurrauUin01VVVUmfR48evXHjxpSUFDdNiaL44YcfTp8+3eX8yJEjDx8+HBERIR0WFxenp6efPHmyzUasVqtSqXT+/i+K7f460KmW2wz4yJEjjnTVxYsXH3/88cLCQkEQNm3adO7cub/85S9S0auvvhoeHr506VIPW/aw9zbvSxTF3bt3z549u83L3IwG0FNWrVrV0NCwbt06uQMBOk0pdwAAAAAdq6ur64eZFOYfeeI//uM/4uLiNmzYIHcgbYiJiZE+OFJFbWYoLl++PGrUqA5ba508EgShtLR02LBhzmc0Go3jc21t7Ztvvnnw4MGKigqtVjtmzBjPg3ffsiceeOABx+eYmJiysjLp84IFC7Kysi5dupSQkPDNN9988MEHX375Zada7g5H8ggA0CmsXwMAAL5BFMXAwEC5o+hT5I/6iejo6PPnz3etbkJCQlFRkfOqK4PB4ChNTU2dMWPGpUuXDAZDVVXV1q1b3bdmMpk8bNkTzkvSLl++7NjRKSAgYM2aNcuXLxcEYcWKFZmZmWq1ulMt9w3n0QAAkD8CAAA+QKfTxcTEBAUFyR1In5LW65E/8nsrV65cvHhxSUmJIAh6vb6oqCg7Ozs9Pd2TuqtXr87IyDhz5ozRaNTr9efOnZs5c6ajtKKioqGhwWQy3bhxo6CgYO3atS7VVSqVtId0TU3Nhg0bxo8f72HLnjh48ODRo0cNBsPZs2efeeaZFStWOIoefvhhm822Zs2asrKyNicEdXn/7O5wMxoAANavAQAA36BQ9Lu/ezH/yP9ERka2PjlnzpzBgwcvWrSoqKjIaDTGxcX9/Oc/f+eddxwXOF4NJh06r4CbPn26QqF47rnnLly4cMcdd/zkJz95++23HaU7d+5cunTpY489NnDgwEceeSQzM3P9+vXOa+ikPaRbWlqGDRuWlpZ24MABD1t2Twp15cqVzz777M9+9rNBgwatWLHCJf301ltvJSYmFhQUtNmC1Wrtwn/yLq91kz44btYxjNIZl0PB7WgAANgiDgAAwEtZrdbGxkaVSjVgwAC5Y/Feb7zxRlVVldfuf5Sfn5+YmCh3IN4oPz9/x44dubm5cgcC9Cn2z4bvYv4RAACAlwoICLjzzjvljgLoeS0tLZmZme+//77cgQAAPEX+CAAAAEAfcV5iFhMTw2IIAPAV/W4fAQAAAADdERUVJbYjKirKfV37v+qbgAEA3cf8IwAAAACdUFlZKXcIAIC+xvwjAAAAAAAAuEP+CAAAeDVWuAAAAMiO/BEAAPBeVqu1tLT022+/JYsEAAAgI/JHAADAexmNRrvdbrVand/ZBMA/8N81APgQ8kcAAMB73b59WxAEjUYjdyByslqtRqPRarXKHQjkIb3XTO4o+h2GHQBckD8CAADey2g0CoIQFBQkdyByqqqq+vbbb6WhgK/r8PX2rfno4k2dTtfhNd58a52NzZP7BQCfppQ7AAAAgLbZ7XaTyST0+/yRSqWyWq3e/Js2PHf16lW5Q+gjNTU1cofQp/rb/QLoh5h/BAAAvJTJZLLb7QEBAWq1Wu5Y5DR06NDo6OgBAwbIHQh60enTp6dNmxYWFqbRaCZMmHD06NERI0Y4X1BcXDx+/HilUqlWq/ft2+dclJWVtXDhQp1OFxERkZGRUV5e7iiSFmE1Nzenpqaq1erWdTdv3hwdHR0SEjJnzpzGxkaXRVv79+9PSUnRarUJCQl5eXke3ktsbKzUiOjE5Zri4uI2z0sn169fP2DAgIKCgvz8/LCwMJeYO4wqOTk5OTnZw2idbdmyJS4uLiQkZNasWXV1dS6l7Y2zJ/fbtZEEAK9C/ggAAHgpFq+hnzh8+PCiRYuWLFlSXl7e1NS0ffv2K1eu1NfXO1+zdOnSTZs2WSyW3NzcuXPnOhdNmTLl3Xffra6uLiwsHDx48OTJkx1F0rS15cuXv/TSSyaTyaXunj173nvvvU8++aShoeG3v/3t6tWrBad1W7m5ubm5ubt27bp58+aePXuysrI+/vhjT26npKREasTuxOWauLi4NqfUSSevX7++ZcuWtLS03bt3b9682TlmT6Jqs8cO5eTkbNu27ciRI/X19S+//PJrr73mckF749zh/XZ5JAHAq4jMhQYAAN6ppqamubn5rrvuuvPOO+WOBd7rjTfeqKqq2rBhg9yBtCEmJiY/Pz8xMTEiIqK6utq5SKfTVVVVSZ9Hjx69cePGlJSU9toRRbGmpmbIkCGOw/a+w1utVqVS6VwqiuLu3btnz57duu6YMWNycnISExOlwzNnzqSkpDhKR44cefjw4YiICOmwuLg4PT395MmTHt67myDdXyOKosViUSqVoigaDAaNRuN8WTejcmPUqFG5ubkjR46UDs+dO3f//fd3apzbu7j3YoYvWrVqVUNDw7p16+QOBOg09j8CAABeipevwW84UkVtZhkuX748atQo9y04kkcuamtr33zzzYMHD1ZUVGi12jFjxrS+xpE8clFSUhIbG+s4dKROJKWlpcOGDXM+02f/MSqVyvZ67L2oSkpKYmJiHIfx8fHOpZ6Mc3tkHEkA6EGsXwMAAN7IYrG0tLSIohgYGCh3LEDvio6OPn/+fNfqpqamzpgx49KlSwaDoaqqauvWrZ7XjY2NLS0tdRwWFhY6lyYkJBQVFTmvyTIYDF0LUhAEaS/87uvZqJzFxsaWlZU5Dq9cueJc2tlxdr7f3osZAPoS+SMAAOCNpMlHarVaoeDrCvzcypUrFy9eXFJSIgiCXq8vKirKzs5OT0/3pG5FRUVDQ4PJZLpx40ZBQcHatWs973fFihVLliy5du2a1Wq9ePHitm3bnEtXr16dkZFx5swZo9Go1+vPnTs3c+ZMzxtXqVTSvtc1NTUbNmwYP36853Xd8CSqru2fvXz58ueff76ystJsNn/xxRebN292Lu1wnN3cbzdHEgC8BOvXAACAN2LxGvxSZGRk65Nz5swZPHjwokWLioqKjEZjXFzcz3/+83feeUcqdbzbS1r45nK4c+fOpUuXPvbYYwMHDnzkkUcyMzPXr1/f3sUuh7Nnz7558+YDDzxQW1s7bdq0jRs3ZmVlOaKaPn26QqF47rnnLly4cMcdd/zkJz95++23Pb9Taa/ulpaWYcOGpaWlHThwwFHk/Hoyx+f2Anb54ElUVqu1C3nnp556ymQyTZw48dq1a1OnTs3Ozs7KyvJwnN3fbzdHEgC8BPtnAwAAb3T16lWTyTRkyBDeWw/3fGL/bLkD8UhDQ8OQIUN6aqEZgDaxfzZ8F/OPAACA17HZbGazWRCEoKAguWMB+oW6uro33nhj/vz5cgcCAPBSbCgAAAC8zu3bt+12u1KpVKlUcsfiFUwm07fffut4hxfQI8xm88qVKxUKhSiKsbGxwcHB2dnZcgcFAPBS5I8AAIDXMRqNApsfORFF0Wg0SsMC9BS1Wp2ZmWmz2ex2+82bN3/3u98FBAR4UjEqKkpsR1RUVG+HDQCQBevXAACA1yF/5EKlUkk79VosFuZkQXaVlZVyhwAA6GvMPwIAAN7FbrdLL1/TarVyx+ItRFGU0kbStlAAAAB9jPwRAADwLkajkc2PWlOr1YIgWCwWuQMBAAD9EfkjAADgXVi81iYpf8T8IwAAIAv2PwIAAN5Fq9XabDbyRy5YvwYAAGRE/ggAAHgXjUZD8qg15h8BnpP2m5c7CgDwK6xfAwAA8AFS/shqtdpsNrljQZ8SRVEURbmj6BxfjBkA4B75IwAAAB+gUCiUSqXAFCQfFxUV1dkqvjiPRvaYuxaATqfr8UgAwG+QPwIAAPANbIHkB65evSp3CGhXTU2N3CEAgPcifwQAAOAb2ALJj50+fXratGlhYWEajWbChAlHjx4dMWKE8wXFxcXjx49XKpVqtXrfvn3ORVlZWQsXLtTpdBERERkZGeXl5Y4iaR1Zc3NzamqqWq1uXXfz5s3R0dEhISFz5sxpbGx0WXe2f//+lJQUrVabkJCQl5fX2ZsyGo1PP/10SEjI3XffnZ2d7RyScy/SYVxcnHPd5OTk5OTkzvYoCEJxcXF7q+fcjEZsbKxURXTShd4BwI+RPwIAAPAN5I/81eHDhxctWrRkyZLy8vKmpqbt27dfuXKlvr7e+ZqlS5du2rTJYrHk5ubOnTvXuWjKlCnvvvtudXV1YWHh4MGDJ0+e7CiSlnEtX778pZdeMplMLnX37Nnz3nvvffLJJw0NDb/97W9Xr14tOK38ys3Nzc3N3bVr182bN/fs2ZOVlfXxxx936r5+85vfPPHEE9evX8/Ly/vrX/+6a9cuQRBu3bo1YsSI2tpax2VNTU3x8fGff/65c1273d61NWhxcXHtVXQzGiUlJVKp3UkXegcAP8aLCQAAAHyDwWCoqqpSq9Vd2EPHj73xxhv/+Mc/Xn75ZbkDaUNaWtqHH36YmJgYERFRXV3tXKTT6aqqqqTPo0eP3rhxY0pKSnvtiKJYU1MzZMgQx2F73+GtVqtSqXQuFUVx9+7ds2fPbl13zJgxOTk5iYmJ0uGZM2dSUlIcpSNHjjx8+HBERIR0WFxcnJ6efvLkSQ/vXRTFI0eOOJJZFy9efPzxxwsLCwVB2LRp07lz5/7yl79IRa+++mp4ePjSpUs9bNnD3tscIjej4aYW0INWrVrV0NCwbt06uQMBOk0pdwAAAADwiDT/yGKx2O12Ftc4DBw48IsvvpgzZ47cgbShsbFR+uBIFbWZobh8+fKoUaPcN+VIHrmora198803Dx48WFFRodVqx4wZ0/oaR7rERUlJSWxsrONw5MiRzqWlpaXDhg1zPqPRaNwH6eKBBx5wfI6JiSkrK5M+L1iwICsr69KlSwkJCd98880HH3zw5Zdfdqrl7mhvNAAA7pE/AgAAXsFutzc2Nmo0msDAQLlj8VJKpVKhUNhsNovFIuWSIAjCs88+++yzz8odRdtiYmI8uSw6Ovr8+fM//OEPu9BFamrq66+//tZbbwmCYDKZbty4MXz4cA/rxsbGlpaWOlJX0uQgh4SEhB07dsTHx3chKsnnn38+adIk6fPly5cdOzoFBASsWbNm+fLlH3744YoVKzIzM73z59lkMvG/IwBwYP8jAADgFW7fvn3jxg3HNA20iVew+aWVK1cuXry4pKREEAS9Xl9UVJSdnZ2enu5J3YqKioaGBilzVFBQsHbtWs/7XbFixZIlS65du2a1Wi9evLht2zbn0tWrV2dkZJw5c8ZoNOr1+nPnzs2cObNT93Xw4MGjR48aDIazZ88+88wzK1ascBQ9/PDDNpttzZo1ZWVlbU4I6vL+2d2hUqmkHbVramo2bNgwfvz4Pg4AALwZ848AAIC30Gq1SiVfTtxRq9Umk8liscgdCLooMjKy9ck5c+YMHjx40aJFRUVFRqMxLi7u5z//+TvvvCOVOt4LJi18czncuXPn0qVLH3vssYEDBz7yyCOZmZnr169v72KXw9mzZ9+8efOBBx6ora2dNm3axo0bs7KyHFFNnz5doVA899xzFy5cuOOOO37yk5+8/fbbHt6m1NHKlSufffbZn/3sZ4MGDVqxYoVL+umtt95KTEwsKChoswWr1apQdPpP3S6vdZM+OBYMuh8NQRCkHbVbWlqGDRuWlpZ24MCBzgYAAH6MLeIAAAB8xnfffVdfXx8aGjp48GC5Y0HHYmJi8vPzHRtUe7mGhoYhQ4aYTKa+6S4/P3/Hjh25ubl90x3gJdg/G76LP/EBAAD4DGmbmD77DR/9R11d3RtvvDF//vy+6a6lpSUzM/P999/vm+4AAN3H/kcAAAA+Q61Wi6LYhXU9QGtms3nlypUKhUIUxdjY2ODg4Ozs7N7uVBRFURRVKlVhYaGH+4sDALwB848AAAB8hlqtvueee5w3eQG6TK1WZ2ZmZmZmdrZiVFTU1atX2yyKjIysrKx0U5fdMwDAR5E/AgAA8CUkjyA79xkiAIBfYvIzAAAAAAAA3GH+EQAAANArzGbzgQMHLly4IHcgALzFhQsX7rzzTrmjALpCZAUyAAAA0BvCwsLUarVSyZ9sAfyf5ubm0aNHnzx5Uu5AgE7jHzMAACAzvV4fFBQUEBAgdyBAD7vrrrvy8/MTExPlDgSAt1i1alVDQ4PcUQBdwf5HAABATmazubq6uqKigjnRAAAAXov8EQAAkJNerxcEISgoiNeKAQAAeC3WrwEAADkZDAZBELRardyBAL3ivvvukzsEAN7lxRdflDsEoCvIHwEAANnY7Xaj0SiQP+qk27dv37hxQ6FQREREyB0L3CkrK5M7BAAAegb5IwAAIBuj0Wi325VKZWBgoNyx+BKFQnH79m1RFO12O+v+AABAHyB/BAAAZMPita5Rq9VDhw4NDAwkeQQAAPoG+SMAACAb8kddFhISIncIAACgH+H9awAAQB4tLS0mk0kgfwQAAOD1yB8BAAB5SDtnBwYGBgQEyB0LAAAA3CF/BAAA5MHiNQAAAF9B/ggAAMhDr9cL5I8AAAB8AfkjAAAgA5PJZLVaRVHUaDRyxwIAAIAOkD8CAAAykBavaTQa3kAPAADg/cgfAQAAGUiL14KDg+UOBAAAAB0jfwQAAPqa1WqVXr4WEhIidyw+zGaz3bx588aNG3IHAgAA/B/5IwAA0NekxWuBgYFKpVLuWHzbjRs3bt682dLSIncgAADAz5E/AgAAfa25uVlg8Vq3KRQKtVotCILJZJI7FgAA4OfIHwEAgD5lt9ul+Ufkj7ovKChIEITbt2/LHQgAAPBz5I8AAECfMhqNNpstICBAyn2gO8gfAQCAvkH+CAAA9CmLxSKKolarlTsQfxAYGCiwfg0AAPQ+Nq0EAAB9KiwsbMCAATabTe5A/EFgYKAoilar1WKxqFQqucMBAAB+i/lHAACgrykUCt681iNEUZSmILGEDQAA9CryRwAAAD6M/BEAAOgD5I8AAAB8mLSFNlsgAQCAXkX+CAAAwIc55h/Z7Xa5YwEAAH6L/BEAAIAPCwwMVCgUdrvdbDbLHQsAAPBb5I8AAAB8mzQFiSVsAACg95A/AgAA8G1soQ0AAHob+SMAANAXrFar1WqVOwr/xBbaAACgt5E/AgAAfeG7774rKyv77rvv5A7EDznyR2yhDQAAegn5IwAA0BcsFosgCGq1Wu5A/JBKpVIqlXa7nSVsAACglyjlDgAAAPQLOp3OYrEolXz36BUajebWrVtGo1Gj0cgdCwAA8EPMPwIAAH1EpVKJoih3FP5JWsJmNBrlDgQAAPgn8kcAAAA+T5p2xPo1AADQS8gfAQAA+LzAwECFQiH8c58pAACAniXyng4AAAA/0NLSwvZSAACgl5A/AgAAAAAAgDusXwMAAAAAAIA75I8AAAAAAADgDvkjAADQi8xms9whAAAAoLvIHwEAgN7S0tJSWVlZXl5us9nkjgUAAABdR/4IAAD0lubmZkEQVCqV9Gp5AAAA+Ci+zAEAgN4i5Y9CQkLkDgQAAADdQv4IAAD0ipaWFqPRKJA/koPdbpc7BAAA4FeUcgcAAAD8kzT5KCgoSKnk+0bfuXXrVn19fXBw8KBBg+SOBQAA+A/mHwEAgF7B4jW5WCyW27dvyx0FAADwK/w9EAAA9DwWr8lFq9XqdDqNRiN3IAAAwK/4c/7IbDbr9Xq5owDgdQYOHCiKotxRAH5O+ic4KChIpVLJHUv/EhAQEBwcLHcUAADA3/hz/mjnzp1PP/203FEA8Do3b94MCwuTOwrAz7F4DQAAwJ/4c/5IEISZM2fu3btX7igAeBH28QX6gNVqNRgMAvkjAAAAf8H+2QAAoIdJi9cCAwNZvAYAAOAfyB8BAIAe1tTUJAjCgAED5A4EAAAAPYP8EQAA6EkWi0V68xr5IwAAAL/BPiDwVW7en2W32/syEgCAs1u3bgmCoNVq2W4MAADAb/DFDr7KOUkkimJP5Yx6sCkA6J+k/BGTjwAAAPwJ69cAAECPMZlMZrNZFEXevCa7W7duffvtt42NjXIHAgAA/AH5I/g58Z/aO+9cJH1u83oAgCekyUfBwcEKBd8xZNbS0mI0GqV34QEAAHQT69fgz5wXo7X32fnQbrezfg0AukPKH4WGhsodCAStVisIgtFolP51kzscAADg2/jbIPyWSyaIb88A0NsMBkNLS0tAQICUuYC8AgMDAwICbDbb7du35Y4FAAD4PPJH6Kecc0lMOAKAHmGz2VQqVUhICPl6LyEl8gwGg9yBAAAAn8f6Nfiz9n6BkRJGUinJIwDoKSEhISEhITabTe5A8H+0Wu2tW7cMBsNdd90ldywAAMC3kT+CP3OfGyKLBAC9gZ2zvYc0/+j27dtWqzUgIEDucAAAgA/jGx76Ecd0JBavAQD6A6VSqVarBUEwGo1yxwIAAHwb+SP4LZcNs3mxGgCgH2ILJAAA0CPIH8GfSSkkSet3sbkvkiNeAAB6mEajEZh/BAAAuo39j+AP3Ewsaq+oC1UAAPA50vwjs9lssVhUKpXc4QAAAF/F/CMAAAC/pVAopClIer1e7lgAAIAPI38EAADgz4KDgwXyRwAAoHvIHwEAgG757rvvTCaT3FGgXVL+yGg02mw2uWMBAAC+ivwRAADoOqPRWF9f/80335Cb8FpqtVqlUtntdt7CBgAAuoz8EQAA6DqFQhEcHBwaGqpQ8KXCe0lTkMgfAQCALvPn96+dPHnyb3/7Gy9iB+CiqakpLCxM7igAPxEYGKjT6eSOAh0IDg6+efMmWyABAIAu8+f80YMPPtjQ0LB37165AwHgRZRKZWhoqNxRAECf0mg0CoWipaXFZDIFBgbKHQ4AAPA9TDUHAADwc6IoajQagbewAQCAriJ/BAAA4P+kLZDIHwEAgK7x5/VrAAAAkISEhNy+fVvKIgEAAHQW+aN/IYqi3W7vP/0CAIB+IiAgYPDgwXJHAQAAfBXr1zpNFEXe6QYAAAAAAPqPfpc/ioqKclPqySSg3pgo1LU2eV8yAAAAAADoA/0uf3T16lW5Q+gxNTU1cocAAOiPLBbLN998c+vWLbkDAQAAQB/pd/mj9hQXF7tZmLZly5a4uLiQkJBZs2bV1dW1viA5OTk5Obln+5XONzc3p6amqtVqtVq9b98+qSg2NlaqIjrpQu8AAHRBY2Pj7du3m5qa5A4EAAAAfYT80f+Ji4trbxFZTk7Otm3bjhw5Ul9f//LLL7/22mutr7Hb7V1bg+amX+n88uXLX3rpJZPJlJubO3fuXKmopKREKrU76ULvAAB0lt1ulzJHYWFhcscCAACAPtJf3r8WERFRXV0tfZam6uh0uqqqKk/qrlmzJjc39+677xYEITk5WalUZmdnu1xz9uzZngzXycSJEydMmCAIQlpamsVi6aVeAADwkF6vt1qtAQEBvAkeAACg/+gv+SNHqkgUxc5O1SkpKYmJiXEcxsfH92RkHZk9e3ZfdgcAgHvS5KPQ0FCWTgMAAPQfrF/rWGxsbFlZmePwypUrMgbjhslkkjsEAICfa2lp0ev1giCEhobKHQu6yG6337x5s6amhsXvAADAc+SPOrZ8+fLnn3++srLSbDZ/8cUXmzdvbn1Nl/fP7g6VSiXtqF1TU7Nhw4bx48f3cQAAgP5GmnwUFBSkVqvljgVdJIpiQ0NDc3OzwWCQOxYAAOAz+sv6NYfIyMjWJ51n4Ds+O/4o99RTT5lMpokTJ167dm3q1KnZ2dlZWVku6+CsVqtC0elknPt+HW9Yk864HAqCIO2o3dLSMmzYsLS0tAMHDnQ2AAAAOsWxeE3uQNAtd9xxhyAIQUFBcgcCAAB8Rqc3A/Ih77333gcffLB37165AwHgRZRKZX19Pe+NArrAYDBUVVUpFIro6Ogu/NUEAAAAvosvfwAAwCMNDQ2CIISFhZE8AgAA6G/4/gcAADpmNpul7XIGDhwodywAAADoa+SPAABAxxobGwVBCA4OVir73eaJAAAAIH8EAAA6YLPZpJ2zmXwEAADQP5E/AgAAHbh165bNZlOr1VqtVu5YAAAAIAPyRwAAoAM3b94UBIEXFwIAAPRb5I8AAIA7BoPBbDYrFIrQ0FC5YwEAAIA82AITgC+xWCwqlUruKID+Rdo5e8CAAQoFf3byN2azuaGhQRCEwYMHyx0LAADwanwR9GGFhYWiKIqiKHcgneCdMXtnVF6oz0bpxo0bkyZNcjn55ZdfLl26VKfTtb7+xIkTU6dOnThxoiiKarV63759bkrtdrtz6YMPPlhfX9/jtwD4DYvF0tzcLLBztv9qamq6deuW1WqVOxAAAODV+l3+KCoqSu4Qesx9993n8ptw32jzF3gPyRWze94ZlRfqs1F65ZVXnnnmGcdhdXX1ggULTp8+/etf/7qurq719RkZGTk5OceOHbPb7cePH58/f76bUpvN5lz6i1/84tVXX+2lGwH8gDT5SKvVqtVquWNBz1Or1YGBgXa7XcoSAgAAtKffrV+7evWq3CH4vJqaGrlDgD8rLS398ssv3333XccZnU63ZcsWN1UUCsWgQYOkz+PHj9fr9W5KXeo+8cQTa9asKS0tveeee3ogesAfKRQKds72YwMGDDCZTM3NzTxlAADgRr+bf9SezZs3R0dHh4SEzJkzp7Gx0WWdzv79+1NSUrRabUJCQl5ennNF6crm5ubU1FS1Wt167Yybuoe1g2MAACAASURBVILTgqCcnJx77703NDR01apVjtKsrKyFCxfqdLqIiIiMjIzy8vKeut/Tp09PmzYtLCxMo9FMmDDh6NGjI0aM6LDf2NhYKVrRiUvL3Yl5165d3//+94ODg8eOHbt7926XUvfPqDv3656bO9q3b59arRZFUaPRjBs3Li8vb9SoUR6WSpKTk5OTkz2MxMFl8Fs/C/dPwf1PXYdjVVxcPH78eKVS2fqnvTv9OmRnZy9cuLBTA1JbW9vlUkEQ0tPTs7OzO9Uj0H+Eh4dHR0cHBwfLHQh6S0hIiCAIBoOhpaVF7lgAAIAXs/uvrVu3zpw50+Vkm7e8e/fuBx98sKSkxGw2X7x4cdmyZc6X7dq16/HHHy8rKzOZTBcvXpw0adJHH33k0uazzz574sQJm82Wl5enUqk8rytVnzt37qOPPvrll1+azeZDhw45ikpKSqQPdXV1K1asiImJaR18Fx7ixx9/nJiY+NFHH9XX15vN5srKynfeeefOO+/0sF/3PXY55p07d86aNUuv19vtdr1eP2vWrNzcXEep+2fUzft1f19u7kilUuXl5dntdqvVWltbm5OTM2jQIA9LJePGjRs3bpyHN+JswoQJp06dkj6fOnXqoYce8jBmSXs/dR2OlSAIP/3pTy9evNj6p707/TpLTEz83//93/ZuvM3HJIqim2tal968edP5zFdffTVq1Kj2egQAv/fNN998/fXX9fX1cgcCAAC8V3/JH7Xesken0zmuHD16dGFhoePw888/d/79MyEh4dtvv3Ucfv311z/84Q+dOxIEYffu3c6HnteVrv/www87vB3pr4Ktz3chf3Tfffd99tlnHl7cul/Pe+xUzPfee+/ly5cdh5cvX7733nsdh+6fkXse3q8nDbrckVarzcrKcklGeFjaTf/93/+dnp4ufX766adzcnLau7LNp9DeT12HYyUIQk1NjfNhj/TrTKPRSGnE9gLo8GSHhy4Ppbm5OSgoyH1UAODHGhsbv/7664qKCrkDAQAA3ku0+++2we+9994HH3ywd+9e55PSTASXK0NCQm7cuKHRaKRDvV4fEhLiuCwoKMhkMjlfr9FoDAZDe206H3ZYt72QBEGora198803Dx48WFFRodVqx4wZc/To0dZXtlfdjcDAwO+++669xQgd9uumx+7ErFarGxsbHU/BaDQOHDjQMXrun1F37td9VO7v6NChQ4888ojFYlGr1f/2b/82YMCA9957LykpyZPSbjIajXFxcZcuXRIEISEhoaSkJCgoyJOY3dys4MFYuflp706/zjQaTX19vVar9SSA9qKy2WzO6/tcShsaGpzfJKXX6wcNGuTyHyYA9B82m628vNxmsw0fPtzxrwkAAIAz9j8SBEGIjY0tLS11HBYWFjqXJiQkFBUVOWfdPP89szt1U1NTZ8yYcenSJYPBUFVVtXXrVg8rdig6Ovr8+fM91a9zgqw7McfGxlZWVjoOKysrnfczdv+M3HN/v+65v6Np06aZzWaz2VxVVXXixIn58+c//PDDHpZ2k0ajSU1N3bFjx/bt29PS0py/7nfnKfTeWHnunnvuqaio6FpdB/cvonYpLS8vj42N7WaPAOC7FAqF9JeDW7duyR0LAADwUuSPBEEQVqxYsWTJkmvXrlmt1osXL27bts25dPXq1RkZGWfOnDEajXq9/ty5czNnzvSw5e7UraioaGhoMJlMN27cKCgoWLt2befuqn0rV65cvHhxSUmJIAh6vb6oqCg7Ozs9Pd3DflUqlbRrck1N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f/+mTZseeuihW265pZ4KpxP5EeplWZaqqoIg1JiBGY/HvV5vU1MTM9EAAAAAYBaZhv6jERYsWPD444/b08RGMwzjN7/5zcGDB/fv3//kk0/+9re/FUXx0Ucfve666+p9SXXUVk86c9pKKi+ya9eu22+//aqrrrIs67nnntu1a9eXvvSlOm/U39+/cuXKVatWvfjii85PjPwIs4BpmqVSSVEUVVVVVdV1XRCEcDg8f/58t0sDAAAAAEymSy+99Je//OXTTz/9iU98YswBTz/99DXXXHPppZe+8soro4/WP3+tXC4fOXLknnvuefjhhzs6On796193dXXVrs00za1bt377298e8XSzOk0wPzptJZUXyWQy8+fPL5VKgiAEg8GTJ082NTXVeaNPfvKTe/bseeONN84777wzrnDq0CSC3zNNU1GUTCYzNDQ0MDBw+PDhwcHBZDJZKBTs8EiWZRqLAAAAAKDxrF27VhCEBx98sNoA+5A9bCK8Xu/y5ct//OMfX3PNNfF4fOvWrac9RZKkLVu2CIJw8ODBCd59gk5bSSwWu/766y3LsizrhhtusMOjOj355JOapq1YsUKsYB+q3HYL/Udzmq7rmqapqqooiqZpmqaNGODxePx+v9/vDwQCfr+/2jxYAAAAAMCs1t/fv2zZsnK5/PDDD998880jjj788MPr16/3+XzvvffewoULR58+rvWzbe++++7KlSsFQTh48ODy5ctrl/fqq69ecskl1WbP1TaJ/UdjVjLiIn19fR/72Mfsjcsvv7z+G502IXI3wCEOmIsSiYQ9K80wjBGHvF6v/32BQIBlsAEAAABgLli0aNHOnTs3b968fv36vXv33nbbbStXrhRF8eDBgw8++KDdfPTtb397zPDozCxfvnzDhg27d+/eunXrT3/6U3vnypUr161bt2bNmhUrVnR2dlqWdfLkyaeeeuqee+4RBOHaa691Th/vo9bGq/5KRlizZs2ZFTBZCdcUof9oLjp27JjdaiSKot1YZKdFXq/X9Y44AAAAAIBb7rnnnm3btpmmOWK/JEnf/OY3v/a1r1U78Qz6jwRBGBwcXLZsmaIo+/fv/9CHPiTU7ME577zznnvuue7u7hrXHG+odNpDZ1xJ/TeqjfwIU6VcLmezWVEUq62ZLwhCJpMRBMGOjQiMAAAAAACOgwcPfv/733/22WdPnDhh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WMxms6lUKh6Pnzx58vjx4wMDA7VPNE2zxmQ0j8fT09OzcOHCefPmtbe3Nzc3h8Nhv99PeAQAAAAAwLRZu3bt+vXrL7744t27dx85ckTTtFwu984773znO99xxmzfvn3z5s19fX35fL5QKDz77LOf/OQnT3vlcZ11wQUXfOc730kmk+l0+qc//ekXv/jF017/j//4j//kT/7k8ssvf+KJJzKZjKIov/jFL9atW2c/f63GBRctWrRnzx7TNMd1982bN2/atOmFF17I5/MvvPDCV77ylS1bttiHent7N23atHfv3kKhsHfv3k2bNp22+Fnk95P9DMMwDMNZfsjedvbUmLC3bNmyagtU2yd6PB5WsAYAAAAAYIbr6+u7//77X3755Xg87vP5Fi9efPXVV99yyy0f+MAH7AEvvvji9u3b9+/fb5rmZZddtnXr1quuukoYay2hyj31n3X06NE777xz7969iqKce+65d9111/r16+0xtZe7fuqpp+6///79+/dnMpm2trbVq1dv3LjxqquuqnHBn/3sZ5s3b+7v7zcMw95T59137dp13333HTt2bPHixVu2bLntttucMh544IGdO3cODg4uXrz4jjvu6O3ttddRagCiZVn9/f2app12SSdJkpyZZc6kM1mWA4EA8RAAAAAAAIBj3759GzZsePvtt90uZHJ4BEGw168SBEEUxcpgaMR2taWwAAAAAAAAcPPNN2/ZsmXJkiW//vWvv/zlL2/YsMHtiiaNRxCE7u5uURRlWWbVIQAAAAAAgDOzdu3aG2+88fDhw4sXL77tttu+8pWvuF3RpKk1exAAAAAAAABgShoAAAAAAABqIT8CAAAAAABALeRHAAAAAAAAqIX8CAAAAAAAALWQHwEAAAAAgN87duzYwMCAvZ3P548ePWpvq6qaSCScYZlMplQqVZ5YOTiRSPT394+4snMFVVWPHz9+/PjxXC43Ja8Bk03+m7/5G7drAAAAAAAAM8Ljjz/+zDPPPP/88+++++6iRYs2btwYj8f379/f0dGxdevWn/zkJ3/+538uCEIul7viiiu6urpWrFhhn3jy5ElnsCAIO3fuPH78+K9+9atLL73UHvDb3/7WucJLL7309a9/fWhoKBwOL1y40K0Xi/qJlmW5XQMAAAAAAJhBstns7bff/pGPfGTlypVXXHHFpz/96Z/97GeCIKxbt+6xxx4TBGHbtm2tra0LFiy4/vrr7VO+//3vO4PPPffcz372s+eff/7atWv37NlTeWX7Ci+88MK//uu/XnfddVdffbUkMTVqFuCXBAAAAAAAfs+yrN7e3q9+9avxeLyjo2P0gBdeeOGcc85pb28XBOHw4cOvvvpqqVSqHHz55Zf/4Ac/eOihh9577z1nQOUVli9ffsMNNwwODv7FX/zFNLwiTJzH7QIAAAAAAMAMsnnz5htuuOHCCy/cv3//4ODg+eefL4pi5YDnnnsumUy+++67sizHYrFTp04tXbr0rLPOcgZfe+21y5cvVxTl4osvHhwcPHr06NKlS4PBoHOF+fPnz58/XxCE6667brpfHs4I89cAAAAAAMD/27179w9+8IPVq1efffbZN99885e//OV58+ZdcMEF69at27Zt25NPPvnFL37x7rvvFgThn//5nwOBgDN/LZlMOoPXrFnz0EMPDQ4O3nrrrWvWrHEGOFf4wAc+sHfv3sHBwY9//OMbNmxw7dWibuRHAAAAAABgbJZlKYpS2TpU5+BcLhcOh2usbZTJZEKhkNfrnbRaMZX+D8EIbOTPYe07AAAAAElFTkSuQmCC
PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiID8+CjxvdHJzX2NvbmZpZyB2ZXJzaW9uPSIxLjAiIGluaXQ9IkZyYW1ld29yayI+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJGcm9udGVuZDo6TW9kdWxlIyMjQWRtaW5HZW5lcmFsQ2F0YWxvZyIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gVHJhbnNsYXRhYmxlPSIxIj5Gcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPkZyYW1ld29yazwvR3JvdXA+CiAgICAgICAgPFN1Ykdyb3VwPkZyb250ZW5kOjpBZG1pbjo6TW9kdWxlUmVnaXN0cmF0aW9uPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPEZyb250ZW5kTW9kdWxlUmVnPgogICAgICAgICAgICAgICAgPEdyb3VwPmFkbWluPC9Hcm91cD4KICAgICAgICAgICAgICAgIDxEZXNjcmlwdGlvbiBUcmFuc2xhdGFibGU9IjEiPkFkbWluLjwvRGVzY3JpcHRpb24+CiAgICAgICAgICAgICAgICA8VGl0bGUgVHJhbnNsYXRhYmxlPSIxIj5HZW5lcmFsIENhdGFsb2c8L1RpdGxlPgogICAgICAgICAgICAgICAgPE5hdkJhck5hbWU+QWRtaW48L05hdkJhck5hbWU+CiAgICAgICAgICAgICAgICA8TmF2QmFyTW9kdWxlPgogICAgICAgICAgICAgICAgICAgIDxNb2R1bGU+S2VybmVsOjpPdXRwdXQ6OkhUTUw6Ok5hdkJhcjo6TW9kdWxlQWRtaW48L01vZHVsZT4KICAgICAgICAgICAgICAgICAgICA8TmFtZSBUcmFuc2xhdGFibGU9IjEiPkdlbmVyYWwgQ2F0YWxvZzwvTmFtZT4KICAgICAgICAgICAgICAgICAgICA8RGVzY3JpcHRpb24gVHJhbnNsYXRhYmxlPSIxIj5DcmVhdGUgYW5kIG1hbmFnZSB0aGUgR2VuZXJhbCBDYXRhbG9nLjwvRGVzY3JpcHRpb24+CiAgICAgICAgICAgICAgICAgICAgPEJsb2NrPlRpY2tldDwvQmxvY2s+CiAgICAgICAgICAgICAgICAgICAgPFByaW8+NDEwPC9QcmlvPgogICAgICAgICAgICAgICAgPC9OYXZCYXJNb2R1bGU+CiAgICAgICAgICAgIDwvRnJvbnRlbmRNb2R1bGVSZWc+CiAgICAgICAgPC9TZXR0aW5nPgogICAgPC9Db25maWdJdGVtPgogICAgPENvbmZpZ0l0ZW0gTmFtZT0iR2VuZXJhbENhdGFsb2dQcmVmZXJlbmNlcyMjI0NvbW1lbnQyIiBSZXF1aXJlZD0iMCIgVmFsaWQ9IjAiPgogICAgICAgIDxEZXNjcmlwdGlvbiBUcmFuc2xhdGFibGU9IjEiPlBhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8R3JvdXA+R2VuZXJhbENhdGFsb2c8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5HZW5lcmFsQ2F0YWxvZzo6UHJlZmVyZW5jZXM8L1N1Ykdyb3VwPgogICAgICAgIDxTZXR0aW5nPgogICAgICAgICAgICA8SGFzaD4KICAgICAgICAgICAgICAgIDxJdGVtIEtleT0iTW9kdWxlIj5LZXJuZWw6Ok91dHB1dDo6SFRNTDo6R2VuZXJhbENhdGFsb2dQcmVmZXJlbmNlczo6R2VuZXJpYzwvSXRlbT4KICAgICAgICAgICAgICAgIDxJdGVtIEtleT0iTGFiZWwiPkNvbW1lbnQyPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJEZXNjIj5EZWZpbmUgdGhlIGdlbmVyYWwgY2F0YWxvZyBjb21tZW50IDIuPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJCbG9jayI+VGV4dEFyZWE8L0l0ZW0+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IkNvbHMiPjUwPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJSb3dzIj41PC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJQcmVmS2V5Ij5Db21tZW50MjwvSXRlbT4KICAgICAgICAgICAgPC9IYXNoPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkdlbmVyYWxDYXRhbG9nUHJlZmVyZW5jZXMjIyNQZXJtaXNzaW9ucyIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIwIj4KICAgICAgICA8RGVzY3JpcHRpb24gVHJhbnNsYXRhYmxlPSIxIj5QYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBwZXJtaXNzaW9uIGdyb3VwcyBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8R3JvdXA+R2VuZXJhbENhdGFsb2c8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5HZW5lcmFsQ2F0YWxvZzo6UHJlZmVyZW5jZXM8L1N1Ykdyb3VwPgogICAgICAgIDxTZXR0aW5nPgogICAgICAgICAgICA8SGFzaD4KICAgICAgICAgICAgICAgIDxJdGVtIEtleT0iTW9kdWxlIj5LZXJuZWw6Ok91dHB1dDo6SFRNTDo6R2VuZXJhbENhdGFsb2dQcmVmZXJlbmNlczo6R2VuZXJpYzwvSXRlbT4KICAgICAgICAgICAgICAgIDxJdGVtIEtleT0iTGFiZWwiPlBlcm1pc3Npb25zPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJEZXNjIj5EZWZpbmUgdGhlIGdyb3VwIHdpdGggcGVybWlzc2lvbnMuPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJCbG9jayI+UGVybWlzc2lvbjwvSXRlbT4KICAgICAgICAgICAgICAgIDxJdGVtIEtleT0iQ2xhc3MiPklUU006OkNvbmZpZ0l0ZW06OkNsYXNzPC9JdGVtPgogICAgICAgICAgICAgICAgPEl0ZW0gS2V5PSJQcmVmS2V5Ij5QZXJtaXNzaW9uczwvSXRlbT4KICAgICAgICAgICAgPC9IYXNoPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IkxvYWRlcjo6QWdlbnQ6OkNvbW1vbkpTIyMjMTAwLUdlbmVyYWxDYXRhbG9nIiBSZXF1aXJlZD0iMSIgVmFsaWQ9IjEiPgogICAgICAgIDxEZXNjcmlwdGlvbiBUcmFuc2xhdGFibGU9IjEiPkxpc3Qgb2YgSlMgZmlsZXMgdG8gYWx3YXlzIGJlIGxvYWRlZCBmb3IgdGhlIGFnZW50IGludGVyZmFjZS48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5GcmFtZXdvcms8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5Db3JlOjpXZWI8L1N1Ykdyb3VwPgogICAgICAgIDxTZXR0aW5nPgogICAgICAgICAgICA8QXJyYXk+CiAgICAgICAgICAgICAgICA8SXRlbT50aGlyZHBhcnR5L2pzY29sb3JfMS40LjEvanNjb2xvci5qczwvSXRlbT4KICAgICAgICAgICAgPC9BcnJheT4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+Cjwvb3Ryc19jb25maWc+Cg==
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6YmdfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ9Ck0YPQvdC60YbQuNC+0L3QsNC70L3QvtGB0YInOwoKICAgICMgVGVtcGxhdGU6IEFkbWluR2VuZXJhbENhdGFsb2cKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyBNYW5hZ2VtZW50J30gPSAn0KPQv9GA0LDQstC70LXQvdC40LUg0L3QsCDQvtGB0L3QvtCy0L3QuNGPINC60LDRgtCw0LvQvtCzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICfQlNC+0LHQsNCy0Lgg0LXQu9C10LzQtdC90YIg0LrRitC8INC60LDRgtCw0LvQvtCz0LAnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICfQlNC+0LHQsNCy0Lgg0LrQu9Cw0YEg0LIg0LrQsNGC0LDQu9C+0LPQsCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAn0JrQu9Cw0YHQvtCy0LUg0LIg0LrQsNGC0LDQu9C+0LPQsCc7CgogICAgIyBTeXNDb25maWcKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkbWluLid9ID0gJyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDcmVhdGUgYW5kIG1hbmFnZSB0aGUgR2VuZXJhbCBDYXRhbG9nLid9ID0gJyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLid9ID0KICAgICAgICAnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyd9ID0gJ9Ce0YHQvdC+0LLQtdC9INC60LDRgtCw0LvQvtCzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnJzsKCn0KCjE7Cg==
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6Y3NfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmtjaW9uYWxpdGEnOwoKICAgICMgVGVtcGxhdGU6IEFkbWluR2VuZXJhbENhdGFsb2cKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyBNYW5hZ2VtZW50J30gPSAnU3Byw6F2YSBIbGF2bsOtaG8gS2F0YWxvZ3UnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgSXRlbSd9ID0gJ1DFmWlkYXQgcG9sb8W+a3UgS2F0YWxvZ3UnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICdQxZlpZGF0IHTFmcOtZHUgS2F0YWxvZ3UnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2F0YWxvZyBDbGFzcyd9ID0gJ1TFmcOtZHkgS2F0YWxvZ3UnOwoKICAgICMgU3lzQ29uZmlnCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZG1pbi4nfSA9ICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ3JlYXRlIGFuZCBtYW5hZ2UgdGhlIEdlbmVyYWwgQ2F0YWxvZy4nfSA9ICdWeXR2b8WZaXQgYSBzcHJhdm92YXQgaGxhdm7DrSBrYXRhbG9nJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICdGcm9udGVuZG92w6EgcmVnaXN0cmFjZSBtb2R1bHUgcHJvIGtvbmZpZ3VyYWNpIGhsYXZuw61obyBrYXRhbG9ndSB2IGFkbWluaXN0cmF0aXZuw60gb2JsYXN0aS4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nJ30gPSAnSGxhdm7DrSBLYXRhbG9nJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQxZnDrWtsYWQgcGFyYW1ldHLFryBwcm8ga29tZW50w6HFmSAyIG9iZWNuw71jaCBhdHJpYnV0xa8ga2F0YWxvZ3UnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyYW1ldHJ5IHNrdXBpbnkgcHJvIHDFmcOta2xhZCBvcHLDoXZuxJtuw60gb2JlY27DvWNoIGF0cmlidXTFryBrYXRhbG9ndSc7Cgp9CgoxOwo=
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZGFfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmt0aW9uYWxpdGV0JzsKCiAgICAjIFRlbXBsYXRlOiBBZG1pbkdlbmVyYWxDYXRhbG9nCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ0dlbmVyYWwgS2F0YWxvZyBNYW5hZ2VtZW50JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdUaWxmw7hqIGthdGFsb2cgcG9zdCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBDbGFzcyd9ID0gJ1RpbGbDuGogS2F0YWxvZyBrbGFzc2UnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2F0YWxvZyBDbGFzcyd9ID0gJ0thdGFsb2cgS2xhc3NlJzsKCiAgICAjIFN5c0NvbmZpZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRtaW4uJ30gPSAnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NyZWF0ZSBhbmQgbWFuYWdlIHRoZSBHZW5lcmFsIENhdGFsb2cuJ30gPSAnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nJ30gPSAnR2VuZXJhbCBLYXRhbG9nJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnJzsKCn0KCjE7Cg==
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZGVfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmt0aW9uYWxpdMOkdCc7CgogICAgIyBUZW1wbGF0ZTogQWRtaW5HZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nIE1hbmFnZW1lbnQnfSA9ICdHZW5lcmFsLUthdGFsb2ctVmVyd2FsdHVuZyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBJdGVtJ30gPSAnS2F0YWxvZy1FaW50cmFnIGhpbnp1ZsO8Z2VuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIENsYXNzJ30gPSAnS2F0YWxvZy1LbGFzc2UgaGluenVmw7xnZW4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2F0YWxvZyBDbGFzcyd9ID0gJ0thdGFsb2ctS2xhc3NlJzsKCiAgICAjIFN5c0NvbmZpZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRtaW4uJ30gPSAnQWRtaW4uJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NyZWF0ZSBhbmQgbWFuYWdlIHRoZSBHZW5lcmFsIENhdGFsb2cuJ30gPSAnR2VuZXJhbC1LYXRhbG9nIGVyc3RlbGxlbiB1bmQgdmVyd2FsdGVuLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLid9ID0KICAgICAgICAnRnJvbnRlbmRtb2R1bC1SZWdpc3RyYXRpb24gZGVyIEFkbWluR2VuZXJhbENhdGFsb2cgS29uZmlndXJhdGlvbiBpbSBBZG1pbi1CZXJlaWNoLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cnfSA9ICdHZW5lcmFsLUthdGFsb2cnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgY29tbWVudCAyIG9mIHRoZSBnZW5lcmFsIGNhdGFsb2cgYXR0cmlidXRlcy4nfSA9CiAgICAgICAgJ1BhcmFtZXRlciBmw7xyIGRlbiBCZWlzcGllbC1Lb21tZW50YXIgMiBkZXIgR2VuZXJhbC1LYXRhbG9nLUF0dHJpYnV0ZS4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyYW1ldGVyIGbDvHIgZGllIHp1Z3JpZmZzYmVyZWNodGlndGUgR3J1cHBlIGRlciBHZW5lcmFsLUthdGFsb2ctQXR0cmlidXRlLic7Cgp9CgoxOwo=
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZXNfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmNpb25hbGlkYWQnOwoKICAgICMgVGVtcGxhdGU6IEFkbWluR2VuZXJhbENhdGFsb2cKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyBNYW5hZ2VtZW50J30gPSAnR2VzdGnDs24gZGVsIENhdMOhbG9nbyBHZW5lcmFsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdBw7FhZGlyIEVsZW1lbnRvIGFsIENhdMOhbG9nbyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBDbGFzcyd9ID0gJ0HDsWFkaXIgQ2xhc2UgYWwgQ2F0w6Fsb2dvJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhdGFsb2cgQ2xhc3MnfSA9ICdDbGFzZSBkZSBDYXTDoWxvZ28nOwoKICAgICMgU3lzQ29uZmlnCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZG1pbi4nfSA9ICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ3JlYXRlIGFuZCBtYW5hZ2UgdGhlIEdlbmVyYWwgQ2F0YWxvZy4nfSA9ICdDcmVhciB5IGFkbWluaXN0cmFyIGVsIENhdMOhbG9nbyBHZW5lcmFsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICdFbCBGcm9udGVuZCBkZWwgcmVnaXN0cm8gZGVsIG3Ds2R1bG8gcGFyYSBsYSBjb25maWd1cmFjacOzbiBkZWwgQWRtaW5HZW5lcmFsQ2F0YWxvZyBlbiBlbCDDoXJlYSBhZG1pbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cnfSA9ICdDYXTDoWxvZ28gR2VuZXJhbCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBjb21tZW50IDIgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyw6FtZXRyb3MgcGFyYSBlbCBlamVtcGxvIGNvbWVudGFyaW8gMiBkZSBsb3MgYXRyaWJ1dG9zIGRlbCBjYXTDoWxvZ28gZ2VuZXJhbC4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyw6FtZXRyb3MgcGFyYSBsb3MgcGVybWlzb3MgZGUgZWplbXBsbyBkZSBsb3MgYXRyaWJ1dG9zIGRlbCBjYXTDoWxvZ28gZ2VuZXJhbC4nOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZmFfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ9qp2KfYsdqp2LHYr9uMJzsKCiAgICAjIFRlbXBsYXRlOiBBZG1pbkdlbmVyYWxDYXRhbG9nCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ9mF2K/bjNix24zYqiDZgdmH2LHYs9iqINi52YXZiNmF24wnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgSXRlbSd9ID0gJ9in2LbYp9mB2Ycg2qnYsdiv2YYg24zaqSDZgtmE2YUg2YHZh9ix2LPYqic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBDbGFzcyd9ID0gJ9in2LbYp9mB2Ycg2qnYsdiv2YYg2qnZhNin2LMg2YHZh9ix2LPYqtuMJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhdGFsb2cgQ2xhc3MnfSA9ICfZgdmH2LHYs9iqINqp2YTYp9iz24wnOwoKICAgICMgU3lzQ29uZmlnCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZG1pbi4nfSA9ICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ3JlYXRlIGFuZCBtYW5hZ2UgdGhlIEdlbmVyYWwgQ2F0YWxvZy4nfSA9ICfYs9in2K7YqiDZiCDZhdiv24zYsduM2Kog2YHZh9ix2LPYqiDYudmF2YjZhduMJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICfYq9io2Kog2YXYp9qY2YjZhCDYqNix2KfbjCDZvtuM2qnYsdio2YbYr9uMINmB2YfYsdiz2Kog2LnZhdmI2YXbjCDYr9ixINio2K7YtCDZhdiv24zYsduM2KonOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nJ30gPSAn2YHZh9ix2LPYqiDYudmF2YjZhduMJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICfZvtin2LHYp9mF2KrYsdmH2KfbjNuMINio2LHYp9uMINiq2YjYttuM2K0g2YbZhdmI2YbZhyDbsiDZhdix2KjZiNi3INio2Ycg2YjbjNqY2q/bjOKAjNmH2KfbjCDZgdmH2LHYs9iqINi52YXZiNmF24wnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAn2b7Yp9ix2KfZhdiq2LHZh9in24zbjCDYqNix2KfbjCDar9ix2YjZh+KAjNmH2KfbjCDYr9iz2KrYsdiz24wg2YbZhdmI2YbZhyDZhdix2KjZiNi3INio2Ycg2YjbjNqY2q/bjOKAjNmH2KfbjCDZgdmH2LHYs9iqINi52YXZiNmF24wnOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZnJfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0ZvbmN0aW9ubmFsaXTDqSc7CgogICAgIyBUZW1wbGF0ZTogQWRtaW5HZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nIE1hbmFnZW1lbnQnfSA9ICdHZXN0aW9uIGR1IENhdGFsb2d1ZSBHw6luw6lyYWwnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgSXRlbSd9ID0gJ0Fqb3V0ZXIgdW4gRWxlbWVudCBhdSBDYXRhbG9ndWUnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICdBam91dGVyIHVuZSBDbGFzc2UgZGUgQ2F0YWxvZ3VlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhdGFsb2cgQ2xhc3MnfSA9ICdDbGFzc2UgZGUgQ2F0YWxvZ3VlJzsKCiAgICAjIFN5c0NvbmZpZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRtaW4uJ30gPSAnQWRtaW5pc3RyYXRldXIuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NyZWF0ZSBhbmQgbWFuYWdlIHRoZSBHZW5lcmFsIENhdGFsb2cuJ30gPSAnQ3LDqWVyIGV0IGfDqXJlciBsZSBDYXRhbG9ndWUgR8OpbsOpcmFsLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLid9ID0KICAgICAgICAnSW50ZXJmYWNlIGRcJ2VucmVnaXN0cmVtZW50IGRlIG1vZHVsZSBwb3VyIGxhIGNvbmZpZ3VyYXRpb24gZHUgQ2F0YWxvZ3VlIEfDqW7DqXJhbCBBZG1pbiBkYW5zIGxhIHNlY3Rpb24gYWRtaW5pc3RyYXRldXInOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nJ30gPSAnQ2F0YWxvZ3VlIEfDqW7DqXJhbCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBjb21tZW50IDIgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyYW3DqHRyZXMgcG91ciBsXCdleGVtcGxlIGR1IGNvbW1lbnRhaXJlIDIgZGVzIGF0dHJpYnV0cyBkdSBDYXRhbG9ndWUgR8OpbsOpcmFsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIHBlcm1pc3Npb24gZ3JvdXBzIG9mIHRoZSBnZW5lcmFsIGNhdGFsb2cgYXR0cmlidXRlcy4nfSA9CiAgICAgICAgJ1BhcmFtw6h0cmVzIHBvdXIgbFwnZXhlbXBsZSBkZXMgcGVybWlzc2lvbnMgZGUgZ3JvdXBlIGRlcyBhdHRyaWJ1dHMgZHUgQ2F0YWxvZ3VlIEfDqW7DqXJhbCc7Cgp9CgoxOwo=
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6aHVfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmtjaW9uYWxpdMOhcyc7CgogICAgIyBUZW1wbGF0ZTogQWRtaW5HZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nIE1hbmFnZW1lbnQnfSA9ICfDgWx0YWzDoW5vcyBrYXRhbMOzZ3VzIGtlemVsw6lzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdLYXRhbMOzZ3VzZWxlbSBob3p6w6FhZMOhc2EnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICdLYXRhbMOzZ3Vzb3N6dMOhbHkgaG96esOhYWTDoXNhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhdGFsb2cgQ2xhc3MnfSA9ICdLYXRhbMOzZ3Vzb3N6dMOhbHknOwoKICAgICMgU3lzQ29uZmlnCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZG1pbi4nfSA9ICdBZG1pbmlzenRyw6FjacOzLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDcmVhdGUgYW5kIG1hbmFnZSB0aGUgR2VuZXJhbCBDYXRhbG9nLid9ID0gJ0F6IMOhbHRhbMOhbm9zIGthdGFsw7NndXMgbMOpdHJlaG96w6FzYSDDqXMga2V6ZWzDqXNlLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLid9ID0KICAgICAgICAnRWzFkXTDqXRwcm9ncmFtIG1vZHVsIHJlZ2lzenRyw6FjacOzIGF6IGFkbWluaXN6dHLDoWNpw7NzIHRlcsO8bGV0ZW4gbMOpdsWRIEFkbWluR2VuZXJhbENhdGFsb2cgYmXDoWxsw610w6FzaG96Lic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cnfSA9ICfDgWx0YWzDoW5vcyBrYXRhbMOzZ3VzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQYXJhbcOpdGVyZWsgYXogw6FsdGFsw6Fub3Mga2F0YWzDs2d1cyBhdHRyaWLDunR1bWFpbmFrIDIuIHDDqWxkYSBtZWdqZWd5esOpc2VpaGV6Lic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBwZXJtaXNzaW9uIGdyb3VwcyBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQYXJhbcOpdGVyZWsgYXogw6FsdGFsw6Fub3Mga2F0YWzDs2d1cyBhdHRyaWLDunR1bWFpbmFrIHDDqWxkYSBqb2dvc3VsdHPDoWcgY3NvcG9ydGphaWhvei4nOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6aXRfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bnppb25hbGl0w6AnOwoKICAgICMgVGVtcGxhdGU6IEFkbWluR2VuZXJhbENhdGFsb2cKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyBNYW5hZ2VtZW50J30gPSAnR2VzdGlvbmUgZGVsIENhdGFsb2dvIEdlbmVyYWxlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdBZ2dpdW5naSBFbGVtZW50byBhbCBDYXRhbG9nbyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBDbGFzcyd9ID0gJ0FnZ2l1bmdpIENsYXNzZSBhbCBDYXRhbG9nbyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAnQ2xhc3NlIGRpIENhdGFsb2dvJzsKCiAgICAjIFN5c0NvbmZpZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRtaW4uJ30gPSAnQWRtaW4uJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NyZWF0ZSBhbmQgbWFuYWdlIHRoZSBHZW5lcmFsIENhdGFsb2cuJ30gPSAnQ3JlYSBlIGdlc3Rpc2NpIGlsIENhdGFsb2dvIEdlbmVyYWxlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICdNb2R1bG8gZGkgcmVnaXN0cmF6aW9uZSBwZXIgbGEgY29uZmlndXJhemlvbmUgZGkgQWRtaW5HZW5lcmFsQ2F0YWxvZyBuZWxsXCdhcmVhIGRpIGFkbWluLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cnfSA9ICdDYXRhbG9nbyBHZW5lcmFsZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBjb21tZW50IDIgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyYW1ldHJpIHBlciBpbCBjb21tZW50byBkaSBlc2VtcGlvIDIgZGVnbGkgYXR0cmlidXRpIGRlbCBjYXRhbG9nbyBnZW5lcmFsZS4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyYW1ldHJpIHBlciBpIGdydXBwaSBkaSBwZXJtZXNzaSBkaSBlc2VtcGlvIGRlZ2xpIGF0dHJpYnV0aSBkZWwgY2F0YWxvZ28gZ2VuZXJhbGUuJzsKCn0KCjE7Cg==
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6amFfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ+apn+iDveaApyc7CgogICAgIyBUZW1wbGF0ZTogQWRtaW5HZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nIE1hbmFnZW1lbnQnfSA9ICfkuIDoiKzjgqvjgr/jg63jgrDnrqHnkIYnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgSXRlbSd9ID0gJ+OCq+OCv+ODreOCsOmgheebruOCkui/veWKoCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBDbGFzcyd9ID0gJ+OCq+OCv+ODreOCsOOCr+ODqeOCueOCkui/veWKoCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAn44Kr44K/44Ot44Kw44Kv44Op44K5JzsKCiAgICAjIFN5c0NvbmZpZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRtaW4uJ30gPSAnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NyZWF0ZSBhbmQgbWFuYWdlIHRoZSBHZW5lcmFsIENhdGFsb2cuJ30gPSAn44K444Kn44ON44Op44Or44Kr44K/44Ot44Kw44Gu5L2c5oiQ44Go566h55CGJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICfnrqHnkIbjgqjjg6rjgqLjgafjga5BZG1pbkdlbmVyYWxDYXRhbG9n44Gu44OV44Ot44Oz44OI44Ko44Oz44OJ44Oi44K444Ol44O844Or44Gu55m76YyyJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyd9ID0gJ+OCuOOCp+ODjeODqeODq+OCq+OCv+ODreOCsCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBjb21tZW50IDIgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAn44K444Kn44ON44Op44Or44Kr44K/44Ot44Kw5bGe5oCn44Gu44Kz44Oh44Oz44OI5L6LIDLjgIDjga7oqK3lrprlgKQnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAn44K444Kn44ON44Op44Or44Kr44K/44Ot44Kw5bGe5oCn44Gu44OR44O844Of44OD44K344On44Oz44Kw44Or44O844OX44CA44Gu6Kit5a6a5YCkJzsKCn0KCjE7Cg==
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6bXNfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmdzaSc7CgogICAgIyBUZW1wbGF0ZTogQWRtaW5HZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nIE1hbmFnZW1lbnQnfSA9ICdLYXRhbG9nIFBlbmd1cnVzYW4gR2VuZXJhbCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBJdGVtJ30gPSAnVGFtYmFoYW4gSXRlbSBLYXRhbG9nJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIENsYXNzJ30gPSAnVGFtYmFoIEtlbGFzIEthdGFsb2cnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2F0YWxvZyBDbGFzcyd9ID0gJ0tlbGFzIEthdGFsb2cnOwoKICAgICMgU3lzQ29uZmlnCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZG1pbi4nfSA9ICdBZG1pbi4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ3JlYXRlIGFuZCBtYW5hZ2UgdGhlIEdlbmVyYWwgQ2F0YWxvZy4nfSA9ICdDaXB0YSBkYW4gdXJ1cyBLYXRhbG9nIEdlbmVyYWwuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICdNb2R1bCBwZW5kYWZ0YXJhbiBtdWthIGhhZGFwYW4gYmFnaSBrb25maWd1cmFzaSBLYXRhbG9nVW11bVRhZGJpciBkYWxhbSBydWFuZ2FuIHBlbnRhZGJpci4gJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyd9ID0gJ0thdGFsb2cgR2VuZXJhbCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBjb21tZW50IDIgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyYW1ldGVyIHVudHVrIGNvbnRvaCBrb21lbiAyIHBhZGEgY2lyaS1jaXJpIGthdGFsb2cuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIHBlcm1pc3Npb24gZ3JvdXBzIG9mIHRoZSBnZW5lcmFsIGNhdGFsb2cgYXR0cmlidXRlcy4nfSA9CiAgICAgICAgJ1BhcmFtZXRlciB1bnR1ayBjb250b2gga3VtcHVsYW4geWFuZyBkaWJlbmFya2FuIHBhZGEgY2lyaS1jaXJpIGthdGFsb2cuJzsKCn0KCjE7Cg==
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6bmJfTk9fR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmtzam9uYWxpdGV0JzsKCiAgICAjIFRlbXBsYXRlOiBBZG1pbkdlbmVyYWxDYXRhbG9nCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ0FkbWluaXN0cmFzam9uIGF2IEdlbmVyZWxsIEthdGFsb2cnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgSXRlbSd9ID0gJ0xlZ2cgdGlsIGthdGFsb2dvYmpla3QnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICdMZWdnIHRpbCBrYXRhbG9nLWtsYXNzZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAnS2F0YWxvZy1rbGFzc2UnOwoKICAgICMgU3lzQ29uZmlnCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZG1pbi4nfSA9ICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ3JlYXRlIGFuZCBtYW5hZ2UgdGhlIEdlbmVyYWwgQ2F0YWxvZy4nfSA9ICdPcHByZXR0IG9nIGFkbWluaXN0csOpciBkZW4gZ2VuZXJlbGxlIGthdGFsb2dlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLid9ID0KICAgICAgICAnRm9yc2lkZW1vZHVsLXJlZ2lzdHJlcmluZyBmb3IgQWRtaW5HZW5lcmFsQ2F0YWxvZy1vcHBzZXR0IGkgYWRtaW4tZGVsZW4uJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyd9ID0gJ0dlbmVyZWxsIEthdGFsb2cnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgY29tbWVudCAyIG9mIHRoZSBnZW5lcmFsIGNhdGFsb2cgYXR0cmlidXRlcy4nfSA9CiAgICAgICAgJ1BhcmFtZXRyZSBmb3IgZWtzZW1wZWxrb21tZW50YXIgMiBpIGF0dHJpYnV0dGVuZSBmb3IgZ2VuZXJlbGwga2F0YWxvZyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBwZXJtaXNzaW9uIGdyb3VwcyBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQYXJhbWV0ZXJlIGZvciB0aWxnYW5nc2dydXBwZS1la3NlbXBlbCBpIGF0dHJpYnV0dGVuZSBmb3IgZ2VuZXJlbGwga2F0YWxvZy4nOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6bmxfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmN0aW9uYWxpdGVpdCc7CgogICAgIyBUZW1wbGF0ZTogQWRtaW5HZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nIE1hbmFnZW1lbnQnfSA9ICdDYXRhbG9ndXMgQmVoZWVyJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdDYXRhbG9ndXMtaXRlbSB0b2V2b2VnZW4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICdDYXRhbG9ndXMta2xhc3NlIHRvZXZvZWdlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAnQ2F0YWxvZ3VzIGtsYXNzZSc7CgogICAgIyBTeXNDb25maWcKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkbWluLid9ID0gJyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDcmVhdGUgYW5kIG1hbmFnZSB0aGUgR2VuZXJhbCBDYXRhbG9nLid9ID0gJ0Fhbm1ha2VuIGVuIGJlaGVyZW4gdmFuIGl0ZW1zIGluIGRlIGNhdGFsb2d1cy4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnJvbnRlbmQgbW9kdWxlIHJlZ2lzdHJhdGlvbiBmb3IgdGhlIEFkbWluR2VuZXJhbENhdGFsb2cgY29uZmlndXJhdGlvbiBpbiB0aGUgYWRtaW4gYXJlYS4nfSA9CiAgICAgICAgJ0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpZSB2b29yIGRlIEFkbWluR2VuZXJhbENhdGFsb2cgY29uZmlndXJhdGllIGluIGhldCBiZWhlZXIgZGVlbC4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nJ30gPSAnQ2F0YWxvZ3VzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQYXJhbWV0ZXJzIHZvb3IgaGV0IHZvb3JiZWVsZCBjb21tZW50YWFyIDIgdmFuIGRlIGFsZ2VtZW5lIGNhdGFsb2cgYXR0cmlidXRlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBwZXJtaXNzaW9uIGdyb3VwcyBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQYXJhbWV0ZXJzIHZvb3IgZGUgdm9vcmJlZWxkIHBlcmltc3NpZWdyb2VwZW4gdmFuIGRlIGFsZ2VtZW5lIGNhdGFsb2cgYXR0cmlidXRlbi4nOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6cGxfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmtjam9uYWxub8WbxIcnOwoKICAgICMgVGVtcGxhdGU6IEFkbWluR2VuZXJhbENhdGFsb2cKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyBNYW5hZ2VtZW50J30gPSAnWmFyesSFZHphbmllIGthdGFsb2dpZW0gZ8WCw7N3bnltJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdEb2RhaiBlbGVtZW50IGthdGFsb2d1JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIENsYXNzJ30gPSAnRG9kYWoga2xhc8SZIGthdGFsb2d1JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhdGFsb2cgQ2xhc3MnfSA9ICdLbGFzYSBrYXRhbG9ndSc7CgogICAgIyBTeXNDb25maWcKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkbWluLid9ID0gJyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDcmVhdGUgYW5kIG1hbmFnZSB0aGUgR2VuZXJhbCBDYXRhbG9nLid9ID0gJ1V0d8OzcnogaSB6YXJ6xIVkemFqIGthdGFsb2dpZW0gZ8WCw7N3bnltLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLid9ID0KICAgICAgICAnUmVqZXN0cmFjamEgbW9kdcWCdSBmcm9udGVuZCBkbyBrb25maWd1cmFjamkgbW9kdcWCdSBBZG1pbkdlbmVyYWxDYXRhbG9nIHcgcGFuZWx1IGFkbWluaXN0cmF0b3JhLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cnfSA9ICdLYXRhbG9nIGfFgsOzd255JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQYXJhbWV0cnkgZG8gcHJ6eWvFgmFkb3dlZ28ga29tZW50YXJ6YSAyIGF0cnlidXTDs3cga2F0YWxvZ3UgZ2VuZXJhbG5lZ28uJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIHBlcm1pc3Npb24gZ3JvdXBzIG9mIHRoZSBnZW5lcmFsIGNhdGFsb2cgYXR0cmlidXRlcy4nfSA9CiAgICAgICAgJ1BhcmFtZXRyeSBkbGEgcHJ6eWvFgmFkb3d5Y2ggZ3J1cCB1cHJhd25pZcWEIGF0cnlidXTDs3cga2F0YWxvZ3UgZ8WCw7N3bmVnby4nOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6cHRfQlJfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmNpb25hbGlkYWRlJzsKCiAgICAjIFRlbXBsYXRlOiBBZG1pbkdlbmVyYWxDYXRhbG9nCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ0dlcmVuY2lhbWVudG8gZG8gQ2F0w6Fsb2dvIEdlcmFsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdBZGljaW9uYXIgSXRlbSBhbyBDYXTDoWxvZ28nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICdBZGljaW9uYXIgQ2xhc3NlIGFvIENhdMOhbG9nbyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAnQ2xhc3NlIGRvIENhdMOhbG9nbyc7CgogICAgIyBTeXNDb25maWcKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkbWluLid9ID0gJ0FkbWluaXN0cmHDp8Ojby4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ3JlYXRlIGFuZCBtYW5hZ2UgdGhlIEdlbmVyYWwgQ2F0YWxvZy4nfSA9ICdDcmlhciBlIGdlcmVuY2lhciBvIENhdMOhbG9nbyBHZXJhbC4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnJvbnRlbmQgbW9kdWxlIHJlZ2lzdHJhdGlvbiBmb3IgdGhlIEFkbWluR2VuZXJhbENhdGFsb2cgY29uZmlndXJhdGlvbiBpbiB0aGUgYWRtaW4gYXJlYS4nfSA9CiAgICAgICAgJ03Ds2R1bG8gZGUgcmVnaXN0byBkYSBpbnRlcmZhY2UgcGFyYSBhIGNvbmZpZ3VyYcOnw6NvIEFkbWluR2VuZXJhbENhdGFsb2cgbmEgw6FyZWEgYWRtaW5pc3RyYXRpdmEuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyd9ID0gJ0NhdMOhbG9nbyBHZXJhbCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBjb21tZW50IDIgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyw6JtZXRyb3MgcGFyYSBvIGNvbWVudMOhcmlvIGRlIGV4ZW1wbG8gMiBkb3MgYXRyaWJ1dG9zIGRvIGNhdMOhbG9nbyBnZXJhbC4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnUGFyw6JtZXRyb3MgZG8gZ3J1cG9zIGRlIHBlcm1pc3PDo28gZGUgZXhlbXBsbyBkb3MgYXRyaWJ1dG9zIGRvIGNhdMOhbG9nbyBnZXJhbC4nOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6cHRfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmNpb25hbEFudGlndWlkYWRlJzsKCiAgICAjIFRlbXBsYXRlOiBBZG1pbkdlbmVyYWxDYXRhbG9nCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ0dlc3TDo28gZG8gQ2F0w6Fsb2dvIEdlcmFsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdBZGljaW9uYXIgSXRlbSBhbyBDYXTDoWxvZ28nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICdBZGljaW9uYXIgQ2xhc3NlIGFvIENhdMOhbG9nbyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAnQ2xhc3NlIGRvIENhdMOhbG9nbyc7CgogICAgIyBTeXNDb25maWcKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkbWluLid9ID0gJ0FkbWluaXN0cmHDp8Ojby4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ3JlYXRlIGFuZCBtYW5hZ2UgdGhlIEdlbmVyYWwgQ2F0YWxvZy4nfSA9ICdDcmlhciBlIGdlcmlyIG8gQ2F0w6Fsb2dvIEdlcmFsLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLid9ID0KICAgICAgICAnTcOzZHVsbyBkZSByZWdpc3RvIGRhIGludGVyZmFjZSBwYXJhIGEgY29uZmlndXJhw6fDo28gQWRtaW5HZW5lcmFsQ2F0YWxvZyBuYSDDoXJlYSBhZG1pbmlzdHJhdGl2YS4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nJ30gPSAnQ2F0w6Fsb2dvIEdlcmFsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQYXLDom1ldHJvcyBwYXJhIG8gY29tZW50w6FyaW8gZGUgZXhlbXBsbyAyIGRvcyBhdHJpYnV0b3MgZG8gY2F0w6Fsb2dvIGdlcmFsLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBwZXJtaXNzaW9uIGdyb3VwcyBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdQYXLDom1ldHJvcyBwYXJhIG9zIGdydXBvcyBkZSBwZXJtaXNzw6NvIGRlIGV4ZW1wbG8gZG9zIGF0cmlidXRvcyBkbyBjYXTDoWxvZ28gZ2VyYWwuJzsKCn0KCjE7Cg==
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6cnVfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ9Ck0YPQvdC60YbQuNC+0L3QsNC70YzQvdC+0YHRgtGMJzsKCiAgICAjIFRlbXBsYXRlOiBBZG1pbkdlbmVyYWxDYXRhbG9nCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ9Cj0L/RgNCw0LLQu9C10L3QuNC1INCe0LHRidC40Lwg0LrQsNGC0LDQu9C+0LPQvtC8JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICfQlNC+0LHQsNCy0LvQtdC90LjQtSDRjdC70LXQvNC10L3RgtCwINC60LDRgtCw0LvQvtCz0LAnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICfQlNC+0LHQsNCy0LvQtdC90LjQtSDQutC70LDRgdGB0LAg0LrQsNGC0LDQu9C+0LPQsCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAn0JrQu9Cw0YHRgSDQutCw0YLQsNC70L7Qs9CwJzsKCiAgICAjIFN5c0NvbmZpZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRtaW4uJ30gPSAnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NyZWF0ZSBhbmQgbWFuYWdlIHRoZSBHZW5lcmFsIENhdGFsb2cuJ30gPSAn0KHQvtC30LTQsNC90LjQtSDQuCDRg9C/0YDQsNCy0LvQtdC90LjQtSDQntCx0YnQuNC8INC60LDRgtCw0LvQvtCz0L7QvCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGcm9udGVuZCBtb2R1bGUgcmVnaXN0cmF0aW9uIGZvciB0aGUgQWRtaW5HZW5lcmFsQ2F0YWxvZyBjb25maWd1cmF0aW9uIGluIHRoZSBhZG1pbiBhcmVhLid9ID0KICAgICAgICAnTW9kdWxlIHJlZ2lzdHJhdGlvbiDQtNC70Y8g0LrQvtC90YTQuNCz0YPRgNCw0YbQuNC4IEFkbWluR2VuZXJhbENhdGFsb2cg0LIg0L/QsNC90LXQu9C4INCw0LTQvNC40L3QuNGB0YLRgNCw0YLQvtGA0LAuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyd9ID0gJ9Ce0LHRidC40Lkg0LrQsNGC0LDQu9C+0LMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgY29tbWVudCAyIG9mIHRoZSBnZW5lcmFsIGNhdGFsb2cgYXR0cmlidXRlcy4nfSA9CiAgICAgICAgJ9CU0L7QsdCw0LLQu9C10L3QuNC1INC00L7Qv9C+0LvQvdC40YLQtdC70YzQvdC+0LPQviDQutC+0LzQvNC10L3RgtCw0YDQuNGPINC6INCw0YLRgNC40LHRg9GC0LDQvCDQntCx0YnQtdCz0L4g0LrQsNGC0LDQu9C+0LPQsCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBwZXJtaXNzaW9uIGdyb3VwcyBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICfQn9Cw0YDQsNC80LXRgtGA0Ysg0LTQu9GPINC/0YDQuNC80LXRgNC90YvRhSDQs9GA0YPQv9C/0L7QstGL0YUg0L/RgNCw0LIg0LTQu9GPINCw0YLRgNC40LHRg9GC0L7QsiDQntCx0YnQtdCz0L4g0LrQsNGC0LDQu9C+0LPQsCc7Cgp9CgoxOwo=
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6c3ZfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ0Z1bmt0aW9uYWxpdGV0JzsKCiAgICAjIFRlbXBsYXRlOiBBZG1pbkdlbmVyYWxDYXRhbG9nCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ0hhbnRlcmEgZ3J1bmRrYXRhbG9nJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIEl0ZW0nfSA9ICdMw6RnZyB0aWxsIGthdGFsb2dwb3N0JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkZCBDYXRhbG9nIENsYXNzJ30gPSAnTMOkZ2cgdGlsbCBrbGFzcyBpIGthdGFsb2cnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2F0YWxvZyBDbGFzcyd9ID0gJ0thdGFsb2drbGFzcyc7CgogICAgIyBTeXNDb25maWcKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0FkbWluLid9ID0gJyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDcmVhdGUgYW5kIG1hbmFnZSB0aGUgR2VuZXJhbCBDYXRhbG9nLid9ID0gJ1NrYXBhIG9jaCBoYW50ZXJhIGdydW5ka2F0YWxvZ2VuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICdSZWdpc3RyZXJpbmcgYXYgZnJvbnRlbmRtb2R1bCBmw7ZyIEFkbWluR2VuZXJhbENhdGFsb2ctaW5zdMOkbGxuaW5nYXIgaSBhZG1pbmFyZWFuLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cnfSA9ICdHcnVuZGthdGFsb2cnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgY29tbWVudCAyIG9mIHRoZSBnZW5lcmFsIGNhdGFsb2cgYXR0cmlidXRlcy4nfSA9CiAgICAgICAgJ1BhcmFtZXRyYXIgZsO2ciBleGVtcGVsa29tbWVudGFyIDIgaSBhdHRyaWJ1dGVuIGbDtnIgZ3J1bmRrYXRhbG9nZW4uJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIHBlcm1pc3Npb24gZ3JvdXBzIG9mIHRoZSBnZW5lcmFsIGNhdGFsb2cgYXR0cmlidXRlcy4nfSA9CiAgICAgICAgJ1BhcmFtZXRyYXIgZsO2ciBleGVtcGVsIHDDpSBiZWjDtnJpZ2hldHNlZ3J1cHBlciBpIGdydW5ka2F0YWxvZ2VucyBhdHRyaWJ1dC4nOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6c3dfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ1V0ZW5kYWppJzsKCiAgICAjIFRlbXBsYXRlOiBBZG1pbkdlbmVyYWxDYXRhbG9nCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydHZW5lcmFsIENhdGFsb2cgTWFuYWdlbWVudCd9ID0gJ1VzaW1hbWl6aSB3YSBrYXRhbG9naSB3YSB1anVtbGEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgSXRlbSd9ID0gJ09uZ2V6YSBraXBlbmdlbGUgeWEga2F0YWxvZ2knOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgQ2xhc3MnfSA9ICdPbmdlemEgdGFiYWthIGxhIGthdGFsb2dpJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhdGFsb2cgQ2xhc3MnfSA9ICdUYWJha2EgbGEga2F0YWxvZ2knOwoKICAgICMgU3lzQ29uZmlnCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZG1pbi4nfSA9ICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ3JlYXRlIGFuZCBtYW5hZ2UgdGhlIEdlbmVyYWwgQ2F0YWxvZy4nfSA9ICdUZW5nZW5lemEgbmEgc2ltYW1pYSBLYXRhbG9naSB5YSB1anVtbGEuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICdVc2FqaWxpIHdhIG1vZHVsaSB5YSBtYXppbmdpcmEgeWEgbWJlbGUga3dhIHVzYW5pZGkgd2Ega2F0YWxvZ2kgeWEgdWp1bWxhIHlhIG1zaW1hbWl6aSBrYXRpa2EgZW5lbyBsYSB1c2ltYW1pemkuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyd9ID0gJ0thdGFsb2dpIHlhIHVqdW1sYSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBjb21tZW50IDIgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnVmlnZXpvIGt3YSBtZmFubyBNYW9uaSAyIHlhIHNpZmEgemEga2F0YWxvZ2kgemEgdWp1bWxhLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBwZXJtaXNzaW9uIGdyb3VwcyBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICdWaWdlem8ga3dhIG1mYW5vIHJ1aHVzYSB6YSB2aWt1bmRpIGt3YSBzaWZhIHphIGthdGFsb2dpIHphIHVqdW1sYS4nOwoKfQoKMTsK
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6emhfQ05fR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ+WKn+iDvSc7CgogICAgIyBUZW1wbGF0ZTogQWRtaW5HZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nIE1hbmFnZW1lbnQnfSA9ICfnm67lvZXnrqHnkIYnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgSXRlbSd9ID0gJ+a3u+WKoOebruW9lemhueebric7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBDbGFzcyd9ID0gJ+a3u+WKoOaWsOebruW9leexuyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAn55uu5b2V57G7JzsKCiAgICAjIFN5c0NvbmZpZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRtaW4uJ30gPSAnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NyZWF0ZSBhbmQgbWFuYWdlIHRoZSBHZW5lcmFsIENhdGFsb2cuJ30gPSAn5Yib5bu65ZKM566h55CG55uu5b2VJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICflnKjns7vnu5/nrqHnkIbkuK3ms6jlhoznm67lvZXnrqHnkIbmqKHlnZdBZG1pbkdlbmVyYWxDYXRhbG9n55qE5YmN56uv5qih5Z2X44CCJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0dlbmVyYWwgQ2F0YWxvZyd9ID0gJ+ebruW9lSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQYXJhbWV0ZXJzIGZvciB0aGUgZXhhbXBsZSBjb21tZW50IDIgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAn55uu5b2V5bGe5oCn5qC35L6LLeazqOmHijLnmoTlj4LmlbDorr7nva7jgIInOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAn55uu5b2V5bGe5oCn5qC35L6LLeadg+mZkOe7hOeahOWPguaVsOOAgic7Cgp9CgoxOwo=
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6emhfVFdfR2VuZXJhbENhdGFsb2c7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CnVzZSB1dGY4OwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAjIFRlbXBsYXRlOiBBQUFHZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRnVuY3Rpb25hbGl0eSd9ID0gJ+WKn+iDvSc7CgogICAgIyBUZW1wbGF0ZTogQWRtaW5HZW5lcmFsQ2F0YWxvZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nIE1hbmFnZW1lbnQnfSA9ICfnm67pjITnrqHnkIYnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRkIENhdGFsb2cgSXRlbSd9ID0gJ+a3u+WKoOebrumMhOmgheebric7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBZGQgQ2F0YWxvZyBDbGFzcyd9ID0gJ+a3u+WKoOaWsOebrumMhOmhnuWIpSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYXRhbG9nIENsYXNzJ30gPSAn55uu6YyE6aGe5YilJzsKCiAgICAjIFN5c0NvbmZpZwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQWRtaW4uJ30gPSAnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NyZWF0ZSBhbmQgbWFuYWdlIHRoZSBHZW5lcmFsIENhdGFsb2cuJ30gPSAn5Ym15bu65ZKM566h55CG55uu6YyEJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0Zyb250ZW5kIG1vZHVsZSByZWdpc3RyYXRpb24gZm9yIHRoZSBBZG1pbkdlbmVyYWxDYXRhbG9nIGNvbmZpZ3VyYXRpb24gaW4gdGhlIGFkbWluIGFyZWEuJ30gPQogICAgICAgICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnR2VuZXJhbCBDYXRhbG9nJ30gPSAn55uu6YyEJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1BhcmFtZXRlcnMgZm9yIHRoZSBleGFtcGxlIGNvbW1lbnQgMiBvZiB0aGUgZ2VuZXJhbCBjYXRhbG9nIGF0dHJpYnV0ZXMuJ30gPQogICAgICAgICcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUGFyYW1ldGVycyBmb3IgdGhlIGV4YW1wbGUgcGVybWlzc2lvbiBncm91cHMgb2YgdGhlIGdlbmVyYWwgY2F0YWxvZyBhdHRyaWJ1dGVzLid9ID0KICAgICAgICAnJzsKCn0KCjE7Cg==
# --
# Copyright (C) 2001-2016 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::Modules::AdminGeneralCatalog;

use strict;
use warnings;

our $ObjectManagerDisabled = 1;

sub new {
    my ( $Type, %Param ) = @_;

    # allocate new hash for object
    my $Self = {%Param};
    bless( $Self, $Type );

    return $Self;
}

sub Run {
    my ( $Self, %Param ) = @_;

    # get needed object
    my $ConfigObject         = $Kernel::OM->Get('Kernel::Config');
    my $ParamObject          = $Kernel::OM->Get('Kernel::System::Web::Request');
    my $LayoutObject         = $Kernel::OM->Get('Kernel::Output::HTML::Layout');
    my $ValidObject          = $Kernel::OM->Get('Kernel::System::Valid');
    my $GeneralCatalogObject = $Kernel::OM->Get('Kernel::System::GeneralCatalog');

    # ------------------------------------------------------------ #
    # catalog item list
    # ------------------------------------------------------------ #
    if ( $Self->{Subaction} eq 'ItemList' ) {
        my $Class = $ParamObject->GetParam( Param => "Class" ) || '';

        # check needed class
        if ( !$Class ) {
            return $LayoutObject->Redirect( OP => "Action=$Self->{Action}" );
        }

        # output overview
        $LayoutObject->Block(
            Name => 'Overview',
            Data => {
                %Param,
            },
        );
        $LayoutObject->Block(
            Name => 'OverviewItem',
            Data => {
                %Param,
                Class => $Class,
            },
        );

        # get availability list
        my %ValidList = $ValidObject->ValidList();

        # get catalog item list
        my $ItemIDList = $GeneralCatalogObject->ItemList(
            Class => $Class,
            Valid => 0,
        );

        # check item list
        if ( !$ItemIDList || !%{$ItemIDList} ) {
            return $LayoutObject->ErrorScreen();
        }

        for my $ItemID ( sort { $ItemIDList->{$a} cmp $ItemIDList->{$b} } keys %{$ItemIDList} ) {

            # get item data
            my $ItemData = $GeneralCatalogObject->ItemGet(
                ItemID => $ItemID,
            );

            # output overview item list
            $LayoutObject->Block(
                Name => 'OverviewItemList',
                Data => {
                    %{$ItemData},
                    Valid => $ValidList{ $ItemData->{ValidID} },
                },
            );
        }

        # ActionOverview
        $LayoutObject->Block(
            Name => 'ActionAddItem',
            Data => {
                %Param,
                Class => $Class,
            },
        );

        # ActionOverview
        $LayoutObject->Block(
            Name => 'ActionOverview',
        );

        # output header and navbar
        my $Output = $LayoutObject->Header();
        $Output .= $LayoutObject->NavigationBar();

        # create output string
        $Output .= $LayoutObject->Output(
            TemplateFile => 'AdminGeneralCatalog',
            Data         => \%Param,
        );

        # add footer
        $Output .= $LayoutObject->Footer();

        return $Output;
    }

    # ------------------------------------------------------------ #
    # catalog item edit
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'ItemEdit' ) {
        my %ItemData;

        # get params
        $ItemData{ItemID} = $ParamObject->GetParam( Param => "ItemID" );

        # add a new catalog item
        if ( $ItemData{ItemID} eq 'NEW' ) {

            # get class
            $ItemData{Class} = $ParamObject->GetParam( Param => "Class" );

            # redirect to overview
            if ( !$ItemData{Class} ) {
                return $LayoutObject->Redirect( OP => "Action=$Self->{Action}" );
            }
        }

        # edit an existing catalog item
        else {

            # get item data
            my $ItemDataRef = $GeneralCatalogObject->ItemGet(
                ItemID => $ItemData{ItemID},
            );

            # check item data
            if ( !$ItemDataRef ) {
                return $LayoutObject->ErrorScreen();
            }

            %ItemData = %{$ItemDataRef};
        }

        # output overview
        $LayoutObject->Block(
            Name => 'Overview',
            Data => {
                %Param,
                Class => $ItemData{Class},
            },
        );

        # generate ValidOptionStrg
        my %ValidList        = $ValidObject->ValidList();
        my %ValidListReverse = reverse %ValidList;
        my $ValidOptionStrg  = $LayoutObject->BuildSelection(
            Name       => 'ValidID',
            Data       => \%ValidList,
            SelectedID => $ItemData{ValidID} || $ValidListReverse{valid},
            Class      => 'Modernize',
        );

        # output ItemEdit
        $LayoutObject->Block(
            Name => 'ItemEdit',
            Data => {
                %ItemData,
                ValidOptionStrg => $ValidOptionStrg,
            },
        );

        # show each preferences setting
        my %Preferences = ();
        if ( $ConfigObject->Get('GeneralCatalogPreferences') ) {
            %Preferences = %{ $ConfigObject->Get('GeneralCatalogPreferences') };
        }

        ITEM:
        for my $Item ( sort keys %Preferences ) {

            # skip items that don't belong to the class
            if ( $Preferences{$Item}->{Class} && $Preferences{$Item}->{Class} ne $ItemData{Class} )
            {
                next ITEM;
            }

            # find output module
            my $Module = $Preferences{$Item}->{Module}
                || 'Kernel::Output::HTML::GeneralCatalogPreferences::Generic';

            # load module
            if ( !$Kernel::OM->Get('Kernel::System::Main')->Require($Module) ) {
                return $LayoutObject->FatalError();
            }

            # create object for this preferences item
            my $Object = $Module->new(
                %{$Self},
                ConfigItem => $Preferences{$Item},
                Debug      => $Self->{Debug},
            );

            # show all parameters
            my @Params = $Object->Param( GeneralCatalogData => { %ItemData, %Param } );
            for my $ParamItem (@Params) {

                if (
                    ref( $ParamItem->{Data} ) eq 'HASH'
                    || ref( $Preferences{$Item}->{Data} ) eq 'HASH'
                    )
                {
                    $ParamItem->{'Option'} = $LayoutObject->BuildSelection(
                        %{ $Preferences{$Item} },
                        %{$ParamItem},
                        Class => 'Modernize',
                    );
                }

                $LayoutObject->Block(
                    Name => $ParamItem->{Block} || $Preferences{$Item}->{Block} || 'Option',
                    Data => {
                        %{ $Preferences{$Item} },
                        %{$ParamItem},
                    },
                );
            }
        }

        if ( $ItemData{Class} eq 'NEW' ) {

            # output ItemEditClassAdd
            $LayoutObject->Block(
                Name => 'ItemEditClassAdd',
                Data => {
                    Class => $ItemData{Class},
                },
            );
        }
        else {

            # output ItemEditClassExist
            $LayoutObject->Block(
                Name => 'ItemEditClassExist',
                Data => {
                    Class => $ItemData{Class},
                },
            );
        }

        # ActionOverview
        $LayoutObject->Block(
            Name => 'ActionOverview',
        );

        # output header
        my $Output = $LayoutObject->Header();
        $Output .= $LayoutObject->NavigationBar();

        # create output string
        $Output .= $LayoutObject->Output(
            TemplateFile => 'AdminGeneralCatalog',
            Data         => \%Param,
        );

        # add footer
        $Output .= $LayoutObject->Footer();

        return $Output;
    }

    # ------------------------------------------------------------ #
    # catalog item save
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'ItemSave' ) {
        my %ItemData;

        # get params
        for my $Param (qw(Class ItemID ValidID Comment)) {
            $ItemData{$Param} = $ParamObject->GetParam( Param => $Param ) || '';
        }

        # get name param, name must be not empty, but number zero (0) is allowed
        $ItemData{Name} = $ParamObject->GetParam( Param => 'Name' );

        # check class
        if ( $ItemData{Class} eq 'NEW' ) {
            return $LayoutObject->Redirect( OP => "Action=$Self->{Action}" );
        }

        # save to database
        my $Success;
        my $ItemID = $ItemData{ItemID};
        if ( $ItemData{ItemID} eq 'NEW' ) {
            $Success = $GeneralCatalogObject->ItemAdd(
                %ItemData,
                UserID => $Self->{UserID},
            );
            $ItemID = $Success;
        }
        else {
            $Success = $GeneralCatalogObject->ItemUpdate(
                %ItemData,
                UserID => $Self->{UserID},
            );
        }

        # update preferences
        my $GCData      = $GeneralCatalogObject->ItemGet( ItemID => $ItemID );
        my %Preferences = ();
        my $Note        = '';

        if ( $ConfigObject->Get('GeneralCatalogPreferences') ) {
            %Preferences = %{ $ConfigObject->Get('GeneralCatalogPreferences') };
        }

        for my $Item ( sort keys %Preferences ) {
            my $Module = $Preferences{$Item}->{Module}
                || 'Kernel::Output::HTML::GeneralCatalogPreferences::Generic';

            # load module
            if ( !$Kernel::OM->Get('Kernel::System::Main')->Require($Module) ) {
                return $LayoutObject->FatalError();
            }

            my $Object = $Module->new(
                %{$Self},
                ConfigItem => $Preferences{$Item},
                Debug      => $Self->{Debug},
            );
            my @Params = $Object->Param( GeneralCatalogData => $GCData );
            if (@Params) {
                my %GetParam = ();
                for my $ParamItem (@Params) {
                    my @Array = $ParamObject->GetArray( Param => $ParamItem->{Name} );
                    $GetParam{ $ParamItem->{Name} } = \@Array;
                }
                if (
                    !$Object->Run(
                        GetParam => \%GetParam,
                        ItemID   => $GCData->{ItemID},
                    )
                    )
                {
                    $Note .= $LayoutObject->Notify( Info => $Object->Error() );
                }
            }
        }

        if ( !$Success ) {
            return $LayoutObject->ErrorScreen();
        }

        # redirect to overview class list
        return $LayoutObject->Redirect(
            OP => "Action=$Self->{Action};Subaction=ItemList;Class=$ItemData{Class}"
        );
    }

    # ------------------------------------------------------------ #
    # overview
    # ------------------------------------------------------------ #
    else {

        # output overview
        $LayoutObject->Block(
            Name => 'Overview',
            Data => {
                %Param,
            },
        );
        $LayoutObject->Block(
            Name => 'OverviewClass',
            Data => {
                %Param,
            },
        );

        # get catalog class list
        my $ClassList = $GeneralCatalogObject->ClassList();

        for my $Class ( @{$ClassList} ) {

            # output overview class list
            $LayoutObject->Block(
                Name => 'OverviewClassList',
                Data => {
                    Class => $Class,
                },
            );
        }

        # ActionAddClass
        $LayoutObject->Block(
            Name => 'ActionAddClass',
        );

        # output header and navbar
        my $Output = $LayoutObject->Header();
        $Output .= $LayoutObject->NavigationBar();

        # create output string
        $Output .= $LayoutObject->Output(
            TemplateFile => 'AdminGeneralCatalog',
            Data         => \%Param,
        );

        # add footer
        $Output .= $LayoutObject->Footer();

        return $Output;
    }
}

1;

IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpPdXRwdXQ6OkhUTUw6OkdlbmVyYWxDYXRhbG9nUHJlZmVyZW5jZXM6OkdlbmVyaWM7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7CgpvdXIgQE9iamVjdERlcGVuZGVuY2llcyA9ICgKICAgICdLZXJuZWw6OlN5c3RlbTo6R2VuZXJhbENhdGFsb2cnLAogICAgJ0tlcm5lbDo6U3lzdGVtOjpHcm91cCcsCiAgICAnS2VybmVsOjpTeXN0ZW06OldlYjo6UmVxdWVzdCcsCik7CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHslUGFyYW19OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgZ2V0IG5lZWRlZCBwYXJhbXMKICAgIGZvciBteSAkTmVlZGVkIChxdyggVXNlcklEIENvbmZpZ0l0ZW0gKSkgewogICAgICAgIGRpZSAiR290IG5vICROZWVkZWQhIiBpZiAoICEkU2VsZi0+eyROZWVkZWR9ICk7CiAgICB9CgogICAgcmV0dXJuICRTZWxmOwp9CgpzdWIgUGFyYW0gewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICBteSBAUGFyYW1zID0gKCk7CiAgICBteSAkR2V0UGFyYW0KICAgICAgICA9ICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6U3lzdGVtOjpXZWI6OlJlcXVlc3QnKS0+R2V0UGFyYW0oIFBhcmFtID0+ICRTZWxmLT57Q29uZmlnSXRlbX0tPntQcmVmS2V5fSApOwoKICAgIGlmICggIWRlZmluZWQoJEdldFBhcmFtKSApIHsKICAgICAgICAkR2V0UGFyYW0gPSBkZWZpbmVkKCAkUGFyYW17R2VuZXJhbENhdGFsb2dEYXRhfS0+eyAkU2VsZi0+e0NvbmZpZ0l0ZW19LT57UHJlZktleX0gfSApCiAgICAgICAgICAgID8gJFBhcmFte0dlbmVyYWxDYXRhbG9nRGF0YX0tPnsgJFNlbGYtPntDb25maWdJdGVtfS0+e1ByZWZLZXl9IH0KICAgICAgICAgICAgOiAkU2VsZi0+e0NvbmZpZ0l0ZW19LT57RGF0YVNlbGVjdGVkfTsKICAgIH0KCiAgICBpZiAoICEoIGRlZmluZWQgJFNlbGYtPntDb25maWdJdGVtfS0+e0Jsb2NrfSAmJiAkU2VsZi0+e0NvbmZpZ0l0ZW19LT57QmxvY2t9ICkgKSB7CiAgICAgICAgJFNlbGYtPntDb25maWdJdGVtfS0+e0Jsb2NrfSA9ICdUZXh0JzsKICAgIH0KCiAgICBpZiAoICRTZWxmLT57Q29uZmlnSXRlbX0tPntCbG9ja30gZXEgJ1Blcm1pc3Npb24nICkgewogICAgICAgICRQYXJhbXtEYXRhfSAgICAgICAgID0geyAkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6R3JvdXAnKS0+R3JvdXBMaXN0KCBWYWxpZCA9PiAxICkgfTsKICAgICAgICAkUGFyYW17UG9zc2libGVOb25lfSA9IDE7CiAgICAgICAgJFBhcmFte0Jsb2NrfSAgICAgICAgPSAnT3B0aW9uJzsKICAgIH0KCiAgICBwdXNoKAogICAgICAgIEBQYXJhbXMsCiAgICAgICAgewogICAgICAgICAgICAlUGFyYW0sCiAgICAgICAgICAgIE5hbWUgICAgICAgPT4gJFNlbGYtPntDb25maWdJdGVtfS0+e1ByZWZLZXl9LAogICAgICAgICAgICBTZWxlY3RlZElEID0+ICRHZXRQYXJhbSwKICAgICAgICB9LAogICAgKTsKCiAgICByZXR1cm4gQFBhcmFtczsKfQoKc3ViIFJ1biB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIGZvciBteSAkS2V5ICggc29ydCBrZXlzICV7ICRQYXJhbXtHZXRQYXJhbX0gfSApIHsKICAgICAgICBteSBAQXJyYXkgPSBAeyAkUGFyYW17R2V0UGFyYW19LT57JEtleX0gfTsKICAgICAgICBmb3IgbXkgJFZhbHVlIChAQXJyYXkpIHsKCiAgICAgICAgICAgICMgcHJlZiB1cGRhdGUgZGIKICAgICAgICAgICAgJEtlcm5lbDo6T00tPkdldCgnS2VybmVsOjpTeXN0ZW06OkdlbmVyYWxDYXRhbG9nJyktPkdlbmVyYWxDYXRhbG9nUHJlZmVyZW5jZXNTZXQoCiAgICAgICAgICAgICAgICBJdGVtSUQgPT4gJFBhcmFte0l0ZW1JRH0sCiAgICAgICAgICAgICAgICBLZXkgICAgPT4gJEtleSwKICAgICAgICAgICAgICAgIFZhbHVlICA9PiAkVmFsdWUsCiAgICAgICAgICAgICk7CiAgICAgICAgfQogICAgfQoKICAgICRTZWxmLT57TWVzc2FnZX0gPSAnUHJlZmVyZW5jZXMgdXBkYXRlZCBzdWNjZXNzZnVsbHkhJzsKICAgIHJldHVybiAxOwp9CgpzdWIgRXJyb3IgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICByZXR1cm4gJFNlbGYtPntFcnJvcn0gfHwgJyc7Cn0KCnN1YiBNZXNzYWdlIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgcmV0dXJuICRTZWxmLT57TWVzc2FnZX0gfHwgJyc7Cn0KCjE7Cg==
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCiMgQ29tbW9uClslIFRyYW5zbGF0ZSgiRnVuY3Rpb25hbGl0eSIpIHwgaHRtbCAlXQo=
# --
# Copyright (C) 2001-2016 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

[% InsertTemplate("Colorpicker.tt") %]

[% RenderBlockStart("Overview") %]
<div class="MainBox ARIARoleMain LayoutFixedSidebar SidebarFirst">
    <h1>[% Translate("General Catalog Management") | html %]</h1>

    <div class="SidebarColumn">
        <div class="WidgetSimple">
            <div class="Header">
                <h2>[% Translate("Actions") | html %]</h2>
            </div>
            <div class='Content'>
                <ul class="ActionList">
[% RenderBlockStart("ActionAddItem") %]
                    <li>
                        <form action="[% Env("CGIHandle") %]" method="get">
                            <input type="hidden" name="Action" value="[% Env("Action") %]"/>
                            <input type="hidden" name="Subaction" value="ItemEdit"/>
                            <input type="hidden" name="Class" value="[% Data.Class | html %]"/>
                            <input type="hidden" name="ItemID" value="NEW"/>
                            <button class="CallForAction Plus" type="submit" value="[% Translate("Add") | html %]">
                                <span>[% Translate("Add Catalog Item") | html %]</span>
                            </button>
                        </form>
                    </li>
[% RenderBlockEnd("ActionAddItem") %]
[% RenderBlockStart("ActionAddClass") %]
                    <li>
                        <form action="[% Env("CGIHandle") %]" method="get">
                            <input type="hidden" name="Action" value="[% Env("Action") %]"/>
                            <input type="hidden" name="Subaction" value="ItemEdit"/>
                            <input type="hidden" name="ItemID" value="NEW"/>
                            <input type="hidden" name="Class" value="NEW"/>
                            <button class="CallForAction Plus" type="submit" value="[% Translate("Add") | html %]">
                                <span>[% Translate("Add Catalog Class") | html %]</span>
                            </button>
                        </form>
                    </li>
[% RenderBlockEnd("ActionAddClass") %]
[% RenderBlockStart("ActionOverview") %]
                    <li>
                        <a href="[% Env("Baselink") %]Action=[% Env("Action") %]" class="CallForAction"><span>[% Translate("Go to overview") | html %]</span></a>
                    </li>
[% RenderBlockEnd("ActionOverview") %]
                </ul>
            </div>
        </div>
    </div>

    <div class="ContentColumn">
        <div class="WidgetSimple">
[% RenderBlockStart("OverviewClass") %]
            <div class="Header">
                <h2>[% Translate("List") | html %]</h2>
            </div>
            <div class="Content">
                <table class="DataTable">
                    <thead>
                        <tr>
                            <th>[% Translate("Catalog Class") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
[% RenderBlockStart("OverviewClassList") %]
                        <tr>
                            <td>
                                <a class="AsBlock"  href="[% Env("Baselink") %]Action=[% Env("Action") %];Subaction=ItemList;Class=[% Data.Class | uri %]">[% Data.Class | html %]</a>
                            </td>
                        </tr>
[% RenderBlockEnd("OverviewClassList") %]
                    </tbody>
                </table>
            </div>
[% RenderBlockEnd("OverviewClass") %]

[% RenderBlockStart("OverviewItem") %]
            <div class="Header">
                <h2>[% Translate("List") | html %]</h2>
            </div>
            <div class="Content">

                <table class="DataTable">
                    <thead>
                        <tr>
                            <th class="W60pc">[% Data.Class | html %]</th>
                            <th class="Center">[% Translate("Validity") | html %]</th>
                        </tr>
                    </thead>
                    <tbody>
[% RenderBlockStart("OverviewItemList") %]
                        <tr [% IF Data.ValidID != 1%]class="Invalid"[% END %]>
                            <td>
                                <a href="[% Env("Baselink") %]Action=[% Env("Action") %];Subaction=ItemEdit;ItemID=[% Data.ItemID | uri %]">[% Data.Name | html %]</a>
                            </td>
                            <td class="Center">[% Translate(Data.Valid) | html %]</td>
                        </tr>
[% RenderBlockEnd("OverviewItemList") %]
                    </tbody>
                </table>
            </div>
[% RenderBlockEnd("OverviewItem") %]

[% RenderBlockStart("ItemEdit") %]
            <div class="Header">
                <h2>[% Translate("Item") | html %] [% Translate("Edit") | html %]:</h2>
            </div>
            <div class="Content">

                <form action="[% Env("CGIHandle") %]" method="get" class="Validate">
                    <input type="hidden" name="Action" value="[% Env("Action") %]"/>
                    <input type="hidden" name="Subaction" value="ItemSave"/>
                    <input type="hidden" name="ItemID" value="[% Data.ItemID | html %]"/>
                    <fieldset class="TableLike">
[% RenderBlockStart("ItemEditClassAdd") %]
                        <label class="Mandatory" for="ClassDsc"><span class="Marker">*</span>[% Translate("Catalog Class") | html %]:</label>
                        <div class="Field">
                            <input type="text" name="Class" id="ClassDsc" value="[% Data.Name | html %]" class="W50pc Validate_Required" maxlength="100" />
                            <div id="ClassDscError" class="TooltipErrorMessage" ><p>[% Translate("This field is required.") | html %]</p></div>
                            <div id="ClassDscServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("ItemEditClassAdd") %]
[% RenderBlockStart("ItemEditClassExist") %]
                        <label>[% Translate("Catalog Class") | html %]: </label>
                        <div class="Field">
                            [% Data.Class | html %]
                            <input type="hidden" name="Class" value="[% Data.Class | html %]">
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("ItemEditClassExist") %]
                        <label class="Mandatory" for="Name"><span class="Marker">*</span>[% Translate("Name") | html %]: </label>
                        <div class="Field">
                            <input type="text" name="Name" id="Name" value="[% Data.Name | html %]" class="W50pc Validate_Required" maxlength="100"/>
                            <div id="NameError" class="TooltipErrorMessage" ><p>[% Translate("This field is required.") | html %]</p></div>
                            <div id="NameServerError" class="TooltipErrorMessage"><p>[% Translate("This field is required.") | html %]</p></div>
                        </div>
                        <div class="Clear"></div>
[% RenderBlockStart("InputKey") %]
                        <label for="[% Data.Name | html %]">[% Translate(Data.Label) | html %] [% Translate(Data.Key) | html %]: </label>
                        <div class="Field">
                            <input type="text" name="[% Data.Name | html %]" id="[% Data.Name | html %]" value="[% Data.SelectedID | html %]" class="W50pc" maxlength="100"/>
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("InputKey") %]
[% RenderBlockStart("Input") %]
                        <label for="[% Data.Name | html %]">[% Translate(Data.Label) | html %]:<br/><em>([% Translate(Data.Desc) | html %])</em></label>
                        <div class="Field">
                            <input type="text" name="[% Data.Name | html %]" id="[% Data.Name | html %]" value="[% Data.SelectedID | html %]" class="W50pc"/>
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("Input") %]
[% RenderBlockStart("TextArea") %]
                        <label for="[% Data.Name | html %]">[% Translate(Data.Label) | html %]:<br/><em>([% Translate(Data.Desc) | html %])</em></label>
                        <div class="Field">
                            <textarea name="[% Data.Name | html %]" id="[% Data.Name | html %]" rows="[% Data.Rows | html %]" cols="[% Data.Cols | html %]">[% Data.SelectedID | html %]</textarea>
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("TextArea") %]
[% RenderBlockStart("Option") %]
                        <label for="[% Data.Name | html %]">[% Translate(Data.Label) | html %] [% Translate(Data.Key) | html %]:<br/><em>([% Translate(Data.Desc) | html %])</em></label>
                        <div class="Field">
                            [% Data.Option %]
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("Option") %]
[% RenderBlockStart("Upload") %]
                        <label for="[% Data.Name | html %]">[% Translate(Data.Label) | html %] [% Translate(Data.Key) | html %]: </label>
                        <div class="Field">
                            <input name="[% Data.Name | html %]" id="[% Data.Name | html %]" type="file" size="30" class="fixed"/><br/>
                            <a href="">[% Data.Filename | html %]</a>
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("Upload") %]
[% RenderBlockStart("Password") %]
                        <label for="[% Data.Name | html %]">[% Translate(Data.Label) | html %] [% Translate(Data.Key) | html %]: </label>
                        <div class="Field">
                            <input type="password" name="[% Data.Name | html %]" id="[% Data.Name | html %]" value="" class="W50pc"/>
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("Password") %]
[% RenderBlockStart("ColorPicker") %]
                        <label for="[% Data.Name | html %]">[% Translate(Data.Label) | html %]:<br/><em>([% Translate(Data.Desc) | html %])</em></label>
                        <div class="Field">
                            <input type="text" name="[% Data.Name | html %]" id="[% Data.Name | html %]" value="[% Data.SelectedID | html %]" class="W50pc JSColorPicker {pickerBorderColor:'#BBB #BBB #BBB #BBB', pickerInsetColor:'#BBB #BBB #BBB #BBB'}"/>
                        </div>
                        <div class="Clear"></div>
[% RenderBlockEnd("ColorPicker") %]
                        <label for="ValidID">[% Translate("Validity") | html %]: </label>
                        <div class="Field">
                            [% Data.ValidOptionStrg %]
                        </div>
                        <div class="Clear"></div>

                        <label for="Comment">[% Translate("Comment") | html %]: </label>
                        <div class="Field">
                            <input type="text" name="Comment" id="Comment" value="[% Data.Comment | html %]" class="W50pc" maxlength="200"/>
                        </div>
                        <div class="Clear"></div>

                        <div class="Field SpacingTop">
                            <button class="Primary" type="submit" id="Submit" value="[% Translate("Submit") | html %]">[% Translate("Submit") | html %]</button>
                            [% Translate("or") | html %]
                            <a href="[% Env("Baselink") %]Action=[% Env("Action") %]">[% Translate("Cancel") | html %]</a>
                        </div>
                        <div class="Clear"></div>

                    </fieldset>
                </form>
            </div>
[% RenderBlockEnd("ItemEdit") %]
        </div>
    </div>
    <div class="Clear"></div>
</div>
[% RenderBlockEnd("Overview") %]

IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KClslIFdSQVBQRVIgSlNPbkRvY3VtZW50Q29tcGxldGUgJV0KPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPi8vPCFbQ0RBVEFbCgogICAgLypnbG9iYWwganNjb2xvcjogdHJ1ZSAqLwogICAganNjb2xvci5kaXIgPSAnWyUgQ29uZmlnKCJGcm9udGVuZDo6SmF2YVNjcmlwdFBhdGgiKSAlXScgKyAndGhpcmRwYXJ0eS9qc2NvbG9yXzEuNC4xLyc7CiAgICBqc2NvbG9yLmJpbmRDbGFzcyA9ICdKU0NvbG9yUGlja2VyJzsKICAgIGpzY29sb3IuaW5zdGFsbCgpOwoKLy9dXT48L3NjcmlwdD4KWyUgRU5EICVdCg==
# --
# Copyright (C) 2001-2016 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

package Kernel::System::GeneralCatalog;

use strict;
use warnings;

our @ObjectDependencies = (
    'Kernel::Config',
    'Kernel::System::Cache',
    'Kernel::System::CheckItem',
    'Kernel::System::DB',
    'Kernel::System::Log',
    'Kernel::System::Main',
);

=head1 NAME

Kernel::System::GeneralCatalog - general catalog lib

=head1 SYNOPSIS

All general catalog functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item new()

create an object

    use Kernel::System::ObjectManager;
    local $Kernel::OM = Kernel::System::ObjectManager->new();
    my $GeneralCatalogObject = $Kernel::OM->Get('Kernel::System::GeneralCatalog');

=cut

sub new {
    my ( $Type, %Param ) = @_;

    # allocate new hash for object
    my $Self = {};
    bless( $Self, $Type );

    # load generator preferences module
    my $GeneratorModule = $Kernel::OM->Get('Kernel::Config')->Get('GeneralCatalog::PreferencesModule')
        || 'Kernel::System::GeneralCatalog::PreferencesDB';
    if ( $Kernel::OM->Get('Kernel::System::Main')->Require($GeneratorModule) ) {
        $Self->{PreferencesObject} = $GeneratorModule->new(%Param);
    }

    # define cache settings
    $Self->{CacheType} = 'GeneralCatalog';
    $Self->{CacheTTL}  = 60 * 60 * 3;

    return $Self;
}

=item ClassList()

return an array reference of all general catalog classes

    my $ArrayRef = $GeneralCatalogObject->ClassList();

=cut

sub ClassList {
    my ( $Self, %Param ) = @_;

    # ask database
    $Kernel::OM->Get('Kernel::System::DB')->Prepare(
        SQL => 'SELECT DISTINCT(general_catalog_class) '
            . 'FROM general_catalog ORDER BY general_catalog_class',
    );

    # fetch the result
    my @ClassList;
    while ( my @Row = $Kernel::OM->Get('Kernel::System::DB')->FetchrowArray() ) {
        push @ClassList, $Row[0];
    }

    # cache the result
    my $CacheKey = 'ClassList';
    $Kernel::OM->Get('Kernel::System::Cache')->Set(
        Type  => $Self->{CacheType},
        TTL   => $Self->{CacheTTL},
        Key   => $CacheKey,
        Value => \@ClassList,
    );

    return \@ClassList;
}

=item ClassRename()

rename a general catalog class

    my $True = $GeneralCatalogObject->ClassRename(
        ClassOld => 'ITSM::ConfigItem::State',
        ClassNew => 'ITSM::ConfigItem::DeploymentState',
    );

=cut

sub ClassRename {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ClassOld ClassNew)) {
        if ( !$Param{$Argument} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # cleanup given params
    for my $Argument (qw(ClassOld ClassNew)) {
        $Kernel::OM->Get('Kernel::System::CheckItem')->StringClean(
            StringRef         => \$Param{$Argument},
            RemoveAllNewlines => 1,
            RemoveAllTabs     => 1,
            RemoveAllSpaces   => 1,
        );
    }

    return 1 if $Param{ClassNew} eq $Param{ClassOld};

    # check if new class name already exists
    $Kernel::OM->Get('Kernel::System::DB')->Prepare(
        SQL   => 'SELECT id FROM general_catalog WHERE general_catalog_class = ?',
        Bind  => [ \$Param{ClassNew} ],
        Limit => 1,
    );

    # fetch the result
    my $AlreadyExists = 0;
    while ( my @Row = $Kernel::OM->Get('Kernel::System::DB')->FetchrowArray() ) {
        $AlreadyExists = 1;
    }

    if ($AlreadyExists) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "Can't rename class $Param{ClassOld}! New classname already exists."
        );
        return;
    }

    # reset cache
    $Kernel::OM->Get('Kernel::System::Cache')->CleanUp(
        Type => $Self->{CacheType},
    );

    # rename general catalog class
    return $Kernel::OM->Get('Kernel::System::DB')->Do(
        SQL => 'UPDATE general_catalog SET general_catalog_class = ? '
            . 'WHERE general_catalog_class = ?',
        Bind => [ \$Param{ClassNew}, \$Param{ClassOld} ],
    );
}

=item ItemList()

returns a list as a hash reference of one general catalog class

    my $HashRef = $GeneralCatalogObject->ItemList(
        Class         => 'ITSM::Service::Type',
        Valid         => 0,                      # (optional) default 1
        Preferences   => {                       # (optional) default {}
            Permission => 2,                     # or whatever preferences can be used
        },
    );

=cut

sub ItemList {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{Class} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need Class!'
        );
        return;
    }

    # set default value
    if ( !defined $Param{Valid} ) {
        $Param{Valid} = 1;
    }

    my $PreferencesCacheKey = '';
    my $PreferencesTable    = '';
    my $PreferencesWhere    = '';
    my @PreferencesBind;

    # handle given preferences
    if ( exists $Param{Preferences} && ref $Param{Preferences} eq 'HASH' ) {

        $PreferencesTable = ', general_catalog_preferences';
        my @Wheres;

        # add all preferences given to where-clause
        for my $Key ( sort keys %{ $Param{Preferences} } ) {

            if ( ref( $Param{Preferences}->{$Key} ) ne 'ARRAY' ) {
                $Param{Preferences}->{$Key} = [ $Param{Preferences}->{$Key} ];
            }

            push @Wheres, '(pref_key = ? AND pref_value IN ('
                . join( ', ', map {'?'} @{ $Param{Preferences}->{$Key} } )
                . '))';

            push @PreferencesBind, \$Key, map { \$_ } @{ $Param{Preferences}->{$Key} };

            # add functionality list to cache key
            $PreferencesCacheKey .= '####' if $PreferencesCacheKey;
            $PreferencesCacheKey .= join q{####}, $Key, map {$_} @{ $Param{Preferences}->{$Key} };
        }

        $PreferencesWhere = 'AND general_catalog.id = general_catalog_preferences.general_catalog_id';
        $PreferencesWhere .= ' AND ' . join ' AND ', @Wheres;
    }

    # create sql string
    my $SQL = "SELECT id, name FROM general_catalog $PreferencesTable "
        . "WHERE general_catalog_class = ? $PreferencesWhere ";
    my @BIND = ( \$Param{Class}, @PreferencesBind );

    # add valid string to sql string
    if ( $Param{Valid} ) {
        $SQL .= 'AND valid_id = 1 ';
    }

    # create cache key
    my $CacheKey = 'ItemList::' . $Param{Class} . '####' . $Param{Valid} . '####' . $PreferencesCacheKey;

    # check if result is already cached
    my $Cache = $Kernel::OM->Get('Kernel::System::Cache')->Get(
        Type => $Self->{CacheType},
        Key  => $CacheKey,
    );
    return $Cache if $Cache;

    # ask database
    $Kernel::OM->Get('Kernel::System::DB')->Prepare(
        SQL  => $SQL,
        Bind => \@BIND,
    );

    # fetch the result
    my %Data;
    while ( my @Row = $Kernel::OM->Get('Kernel::System::DB')->FetchrowArray() ) {
        $Data{ $Row[0] } = $Row[1];
    }

    # just return without logging an error and without caching the empty result
    return if !%Data;

    # cache the result
    $Kernel::OM->Get('Kernel::System::Cache')->Set(
        Type  => $Self->{CacheType},
        TTL   => $Self->{CacheTTL},
        Key   => $CacheKey,
        Value => \%Data,
    );

    return \%Data;
}

=item ItemGet()

get item attributes

    my $ItemDataRef = $GeneralCatalogObject->ItemGet(
        ItemID => 3,
    );

    or

    my $ItemDataRef = $GeneralCatalogObject->ItemGet(
        Class => 'ITSM::Service::Type',
        Name  => 'Underpinning Contract',
    );

returns

    my $Item = {
        'ItemID'     => '23',
        'Class'      => 'ITSM::Service::Type',
        'Name'       => 'Underpinning Contract'
        'Comment'    => 'Some Comment',
        'ValidID'    => '1',
        'CreateTime' => '2012-01-12 09:36:24',
        'CreateBy'   => '1',
        'ChangeTime' => '2012-01-12 09:36:24',
        'ChangeBy'   => '1',
    };

=cut

sub ItemGet {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    if ( !$Param{ItemID} && ( !$Param{Class} || $Param{Name} eq '' ) ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Need ItemID OR Class and Name!'
        );
        return;
    }

    # create sql string
    my $SQL = 'SELECT id, general_catalog_class, name, valid_id, comments, '
        . 'create_time, create_by, change_time, change_by FROM general_catalog WHERE ';
    my @BIND;

    # add options to sql string
    if ( $Param{Class} && $Param{Name} ne '' ) {

        # check if result is already cached
        my $CacheKey = 'ItemGet::Class::' . $Param{Class} . '::' . $Param{Name};
        my $Cache    = $Kernel::OM->Get('Kernel::System::Cache')->Get(
            Type => $Self->{CacheType},
            Key  => $CacheKey,
        );
        return $Cache if $Cache;

        # add class and name to sql string
        $SQL .= 'general_catalog_class = ? AND name = ?';
        push @BIND, ( \$Param{Class}, \$Param{Name} );
    }
    else {

        # check if result is already cached
        my $CacheKey = 'ItemGet::ItemID::' . $Param{ItemID};
        my $Cache    = $Kernel::OM->Get('Kernel::System::Cache')->Get(
            Type => $Self->{CacheType},
            Key  => $CacheKey,
        );
        return $Cache if $Cache;

        # add item id to sql string
        $SQL .= 'id = ?';
        push @BIND, \$Param{ItemID};
    }

    # ask database
    $Kernel::OM->Get('Kernel::System::DB')->Prepare(
        SQL   => $SQL,
        Bind  => \@BIND,
        Limit => 1,
    );

    # fetch the result
    my %ItemData;
    while ( my @Row = $Kernel::OM->Get('Kernel::System::DB')->FetchrowArray() ) {
        $ItemData{ItemID}     = $Row[0];
        $ItemData{Class}      = $Row[1];
        $ItemData{Name}       = $Row[2];
        $ItemData{ValidID}    = $Row[3];
        $ItemData{Comment}    = $Row[4] || '';
        $ItemData{CreateTime} = $Row[5];
        $ItemData{CreateBy}   = $Row[6];
        $ItemData{ChangeTime} = $Row[7];
        $ItemData{ChangeBy}   = $Row[8];
    }

    # check item
    if ( !$ItemData{ItemID} ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => 'Item not found in database!',
        );
        return;
    }

    # get general catalog preferences
    my %Preferences = $Self->GeneralCatalogPreferencesGet( ItemID => $ItemData{ItemID} );

    # merge hash
    if (%Preferences) {
        %ItemData = ( %ItemData, %Preferences );
    }

    # cache the result
    $Kernel::OM->Get('Kernel::System::Cache')->Set(
        Type  => $Self->{CacheType},
        TTL   => $Self->{CacheTTL},
        Key   => 'ItemGet::Class::' . $ItemData{Class} . '::' . $ItemData{Name},
        Value => \%ItemData,
    );
    $Kernel::OM->Get('Kernel::System::Cache')->Set(
        Type  => $Self->{CacheType},
        TTL   => $Self->{CacheTTL},
        Key   => 'ItemGet::ItemID::' . $ItemData{ItemID},
        Value => \%ItemData,
    );

    return \%ItemData;
}

=item ItemAdd()

add a new general catalog item

    my $ItemID = $GeneralCatalogObject->ItemAdd(
        Class         => 'ITSM::Service::Type',
        Name          => 'Item Name',
        ValidID       => 1,
        Comment       => 'Comment',              # (optional)
        UserID        => 1,
    );

=cut

sub ItemAdd {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(Class ValidID UserID)) {
        if ( !$Param{$Argument} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # name must be not empty, but number zero (0) is allowed
    if ( $Param{Name} eq '' ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "Need Name!",
        );
        return;
    }

    # set default values
    for my $Argument (qw(Comment)) {
        $Param{$Argument} ||= '';
    }

    # cleanup given params
    for my $Argument (qw(Class)) {
        $Kernel::OM->Get('Kernel::System::CheckItem')->StringClean(
            StringRef         => \$Param{$Argument},
            RemoveAllNewlines => 1,
            RemoveAllTabs     => 1,
            RemoveAllSpaces   => 1,
        );
    }
    for my $Argument (qw(Name Comment)) {
        $Kernel::OM->Get('Kernel::System::CheckItem')->StringClean(
            StringRef         => \$Param{$Argument},
            RemoveAllNewlines => 1,
            RemoveAllTabs     => 1,
        );
    }

    # find exiting item with same name
    $Kernel::OM->Get('Kernel::System::DB')->Prepare(
        SQL => 'SELECT id FROM general_catalog '
            . 'WHERE general_catalog_class = ? AND name = ?',
        Bind  => [ \$Param{Class}, \$Param{Name} ],
        Limit => 1,
    );

    # fetch the result
    my $NoAdd;
    while ( $Kernel::OM->Get('Kernel::System::DB')->FetchrowArray() ) {
        $NoAdd = 1;
    }

    # abort insert of new item, if item name already exists
    if ($NoAdd) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message =>
                "Can't add new item! General catalog item with same name already exists in this class.",
        );
        return;
    }

    # reset cache
    $Kernel::OM->Get('Kernel::System::Cache')->CleanUp(
        Type => $Self->{CacheType},
    );

    # insert new item
    return if !$Kernel::OM->Get('Kernel::System::DB')->Do(
        SQL => 'INSERT INTO general_catalog '
            . '(general_catalog_class, name, valid_id, comments, '
            . 'create_time, create_by, change_time, change_by) VALUES '
            . '(?, ?, ?, ?, current_timestamp, ?, current_timestamp, ?)',
        Bind => [
            \$Param{Class}, \$Param{Name},
            \$Param{ValidID},
            \$Param{Comment}, \$Param{UserID},
            \$Param{UserID},
        ],
    );

    # find id of new item
    $Kernel::OM->Get('Kernel::System::DB')->Prepare(
        SQL => 'SELECT id FROM general_catalog '
            . 'WHERE general_catalog_class = ? AND name = ?',
        Bind  => [ \$Param{Class}, \$Param{Name} ],
        Limit => 1,
    );

    # fetch the result
    my $ItemID;
    while ( my @Row = $Kernel::OM->Get('Kernel::System::DB')->FetchrowArray() ) {
        $ItemID = $Row[0];
    }

    return $ItemID;
}

=item ItemUpdate()

update an existing general catalog item

    my $True = $GeneralCatalogObject->ItemUpdate(
        ItemID        => 123,
        Name          => 'Item Name',
        ValidID       => 1,
        Comment       => 'Comment',    # (optional)
        UserID        => 1,
    );

=cut

sub ItemUpdate {
    my ( $Self, %Param ) = @_;

    # check needed stuff
    for my $Argument (qw(ItemID ValidID UserID)) {
        if ( !$Param{$Argument} ) {
            $Kernel::OM->Get('Kernel::System::Log')->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # name must be not empty, but number zero (0) is allowed
    if ( $Param{Name} eq '' ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "Need Name!",
        );
        return;
    }

    # set default values
    for my $Argument (qw(Comment)) {
        $Param{$Argument} ||= '';
    }

    # cleanup given params
    for my $Argument (qw(Class)) {
        $Kernel::OM->Get('Kernel::System::CheckItem')->StringClean(
            StringRef         => \$Param{$Argument},
            RemoveAllNewlines => 1,
            RemoveAllTabs     => 1,
            RemoveAllSpaces   => 1,
        );
    }
    for my $Argument (qw(Name Comment)) {
        $Kernel::OM->Get('Kernel::System::CheckItem')->StringClean(
            StringRef         => \$Param{$Argument},
            RemoveAllNewlines => 1,
            RemoveAllTabs     => 1,
        );
    }

    # get class of item
    $Kernel::OM->Get('Kernel::System::DB')->Prepare(
        SQL   => 'SELECT general_catalog_class FROM general_catalog WHERE id = ?',
        Bind  => [ \$Param{ItemID} ],
        Limit => 1,
    );

    # fetch the result
    my $Class;
    while ( my @Row = $Kernel::OM->Get('Kernel::System::DB')->FetchrowArray() ) {
        $Class = $Row[0];
    }

    if ( !$Class ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message  => "Can't update item! General catalog item not found in this class.",
        );
        return;
    }

    # find exiting item with same name
    $Kernel::OM->Get('Kernel::System::DB')->Prepare(
        SQL   => 'SELECT id FROM general_catalog WHERE general_catalog_class = ? AND name = ?',
        Bind  => [ \$Class, \$Param{Name} ],
        Limit => 1,
    );

    # fetch the result
    my $Update = 1;
    while ( my @Row = $Kernel::OM->Get('Kernel::System::DB')->FetchrowArray() ) {
        if ( $Param{ItemID} ne $Row[0] ) {
            $Update = 0;
        }
    }

    if ( !$Update ) {
        $Kernel::OM->Get('Kernel::System::Log')->Log(
            Priority => 'error',
            Message =>
                "Can't update item! General catalog item with same name already exists in this class.",
        );
        return;
    }

    # reset cache
    $Kernel::OM->Get('Kernel::System::Cache')->CleanUp(
        Type => $Self->{CacheType},
    );

    return $Kernel::OM->Get('Kernel::System::DB')->Do(
        SQL => 'UPDATE general_catalog SET '
            . 'name = ?, valid_id = ?, comments = ?, '
            . 'change_time = current_timestamp, change_by = ? '
            . 'WHERE id = ?',
        Bind => [
            \$Param{Name},
            \$Param{ValidID}, \$Param{Comment},
            \$Param{UserID},  \$Param{ItemID},
        ],
    );
}

=item GeneralCatalogPreferencesSet()

set GeneralCatalog preferences

    $GeneralCatalogObject->GeneralCatalogPreferencesSet(
        ItemID => 123,
        Key    => 'UserComment',
        Value  => 'some comment',
    );

=cut

sub GeneralCatalogPreferencesSet {
    my $Self = shift;

    # delete cache
    $Kernel::OM->Get('Kernel::System::Cache')->CleanUp(
        Type => $Self->{CacheType},
    );

    return $Self->{PreferencesObject}->GeneralCatalogPreferencesSet(@_);
}

=item GeneralCatalogPreferencesGet()

get GeneralCatalog preferences

    my %Preferences = $QueueObject->GeneralCatalogPreferencesGet(
        ItemID => 123,
    );

=cut

sub GeneralCatalogPreferencesGet {
    my $Self = shift;

    return $Self->{PreferencesObject}->GeneralCatalogPreferencesGet(@_);
}

1;

=back

=head1 TERMS AND CONDITIONS

This Software is part of the OTRS project (http://otrs.org/).

This software comes with ABSOLUTELY NO WARRANTY. For details, see
the enclosed file COPYING for license information (AGPL). If you
did not receive this file, see L<http://www.gnu.org/licenses/agpl.txt>.

=cut

IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpTeXN0ZW06OkdlbmVyYWxDYXRhbG9nOjpQcmVmZXJlbmNlc0RCOwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKb3VyIEBPYmplY3REZXBlbmRlbmNpZXMgPSAoCiAgICAnS2VybmVsOjpDb25maWcnLAogICAgJ0tlcm5lbDo6U3lzdGVtOjpEQicsCiAgICAnS2VybmVsOjpTeXN0ZW06OkxvZycsCik7Cgo9aGVhZDEgTkFNRQoKS2VybmVsOjpTeXN0ZW06OkdlbmVyYWxDYXRhbG9nOjpQcmVmZXJlbmNlc0RCIC0gc29tZSBwcmVmZXJlbmNlcyBmdW5jdGlvbnMgZm9yIGdlbmVyYWwgY2F0YWxvZwoKPWhlYWQxIFNZTk9QU0lTCgpzb21lIHByZWZlcmVuY2VzIGZ1bmN0aW9ucyBmb3IgZ2VuZXJhbCBjYXRhbG9nCgo9aGVhZDEgUFVCTElDIElOVEVSRkFDRQoKPW92ZXIgNAoKPWN1dAoKPWl0ZW0gbmV3KCkKCmNyZWF0ZSBhbiBvYmplY3QKCiAgICB1c2UgS2VybmVsOjpTeXN0ZW06Ok9iamVjdE1hbmFnZXI7CiAgICBsb2NhbCAkS2VybmVsOjpPTSA9IEtlcm5lbDo6U3lzdGVtOjpPYmplY3RNYW5hZ2VyLT5uZXcoKTsKICAgIG15ICRHZW5lcmFsQ2F0YWxvZ1ByZWZlcmVuY2VzREJPYmplY3QgPSAkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6R2VuZXJhbENhdGFsb2c6OlByZWZlcmVuY2VzREInKTsKCj1jdXQKCnN1YiBuZXcgewogICAgbXkgKCAkVHlwZSwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGFsbG9jYXRlIG5ldyBoYXNoIGZvciBvYmplY3QKICAgIG15ICRTZWxmID0ge307CiAgICBibGVzcyggJFNlbGYsICRUeXBlICk7CgogICAgIyBwcmVmZXJlbmNlcyB0YWJsZSBkYXRhCiAgICAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGV9ICAgICAgPSAnZ2VuZXJhbF9jYXRhbG9nX3ByZWZlcmVuY2VzJzsKICAgICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZUtleX0gICA9ICdwcmVmX2tleSc7CiAgICAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGVWYWx1ZX0gPSAncHJlZl92YWx1ZSc7CiAgICAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGVHY0lEfSAgPSAnZ2VuZXJhbF9jYXRhbG9nX2lkJzsKCiAgICByZXR1cm4gJFNlbGY7Cn0KCj1pdGVtIEdlbmVyYWxDYXRhbG9nUHJlZmVyZW5jZXNTZXQoKQoKU2V0IHByZWZlcmVuY2VzIGZvciBhbiBpdGVtCgogICAgJFByZWZlcmVuY2VzT2JqZWN0LT5HZW5lcmFsQ2F0YWxvZ1ByZWZlcmVuY2VzU2V0KAogICAgICAgIEl0ZW1JRCA9PiAxMjM0LAogICAgICAgIEtleSAgICA9PiAnRnVuY3Rpb25hbGl0eScsCiAgICAgICAgVmFsdWUgID0+ICdvcGVyYXRpb25hbCcsCiAgICApOwoKPWN1dAoKc3ViIEdlbmVyYWxDYXRhbG9nUHJlZmVyZW5jZXNTZXQgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGNoZWNrIG5lZWRlZCBzdHVmZgogICAgZm9yIG15ICROZWVkZWQgKHF3KEl0ZW1JRCBLZXkgVmFsdWUpKSB7CiAgICAgICAgaWYgKCAhZGVmaW5lZCggJFBhcmFteyROZWVkZWR9ICkgKSB7CiAgICAgICAgICAgICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6U3lzdGVtOjpMb2cnKS0+TG9nKAogICAgICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgICAgIE1lc3NhZ2UgID0+ICJOZWVkICROZWVkZWQhIiwKICAgICAgICAgICAgKTsKICAgICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgIH0KCiAgICAjIGRlbGV0ZSBvbGQgZGF0YQogICAgcmV0dXJuIGlmICEkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6REInKS0+RG8oCiAgICAgICAgU1FMID0+ICJERUxFVEUgRlJPTSAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGV9IFdIRVJFICIKICAgICAgICAgICAgLiAiJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlR2NJRH0gPSA/IEFORCAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGVLZXl9ID0gPyIsCiAgICAgICAgQmluZCA9PiBbCiAgICAgICAgICAgIFwkUGFyYW17SXRlbUlEfSwKICAgICAgICAgICAgXCRQYXJhbXtLZXl9LAogICAgICAgIF0sCiAgICApOwoKICAgICMgaW5zZXJ0IG5ldyBkYXRhCiAgICByZXR1cm4gJEtlcm5lbDo6T00tPkdldCgnS2VybmVsOjpTeXN0ZW06OkRCJyktPkRvKAogICAgICAgIFNRTCA9PiAiSU5TRVJUIElOVE8gJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlfSAoJFNlbGYtPntQcmVmZXJlbmNlc1RhYmxlR2NJRH0sICIKICAgICAgICAgICAgLiAiICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZUtleX0sICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZVZhbHVlfSkgIgogICAgICAgICAgICAuICIgVkFMVUVTICg/LCA/LCA/KSIsCiAgICAgICAgQmluZCA9PiBbCiAgICAgICAgICAgIFwkUGFyYW17SXRlbUlEfSwKICAgICAgICAgICAgXCRQYXJhbXtLZXl9LAogICAgICAgICAgICBcJFBhcmFte1ZhbHVlfSwKICAgICAgICBdLAogICAgKTsKfQoKPWl0ZW0gR2VuZXJhbENhdGFsb2dQcmVmZXJlbmNlc0dldCgpCgpHZXQgYWxsIFByZWZlcmVuY2VzIGZvciBhbiBpdGVtCgogICAgbXkgJVByZWZlcmVuY2VzID0gJFByZWZlcmVuY2VzT2JqZWN0LT5HZW5lcmFsQ2F0YWxvZ1ByZWZlcmVuY2VzR2V0KAogICAgICAgIEl0ZW1JRCA9PiAxMjMsCiAgICApOwoKPWN1dAoKc3ViIEdlbmVyYWxDYXRhbG9nUHJlZmVyZW5jZXNHZXQgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICAjIGNoZWNrIG5lZWRlZCBzdHVmZgogICAgZm9yIG15ICROZWVkZWQgKHF3KEl0ZW1JRCkpIHsKICAgICAgICBpZiAoICEkUGFyYW17JE5lZWRlZH0gKSB7CiAgICAgICAgICAgICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6U3lzdGVtOjpMb2cnKS0+TG9nKAogICAgICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgICAgIE1lc3NhZ2UgID0+ICJOZWVkICROZWVkZWQhIiwKICAgICAgICAgICAgKTsKICAgICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgIH0KCiAgICAjIGNoZWNrIGlmIHF1ZXVlIHByZWZlcmVuY2VzIGFyZSBhdmFpbGFibGUKICAgIGlmICggISRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6Q29uZmlnJyktPkdldCgnR2VuZXJhbENhdGFsb2dQcmVmZXJlbmNlcycpICkgewogICAgICAgIHJldHVybjsKICAgIH0KCiAgICAjIGdldCBwcmVmZXJlbmNlcwogICAgcmV0dXJuIGlmICEkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6REInKS0+UHJlcGFyZSgKICAgICAgICBTUUwgPT4gIlNFTEVDVCAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGVLZXl9LCAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGVWYWx1ZX0gIgogICAgICAgICAgICAuICIgRlJPTSAkU2VsZi0+e1ByZWZlcmVuY2VzVGFibGV9IFdIRVJFICRTZWxmLT57UHJlZmVyZW5jZXNUYWJsZUdjSUR9ID0gPyIsCiAgICAgICAgQmluZCA9PiBbIFwkUGFyYW17SXRlbUlEfSBdLAogICAgKTsKCiAgICBteSAlRGF0YTsKICAgIHdoaWxlICggbXkgQFJvdyA9ICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6U3lzdGVtOjpEQicpLT5GZXRjaHJvd0FycmF5KCkgKSB7CiAgICAgICAgJERhdGF7ICRSb3dbMF0gfSA9ICRSb3dbMV07CiAgICB9CgogICAgIyByZXR1cm4gZGF0YQogICAgcmV0dXJuICVEYXRhOwp9CgoxOwoKPWJhY2sKCj1oZWFkMSBURVJNUyBBTkQgQ09ORElUSU9OUwoKVGhpcyBzb2Z0d2FyZSBpcyBwYXJ0IG9mIHRoZSBPVFJTIHByb2plY3QgKEw8aHR0cDovL290cnMub3JnLz4pLgoKVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQpkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgTDxodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQ+LgoKPWN1dAo=
# --
# Copyright (C) 2001-2016 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

use strict;
use warnings;
use utf8;

use vars qw($Self);

# create local objects
my $ConfigObject         = $Kernel::OM->Get('Kernel::Config');
my $GeneralCatalogObject = $Kernel::OM->Get('Kernel::System::GeneralCatalog');
my $UserObject           = $Kernel::OM->Get('Kernel::System::User');

# get helper object
$Kernel::OM->ObjectParamAdd(
    'Kernel::System::UnitTest::Helper' => {
        RestoreDatabase => 1,
    },
);
my $Helper = $Kernel::OM->Get('Kernel::System::UnitTest::Helper');

# define needed variable
my $RandomID = $Helper->GetRandomID();

# ------------------------------------------------------------ #
# make preparations
# ------------------------------------------------------------ #

# create needed users
my @UserIDs;
{

    # disable email checks to create new user
    my $CheckEmailAddressesOrg = $ConfigObject->Get('CheckEmailAddresses') || 1;
    $ConfigObject->Set(
        Key   => 'CheckEmailAddresses',
        Value => 0,
    );

    for my $Counter ( 1 .. 2 ) {

        # create new users for the tests
        my $UserID = $UserObject->UserAdd(
            UserFirstname => 'GeneralCatalog' . $Counter,
            UserLastname  => 'UnitTest',
            UserLogin     => 'UnitTest-GeneralCatalog-' . $Counter . $RandomID,
            UserEmail     => 'UnitTest-GeneralCatalog-' . $Counter . '@localhost',
            ValidID       => 1,
            ChangeUserID  => 1,
        );

        push @UserIDs, $UserID;
    }

    # restore original email check param
    $ConfigObject->Set(
        Key   => 'CheckEmailAddresses',
        Value => $CheckEmailAddressesOrg,
    );
}

# create needed random classes
my @ClassRand;

for my $Counter ( 1 .. 3 ) {

    push @ClassRand, $Helper->GetRandomNumber();
}

# store original general catalog permission preferences setting
my $GeneralCatalogPreferencesPermissionsOrg;
if ( $ConfigObject->Get('GeneralCatalogPreferences') ) {
    $GeneralCatalogPreferencesPermissionsOrg = $ConfigObject->Get('GeneralCatalogPreferences')->{Permissions};
}

# enable general catalog permission preferences setting with a dummy true value
$ConfigObject->Set(
    Key   => 'GeneralCatalogPreferences###Permissions',
    Value => 1,
);

# ------------------------------------------------------------ #
# define general tests
# ------------------------------------------------------------ #

my $ItemData = [

    # this item is NOT complete and must not be added
    {
        Add => {
            Name    => 'TestItem1',
            ValidID => 1,
            UserID  => 1,
        },
    },

    # this item is NOT complete and must not be added
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            ValidID => 1,
            UserID  => 1,
        },
    },

    # this item is NOT complete and must not be added
    {
        Add => {
            Class  => 'UnitTest::TestClass' . $ClassRand[0],
            Name   => 'TestItem2',
            UserID => 1,
        },
    },

    # this item is NOT complete and must not be added
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            Name    => 'TestItem3',
            ValidID => 1,
        },
    },

    # this item must be inserted successfully
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            Name    => 'TestItem4',
            ValidID => 1,
            UserID  => 1,
        },
        AddGet => {
            Class    => 'UnitTest::TestClass' . $ClassRand[0],
            Name     => 'TestItem4',
            ValidID  => 1,
            Comment  => '',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the preferences of the item one add-test before must be set
    {
        PreferencesSet => {
            Hello => 'World',
            Color => 'Red',
        },
        PreferencesGet => {
            Hello => 'World',
            Color => 'Red',
        },
    },

    # this item have the same name as one test before and must not be added
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            Name    => 'TestItem4',
            ValidID => 1,
            UserID  => 1,
        },
    },

    # this item must be inserted successfully
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            Name    => 'TestItem5',
            ValidID => 1,
            UserID  => 1,
        },
        AddGet => {
            Class    => 'UnitTest::TestClass' . $ClassRand[0],
            Name     => 'TestItem5',
            ValidID  => 1,
            Comment  => '',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the preferences of the item one add-test before must be set
    {
        PreferencesSet => {
            Hello => 'NewWorld',
            Color => 'Blue',
        },
        PreferencesGet => {
            Hello => 'NewWorld',
            Color => 'Blue',
        },
    },

    # the item one add-test before must be NOT updated (item update arguments NOT complete)
    {
        Update => {
            ValidID => $UserIDs[0],
            UserID  => $UserIDs[0],
        },
    },

    # the item one add-test before must be NOT updated (item update arguments NOT complete)
    {
        Update => {
            Name   => 'TestItem5UPDATE1',
            UserID => $UserIDs[0],
        },
    },

    # the item one add-test before must be NOT updated (item update arguments NOT complete)
    {
        Update => {
            ValidID => $UserIDs[0],
        },
    },

    # the item one add-test before must be updated (item update arguments are complete)
    {
        Update => {
            Name    => 'TestItem5UPDATE2',
            ValidID => $UserIDs[0],
            UserID  => $UserIDs[0],
        },
        UpdateGet => {
            Name     => 'TestItem5UPDATE2',
            ValidID  => $UserIDs[0],
            Comment  => '',
            CreateBy => 1,
            ChangeBy => $UserIDs[0],
        },
    },

    # the item one add-test before must be updated (item update arguments are complete)
    {
        Update => {
            Name    => 'TestItem5UPDATE3',
            ValidID => 1,
            UserID  => 1,
        },
        UpdateGet => {
            Name     => 'TestItem5UPDATE3',
            ValidID  => 1,
            Comment  => '',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # this template must be inserted successfully (check string cleaner function)
    {
        Add => {
            Class   => " \t \n \r Unit Test :: Test Class \t \n \r " . $ClassRand[0],
            Name    => " \t \n \r Test Item \t \n \r ",
            ValidID => 1,
            Comment => " \t \n \r Test Comment \t \n \r ",
            UserID  => 1,
        },
        AddGet => {
            Class    => 'UnitTest::TestClass' . $ClassRand[0],
            Name     => 'Test Item',
            ValidID  => 1,
            Comment  => 'Test Comment',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the item one add-test before must be updated successfully (check string cleaner function)
    {
        Update => {
            Name    => " \t \n \r Test Item UPDATE1 \t \n \r ",
            ValidID => $UserIDs[0],
            Comment => " \t \n \r Test Comment UPDATE1 \t \n \r ",
            UserID  => $UserIDs[0],
        },
        UpdateGet => {
            Name     => 'Test Item UPDATE1',
            ValidID  => $UserIDs[0],
            Comment  => 'Test Comment UPDATE1',
            CreateBy => 1,
            ChangeBy => $UserIDs[0],
        },
    },

    # this item must be inserted successfully (unicode checks)
    {
        Add => {
            Class   => 'UnitTest::TestClass©' . $ClassRand[1],
            Name    => ' ϒ ϡ Test Item Ʃ Ϟ ',
            ValidID => 1,
            Comment => ' Ϡ Я Test Comment Ѭ Ѡ ',
            UserID  => 1,
        },
        AddGet => {
            Class    => 'UnitTest::TestClass©' . $ClassRand[1],
            Name     => 'ϒ ϡ Test Item Ʃ Ϟ',
            ValidID  => 1,
            Comment  => 'Ϡ Я Test Comment Ѭ Ѡ',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the item one add-test before must be updated successfully (unicode checks)
    {
        Update => {
            Name    => 'Test Item Ʃ ɤ UPDATE1',
            ValidID => $UserIDs[1],
            Comment => ' Test Comment љ ђ UPDATE1 ',
            UserID  => $UserIDs[1],
        },
        UpdateGet => {
            Name     => 'Test Item Ʃ ɤ UPDATE1',
            ValidID  => $UserIDs[1],
            Comment  => 'Test Comment љ ђ UPDATE1',
            CreateBy => 1,
            ChangeBy => $UserIDs[1],
        },
    },

    # this item must be inserted successfully (a second item with Functionality 'test1')
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            Name    => 'TestItem6',
            ValidID => 1,
            UserID  => 1,
        },
        AddGet => {
            Class    => 'UnitTest::TestClass' . $ClassRand[0],
            Name     => 'TestItem6',
            ValidID  => 1,
            Comment  => '',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the item one add-test before must be updated (set functionality to '')
    {
        Update => {
            Name    => 'TestItem6UPDATE1',
            ValidID => 1,
            UserID  => 1,
        },
        UpdateGet => {
            Name     => 'TestItem6UPDATE1',
            ValidID  => 1,
            Comment  => '',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # this item must be inserted successfully (special character checks)
    {
        Add => {
            Class   => 'UnitTest::TestClass[test]%*\\' . $ClassRand[1],
            Name    => ' [test]%*\\ Test Item [test]%*\\ ',
            ValidID => 1,
            Comment => ' [test]%*\\ Test Comment [test]%*\\ ',
            UserID  => 1,
        },
        AddGet => {
            Class    => 'UnitTest::TestClass[test]%*\\' . $ClassRand[1],
            Name     => '[test]%*\\ Test Item [test]%*\\',
            ValidID  => 1,
            Comment  => '[test]%*\\ Test Comment [test]%*\\',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the item one add-test before must be updated successfully (special character checks)
    {
        Update => {
            Name    => ' [test]%*\\ Test Item UPDATE1 [test]%*\\ ',
            ValidID => $UserIDs[1],
            Comment => ' [test]%*\\ Test Comment UPDATE1 [test]%*\\ ',
            UserID  => $UserIDs[1],
        },
        UpdateGet => {
            Name     => '[test]%*\\ Test Item UPDATE1 [test]%*\\',
            ValidID  => $UserIDs[1],
            Comment  => '[test]%*\\ Test Comment UPDATE1 [test]%*\\',
            CreateBy => 1,
            ChangeBy => $UserIDs[1],
        },
    },

    # this item must be inserted successfully
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            Name    => 'TestItemPreferences',
            ValidID => 1,
            UserID  => 1,
        },
        AddGet => {
            Class    => 'UnitTest::TestClass' . $ClassRand[0],
            Name     => 'TestItemPreferences',
            ValidID  => 1,
            Comment  => '',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the preferences of the item one add-test before must be set
    {
        PreferencesSet => {
            Test  => 'hello world',
            Group => 33,
        },
        PreferencesGet => {
            Test  => 'hello world',
            Group => 33,
        },
    },

    # the preferences of the item one add-test before must be set
    {
        PreferencesSet => {
            Test => 'hello',
            Size => 38,
        },
        PreferencesGet => {
            Test => 'hello',
            Size => 38,
        },
    },

    # this item has an empty name and must not be added
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            Name    => '',
            ValidID => 1,
            UserID  => 1,
        },
    },

    # this item must be added, the number zero (0) is allowed as name
    {
        Add => {
            Class   => 'UnitTest::TestClass' . $ClassRand[0],
            Name    => '0',
            ValidID => 1,
            UserID  => 1,
        },
        AddGet => {
            Class    => 'UnitTest::TestClass' . $ClassRand[0],
            Name     => '0',
            ValidID  => 1,
            Comment  => '',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the item one add-test before must be updated successfully (updating name to number zero (0) )
    {
        Update => {
            Name    => '0',
            ValidID => 1,
            Comment => '',
            UserID  => 1,
        },
        UpdateGet => {
            Name     => '0',
            ValidID  => 1,
            Comment  => '',
            CreateBy => 1,
            ChangeBy => 1,
        },
    },

    # the item one add-test before must not be updated successfully
    # (empty string as name is not allowed )
    {
        Update => {
            Name    => '',
            ValidID => 1,
            Comment => '',
            UserID  => 1,
        },
    },
];

# ------------------------------------------------------------ #
# run general tests
# ------------------------------------------------------------ #

my $TestCount = 1;
my $LastAddedItemID;
my %AddedItemCounter;

for my $Item ( @{$ItemData} ) {

    if ( $Item->{Add} ) {

        # add new item
        my $ItemID = $GeneralCatalogObject->ItemAdd(
            %{ $Item->{Add} },
        );

        # check if item was added successfully or not
        if ( $Item->{AddGet} ) {

            $Self->True(
                $ItemID,
                "Test $TestCount: ItemAdd() - ItemKey: $ItemID",
            );

            if ($ItemID) {

                # set last item id variable
                $LastAddedItemID = $ItemID;

                # increment the added item counter
                $AddedItemCounter{ $Item->{AddGet}->{Class} }++;
            }
        }
        else {
            $Self->False(
                $ItemID,
                "Test $TestCount: ItemAdd()",
            );
        }

        # get item data to check the values after creation of item using ItemId and UserID
        my $ItemGet = $GeneralCatalogObject->ItemGet(
            ItemID => $ItemID,
            UserID => $Item->{Add}->{UserID},
        );

        # check item data after creation of item
        for my $ItemAttribute ( sort keys %{ $Item->{AddGet} } ) {
            $Self->Is(
                $ItemGet->{$ItemAttribute},
                $Item->{AddGet}->{$ItemAttribute},
                "Test $TestCount: ItemGet() - Using ItemID and UserID - $ItemAttribute ",
            );
        }

        # get item data to check the values after creation of item using Class and Name
        $ItemGet = $GeneralCatalogObject->ItemGet(
            Class => $Item->{AddGet}->{Class},
            Name  => $Item->{AddGet}->{Name},
        );

        # check item data after creation of item
        for my $ItemAttribute ( sort keys %{ $Item->{AddGet} } ) {
            $Self->Is(
                $ItemGet->{$ItemAttribute},
                $Item->{AddGet}->{$ItemAttribute},
                "Test $TestCount: ItemGet() - Using Class and Name - $ItemAttribute ",
            );
        }
    }

    if ( $Item->{Update} ) {

        # check last item id variable
        if ( !$LastAddedItemID ) {
            $Self->False(
                1,
                "Test $TestCount: NO LAST ITEM ID GIVEN",
            );
        }

        # update the item
        my $UpdateSucess = $GeneralCatalogObject->ItemUpdate(
            %{ $Item->{Update} },
            ItemID => $LastAddedItemID,
        );

        # check if item was updated successfully or not
        if ( $Item->{UpdateGet} ) {
            $Self->True(
                $UpdateSucess,
                "Test $TestCount: ItemUpdate() - ItemKey: $LastAddedItemID",
            );
        }
        else {
            $Self->False(
                $UpdateSucess,
                "Test $TestCount: ItemUpdate()",
            );
        }

        # get item data to check the values after the update
        my $ItemGet2 = $GeneralCatalogObject->ItemGet(
            ItemID => $LastAddedItemID,
            UserID => $Item->{Update}->{UserID},
        );

        # check item data after update
        for my $ItemAttribute ( sort keys %{ $Item->{UpdateGet} } ) {
            $Self->Is(
                $ItemGet2->{$ItemAttribute},
                $Item->{UpdateGet}->{$ItemAttribute},
                "Test $TestCount: ItemGet() - $ItemAttribute",
            );
        }
    }

    if ( $Item->{PreferencesSet} ) {

        for my $Key ( sort keys %{ $Item->{PreferencesSet} } ) {

            # set preferences
            my $Success = $GeneralCatalogObject->GeneralCatalogPreferencesSet(
                Key    => $Key,
                Value  => $Item->{PreferencesSet}->{$Key},
                ItemID => $LastAddedItemID,
            );

            $Self->True(
                $Success,
                "Test $TestCount: PreferencesSet() - $Key",
            );
        }
    }

    # check preferences
    if ( $Item->{PreferencesGet} ) {
        my %Preferences = $GeneralCatalogObject->GeneralCatalogPreferencesGet(
            ItemID => $LastAddedItemID,
        );

        for my $Key ( sort keys %{ $Item->{PreferencesGet} } ) {
            if ( $Item->{PreferencesGet}->{$Key} eq $Preferences{$Key} ) {
                $Self->True(
                    1,
                    "Test $TestCount: PreferencesGet() - $Key",
                );
            }
            else {
                $Self->True(
                    0,
                    "Test $TestCount: PreferencesGet() - $Key",
                );
            }
        }
    }

    $TestCount++;
}

# ------------------------------------------------------------ #
# make preparations for later tests
# ------------------------------------------------------------ #

# create needed arrays
my %ExistingClassesTmp;
ITEM:
for my $Item ( @{$ItemData} ) {
    next ITEM if !$Item->{AddGet}->{Class};
    $ExistingClassesTmp{ $Item->{AddGet}->{Class} } = 1;
}
my @ExistingClasses = sort keys %ExistingClassesTmp;

my %ExistingFunctionalitiesTmp;
ITEM:
for my $Item ( @{$ItemData} ) {
    $Item->{UpdateGet}->{Functionality} ||= '';
    $ExistingFunctionalitiesTmp{ $Item->{UpdateGet}->{Functionality} } = 1;
}
my @ExistingFunctionalities = sort keys %ExistingFunctionalitiesTmp;

my @NonExistingClasses = ( 'UnitTest::NoExistingClass1', 'UnitTest::NoExistingClass2' );

# ------------------------------------------------------------ #
# ClassList test 1
# ------------------------------------------------------------ #

my $ClassList1 = $GeneralCatalogObject->ClassList();

for my $Class (@ExistingClasses) {

    my $ClassCount = 0;
    if ( $ClassList1 && ref $ClassList1 eq 'ARRAY' ) {
        $ClassCount = grep { $_ eq $Class } @{$ClassList1};
    }

    $Self->Is(
        $ClassCount,
        1,
        "Test $TestCount: ClassList() - $Class listed",
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# ItemList test 1
# ------------------------------------------------------------ #

for my $Class (@NonExistingClasses) {

    my $ItemList = $GeneralCatalogObject->ItemList(
        Class => $Class,
        Valid => 0,
    );

    $Self->False(
        $ItemList,
        "Test $TestCount: ItemList() - $Class not exists",
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# ItemList test 2
# ------------------------------------------------------------ #

for my $Class (@ExistingClasses) {

    my $ItemList = $GeneralCatalogObject->ItemList(
        Class => $Class,
        Valid => 0,
    );

    my $ListCount = 'NULL';
    if ( defined $ItemList && ref $ItemList eq 'HASH' ) {
        $ListCount = keys %{$ItemList};
    }

    $Self->Is(
        $ListCount,
        $AddedItemCounter{$Class},
        "Test $TestCount: ItemList() - $Class correct number of items",
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# ItemList test 3 - Item List with preferences (single hash entry)
# ------------------------------------------------------------ #

{

    my $Class    = 'UnitTest::TestClass' . $ClassRand[0];
    my $ItemList = $GeneralCatalogObject->ItemList(
        Class       => $Class,
        Valid       => 1,
        Preferences => {
            Hello => 'World',
        },
    );

    my $ListCount = 'NULL';
    if ( defined $ItemList && ref $ItemList eq 'HASH' ) {
        $ListCount = keys %{$ItemList};
    }

    $Self->Is(
        $ListCount,
        1,
        "Test $TestCount: ItemList() preferences (single hash entry) - $Class correct number of items",
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# ItemList test 4 - Item List with preferences (array)
# ------------------------------------------------------------ #

{

    my $Class    = 'UnitTest::TestClass' . $ClassRand[0];
    my $ItemList = $GeneralCatalogObject->ItemList(
        Class       => $Class,
        Valid       => 1,
        Preferences => {
            Color => [ 'Red', 'Blue' ],
        },
    );

    my $ListCount = 'NULL';
    if ( defined $ItemList && ref $ItemList eq 'HASH' ) {
        $ListCount = keys %{$ItemList};
    }

    $Self->Is(
        $ListCount,
        2,
        "Test $TestCount: ItemList() preferences (array) - $Class correct number of items",
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# Preferences test 1
# ------------------------------------------------------------ #
for my $Class (@ExistingClasses) {

    my $ItemID = $GeneralCatalogObject->ItemAdd(
        Class   => $Class,
        Name    => 'Item Preferences',
        ValidID => 1,
        UserID  => 1,
    );

    $GeneralCatalogObject->GeneralCatalogPreferencesSet(
        ItemID => $ItemID,
        Key    => 'UnitTestPref',
        Value  => '1',
    );

    my $ItemList = $GeneralCatalogObject->ItemList(
        Class       => $Class,
        Preferences => {
            UnitTestPref => 1,
        },
    );

    $Self->Is(
        $ItemList->{$ItemID},
        'Item Preferences',
        "Test $TestCount: ItemList() - Class $Class Preferences match",
    );

    $GeneralCatalogObject->GeneralCatalogPreferencesSet(
        ItemID => $ItemID,
        Key    => 'UnitTestPref',
        Value  => '2',
    );

    $ItemList = $GeneralCatalogObject->ItemList(
        Class       => $Class,
        Preferences => {
            UnitTestPref => 1,
        },
    );

    $Self->False(
        $ItemList,
        "Test $TestCount: ItemList() - Class $Class Preferences not match after PreferencesSet Change"
    );

    $GeneralCatalogObject->ItemUpdate(
        ItemID  => $ItemID,
        Name    => 'Item Preferences',
        ValidID => 2,
        UserID  => 1,
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# Preferences test 2
# ------------------------------------------------------------ #

=pod

my %FunctionalityList1;
map { $FunctionalityList1{$_} = 1 } @ExistingFunctionalities;

for my $Class (@ExistingClasses) {

    my $FunctionalityList = $GeneralCatalogObject->FunctionalityList(
        Class => $Class,
    );

    $Self->True(
        $FunctionalityList && ref $FunctionalityList eq 'ARRAY',
        "Test $TestCount: FunctionalityList() - return a array reference",
    );

    for my $Functionality ( @{$FunctionalityList} ) {
        delete $FunctionalityList1{$Functionality};
    }

    $TestCount++;
}

$Self->True(
    !keys %FunctionalityList1,
    "Test $TestCount: FunctionalityList()",
);

$TestCount++;

=cut

# ------------------------------------------------------------ #
# ClassRename test 1 (check normal rename)
# ------------------------------------------------------------ #

CLASS:
for my $Class (@ExistingClasses) {

    my $OldItemList = $GeneralCatalogObject->ItemList(
        Class => $Class,
        Valid => 0,
    );

    my $Success = $GeneralCatalogObject->ClassRename(
        ClassOld => $Class,
        ClassNew => $Class . 'RENAME1',
    );

    if ( !$Success ) {
        $Self->False(
            1,
            "Test $TestCount: ClassRename() - Rename failed",
        );
        next CLASS;
    }

    my $NewItemList = $GeneralCatalogObject->ItemList(
        Class => $Class . 'RENAME1',
        Valid => 0,
    );

    if (
        !$OldItemList
        || !$NewItemList
        || ref $OldItemList ne 'HASH'
        || ref $NewItemList ne 'HASH'
        )
    {
        $Self->False(
            1,
            "Test $TestCount: ClassRename() - ItemList failed",
        );
        next CLASS;
    }

    OLDKEY:
    for my $OldKey ( sort keys %{$OldItemList} ) {

        if ( !exists $NewItemList->{$OldKey} ) {
            $NewItemList->{FailedDummy} = 1;
            next OLDKEY;
        }

        next OLDKEY if $OldItemList->{$OldKey} ne $NewItemList->{$OldKey};

        delete $NewItemList->{$OldKey};
    }

    $Self->True(
        !keys %{$NewItemList},
        "Test $TestCount: ClassRename()",
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# ClassRename test 2 (check string cleaner function)
# ------------------------------------------------------------ #

CLASS:
for my $Class (@ExistingClasses) {

    my $OldItemList = $GeneralCatalogObject->ItemList(
        Class => $Class . 'RENAME1',
        Valid => 0,
    );

    my $Success = $GeneralCatalogObject->ClassRename(
        ClassOld => $Class . 'RENAME1',
        ClassNew => ' ' . $Class . "RE NA ME 2 \n \r \t ",
    );

    if ( !$Success ) {
        $Self->False(
            1,
            "Test $TestCount: ClassRename() - Rename failed",
        );
        next CLASS;
    }

    my $NewItemList = $GeneralCatalogObject->ItemList(
        Class => $Class . 'RENAME2',
        Valid => 0,
    );

    if (
        !$OldItemList
        || !$NewItemList
        || ref $OldItemList ne 'HASH'
        || ref $NewItemList ne 'HASH'
        )
    {
        $Self->False(
            1,
            "Test $TestCount: ClassRename() - ItemList failed",
        );
        next CLASS;
    }

    OLDKEY:
    for my $OldKey ( sort keys %{$OldItemList} ) {

        if ( !exists $NewItemList->{$OldKey} ) {
            $NewItemList->{FailedDummy} = 1;
            next OLDKEY;
        }

        next OLDKEY if $OldItemList->{$OldKey} ne $NewItemList->{$OldKey};

        delete $NewItemList->{$OldKey};
    }

    $Self->True(
        !keys %{$NewItemList},
        "Test $TestCount: ClassRename()",
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# ClassRename test 2 (identical name test)
# ------------------------------------------------------------ #

for my $Class (@ExistingClasses) {

    my $Success = $GeneralCatalogObject->ClassRename(
        ClassOld => $Class . 'RENAME2',
        ClassNew => $Class . 'RENAME2',
    );

    $Self->True(
        $Success,
        "Test $TestCount: ClassRename() - oldname and newname identical",
    );

    $TestCount++;
}

# ------------------------------------------------------------ #
# ClassRename test 3 (new class name already exists)
# ------------------------------------------------------------ #

$GeneralCatalogObject->ItemAdd(
    Class         => 'UnitTest::TestClass' . $ClassRand[2],
    Name          => 'Dummy',
    Functionality => '',
    ValidID       => 1,
    UserID        => 1,
);

for my $Class (@ExistingClasses) {

    my $Success = $GeneralCatalogObject->ClassRename(
        ClassOld => $Class . 'RENAME2',
        ClassNew => 'UnitTest::TestClass' . $ClassRand[2],
    );

    $Self->False(
        $Success,
        "Test $TestCount: ClassRename() - new class name already exists",
    );

    $TestCount++;
}

# restore original general catalog permission preferences setting
$ConfigObject->Set(
    Key   => 'GeneralCatalogPreferences###Permissions',
    Value => $GeneralCatalogPreferencesPermissionsOrg,
);

# cleanup is done by RestoreDatabase

1;

# --
# Copyright (C) 2001-2016 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

use strict;
use warnings;
use utf8;

use vars (qw($Self));

# get selenium object
my $Selenium = $Kernel::OM->Get('Kernel::System::UnitTest::Selenium');

$Selenium->RunTest(
    sub {

        # get helper object
        my $Helper = $Kernel::OM->Get('Kernel::System::UnitTest::Helper');

        # get sysconfig object
        my $SysConfigObject = $Kernel::OM->Get('Kernel::System::SysConfig');

        $Helper->ConfigSettingChange(
            Valid => 0,
            Key   => 'GeneralCatalogPreferences###Comment2',
            Value => {
                Module  => 'Kernel::Output::HTML::GeneralCatalogPreferences::Generic',
                Label   => 'Comment2',
                Desc    => 'Define the general catalog comment 2.',
                Block   => 'TextArea',
                Cols    => '50',
                Rows    => '5',
                PrefKey => 'Comment2',
            },
        );

        $Helper->ConfigSettingChange(
            Valid => 0,
            Key   => 'GeneralCatalogPreferences###Permissions',
            Value => {
                Module  => 'Kernel::Output::HTML::GeneralCatalogPreferences::Generic',
                Label   => 'Permissions',
                Desc    => 'Define the group with permissions.',
                Block   => 'Permission',
                Class   => 'ITSM::ConfigItem::Class',
                PrefKey => 'Permissions',
            },
        );

        # create and log in test user
        my $TestUserLogin = $Helper->TestUserCreate(
            Groups => ['admin'],
        ) || die "Did not get test user";

        $Selenium->Login(
            Type     => 'Agent',
            User     => $TestUserLogin,
            Password => $TestUserLogin,
        );

        # get script alias
        my $ScriptAlias = $Kernel::OM->Get('Kernel::Config')->Get('ScriptAlias');

        # ---------------------------------------------------- #
        # Test case: Comment2                                  #
        # ---------------------------------------------------- #

        # navigate to AdminGeneralCatalog screen
        $Selenium->VerifiedGet("${ScriptAlias}index.pl?Action=AdminGeneralCatalog");

        # click "Add Catalog Class"
        $Selenium->find_element("//button[\@value='Add'][\@type='submit']")->VerifiedClick();

        # verify that general catalog preference Comment2 is not present while invalid
        $Self->True(
            index( $Selenium->get_page_source(), "#Comment2" ) == -1,
            "#Comment2 is not enabled!",
        );

        # get general catalog preference Comment2 default sysconfig
        my %PreferenceComment2Config = $SysConfigObject->ConfigItemGet(
            Name    => 'GeneralCatalogPreferences###Comment2',
            Default => 1,
        );

        # set general catalog preference Comment2 to valid
        my %PreferenceComment2ConfigUpdate = map { $_->{Key} => $_->{Content} }
            grep { defined $_->{Key} } @{ $PreferenceComment2Config{Setting}->[1]->{Hash}->[1]->{Item} };

        $Helper->ConfigSettingChange(
            Valid => 1,
            Key   => 'GeneralCatalogPreferences###Comment2',
            Value => \%PreferenceComment2ConfigUpdate,
        );

        # refresh screen for sysconfig update to take effect
        $Selenium->VerifiedRefresh();

        # verify that general catalog preference Comment2 is present while valid
        my $Success = $Selenium->find_element( "#Comment2", 'css' )->is_enabled();
        $Self->True(
            $Success,
            "#Comment2 is enabled!",
        );

        # create real test catalog class
        my $CatalogClassDsc  = "CatalogClassDsc" . $Helper->GetRandomID();
        my $CatalogClassName = "CatalogClassName" . $Helper->GetRandomID();
        $Selenium->find_element( "#ClassDsc", 'css' )->send_keys($CatalogClassDsc);
        $Selenium->find_element( "#Name",     'css' )->send_keys($CatalogClassName);
        $Selenium->find_element( "#Comment",  'css' )->send_keys("Selenium catalog class");
        $Selenium->execute_script("\$('#ValidID').val('1').trigger('redraw.InputField').trigger('change');");
        $Selenium->find_element("//button[\@value='Submit'][\@type='submit']")->VerifiedClick();

        # click "Add Catalog Item"
        $Selenium->find_element("//button[\@value='Add'][\@type='submit']")->VerifiedClick();

        # create real test catalog item
        my $CatalogClassItem = "CatalogClassItem" . $Helper->GetRandomID();
        $Selenium->find_element( "#Name",    'css' )->send_keys($CatalogClassItem);
        $Selenium->find_element( "#Comment", 'css' )->send_keys("Selenium catalog item");
        $Selenium->execute_script("\$('#ValidID').val('1').trigger('redraw.InputField').trigger('change');");

        # set included queue attribute Comment2
        $Selenium->find_element( "#Comment2", 'css' )->send_keys('GeneralCatalogPreferencesGeneric Comment2');
        $Selenium->find_element("//button[\@value='Submit'][\@type='submit']")->VerifiedClick();

        # get test catalog items IDs
        my @CatalogItemIDs;
        for my $CatalogItems ( $CatalogClassName, $CatalogClassItem ) {
            my $CatalogClassItemData = $Kernel::OM->Get('Kernel::System::GeneralCatalog')->ItemGet(
                Class => $CatalogClassDsc,
                Name  => $CatalogItems,
            );
            my $CatalogItemID = $CatalogClassItemData->{ItemID};
            push @CatalogItemIDs, $CatalogItemID;
        }

        # check new test catalog item Comment2 value
        $Selenium->find_element(
            "//a[contains(\@href, \'Action=AdminGeneralCatalog;Subaction=ItemEdit;ItemID=$CatalogItemIDs[1]' )]"
        )->VerifiedClick();

        $Self->Is(
            $Selenium->find_element( '#Comment2', 'css' )->get_value(),
            'GeneralCatalogPreferencesGeneric Comment2',
            "#Comment2 stored value",
        );

        # update Comment2
        my $UpdateComment2 = "Updated comment for GeneralCatalogPreferencesGeneric Comment2";
        $Selenium->find_element( "#Comment2", 'css' )->clear();
        $Selenium->find_element( "#Comment2", 'css' )->send_keys($UpdateComment2);
        $Selenium->find_element("//button[\@value='Submit'][\@type='submit']")->VerifiedClick();

        # check updated Comment2 value
        $Selenium->find_element( $CatalogClassItem, 'link_text' )->VerifiedClick();
        $Self->Is(
            $Selenium->find_element( '#Comment2', 'css' )->get_value(),
            $UpdateComment2,
            "#Comment2 updated value",
        );

        # ---------------------------------------------------- #
        # Test case: Permissions                               #
        # ---------------------------------------------------- #

        # navigate to AdminGeneralCatalog screen
        $Selenium->VerifiedGet("${ScriptAlias}index.pl?Action=AdminGeneralCatalog");

        # click on test CatalogClass
        $Selenium->find_element( $CatalogClassDsc, 'link_text' )->VerifiedClick();

        # click "Add Catalog Item"
        $Selenium->find_element("//button[\@value='Add'][\@type='submit']")->VerifiedClick();

        # verify that general catalog preference Permissions is not present while invalid
        $Self->True(
            index( $Selenium->get_page_source(), "#Permission_Search" ) == -1,
            "#Permissions is not enabled!",
        );

        # get general catalog preference Permission default sysconfig
        my %PreferencePermissionsConfig = $SysConfigObject->ConfigItemGet(
            Name    => 'GeneralCatalogPreferences###Permissions',
            Default => 1,
        );

        # set Class for GeneralCatalogPreferences###Permissions as test CatalogClass
        $PreferencePermissionsConfig{Setting}->[1]->{Hash}->[1]->{Item}->[5]->{Content} = $CatalogClassDsc;

        # set general catalog preference Permission to valid
        my %PreferencePermissionsConfigUpdate = map { $_->{Key} => $_->{Content} }
            grep { defined $_->{Key} } @{ $PreferencePermissionsConfig{Setting}->[1]->{Hash}->[1]->{Item} };

        $Helper->ConfigSettingChange(
            Valid => 1,
            Key   => 'GeneralCatalogPreferences###Permissions',
            Value => \%PreferencePermissionsConfigUpdate,
        );

        # refresh screen for sysconfig update to take effect
        $Selenium->VerifiedRefresh();

        # verify that general catalog preference Permissions is present while valid
        $Success = $Selenium->find_element( "#Permission_Search", 'css' )->is_enabled();
        $Self->True(
            $Success,
            "#Permissions is enabled!",
        );

        # get DB object
        my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

        # delete created test catalog class
        for my $CatalogItem (@CatalogItemIDs) {

            $Success = $DBObject->Do(
                SQL => "DELETE FROM general_catalog_preferences WHERE general_catalog_id = $CatalogItem",
            );
            $Self->True(
                $Success,
                "CatalogItemID $CatalogItem preference - deleted",
            );
            $Success = $DBObject->Do(
                SQL => "DELETE FROM general_catalog WHERE id = $CatalogItem",
            );
            $Self->True(
                $Success,
                "CatalogItemID $CatalogItem - deleted",
            );
        }

        # clean up cache
        $Kernel::OM->Get('Kernel::System::Cache')->CleanUp( Type => 'GeneralCatalog' );
    }
);

1;

# --
# Copyright (C) 2001-2016 OTRS AG, http://otrs.com/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --

use strict;
use warnings;
use utf8;

use vars (qw($Self));

# get selenium object
my $Selenium = $Kernel::OM->Get('Kernel::System::UnitTest::Selenium');

$Selenium->RunTest(
    sub {

        # get helper object
        my $Helper = $Kernel::OM->Get('Kernel::System::UnitTest::Helper');

        # create and log in test user
        my $TestUserLogin = $Helper->TestUserCreate(
            Groups => ['admin'],
        ) || die "Did not get test user";

        $Selenium->Login(
            Type     => 'Agent',
            User     => $TestUserLogin,
            Password => $TestUserLogin,
        );

        # get script alias
        my $ScriptAlias = $Kernel::OM->Get('Kernel::Config')->Get('ScriptAlias');

        # navigate to AdminGeneralCatalog screen
        $Selenium->VerifiedGet("${ScriptAlias}index.pl?Action=AdminGeneralCatalog");

        # click "Add Catalog Class"
        $Selenium->find_element("//button[\@value='Add'][\@type='submit']")->VerifiedClick();

        # check for input fields
        for my $ID (
            qw(ClassDsc Name ValidID Comment)
            )
        {
            my $Element = $Selenium->find_element( "#$ID", 'css' );
            $Element->is_enabled();
            $Element->is_displayed();
        }

        # check client side validation
        $Selenium->find_element( "#Name", 'css' )->clear();
        $Selenium->find_element( "#Name", 'css' )->VerifiedSubmit();
        $Self->Is(
            $Selenium->execute_script(
                "return \$('#Name').hasClass('Error')"
            ),
            '1',
            'Client side validation correctly detected missing input value',
        );

        # create real test catalog class
        my $CatalogClassDsc  = "CatalogClassDsc" . $Helper->GetRandomID();
        my $CatalogClassName = "CatalogClassName" . $Helper->GetRandomID();
        $Selenium->find_element( "#ClassDsc", 'css' )->send_keys($CatalogClassDsc);
        $Selenium->find_element( "#Name",     'css' )->send_keys($CatalogClassName);
        $Selenium->find_element( "#Comment",  'css' )->send_keys("Selenium catalog class");
        $Selenium->execute_script("\$('#ValidID').val('1').trigger('redraw.InputField').trigger('change');");
        $Selenium->find_element("//button[\@value='Submit'][\@type='submit']")->VerifiedClick();

        # click "Go to overview"
        $Selenium->find_element("//a[contains(\@href, \'Action=AdminGeneralCatalog' )]")->VerifiedClick();

        # check for created test catalog class in AdminGeneralCatalog screen and click on it
        $Self->True(
            index( $Selenium->get_page_source(), $CatalogClassDsc ) > -1,
            "Created test catalog class $CatalogClassDsc - found",
        );
        $Selenium->find_element(
            "//a[contains(\@href, \'Action=AdminGeneralCatalog;Subaction=ItemList;Class=$CatalogClassDsc' )]"
        )->VerifiedClick();

        # click "Add Catalog Item"
        $Selenium->find_element("//button[\@value='Add'][\@type='submit']")->VerifiedClick();

        # check client side validation
        $Selenium->find_element( "#Name", 'css' )->clear();
        $Selenium->find_element( "#Name", 'css' )->VerifiedSubmit();
        $Self->Is(
            $Selenium->execute_script(
                "return \$('#Name').hasClass('Error')"
            ),
            '1',
            'Client side validation correctly detected missing input value',
        );

        # try to create catalog item that already exists
        $Selenium->find_element( "#Name", 'css' )->send_keys($CatalogClassName);
        $Selenium->find_element("//button[\@value='Submit'][\@type='submit']")->VerifiedClick();

        # verify error message
        $Self->True(
            index( $Selenium->get_page_source(), 'Need ItemID OR Class and Name!' ) > -1,
            "Error message - displayed",
        );

        # return back to test catalog class screen and click on "Add Catalog Item"
        $Selenium->VerifiedGet(
            "${ScriptAlias}index.pl?Action=AdminGeneralCatalog;Subaction=ItemList;Class=$CatalogClassDsc"
        );
        $Selenium->find_element("//button[\@value='Add'][\@type='submit']")->VerifiedClick();

        # create real test catalog item
        my $CatalogClassItem = "CatalogClassItem" . $Helper->GetRandomID();
        $Selenium->find_element( "#Name",    'css' )->send_keys($CatalogClassItem);
        $Selenium->find_element( "#Comment", 'css' )->send_keys("Selenium catalog item");
        $Selenium->execute_script("\$('#ValidID').val('1').trigger('redraw.InputField').trigger('change');");
        $Selenium->find_element("//button[\@value='Submit'][\@type='submit']")->VerifiedClick();

        # get test catalog items IDs
        my @CatalogItemIDs;
        for my $CatalogItems ( $CatalogClassName, $CatalogClassItem ) {
            my $CatalogClassItemData = $Kernel::OM->Get('Kernel::System::GeneralCatalog')->ItemGet(
                Class => $CatalogClassDsc,
                Name  => $CatalogItems,
            );
            my $CatalogItemID = $CatalogClassItemData->{ItemID};
            push @CatalogItemIDs, $CatalogItemID;
        }

        # check for created test catalog item and click on it
        $Self->True(
            index( $Selenium->get_page_source(), $CatalogClassItem ) > -1,
            "Created test catalog item $CatalogClassItem - found",
        );
        $Selenium->find_element(
            "//a[contains(\@href, \'Action=AdminGeneralCatalog;Subaction=ItemEdit;ItemID=$CatalogItemIDs[1]' )]"
        )->VerifiedClick();

        # check new test catalog item values
        $Self->Is(
            $Selenium->find_element( '#Name', 'css' )->get_value(),
            $CatalogClassItem,
            "#Name stored value",
        );
        $Self->Is(
            $Selenium->find_element( '#Comment', 'css' )->get_value(),
            "Selenium catalog item",
            "#Comment stored value",
        );

        # edit name and comment
        my $EditCatalogClassItem = "Edit" . $CatalogClassItem;
        $Selenium->find_element( "#Name",    'css' )->clear();
        $Selenium->find_element( "#Name",    'css' )->send_keys($EditCatalogClassItem);
        $Selenium->find_element( "#Comment", 'css' )->send_keys(" edit");
        $Selenium->find_element("//button[\@value='Submit'][\@type='submit']")->VerifiedClick();

        # check edited test catalog item values
        $Selenium->find_element( $EditCatalogClassItem, 'link_text' )->VerifiedClick();
        $Self->Is(
            $Selenium->find_element( '#Name', 'css' )->get_value(),
            $EditCatalogClassItem,
            "#Name updated value",
        );
        $Self->Is(
            $Selenium->find_element( '#Comment', 'css' )->get_value(),
            "Selenium catalog item edit",
            "#Comment updated value",
        );

        # get DB object
        my $DBObject = $Kernel::OM->Get('Kernel::System::DB');

        # delete created test catalog class
        for my $CatalogItem (@CatalogItemIDs) {

            my $Success = $DBObject->Do(
                SQL => "DELETE FROM general_catalog_preferences WHERE general_catalog_id = $CatalogItem",
            );
            $Self->True(
                $Success,
                "CatalogItemID $CatalogItem preference - deleted",
            );

            $Success = $DBObject->Do(
                SQL => "DELETE FROM general_catalog WHERE id = $CatalogItem",
            );
            $Self->True(
                $Success,
                "CatalogItemID $CatalogItem - deleted",
            );
        }

        # clean up cache
        $Kernel::OM->Get('Kernel::System::Cache')->CleanUp( Type => 'GeneralCatalog' );
    }
);

1;

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
/**
 * jscolor, JavaScript Color Picker
 *
 * @version 1.4.1
 * @license GNU Lesser General Public License, http://www.gnu.org/copyleft/lesser.html
 * @author  Jan Odvarko, http://odvarko.cz
 * @created 2008-06-15
 * @updated 2013-04-08
 * @link    http://jscolor.com
 */


var jscolor = {


	dir : '', // location of jscolor directory (leave empty to autodetect)
	bindClass : 'color', // class name
	binding : true, // automatic binding via <input class="...">
	preloading : true, // use image preloading?


	install : function() {
		jscolor.addEvent(window, 'load', jscolor.init);
	},


	init : function() {
		if(jscolor.binding) {
			jscolor.bind();
		}
		if(jscolor.preloading) {
			jscolor.preload();
		}
	},


	getDir : function() {
		if(!jscolor.dir) {
			var detected = jscolor.detectDir();
			jscolor.dir = detected!==false ? detected : 'jscolor/';
		}
		return jscolor.dir;
	},


	detectDir : function() {
		var base = location.href;

		var e = document.getElementsByTagName('base');
		for(var i=0; i<e.length; i+=1) {
			if(e[i].href) { base = e[i].href; }
		}

		var e = document.getElementsByTagName('script');
		for(var i=0; i<e.length; i+=1) {
			if(e[i].src && /(^|\/)jscolor\.js([?#].*)?$/i.test(e[i].src)) {
				var src = new jscolor.URI(e[i].src);
				var srcAbs = src.toAbsolute(base);
				srcAbs.path = srcAbs.path.replace(/[^\/]+$/, ''); // remove filename
				srcAbs.query = null;
				srcAbs.fragment = null;
				return srcAbs.toString();
			}
		}
		return false;
	},


	bind : function() {
		var matchClass = new RegExp('(^|\\s)('+jscolor.bindClass+')\\s*(\\{[^}]*\\})?', 'i');
		var e = document.getElementsByTagName('input');
		for(var i=0; i<e.length; i+=1) {
			var m;
			if(!e[i].color && e[i].className && (m = e[i].className.match(matchClass))) {
				var prop = {};
				if(m[3]) {
					try {
						prop = (new Function ('return (' + m[3] + ')'))();
					} catch(eInvalidProp) {}
				}
				e[i].color = new jscolor.color(e[i], prop);
			}
		}
	},


	preload : function() {
		for(var fn in jscolor.imgRequire) {
			if(jscolor.imgRequire.hasOwnProperty(fn)) {
				jscolor.loadImage(fn);
			}
		}
	},


	images : {
		pad : [ 181, 101 ],
		sld : [ 16, 101 ],
		cross : [ 15, 15 ],
		arrow : [ 7, 11 ]
	},


	imgRequire : {},
	imgLoaded : {},


	requireImage : function(filename) {
		jscolor.imgRequire[filename] = true;
	},


	loadImage : function(filename) {
		if(!jscolor.imgLoaded[filename]) {
			jscolor.imgLoaded[filename] = new Image();
			jscolor.imgLoaded[filename].src = jscolor.getDir()+filename;
		}
	},


	fetchElement : function(mixed) {
		return typeof mixed === 'string' ? document.getElementById(mixed) : mixed;
	},


	addEvent : function(el, evnt, func) {
		if(el.addEventListener) {
			el.addEventListener(evnt, func, false);
		} else if(el.attachEvent) {
			el.attachEvent('on'+evnt, func);
		}
	},


	fireEvent : function(el, evnt) {
		if(!el) {
			return;
		}
		if(document.createEvent) {
			var ev = document.createEvent('HTMLEvents');
			ev.initEvent(evnt, true, true);
			el.dispatchEvent(ev);
		} else if(document.createEventObject) {
			var ev = document.createEventObject();
			el.fireEvent('on'+evnt, ev);
		} else if(el['on'+evnt]) { // alternatively use the traditional event model (IE5)
			el['on'+evnt]();
		}
	},


	getElementPos : function(e) {
		var e1=e, e2=e;
		var x=0, y=0;
		if(e1.offsetParent) {
			do {
				x += e1.offsetLeft;
				y += e1.offsetTop;
			} while(e1 = e1.offsetParent);
		}
		while((e2 = e2.parentNode) && e2.nodeName.toUpperCase() !== 'BODY') {
			x -= e2.scrollLeft;
			y -= e2.scrollTop;
		}
		return [x, y];
	},


	getElementSize : function(e) {
		return [e.offsetWidth, e.offsetHeight];
	},


	getRelMousePos : function(e) {
		var x = 0, y = 0;
		if (!e) { e = window.event; }
		if (typeof e.offsetX === 'number') {
			x = e.offsetX;
			y = e.offsetY;
		} else if (typeof e.layerX === 'number') {
			x = e.layerX;
			y = e.layerY;
		}
		return { x: x, y: y };
	},


	getViewPos : function() {
		if(typeof window.pageYOffset === 'number') {
			return [window.pageXOffset, window.pageYOffset];
		} else if(document.body && (document.body.scrollLeft || document.body.scrollTop)) {
			return [document.body.scrollLeft, document.body.scrollTop];
		} else if(document.documentElement && (document.documentElement.scrollLeft || document.documentElement.scrollTop)) {
			return [document.documentElement.scrollLeft, document.documentElement.scrollTop];
		} else {
			return [0, 0];
		}
	},


	getViewSize : function() {
		if(typeof window.innerWidth === 'number') {
			return [window.innerWidth, window.innerHeight];
		} else if(document.body && (document.body.clientWidth || document.body.clientHeight)) {
			return [document.body.clientWidth, document.body.clientHeight];
		} else if(document.documentElement && (document.documentElement.clientWidth || document.documentElement.clientHeight)) {
			return [document.documentElement.clientWidth, document.documentElement.clientHeight];
		} else {
			return [0, 0];
		}
	},


	URI : function(uri) { // See RFC3986

		this.scheme = null;
		this.authority = null;
		this.path = '';
		this.query = null;
		this.fragment = null;

		this.parse = function(uri) {
			var m = uri.match(/^(([A-Za-z][0-9A-Za-z+.-]*)(:))?((\/\/)([^\/?#]*))?([^?#]*)((\?)([^#]*))?((#)(.*))?/);
			this.scheme = m[3] ? m[2] : null;
			this.authority = m[5] ? m[6] : null;
			this.path = m[7];
			this.query = m[9] ? m[10] : null;
			this.fragment = m[12] ? m[13] : null;
			return this;
		};

		this.toString = function() {
			var result = '';
			if(this.scheme !== null) { result = result + this.scheme + ':'; }
			if(this.authority !== null) { result = result + '//' + this.authority; }
			if(this.path !== null) { result = result + this.path; }
			if(this.query !== null) { result = result + '?' + this.query; }
			if(this.fragment !== null) { result = result + '#' + this.fragment; }
			return result;
		};

		this.toAbsolute = function(base) {
			var base = new jscolor.URI(base);
			var r = this;
			var t = new jscolor.URI;

			if(base.scheme === null) { return false; }

			if(r.scheme !== null && r.scheme.toLowerCase() === base.scheme.toLowerCase()) {
				r.scheme = null;
			}

			if(r.scheme !== null) {
				t.scheme = r.scheme;
				t.authority = r.authority;
				t.path = removeDotSegments(r.path);
				t.query = r.query;
			} else {
				if(r.authority !== null) {
					t.authority = r.authority;
					t.path = removeDotSegments(r.path);
					t.query = r.query;
				} else {
					if(r.path === '') {
						t.path = base.path;
						if(r.query !== null) {
							t.query = r.query;
						} else {
							t.query = base.query;
						}
					} else {
						if(r.path.substr(0,1) === '/') {
							t.path = removeDotSegments(r.path);
						} else {
							if(base.authority !== null && base.path === '') {
								t.path = '/'+r.path;
							} else {
								t.path = base.path.replace(/[^\/]+$/,'')+r.path;
							}
							t.path = removeDotSegments(t.path);
						}
						t.query = r.query;
					}
					t.authority = base.authority;
				}
				t.scheme = base.scheme;
			}
			t.fragment = r.fragment;

			return t;
		};

		function removeDotSegments(path) {
			var out = '';
			while(path) {
				if(path.substr(0,3)==='../' || path.substr(0,2)==='./') {
					path = path.replace(/^\.+/,'').substr(1);
				} else if(path.substr(0,3)==='/./' || path==='/.') {
					path = '/'+path.substr(3);
				} else if(path.substr(0,4)==='/../' || path==='/..') {
					path = '/'+path.substr(4);
					out = out.replace(/\/?[^\/]*$/, '');
				} else if(path==='.' || path==='..') {
					path = '';
				} else {
					var rm = path.match(/^\/?[^\/]*/)[0];
					path = path.substr(rm.length);
					out = out + rm;
				}
			}
			return out;
		}

		if(uri) {
			this.parse(uri);
		}

	},


	//
	// Usage example:
	// var myColor = new jscolor.color(myInputElement)
	//

	color : function(target, prop) {


		this.required = true; // refuse empty values?
		this.adjust = true; // adjust value to uniform notation?
		this.hash = false; // prefix color with # symbol?
		this.caps = true; // uppercase?
		this.slider = true; // show the value/saturation slider?
		this.valueElement = target; // value holder
		this.styleElement = target; // where to reflect current color
		this.onImmediateChange = null; // onchange callback (can be either string or function)
		this.hsv = [0, 0, 1]; // read-only  0-6, 0-1, 0-1
		this.rgb = [1, 1, 1]; // read-only  0-1, 0-1, 0-1
		this.minH = 0; // read-only  0-6
		this.maxH = 6; // read-only  0-6
		this.minS = 0; // read-only  0-1
		this.maxS = 1; // read-only  0-1
		this.minV = 0; // read-only  0-1
		this.maxV = 1; // read-only  0-1

		this.pickerOnfocus = true; // display picker on focus?
		this.pickerMode = 'HSV'; // HSV | HVS
		this.pickerPosition = 'bottom'; // left | right | top | bottom
		this.pickerSmartPosition = true; // automatically adjust picker position when necessary
		this.pickerButtonHeight = 20; // px
		this.pickerClosable = false;
		this.pickerCloseText = 'Close';
		this.pickerButtonColor = 'ButtonText'; // px
		this.pickerFace = 10; // px
		this.pickerFaceColor = 'ThreeDFace'; // CSS color
		this.pickerBorder = 1; // px
		this.pickerBorderColor = 'ThreeDHighlight ThreeDShadow ThreeDShadow ThreeDHighlight'; // CSS color
		this.pickerInset = 1; // px
		this.pickerInsetColor = 'ThreeDShadow ThreeDHighlight ThreeDHighlight ThreeDShadow'; // CSS color
		this.pickerZIndex = 10000;


		for(var p in prop) {
			if(prop.hasOwnProperty(p)) {
				this[p] = prop[p];
			}
		}


		this.hidePicker = function() {
			if(isPickerOwner()) {
				removePicker();
			}
		};


		this.showPicker = function() {
			if(!isPickerOwner()) {
				var tp = jscolor.getElementPos(target); // target pos
				var ts = jscolor.getElementSize(target); // target size
				var vp = jscolor.getViewPos(); // view pos
				var vs = jscolor.getViewSize(); // view size
				var ps = getPickerDims(this); // picker size
				var a, b, c;
				switch(this.pickerPosition.toLowerCase()) {
					case 'left': a=1; b=0; c=-1; break;
					case 'right':a=1; b=0; c=1; break;
					case 'top':  a=0; b=1; c=-1; break;
					default:     a=0; b=1; c=1; break;
				}
				var l = (ts[b]+ps[b])/2;

				// picker pos
				if (!this.pickerSmartPosition) {
					var pp = [
						tp[a],
						tp[b]+ts[b]-l+l*c
					];
				} else {
					var pp = [
						-vp[a]+tp[a]+ps[a] > vs[a] ?
							(-vp[a]+tp[a]+ts[a]/2 > vs[a]/2 && tp[a]+ts[a]-ps[a] >= 0 ? tp[a]+ts[a]-ps[a] : tp[a]) :
							tp[a],
						-vp[b]+tp[b]+ts[b]+ps[b]-l+l*c > vs[b] ?
							(-vp[b]+tp[b]+ts[b]/2 > vs[b]/2 && tp[b]+ts[b]-l-l*c >= 0 ? tp[b]+ts[b]-l-l*c : tp[b]+ts[b]-l+l*c) :
							(tp[b]+ts[b]-l+l*c >= 0 ? tp[b]+ts[b]-l+l*c : tp[b]+ts[b]-l-l*c)
					];
				}
				drawPicker(pp[a], pp[b]);
			}
		};


		this.importColor = function() {
			if(!valueElement) {
				this.exportColor();
			} else {
				if(!this.adjust) {
					if(!this.fromString(valueElement.value, leaveValue)) {
						styleElement.style.backgroundImage = styleElement.jscStyle.backgroundImage;
						styleElement.style.backgroundColor = styleElement.jscStyle.backgroundColor;
						styleElement.style.color = styleElement.jscStyle.color;
						this.exportColor(leaveValue | leaveStyle);
					}
				} else if(!this.required && /^\s*$/.test(valueElement.value)) {
					valueElement.value = '';
					styleElement.style.backgroundImage = styleElement.jscStyle.backgroundImage;
					styleElement.style.backgroundColor = styleElement.jscStyle.backgroundColor;
					styleElement.style.color = styleElement.jscStyle.color;
					this.exportColor(leaveValue | leaveStyle);

				} else if(this.fromString(valueElement.value)) {
					// OK
				} else {
					this.exportColor();
				}
			}
		};


		this.exportColor = function(flags) {
			if(!(flags & leaveValue) && valueElement) {
				var value = this.toString();
				if(this.caps) { value = value.toUpperCase(); }
				if(this.hash) { value = '#'+value; }
				valueElement.value = value;
			}
			if(!(flags & leaveStyle) && styleElement) {
				styleElement.style.backgroundImage = "none";
				styleElement.style.backgroundColor =
					'#'+this.toString();
				styleElement.style.color =
					0.213 * this.rgb[0] +
					0.715 * this.rgb[1] +
					0.072 * this.rgb[2]
					< 0.5 ? '#FFF' : '#000';
			}
			if(!(flags & leavePad) && isPickerOwner()) {
				redrawPad();
			}
			if(!(flags & leaveSld) && isPickerOwner()) {
				redrawSld();
			}
		};


		this.fromHSV = function(h, s, v, flags) { // null = don't change
			if(h !== null) { h = Math.max(0.0, this.minH, Math.min(6.0, this.maxH, h)); }
			if(s !== null) { s = Math.max(0.0, this.minS, Math.min(1.0, this.maxS, s)); }
			if(v !== null) { v = Math.max(0.0, this.minV, Math.min(1.0, this.maxV, v)); }

			this.rgb = HSV_RGB(
				h===null ? this.hsv[0] : (this.hsv[0]=h),
				s===null ? this.hsv[1] : (this.hsv[1]=s),
				v===null ? this.hsv[2] : (this.hsv[2]=v)
			);

			this.exportColor(flags);
		};


		this.fromRGB = function(r, g, b, flags) { // null = don't change
			if(r !== null) { r = Math.max(0.0, Math.min(1.0, r)); }
			if(g !== null) { g = Math.max(0.0, Math.min(1.0, g)); }
			if(b !== null) { b = Math.max(0.0, Math.min(1.0, b)); }

			var hsv = RGB_HSV(
				r===null ? this.rgb[0] : r,
				g===null ? this.rgb[1] : g,
				b===null ? this.rgb[2] : b
			);
			if(hsv[0] !== null) {
				this.hsv[0] = Math.max(0.0, this.minH, Math.min(6.0, this.maxH, hsv[0]));
			}
			if(hsv[2] !== 0) {
				this.hsv[1] = hsv[1]===null ? null : Math.max(0.0, this.minS, Math.min(1.0, this.maxS, hsv[1]));
			}
			this.hsv[2] = hsv[2]===null ? null : Math.max(0.0, this.minV, Math.min(1.0, this.maxV, hsv[2]));

			// update RGB according to final HSV, as some values might be trimmed
			var rgb = HSV_RGB(this.hsv[0], this.hsv[1], this.hsv[2]);
			this.rgb[0] = rgb[0];
			this.rgb[1] = rgb[1];
			this.rgb[2] = rgb[2];

			this.exportColor(flags);
		};


		this.fromString = function(hex, flags) {
			var m = hex.match(/^\W*([0-9A-F]{3}([0-9A-F]{3})?)\W*$/i);
			if(!m) {
				return false;
			} else {
				if(m[1].length === 6) { // 6-char notation
					this.fromRGB(
						parseInt(m[1].substr(0,2),16) / 255,
						parseInt(m[1].substr(2,2),16) / 255,
						parseInt(m[1].substr(4,2),16) / 255,
						flags
					);
				} else { // 3-char notation
					this.fromRGB(
						parseInt(m[1].charAt(0)+m[1].charAt(0),16) / 255,
						parseInt(m[1].charAt(1)+m[1].charAt(1),16) / 255,
						parseInt(m[1].charAt(2)+m[1].charAt(2),16) / 255,
						flags
					);
				}
				return true;
			}
		};


		this.toString = function() {
			return (
				(0x100 | Math.round(255*this.rgb[0])).toString(16).substr(1) +
				(0x100 | Math.round(255*this.rgb[1])).toString(16).substr(1) +
				(0x100 | Math.round(255*this.rgb[2])).toString(16).substr(1)
			);
		};


		function RGB_HSV(r, g, b) {
			var n = Math.min(Math.min(r,g),b);
			var v = Math.max(Math.max(r,g),b);
			var m = v - n;
			if(m === 0) { return [ null, 0, v ]; }
			var h = r===n ? 3+(b-g)/m : (g===n ? 5+(r-b)/m : 1+(g-r)/m);
			return [ h===6?0:h, m/v, v ];
		}


		function HSV_RGB(h, s, v) {
			if(h === null) { return [ v, v, v ]; }
			var i = Math.floor(h);
			var f = i%2 ? h-i : 1-(h-i);
			var m = v * (1 - s);
			var n = v * (1 - s*f);
			switch(i) {
				case 6:
				case 0: return [v,n,m];
				case 1: return [n,v,m];
				case 2: return [m,v,n];
				case 3: return [m,n,v];
				case 4: return [n,m,v];
				case 5: return [v,m,n];
			}
		}


		function removePicker() {
			delete jscolor.picker.owner;
			document.getElementsByTagName('body')[0].removeChild(jscolor.picker.boxB);
		}


		function drawPicker(x, y) {
			if(!jscolor.picker) {
				jscolor.picker = {
					box : document.createElement('div'),
					boxB : document.createElement('div'),
					pad : document.createElement('div'),
					padB : document.createElement('div'),
					padM : document.createElement('div'),
					sld : document.createElement('div'),
					sldB : document.createElement('div'),
					sldM : document.createElement('div'),
					btn : document.createElement('div'),
					btnS : document.createElement('span'),
					btnT : document.createTextNode(THIS.pickerCloseText)
				};
				for(var i=0,segSize=4; i<jscolor.images.sld[1]; i+=segSize) {
					var seg = document.createElement('div');
					seg.style.height = segSize+'px';
					seg.style.fontSize = '1px';
					seg.style.lineHeight = '0';
					jscolor.picker.sld.appendChild(seg);
				}
				jscolor.picker.sldB.appendChild(jscolor.picker.sld);
				jscolor.picker.box.appendChild(jscolor.picker.sldB);
				jscolor.picker.box.appendChild(jscolor.picker.sldM);
				jscolor.picker.padB.appendChild(jscolor.picker.pad);
				jscolor.picker.box.appendChild(jscolor.picker.padB);
				jscolor.picker.box.appendChild(jscolor.picker.padM);
				jscolor.picker.btnS.appendChild(jscolor.picker.btnT);
				jscolor.picker.btn.appendChild(jscolor.picker.btnS);
				jscolor.picker.box.appendChild(jscolor.picker.btn);
				jscolor.picker.boxB.appendChild(jscolor.picker.box);
			}

			var p = jscolor.picker;

			// controls interaction
			p.box.onmouseup =
			p.box.onmouseout = function() { target.focus(); };
			p.box.onmousedown = function() { abortBlur=true; };
			p.box.onmousemove = function(e) {
				if (holdPad || holdSld) {
					holdPad && setPad(e);
					holdSld && setSld(e);
					if (document.selection) {
						document.selection.empty();
					} else if (window.getSelection) {
						window.getSelection().removeAllRanges();
					}
					dispatchImmediateChange();
				}
			};
			if('ontouchstart' in window) { // if touch device
				p.box.addEventListener('touchmove', function(e) {
					var event={
						'offsetX': e.touches[0].pageX-touchOffset.X,
						'offsetY': e.touches[0].pageY-touchOffset.Y
					};
					if (holdPad || holdSld) {
						holdPad && setPad(event);
						holdSld && setSld(event);
						dispatchImmediateChange();
					}
					e.stopPropagation(); // prevent move "view" on broswer
					e.preventDefault(); // prevent Default - Android Fix (else android generated only 1-2 touchmove events)
				}, false);
			}
			p.padM.onmouseup =
			p.padM.onmouseout = function() { if(holdPad) { holdPad=false; jscolor.fireEvent(valueElement,'change'); } };
			p.padM.onmousedown = function(e) {
				// if the slider is at the bottom, move it up
				switch(modeID) {
					case 0: if (THIS.hsv[2] === 0) { THIS.fromHSV(null, null, 1.0); }; break;
					case 1: if (THIS.hsv[1] === 0) { THIS.fromHSV(null, 1.0, null); }; break;
				}
				holdSld=false;
				holdPad=true;
				setPad(e);
				dispatchImmediateChange();
			};
			if('ontouchstart' in window) {
				p.padM.addEventListener('touchstart', function(e) {
					touchOffset={
						'X': e.target.offsetParent.offsetLeft,
						'Y': e.target.offsetParent.offsetTop
					};
					this.onmousedown({
						'offsetX':e.touches[0].pageX-touchOffset.X,
						'offsetY':e.touches[0].pageY-touchOffset.Y
					});
				});
			}
			p.sldM.onmouseup =
			p.sldM.onmouseout = function() { if(holdSld) { holdSld=false; jscolor.fireEvent(valueElement,'change'); } };
			p.sldM.onmousedown = function(e) {
				holdPad=false;
				holdSld=true;
				setSld(e);
				dispatchImmediateChange();
			};
			if('ontouchstart' in window) {
				p.sldM.addEventListener('touchstart', function(e) {
					touchOffset={
						'X': e.target.offsetParent.offsetLeft,
						'Y': e.target.offsetParent.offsetTop
					};
					this.onmousedown({
						'offsetX':e.touches[0].pageX-touchOffset.X,
						'offsetY':e.touches[0].pageY-touchOffset.Y
					});
				});
			}

			// picker
			var dims = getPickerDims(THIS);
			p.box.style.width = dims[0] + 'px';
			p.box.style.height = dims[1] + 'px';

			// picker border
			p.boxB.style.position = 'absolute';
			p.boxB.style.clear = 'both';
			p.boxB.style.left = x+'px';
			p.boxB.style.top = y+'px';
			p.boxB.style.zIndex = THIS.pickerZIndex;
			p.boxB.style.border = THIS.pickerBorder+'px solid';
			p.boxB.style.borderColor = THIS.pickerBorderColor;
			p.boxB.style.background = THIS.pickerFaceColor;

			// pad image
			p.pad.style.width = jscolor.images.pad[0]+'px';
			p.pad.style.height = jscolor.images.pad[1]+'px';

			// pad border
			p.padB.style.position = 'absolute';
			p.padB.style.left = THIS.pickerFace+'px';
			p.padB.style.top = THIS.pickerFace+'px';
			p.padB.style.border = THIS.pickerInset+'px solid';
			p.padB.style.borderColor = THIS.pickerInsetColor;

			// pad mouse area
			p.padM.style.position = 'absolute';
			p.padM.style.left = '0';
			p.padM.style.top = '0';
			p.padM.style.width = THIS.pickerFace + 2*THIS.pickerInset + jscolor.images.pad[0] + jscolor.images.arrow[0] + 'px';
			p.padM.style.height = p.box.style.height;
			p.padM.style.cursor = 'crosshair';

			// slider image
			p.sld.style.overflow = 'hidden';
			p.sld.style.width = jscolor.images.sld[0]+'px';
			p.sld.style.height = jscolor.images.sld[1]+'px';

			// slider border
			p.sldB.style.display = THIS.slider ? 'block' : 'none';
			p.sldB.style.position = 'absolute';
			p.sldB.style.right = THIS.pickerFace+'px';
			p.sldB.style.top = THIS.pickerFace+'px';
			p.sldB.style.border = THIS.pickerInset+'px solid';
			p.sldB.style.borderColor = THIS.pickerInsetColor;

			// slider mouse area
			p.sldM.style.display = THIS.slider ? 'block' : 'none';
			p.sldM.style.position = 'absolute';
			p.sldM.style.right = '0';
			p.sldM.style.top = '0';
			p.sldM.style.width = jscolor.images.sld[0] + jscolor.images.arrow[0] + THIS.pickerFace + 2*THIS.pickerInset + 'px';
			p.sldM.style.height = p.box.style.height;
			try {
				p.sldM.style.cursor = 'pointer';
			} catch(eOldIE) {
				p.sldM.style.cursor = 'hand';
			}

			// "close" button
			function setBtnBorder() {
				var insetColors = THIS.pickerInsetColor.split(/\s+/);
				var pickerOutsetColor = insetColors.length < 2 ? insetColors[0] : insetColors[1] + ' ' + insetColors[0] + ' ' + insetColors[0] + ' ' + insetColors[1];
				p.btn.style.borderColor = pickerOutsetColor;
			}
			p.btn.style.display = THIS.pickerClosable ? 'block' : 'none';
			p.btn.style.position = 'absolute';
			p.btn.style.left = THIS.pickerFace + 'px';
			p.btn.style.bottom = THIS.pickerFace + 'px';
			p.btn.style.padding = '0 15px';
			p.btn.style.height = '18px';
			p.btn.style.border = THIS.pickerInset + 'px solid';
			setBtnBorder();
			p.btn.style.color = THIS.pickerButtonColor;
			p.btn.style.font = '12px sans-serif';
			p.btn.style.textAlign = 'center';
			try {
				p.btn.style.cursor = 'pointer';
			} catch(eOldIE) {
				p.btn.style.cursor = 'hand';
			}
			p.btn.onmousedown = function () {
				THIS.hidePicker();
			};
			p.btnS.style.lineHeight = p.btn.style.height;

			// load images in optimal order
			switch(modeID) {
				case 0: var padImg = 'hs.png'; break;
				case 1: var padImg = 'hv.png'; break;
			}
			p.padM.style.backgroundImage = "url('"+jscolor.getDir()+"cross.gif')";
			p.padM.style.backgroundRepeat = "no-repeat";
			p.sldM.style.backgroundImage = "url('"+jscolor.getDir()+"arrow.gif')";
			p.sldM.style.backgroundRepeat = "no-repeat";
			p.pad.style.backgroundImage = "url('"+jscolor.getDir()+padImg+"')";
			p.pad.style.backgroundRepeat = "no-repeat";
			p.pad.style.backgroundPosition = "0 0";

			// place pointers
			redrawPad();
			redrawSld();

			jscolor.picker.owner = THIS;
			document.getElementsByTagName('body')[0].appendChild(p.boxB);
		}


		function getPickerDims(o) {
			var dims = [
				2*o.pickerInset + 2*o.pickerFace + jscolor.images.pad[0] +
					(o.slider ? 2*o.pickerInset + 2*jscolor.images.arrow[0] + jscolor.images.sld[0] : 0),
				o.pickerClosable ?
					4*o.pickerInset + 3*o.pickerFace + jscolor.images.pad[1] + o.pickerButtonHeight :
					2*o.pickerInset + 2*o.pickerFace + jscolor.images.pad[1]
			];
			return dims;
		}


		function redrawPad() {
			// redraw the pad pointer
			switch(modeID) {
				case 0: var yComponent = 1; break;
				case 1: var yComponent = 2; break;
			}
			var x = Math.round((THIS.hsv[0]/6) * (jscolor.images.pad[0]-1));
			var y = Math.round((1-THIS.hsv[yComponent]) * (jscolor.images.pad[1]-1));
			jscolor.picker.padM.style.backgroundPosition =
				(THIS.pickerFace+THIS.pickerInset+x - Math.floor(jscolor.images.cross[0]/2)) + 'px ' +
				(THIS.pickerFace+THIS.pickerInset+y - Math.floor(jscolor.images.cross[1]/2)) + 'px';

			// redraw the slider image
			var seg = jscolor.picker.sld.childNodes;

			switch(modeID) {
				case 0:
					var rgb = HSV_RGB(THIS.hsv[0], THIS.hsv[1], 1);
					for(var i=0; i<seg.length; i+=1) {
						seg[i].style.backgroundColor = 'rgb('+
							(rgb[0]*(1-i/seg.length)*100)+'%,'+
							(rgb[1]*(1-i/seg.length)*100)+'%,'+
							(rgb[2]*(1-i/seg.length)*100)+'%)';
					}
					break;
				case 1:
					var rgb, s, c = [ THIS.hsv[2], 0, 0 ];
					var i = Math.floor(THIS.hsv[0]);
					var f = i%2 ? THIS.hsv[0]-i : 1-(THIS.hsv[0]-i);
					switch(i) {
						case 6:
						case 0: rgb=[0,1,2]; break;
						case 1: rgb=[1,0,2]; break;
						case 2: rgb=[2,0,1]; break;
						case 3: rgb=[2,1,0]; break;
						case 4: rgb=[1,2,0]; break;
						case 5: rgb=[0,2,1]; break;
					}
					for(var i=0; i<seg.length; i+=1) {
						s = 1 - 1/(seg.length-1)*i;
						c[1] = c[0] * (1 - s*f);
						c[2] = c[0] * (1 - s);
						seg[i].style.backgroundColor = 'rgb('+
							(c[rgb[0]]*100)+'%,'+
							(c[rgb[1]]*100)+'%,'+
							(c[rgb[2]]*100)+'%)';
					}
					break;
			}
		}


		function redrawSld() {
			// redraw the slider pointer
			switch(modeID) {
				case 0: var yComponent = 2; break;
				case 1: var yComponent = 1; break;
			}
			var y = Math.round((1-THIS.hsv[yComponent]) * (jscolor.images.sld[1]-1));
			jscolor.picker.sldM.style.backgroundPosition =
				'0 ' + (THIS.pickerFace+THIS.pickerInset+y - Math.floor(jscolor.images.arrow[1]/2)) + 'px';
		}


		function isPickerOwner() {
			return jscolor.picker && jscolor.picker.owner === THIS;
		}


		function blurTarget() {
			if(valueElement === target) {
				THIS.importColor();
			}
			if(THIS.pickerOnfocus) {
				THIS.hidePicker();
			}
		}


		function blurValue() {
			if(valueElement !== target) {
				THIS.importColor();
			}
		}


		function setPad(e) {
			var mpos = jscolor.getRelMousePos(e);
			var x = mpos.x - THIS.pickerFace - THIS.pickerInset;
			var y = mpos.y - THIS.pickerFace - THIS.pickerInset;
			switch(modeID) {
				case 0: THIS.fromHSV(x*(6/(jscolor.images.pad[0]-1)), 1 - y/(jscolor.images.pad[1]-1), null, leaveSld); break;
				case 1: THIS.fromHSV(x*(6/(jscolor.images.pad[0]-1)), null, 1 - y/(jscolor.images.pad[1]-1), leaveSld); break;
			}
		}


		function setSld(e) {
			var mpos = jscolor.getRelMousePos(e);
			var y = mpos.y - THIS.pickerFace - THIS.pickerInset;
			switch(modeID) {
				case 0: THIS.fromHSV(null, null, 1 - y/(jscolor.images.sld[1]-1), leavePad); break;
				case 1: THIS.fromHSV(null, 1 - y/(jscolor.images.sld[1]-1), null, leavePad); break;
			}
		}


		function dispatchImmediateChange() {
			if (THIS.onImmediateChange) {
				var callback;
				if (typeof THIS.onImmediateChange === 'string') {
					callback = new Function (THIS.onImmediateChange);
				} else {
					callback = THIS.onImmediateChange;
				}
				callback.call(THIS);
			}
		}


		var THIS = this;
		var modeID = this.pickerMode.toLowerCase()==='hvs' ? 1 : 0;
		var abortBlur = false;
		var
			valueElement = jscolor.fetchElement(this.valueElement),
			styleElement = jscolor.fetchElement(this.styleElement);
		var
			holdPad = false,
			holdSld = false,
			touchOffset = {};
		var
			leaveValue = 1<<0,
			leaveStyle = 1<<1,
			leavePad = 1<<2,
			leaveSld = 1<<3;

		// target
		jscolor.addEvent(target, 'focus', function() {
			if(THIS.pickerOnfocus) { THIS.showPicker(); }
		});
		jscolor.addEvent(target, 'blur', function() {
			if(!abortBlur) {
				window.setTimeout(function(){ abortBlur || blurTarget(); abortBlur=false; }, 0);
			} else {
				abortBlur = false;
			}
		});

		// valueElement
		if(valueElement) {
			var updateField = function() {
				THIS.fromString(valueElement.value, leaveValue);
				dispatchImmediateChange();
			};
			jscolor.addEvent(valueElement, 'keyup', updateField);
			jscolor.addEvent(valueElement, 'input', updateField);
			jscolor.addEvent(valueElement, 'blur', blurValue);
			valueElement.setAttribute('autocomplete', 'off');
		}

		// styleElement
		if(styleElement) {
			styleElement.jscStyle = {
				backgroundImage : styleElement.style.backgroundImage,
				backgroundColor : styleElement.style.backgroundColor,
				color : styleElement.style.color
			};
		}

		// require images
		switch(modeID) {
			case 0: jscolor.requireImage('hs.png'); break;
			case 1: jscolor.requireImage('hv.png'); break;
		}
		jscolor.requireImage('cross.gif');
		jscolor.requireImage('arrow.gif');

		this.importColor();
	}

};

//--- OTRSCIDeploymentStateColors
//jscolor.install();
//---
IyAtLQojIENvcHlyaWdodCAoQykgMjAwMS0yMDE2IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLmNvbS8KIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgdmFyOjpwYWNrYWdlc2V0dXA6OkdlbmVyYWxDYXRhbG9nOyAgICAjIyBubyBjcml0aWMKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCm91ciBAT2JqZWN0RGVwZW5kZW5jaWVzID0gKAogICAgJ0tlcm5lbDo6Q29uZmlnJywKICAgICdLZXJuZWw6OlN5c3RlbTo6REInLAogICAgJ0tlcm5lbDo6U3lzdGVtOjpTeXNDb25maWcnLAopOwoKPWhlYWQxIE5BTUUKCkdlbmVyYWxDYXRhbG9nLnBtIC0gY29kZSB0byBleGNlY3V0ZSBkdXJpbmcgcGFja2FnZSBpbnN0YWxsYXRpb24KCj1oZWFkMSBTWU5PUFNJUwoKQWxsIGZ1bmN0aW9ucwoKPWhlYWQxIFBVQkxJQyBJTlRFUkZBQ0UKCj1vdmVyIDQKCj1jdXQKCj1pdGVtIG5ldygpCgpjcmVhdGUgYW4gb2JqZWN0CgogICAgdXNlIEtlcm5lbDo6U3lzdGVtOjpPYmplY3RNYW5hZ2VyOwogICAgbG9jYWwgJEtlcm5lbDo6T00gPSBLZXJuZWw6OlN5c3RlbTo6T2JqZWN0TWFuYWdlci0+bmV3KCk7CiAgICBteSAkQ29kZU9iamVjdCA9ICRLZXJuZWw6Ok9NLT5HZXQoJ3Zhcjo6cGFja2FnZXNldHVwOjpHZW5lcmFsQ2F0YWxvZycpOwoKPWN1dAoKc3ViIG5ldyB7CiAgICBteSAoICRUeXBlLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgYWxsb2NhdGUgbmV3IGhhc2ggZm9yIG9iamVjdAogICAgbXkgJFNlbGYgPSB7fTsKICAgIGJsZXNzKCAkU2VsZiwgJFR5cGUgKTsKCiAgICAjIGFsd2F5cyBkaXNjYXJkIHRoZSBjb25maWcgb2JqZWN0IGJlZm9yZSBwYWNrYWdlIGNvZGUgaXMgZXhlY3V0ZWQsCiAgICAjIHRvIG1ha2Ugc3VyZSB0aGF0IHRoZSBjb25maWcgb2JqZWN0IHdpbGwgYmUgY3JlYXRlZCBuZXdseSwgc28gdGhhdCBpdAogICAgIyB3aWxsIHVzZSB0aGUgcmVjZW50bHkgd3JpdHRlbiBuZXcgY29uZmlnIGZyb20gdGhlIHBhY2thZ2UKICAgICRLZXJuZWw6Ok9NLT5PYmplY3RzRGlzY2FyZCgKICAgICAgICBPYmplY3RzID0+IFsnS2VybmVsOjpDb25maWcnXSwKICAgICk7CgogICAgcmV0dXJuICRTZWxmOwp9Cgo9aXRlbSBDb2RlSW5zdGFsbCgpCgpydW4gdGhlIGNvZGUgaW5zdGFsbCBwYXJ0CgogICAgbXkgJFJlc3VsdCA9ICRDb2RlT2JqZWN0LT5Db2RlSW5zdGFsbCgpOwoKPWN1dAoKc3ViIENvZGVJbnN0YWxsIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgcmV0dXJuIDE7Cn0KCj1pdGVtIENvZGVSZWluc3RhbGwoKQoKcnVuIHRoZSBjb2RlIHJlaW5zdGFsbCBwYXJ0CgogICAgbXkgJFJlc3VsdCA9ICRDb2RlT2JqZWN0LT5Db2RlUmVpbnN0YWxsKCk7Cgo9Y3V0CgpzdWIgQ29kZVJlaW5zdGFsbCB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgIHJldHVybiAxOwp9Cgo9aXRlbSBDb2RlVXBncmFkZSgpCgpydW4gdGhlIGNvZGUgdXBncmFkZSBwYXJ0CgogICAgbXkgJFJlc3VsdCA9ICRDb2RlT2JqZWN0LT5Db2RlVXBncmFkZSgpOwoKPWN1dAoKc3ViIENvZGVVcGdyYWRlIHsKICAgIG15ICggJFNlbGYsICVQYXJhbSApID0gQF87CgogICAgIyBtaWdyYXRlICdmdW5jdGlvbmFsaXR5JyB0byBleHRlcm5hbCB0YWJsZQogICAgIyB0aGlzIGlzIG9ubHkgbmVjY2VzYXJ5IGluIENvZGVVcGdyYWRlLCBmb3IgbmV3IGluc3RhbGxhdGlvbnMgdGhpcyBpcyBkb25lCiAgICAjIGluIHRoZSBwYWNrYWdlIElUU01Db3JlIGR1cmluZyBDb2RlSW5zdGFsbAogICAgJFNlbGYtPl9NaWdyYXRlRnVuY3Rpb25hbGl0eSgpOwoKICAgIHJldHVybiAxOwp9Cgo9aXRlbSBDb2RlVXBncmFkZUZyb21Mb3dlclRoYW5fNF8wXzkxKCkKClRoaXMgZnVuY3Rpb24gaXMgb25seSBleGVjdXRlZCBpZiB0aGUgaW5zdGFsbGVkIG1vZHVsZSB2ZXJzaW9uIGlzIHNtYWxsZXIgdGhhbiA0LjAuOTEuCgpteSAkUmVzdWx0ID0gJENvZGVPYmplY3QtPkNvZGVVcGdyYWRlRnJvbUxvd2VyVGhhbl80XzBfOTEoKTsKCj1jdXQKCnN1YiBDb2RlVXBncmFkZUZyb21Mb3dlclRoYW5fNF8wXzkxIHsgICAgIyMgbm8gY3JpdGljCiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hhbmdlIGNvbmZpZ3VyYXRpb25zIHRvIG1hdGNoIHRoZSBuZXcgbW9kdWxlIGxvY2F0aW9uLgogICAgJFNlbGYtPl9NaWdyYXRlQ29uZmlncygpOwoKICAgIHJldHVybiAxOwp9Cgo9aXRlbSBDb2RlVW5pbnN0YWxsKCkKCnJ1biB0aGUgY29kZSB1bmluc3RhbGwgcGFydAoKICAgIG15ICRSZXN1bHQgPSAkQ29kZU9iamVjdC0+Q29kZVVuaW5zdGFsbCgpOwoKPWN1dAoKc3ViIENvZGVVbmluc3RhbGwgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICByZXR1cm4gMTsKfQoKPWl0ZW0gX01pZ3JhdGVGdW5jdGlvbmFsaXR5KCkKCj1jdXQKCnN1YiBfTWlncmF0ZUZ1bmN0aW9uYWxpdHkgewogICAgbXkgKCAkU2VsZiwgJVBhcmFtICkgPSBAXzsKCiAgICAjIFNFTEVDVCBhbGwgZnVuY3Rpb25hbGl0eSB2YWx1ZXMKICAgICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6U3lzdGVtOjpEQicpLT5QcmVwYXJlKAogICAgICAgIFNRTCA9PiAnU0VMRUNUIGlkLCBmdW5jdGlvbmFsaXR5IEZST00gZ2VuZXJhbF9jYXRhbG9nJywKICAgICk7CgogICAgbXkgQExpc3Q7CiAgICBST1c6CiAgICB3aGlsZSAoIG15IEBSb3cgPSAkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6REInKS0+RmV0Y2hyb3dBcnJheSgpICkgewogICAgICAgIG5leHQgUk9XIGlmICEkUm93WzFdOwoKICAgICAgICBwdXNoIEBMaXN0LCBcQFJvdzsKICAgIH0KCiAgICAjIHNhdmUgZW50cmllcyBpbiBuZXcgdGFibGUKICAgIGZvciBteSAkRW50cnkgKEBMaXN0KSB7CiAgICAgICAgJEtlcm5lbDo6T00tPkdldCgnS2VybmVsOjpTeXN0ZW06OkRCJyktPkRvKAogICAgICAgICAgICBTUUwgPT4KICAgICAgICAgICAgICAgICdJTlNFUlQgSU5UTyBnZW5lcmFsX2NhdGFsb2dfcHJlZmVyZW5jZXMoIGdlbmVyYWxfY2F0YWxvZ19pZCwgcHJlZl9rZXksIHByZWZfdmFsdWUgKScKICAgICAgICAgICAgICAgIC4gJyBWQUxVRVMoID8sIFwnRnVuY3Rpb25hbGl0eVwnLCA/ICknLAogICAgICAgICAgICBCaW5kID0+IFsgXCRFbnRyeS0+WzBdLCBcJEVudHJ5LT5bMV0gXSwKICAgICAgICApOwogICAgfQoKICAgICMgZHJvcCBjb2x1bW4gZnVuY3Rpb25hbGl0eQogICAgbXkgKCREcm9wKSA9ICRLZXJuZWw6Ok9NLT5HZXQoJ0tlcm5lbDo6U3lzdGVtOjpEQicpLT5TUUxQcm9jZXNzb3IoCiAgICAgICAgRGF0YWJhc2UgPT4gWwogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBUYWcgICAgID0+ICdUYWJsZUFsdGVyJywKICAgICAgICAgICAgICAgIE5hbWUgICAgPT4gJ2dlbmVyYWxfY2F0YWxvZycsCiAgICAgICAgICAgICAgICBUYWdUeXBlID0+ICdTdGFydCcsCiAgICAgICAgICAgIH0sCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFRhZyAgICAgPT4gJ0NvbHVtbkRyb3AnLAogICAgICAgICAgICAgICAgTmFtZSAgICA9PiAnZnVuY3Rpb25hbGl0eScsCiAgICAgICAgICAgICAgICBUYWdUeXBlID0+ICdTdGFydCcsCiAgICAgICAgICAgIH0sCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFRhZyAgICAgPT4gJ1RhYmxlQWx0ZXInLAogICAgICAgICAgICAgICAgVGFnVHlwZSA9PiAnRW5kJywKICAgICAgICAgICAgfSwKICAgICAgICBdLAogICAgKTsKCiAgICAkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6REInKS0+RG8oCiAgICAgICAgU1FMID0+ICREcm9wLAogICAgKTsKCiAgICByZXR1cm4gMTsKfQoKPWl0ZW0gX01pZ3JhdGVDb25maWdzKCkKCmNoYW5nZSBjb25maWd1cmF0aW9ucyB0byBtYXRjaCB0aGUgbmV3IG1vZHVsZSBsb2NhdGlvbi4KCiAgICBteSAkUmVzdWx0ID0gJENvZGVPYmplY3QtPl9NaWdyYXRlQ29uZmlncygpOwoKPWN1dAoKc3ViIF9NaWdyYXRlQ29uZmlncyB7CgogICAgIyBjcmVhdGUgbmVlZGVkIG9iamVjdHMKICAgIG15ICRTeXNDb25maWdPYmplY3QgPSAkS2VybmVsOjpPTS0+R2V0KCdLZXJuZWw6OlN5c3RlbTo6U3lzQ29uZmlnJyk7CiAgICBteSAkQ29uZmlnT2JqZWN0ICAgID0gJEtlcm5lbDo6T00tPkdldCgnS2VybmVsOjpDb25maWcnKTsKCiAgICAjIG1pZ3JhdGUgR2VuZXJhbENhdGFsb2cgUHJlZmVyZW5jZXMKICAgICMgZ2V0IHNldHRpbmcgY29udGVudCBmb3IgR2VuZXJhbENhdGFsb2cgUHJlZmVyZW5jZXMKICAgIG15ICRTZXR0aW5nID0gJENvbmZpZ09iamVjdC0+R2V0KCdHZW5lcmFsQ2F0YWxvZ1ByZWZlcmVuY2VzJyk7CgogICAgQ09ORklHSVRFTToKICAgIGZvciBteSAkTWVudU1vZHVsZSAoIHNvcnQga2V5cyAleyRTZXR0aW5nfSApIHsKCiAgICAgICAgIyB1cGRhdGUgbW9kdWxlIGxvY2F0aW9uCiAgICAgICAgbXkgJE1vZHVsZSA9ICRTZXR0aW5nLT57JE1lbnVNb2R1bGV9LT57J01vZHVsZSd9OwogICAgICAgIGlmICggJE1vZHVsZSAhfiBte0tlcm5lbDo6T3V0cHV0OjpIVE1MOjpHZW5lcmFsQ2F0YWxvZ1ByZWZlcmVuY2VzKFx3Kyl9ICkgewogICAgICAgICAgICBuZXh0IENPTkZJR0lURU07CiAgICAgICAgfQoKICAgICAgICAkU2V0dGluZy0+eyRNZW51TW9kdWxlfS0+e01vZHVsZX0gPSAiS2VybmVsOjpPdXRwdXQ6OkhUTUw6OkdlbmVyYWxDYXRhbG9nUHJlZmVyZW5jZXM6OkdlbmVyaWMiOwoKICAgICAgICAjIHNldCBuZXcgc2V0dGluZywKICAgICAgICBteSAkU3VjY2VzcyA9ICRTeXNDb25maWdPYmplY3QtPkNvbmZpZ0l0ZW1VcGRhdGUoCiAgICAgICAgICAgIFZhbGlkID0+IDEsCiAgICAgICAgICAgIEtleSAgID0+ICdHZW5lcmFsQ2F0YWxvZ1ByZWZlcmVuY2VzIyMjJyAuICRNZW51TW9kdWxlLAogICAgICAgICAgICBWYWx1ZSA9PiAkU2V0dGluZy0+eyRNZW51TW9kdWxlfSwKICAgICAgICApOwogICAgfQoKICAgIHJldHVybiAxOwp9CgoxOwoKPWJhY2sKCj1oZWFkMSBURVJNUyBBTkQgQ09ORElUSU9OUwoKVGhpcyBTb2Z0d2FyZSBpcyBwYXJ0IG9mIHRoZSBPVFJTIHByb2plY3QgKGh0dHA6Ly9vdHJzLm9yZy8pLgoKVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQpkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgTDxodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQ+LgoKPWN1dAo=