Survey
1.2.4
OTRS AG
http://otrs.org/
GNU AFFERO GENERAL PUBLIC LICENSE Version 3, November 2007
Added spanish translation.
Improved handling of request mails.
Fixed bug# 5319 - Url link send in email does not open.
Init release for OTRS 2.4.
A customer survey tool.
Ein Kundenumfragen Werkzeug.
2.4.x
<br>
<b>WELCOME</b>
<br>
<br>
You are about to install the OTRS package Survey.<br>
<br>
<br>
<b>ATTENTION</b>
<br>
<br>
Make sure your database accepts packages over 5 MB in size. A MySQL database for example accepts packages up to 1 MB by default. In this case, the value for max_allowed_packet must be increased. The recommended maximum size accepted is 20 MB.<br>
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>WILLKOMMEN</b>
<br>
<br>
Sie sind im Begriff das OTRS-Paket Survey zu installieren.<br>
<br>
<br>
<b>ACHTUNG</b>
<br>
<br>
Vergewissern Sie sich, dass ihre Datenbank Pakete mit einer Größe von mehr als 5 MB akzeptiert. Eine MySQL Datenbank akzeptiert beispielsweise standardmäßig Pakete mit einer Größe von maximal 1 MB. In diesem Fall muss der Wert für max_allowed_packet erhöht werden. Empfohlen werden 20 MB.<br>
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>ATTENTION</b>
<br>
<br>
If you uninstall this package, all database tables that were created during installation will be deleted.
All data from these tables will be irrevocably lost!
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>ACHTUNG</b>
<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>
<b>WELCOME</b>
<br>
<br>
You are about to upgrade the OTRS package Survey.<br>
<br>
<br>
</b>ATTENTION</b>
<br>
<br>
Make sure your database accepts packages over 5 MB in size. A MySQL database for example accepts packages up to 1 MB by default. In this case, the value for max_allowed_packet must be increased. The recommended maximum size accepted is 20 MB.<br>
<br>
<br>
((enjoy))<br>
<br>
<br>
<b>WILLKOMMEN</b>
<br>
<br>
Sie sind im Begriff das OTRS-Paket Survey zu aktualisieren.<br>
<br>
<br>
<b>ACHTUNG</b>
<br>
<br>
Vergewissern Sie sich, dass ihre Datenbank Pakete mit einer Größe von mehr als 5 MB akzeptiert. Eine MySQL Datenbank akzeptiert beispielsweise standardmäßig Pakete mit einer Größe von maximal 1 MB. In diesem Fall muss der Wert für max_allowed_packet erhöht werden. Empfohlen werden 20 MB.<br>
<br>
<br>
((enjoy))<br>
<br>
2010-08-18 11:24:57
opms.otrs.com
PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSIgPz4KPG90cnNfY29uZmlnIHZlcnNpb249IjEuMCIgaW5pdD0iQXBwbGljYXRpb24iPgogICAgPENWUz4kSWQ6IFN1cnZleS54bWwsdiAxLjEwIDIwMDgvMTIvMjIgMTA6MDM6MzggbWFydGluIEV4cCAkPC9DVlM+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJGcm9udGVuZDo6TW9kdWxlIyMjQWdlbnRTdXJ2ZXkiIFJlcXVpcmVkPSIwIiBWYWxpZD0iMSI+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImVuIj5BbGwgcGFyYW1ldGVycyBmb3IgdGhlIFN1cnZleSBvYmplY3QgaW4gdGhlIGFnZW50IGludGVyZmFjZS48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJkZSI+QWxsZSBQYXJhbWV0ZXIgZGVzIEJlZnJhZ3VuZ3MtT2JqZWt0cyBpbSBBZ2VudC1JbnRlcmZhY2UuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8R3JvdXA+U3VydmV5PC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+RnJvbnRlbmQ6OkFnZW50OjpNb2R1bGVSZWdpc3RyYXRpb248L1N1Ykdyb3VwPgogICAgICAgIDxTZXR0aW5nPgogICAgICAgICAgICA8RnJvbnRlbmRNb2R1bGVSZWc+CiAgICAgICAgICAgICAgICA8RGVzY3JpcHRpb24+QSBTdXJ2ZXkgTW9kdWxlPC9EZXNjcmlwdGlvbj4KICAgICAgICAgICAgICAgIDxOYXZCYXJOYW1lPlN1cnZleTwvTmF2QmFyTmFtZT4KICAgICAgICAgICAgICAgIDxUaXRsZT5TdXJ2ZXk8L1RpdGxlPgogICAgICAgICAgICAgICAgPE5hdkJhcj4KICAgICAgICAgICAgICAgICAgICA8RGVzY3JpcHRpb24+QSBTdXJ2ZXkgTW9kdWxlPC9EZXNjcmlwdGlvbj4KICAgICAgICAgICAgICAgICAgICA8TmFtZT5TdXJ2ZXk8L05hbWU+CiAgICAgICAgICAgICAgICAgICAgPFR5cGU+TWVudTwvVHlwZT4KICAgICAgICAgICAgICAgICAgICA8QmxvY2s+SXRlbUFyZWE8L0Jsb2NrPgogICAgICAgICAgICAgICAgICAgIDxJbWFnZT5zdXJ2ZXkucG5nPC9JbWFnZT4KICAgICAgICAgICAgICAgICAgICA8TGluaz5BY3Rpb249QWdlbnRTdXJ2ZXk8L0xpbms+CiAgICAgICAgICAgICAgICAgICAgPE5hdkJhcj5TdXJ2ZXk8L05hdkJhcj4KICAgICAgICAgICAgICAgICAgICA8QWNjZXNzS2V5PnU8L0FjY2Vzc0tleT4KICAgICAgICAgICAgICAgICAgICA8UHJpbz44MDAwPC9QcmlvPgogICAgICAgICAgICAgICAgPC9OYXZCYXI+CiAgICAgICAgICAgICAgICA8TmF2QmFyPgogICAgICAgICAgICAgICAgICAgIDxEZXNjcmlwdGlvbj5PdmVydmlldzwvRGVzY3JpcHRpb24+CiAgICAgICAgICAgICAgICAgICAgPE5hbWU+T3ZlcnZpZXc8L05hbWU+CiAgICAgICAgICAgICAgICAgICAgPEltYWdlPm92ZXJ2aWV3LnBuZzwvSW1hZ2U+CiAgICAgICAgICAgICAgICAgICAgPExpbms+QWN0aW9uPUFnZW50U3VydmV5PC9MaW5rPgogICAgICAgICAgICAgICAgICAgIDxUeXBlPjwvVHlwZT4KICAgICAgICAgICAgICAgICAgICA8QmxvY2s+PC9CbG9jaz4KICAgICAgICAgICAgICAgICAgICA8TmF2QmFyPlN1cnZleTwvTmF2QmFyPgogICAgICAgICAgICAgICAgICAgIDxBY2Nlc3NLZXk+bzwvQWNjZXNzS2V5PgogICAgICAgICAgICAgICAgICAgIDxQcmlvPjEwMDwvUHJpbz4KICAgICAgICAgICAgICAgIDwvTmF2QmFyPgogICAgICAgICAgICAgICAgPE5hdkJhcj4KICAgICAgICAgICAgICAgICAgICA8RGVzY3JpcHRpb24+TmV3PC9EZXNjcmlwdGlvbj4KICAgICAgICAgICAgICAgICAgICA8TmFtZT5OZXc8L05hbWU+CiAgICAgICAgICAgICAgICAgICAgPEltYWdlPm5ldy5wbmc8L0ltYWdlPgogICAgICAgICAgICAgICAgICAgIDxMaW5rPkFjdGlvbj1BZ2VudFN1cnZleSZhbXA7U3ViYWN0aW9uPVN1cnZleUFkZDwvTGluaz4KICAgICAgICAgICAgICAgICAgICA8VHlwZT48L1R5cGU+CiAgICAgICAgICAgICAgICAgICAgPEJsb2NrPjwvQmxvY2s+CiAgICAgICAgICAgICAgICAgICAgPE5hdkJhcj5TdXJ2ZXk8L05hdkJhcj4KICAgICAgICAgICAgICAgICAgICA8QWNjZXNzS2V5Pm48L0FjY2Vzc0tleT4KICAgICAgICAgICAgICAgICAgICA8UHJpbz4yMDA8L1ByaW8+CiAgICAgICAgICAgICAgICA8L05hdkJhcj4KICAgICAgICAgICAgPC9Gcm9udGVuZE1vZHVsZVJlZz4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJQdWJsaWNGcm9udGVuZDo6TW9kdWxlIyMjUHVibGljU3VydmV5IiBSZXF1aXJlZD0iMCIgVmFsaWQ9IjEiPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJlbiI+RnJvbnRlbmQgbW9kdWxlIHJlZ2lzdHJhdGlvbiBmb3IgdGhlIFB1YmxpY1N1cnZleSBvYmplY3QgaW4gdGhlIHB1YmxpYyBTdXJ2ZXkgYXJlYS48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJkZSI+RnJvbnRlbmRtb2R1bC1SZWdpc3RyYXRpb24gZvxyIGRhcyBQdWJsaWNTdXJ2ZXktT2JqZWt0IGltIPZmZmVudGxpY2hlbiBVbWZyYWdlLUJlcmVpY2guPC9EZXNjcmlwdGlvbj4KICAgICAgICA8R3JvdXA+U3VydmV5PC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+RnJvbnRlbmQ6OlB1YmxpYzo6TW9kdWxlUmVnaXN0cmF0aW9uPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPEZyb250ZW5kTW9kdWxlUmVnPgogICAgICAgICAgICAgICAgPERlc2NyaXB0aW9uPlB1YmxpYyBTdXJ2ZXk8L0Rlc2NyaXB0aW9uPgogICAgICAgICAgICAgICAgPE5hdkJhck5hbWU+U3VydmV5PC9OYXZCYXJOYW1lPgogICAgICAgICAgICAgICAgPFRpdGxlPlN1cnZleTwvVGl0bGU+CiAgICAgICAgICAgIDwvRnJvbnRlbmRNb2R1bGVSZWc+CiAgICAgICAgPC9TZXR0aW5nPgogICAgPC9Db25maWdJdGVtPgogICAgPENvbmZpZ0l0ZW0gTmFtZT0iU3VydmV5OjpTZW5kUGVyaW9kIiBSZXF1aXJlZD0iMCIgVmFsaWQ9IjEiPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJlbiI+RGF5cyBzdGFydGluZyBmcm9tIHRoZSBsYXRlc3QgY3VzdG9tZXIgc3VydmV5IGVtYWlsIGJldHdlZW4gbm8gY3VzdG9tZXIgc3VydmV5IGVtYWlsIGlzIHNlbnQuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZGUiPlRhZ2Ugendpc2NoZW4gZGVyIGxldHp0ZW4gS3VuZGVuLVVtZnJhZ2UgdW5kIGRlbiBrZWluZSBLdW5kZW4tVW1mcmFnZSBnZXNlbmRldCB3aXJkLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPlN1cnZleTwvR3JvdXA+CiAgICAgICAgPFN1Ykdyb3VwPkNvcmU8L1N1Ykdyb3VwPgogICAgICAgIDxTZXR0aW5nPgogICAgICAgICAgICA8U3RyaW5nIFJlZ2V4PSIiPjMwMDwvU3RyaW5nPgogICAgICAgIDwvU2V0dGluZz4KICAgIDwvQ29uZmlnSXRlbT4KICAgIDxDb25maWdJdGVtIE5hbWU9IlN1cnZleTo6Tm90aWZpY2F0aW9uU2VuZGVyIiBSZXF1aXJlZD0iMSIgVmFsaWQ9IjEiPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJlbiI+RGVmYXVsdCBzZW5kZXIgZm9yIHRoZSBub3RpZmljYXRpb24gZW1haWwgdG8gY3VzdG9tZXJzIGFib3V0IG5ldyBzdXJ2ZXkuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZGUiPkRlZmF1bHQtU2VuZGVyIGb8ciBkaWUgQmVuYWNocmljaHRpZ3VuZ3NtYWlsIGFuIEt1bmRlbiBiemdsLiBuZXVlIFVtZnJhZ2VuLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPlN1cnZleTwvR3JvdXA+CiAgICAgICAgPFN1Ykdyb3VwPkNvcmU8L1N1Ykdyb3VwPgogICAgICAgIDxTZXR0aW5nPgogICAgICAgICAgICA8U3RyaW5nIFJlZ2V4PSIiPnF1YWxpdHlAZXhhbXBsZS5jb208L1N0cmluZz4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJTdXJ2ZXk6Ok5vdGlmaWNhdGlvblN1YmplY3QiIFJlcXVpcmVkPSIxIiBWYWxpZD0iMSI+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImVuIj5EZWZhdWx0IHN1YmplY3QgZm9yIHRoZSBub3RpZmljYXRpb24gZW1haWwgdG8gY3VzdG9tZXJzIGFib3V0IG5ldyBzdXJ2ZXkuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZGUiPkRlZmF1bHQtQmV0cmVmZiBm/HIgZGllIEJlbmFjaHJpY2h0aWd1bmdzbWFpbCBhbiBLdW5kZW4gYnpnbC4gbmV1ZSBVbWZyYWdlbi48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5TdXJ2ZXk8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5Db3JlPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPFN0cmluZyBSZWdleD0iIj5IZWxwIHVzIHdpdGggeW91ciBmZWVkYmFjayE8L1N0cmluZz4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJTdXJ2ZXk6Ok5vdGlmaWNhdGlvbkJvZHkiIFJlcXVpcmVkPSIxIiBWYWxpZD0iMSI+CiAgICAgICAgPERlc2NyaXB0aW9uIExhbmc9ImVuIj5EZWZhdWx0IGJvZHkgZm9yIHRoZSBub3RpZmljYXRpb24gZW1haWwgdG8gY3VzdG9tZXJzIGFib3V0IG5ldyBzdXJ2ZXkuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZGUiPkRlZmF1bHQtQm9keSBm/HIgZGllIEJlbmFjaHJpY2h0aWd1bmdzbWFpbCBhbiBLdW5kZW4gYnpnbC4gbmV1ZSBVbWZyYWdlbi48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxHcm91cD5TdXJ2ZXk8L0dyb3VwPgogICAgICAgIDxTdWJHcm91cD5Db3JlPC9TdWJHcm91cD4KICAgICAgICA8U2V0dGluZz4KICAgICAgICAgICAgPFRleHRBcmVhPkRlYXIgQ3VzdG9tZXIsCgp0aGFua3MgZm9yIHVzaW5nIG91ciBzZXJ2aWNlLiBIZWxwIHVzIHRvIGltcHJvdmUgdXMgYW5kIG91ciBzZXJ2aWNlcy4KCkdpdmUgdXMgZmVlZGJhY2sgd2hhdCB3ZSBjYW4gZG86CgombHQ7T1RSU19DT05GSUdfSHR0cFR5cGUmZ3Q7Oi8vJmx0O09UUlNfQ09ORklHX0ZRRE4mZ3Q7LyZsdDtPVFJTX0NPTkZJR19TY3JpcHRBbGlhcyZndDtwdWJsaWMucGw/QWN0aW9uPVB1YmxpY1N1cnZleSZhbXA7UHVibGljU3VydmV5S2V5PSZsdDtPVFJTX1B1YmxpY1N1cnZleUtleSZndDsKClRoYW5rcyBmb3IgeW91ciBoZWxwIQoKWW91ciBPVFJTLVRlYW0KICAgICAgICAgICAgPC9UZXh0QXJlYT4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJTdXJ2ZXk6OlNlbmROb1N1cnZleVJlZ0V4cCIgUmVxdWlyZWQ9IjAiIFZhbGlkPSIxIj4KICAgICAgICA8RGVzY3JpcHRpb24gTGFuZz0iZW4iPklmIHRoaXMgcmVnZXggbWF0Y2hlcywgbm8gY3VzdG9tZXIgc3VydmV5IHdpbGwgYmUgc2VudC48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJkZSI+VHJpZmZ0IGRpZXNlciByZWd1bORyZSBBdXNkcnVjayB6dSwgd2lyZCBrZWluZSBCZW5hY2hyaWNodGlndW5nc21haWwgYW4gS3VuZGVuIGJ6Z2wuIG5ldWUgVW1mcmFnZW4gZ2VzZW5kZXQuPC9EZXNjcmlwdGlvbj4KICAgICAgICA8R3JvdXA+U3VydmV5PC9Hcm91cD4KICAgICAgICA8U3ViR3JvdXA+Q29yZTwvU3ViR3JvdXA+CiAgICAgICAgPFNldHRpbmc+CiAgICAgICAgICAgIDxTdHJpbmcgUmVnZXg9IiI+KE1BSUxFUi1EQUVNT058cG9zdG1hc3RlcnxhYnVzZSlALis/XC4uKz88L1N0cmluZz4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+CiAgICA8Q29uZmlnSXRlbSBOYW1lPSJUaWNrZXQ6OkV2ZW50TW9kdWxlUG9zdCMjIzk5LVN1cnZleVNlbmRSZXF1ZXN0IiBSZXF1aXJlZD0iMCIgVmFsaWQ9IjEiPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJlbiI+VGlja2V0IGV2ZW50IG1vZHVsZSB0byBzZW5kIGF1dG9tYXRpY2FsbHkgc3VydmV5IGVtYWlsIHJlcXVlc3RzIHRvIGN1c3RvbWVycyBpZiBhIHRpY2tldCBnZXRzIGNsb3NlZC48L0Rlc2NyaXB0aW9uPgogICAgICAgIDxEZXNjcmlwdGlvbiBMYW5nPSJkZSI+VGlja2V0IEV2ZW50IE1vZHVsIHdlbGNoZXMgYXV0b21hdGlzY2ggVW1mcmFnZW4tRW1haWxzIGFuIEt1bmRlbiB3ZW5uIGRlcmVuIFRpY2tldCBnZXNjaGxvc3NlbiB3aXJkLjwvRGVzY3JpcHRpb24+CiAgICAgICAgPEdyb3VwPlN1cnZleTwvR3JvdXA+CiAgICAgICAgPFN1Ykdyb3VwPkNvcmU8L1N1Ykdyb3VwPgogICAgICAgIDxTZXR0aW5nPgogICAgICAgICAgICA8SGFzaD4KICAgICAgICAgICAgICAgIDxJdGVtIEtleT0iTW9kdWxlIj5LZXJuZWw6OlN5c3RlbTo6VGlja2V0OjpFdmVudDo6U3VydmV5U2VuZFJlcXVlc3Q8L0l0ZW0+CiAgICAgICAgICAgICAgICA8SXRlbSBLZXk9IkV2ZW50Ij4oQXJ0aWNsZUNyZWF0ZXxUaWNrZXRTdGF0ZVVwZGF0ZSk8L0l0ZW0+CiAgICAgICAgICAgIDwvSGFzaD4KICAgICAgICA8L1NldHRpbmc+CiAgICA8L0NvbmZpZ0l0ZW0+Cjwvb3Ryc19jb25maWc+Cg==
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9iZ19BZ2VudFN1cnZleS5wbSAtIHRoZSBidWxnYXJpYW4gbGFuZ3VhZ2UgZm9yIEFnZW50U3VydmV5CiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMDkgT1RSUyBBRywgaHR0cDovL290cnMub3JnLwojIC0tCiMgJElkOiBiZ19BZ2VudFN1cnZleS5wbSx2IDEuNiAyMDA5LzEwLzMwIDA4OjI4OjUyIG1iIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6TGFuZ3VhZ2U6OmJnX0FnZW50U3VydmV5OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIHZhcnMgcXcoJFZFUlNJT04pOwokVkVSU0lPTiA9IHF3KCRSZXZpc2lvbjogMS42ICQpIFsxXTsKCnN1YiBEYXRhIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5J30gPSAnwO3q5fLgJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhblwndCBzZXQgbmV3IHN0YXR1cyEgTm8gcXVlc3Rpb25zIGRlZmluZWQuJ30KICAgICAgICA9ICfN5SDs7uPgIOTgIPPx8uDt7uL/IO3u4iDx8uDy8/EhIM3/7OAg5OX06O3o8ODt6CDi+u/w7vHoLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYW5cJ3Qgc2V0IG5ldyBzdGF0dXMhIFF1ZXN0aW9ucyBpbmNvbXBsZXRlLid9CiAgICAgICAgPSAnzeUg7O7j4CDk4CDz8fLg7e7i/yDt7uIg8fLg8vPxISDC+u/w7vHo8uUg8eAg7eXv+uvt6C4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3RhdHVzIGNoYW5nZWQuJ30gPSAnze7iIMDq8uji5e0g8fLg8vPxISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDaGFuZ2UgU3RhdHVzJ30gICAgID0gJ8/w7uzl7egg8fLg8vPx4Cc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTZW50IHJlcXVlc3RzJ30gICA9ICfI5+/w4PLl7egg5+D/4uroJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1JlY2VpdmVkIHN1cnZleXMnfSAgICA9ICfP7uvz9+Xt6CDj6+Dx8+Lg7ej/JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J2Fuc3dlcmVkJ30gICAgICAgICAgPSAn7vLj7uLu8Ojr6Cc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydub3QgYW5zd2VyZWQnfSAgICAgID0gJ+3l7vLj7uLu8Ojr6Cc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXlzJ30gICAgICAgICAgID0gJ8/w7vP34uDt6P8nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnSW52YWxpZCd9ICAgICAgICAgICA9ICfN5eLg6+jk7egnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnSW50cm9kdWN0aW9uJ30gICAgICA9ICfC+uLl5OXt6OUnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnSW50ZXJuYWwnfSAgICAgICAgICA9ICfC+vLw5fjl7Sc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSAgICAgICAgID0gJ8L67/Du8egnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb24nfSAgICAgICAgICA9ICfC+u/w7vEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUG9zaWJsZSBBbnN3ZXJzJ30gICA9ICfC+ufs7ubt6CDu8uPu4u7w6Cc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydZZXNObyd9ICAgICAgICAgICAgID0gJ8TAIOjr6CDNxSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydMaXN0J30gICAgICAgICAgICAgID0gJ9Hv6PH66ic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydUZXh0YXJlYSd9ICAgICAgICAgID0gJ8fu7eAg5+Ag8uXq8fInOwoKICAgIHJldHVybiAxOwp9CgoxOwo=
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9iZ19QdWJsaWNTdXJ2ZXkucG0gLSB0aGUgYnVsZ2FyaWFuIGxhbmd1YWdlIGZvciBQdWJsaWNTdXJ2ZXkKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAwOSBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgLS0KIyAkSWQ6IGJnX1B1YmxpY1N1cnZleS5wbSx2IDEuNiAyMDA5LzA0LzAyIDE2OjIyOjE5IG1oIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6TGFuZ3VhZ2U6OmJnX1B1YmxpY1N1cnZleTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSB2YXJzIHF3KCRWRVJTSU9OKTsKJFZFUlNJT04gPSBxdygkUmV2aXNpb246IDEuNiAkKSBbMV07CgpzdWIgRGF0YSB7CiAgICBteSAkU2VsZiA9IHNoaWZ0OwoKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSd9ICAgID0gJ8Dt6uXy4Cc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSA9ICfC+u/w7vHoJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1F1ZXN0aW9uJ30gID0gJ8L67/Du8Sc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGaW5pc2gnfSAgICA9ICfH4OL68PjoJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J2ZpbmlzaGVkJ30gID0gJ+fg4vrw+OXt7ic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydUaGlzIFN1cnZleS1LZXkgaXMgaW52YWxpZCEnfQogICAgICAgID0gJ9Lu5+gg6uv+9yDlIO3l4uDr6OTl7SDn4CDv8O7z9+Lg7eXy7iEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGhhbmsgeW91IGZvciB5b3VyIGZlZWRiYWNrLid9CiAgICAgICAgPSAnwevg4+7k4PDo7CDi6CDn4CDu4fDg8u3g8uAg6O307vDs4Pbo/yc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydOZWVkIHRvIHNlbGVjdCBxdWVzdGlvbjonfSAgPSAnJzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9jel9BZ2VudFN1cnZleS5wbSAtIHRoZSBjemVjaCBsYW5ndWFnZSBmb3IgQWdlbnRTdXJ2ZXkKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxMCBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgQ29weXJpZ2h0IChDKSAyMDEwIE8yQlMuY29tLCBzIHIuby4gSmFrdWIgSGFudXMKIyAtLQojICRJZDogY3pfQWdlbnRTdXJ2ZXkucG0sdiAxLjYgMjAxMC8wMi8yMiAxMTo1NDo0OCBtYiBFeHAgJAojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6Okxhbmd1YWdlOjpjel9BZ2VudFN1cnZleTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSB2YXJzIHF3KCRWRVJTSU9OKTsKJFZFUlNJT04gPSBxdygkUmV2aXNpb246IDEuNiAkKSBbMV07CgpzdWIgRGF0YSB7CiAgICBteSAkU2VsZiA9IHNoaWZ0OwoKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSd9ID0gJ1Byxa96a3VtLCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYW5cJ3Qgc2V0IG5ldyBzdGF0dXMhIE5vIHF1ZXN0aW9ucyBkZWZpbmVkLid9CiAgICAgICAgPSAnTmVsemUgbmFzdGF2aXQgbm92w70gc3RhdiEgTmVqc291IGRlZmlub3bDoW55IGRvdGF6eS4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2FuXCd0IHNldCBuZXcgc3RhdHVzISBRdWVzdGlvbnMgaW5jb21wbGV0ZS4nfQogICAgICAgID0gJ05lbHplIG5hc3Rhdml0IG5vdsO9IHN0YXYhIERvdGF6eSBuZWpzb3Uga29tcGxldG7DrS4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3RhdHVzIGNoYW5nZWQuJ30gPSAnTm92w70gYWt0aXZuw60gc3RhdiEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2hhbmdlIFN0YXR1cyd9ICAgICA9ICdabcSbbnkgc3RhdnUnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU2VudCByZXF1ZXN0cyd9ICAgPSAnWmFzbMOhbnkgcG/FvmFkYXZreSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydSZWNlaXZlZCBzdXJ2ZXlzJ30gICAgPSAnT2JkcsW+ZW55IGhsYXN5JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J2Fuc3dlcmVkJ30gICAgICAgICAgPSAnT2Rwb3bEm2RsaSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydub3QgYW5zd2VyZWQnfSAgICAgID0gJ05lb2Rwb3bEm2RsaSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXlzJ30gICAgICAgICAgID0gJ1Byxa96a3VteSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnZhbGlkJ30gICAgICAgICAgID0gJ05lcGxhdG7DqSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnRyb2R1Y3Rpb24nfSAgICAgID0gJ8Oadm9kJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludGVybmFsJ30gICAgICAgICAgPSAnSW50ZXJuw60nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb25zJ30gICAgICAgICA9ICdEb3RhenknOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb24nfSAgICAgICAgICA9ICdEb3Rheic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQb3NpYmxlIEFuc3dlcnMnfSAgID0gJ1DFmcOtcGFkbsOpIG9kcG92xJtkeSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydZZXNObyd9ICAgICAgICAgICAgID0gJ0FubyBhbmVibyBOZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydMaXN0J30gICAgICAgICAgICAgID0gJ3Nlem5hbSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydUZXh0YXJlYSd9ICAgICAgICAgID0gJ3RleHRvdsOpIHBvbGUnOwoKICAgIHJldHVybiAxOwp9CgoxOwo=
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9jel9QdWJsaWNTdXJ2ZXkucG0gLSB0aGUgY3plY2ggbGFuZ3VhZ2UgZm9yIFB1YmxpY1N1cnZleQojIENvcHlyaWdodCAoQykgMjAwMS0yMDEwIE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy8KIyBDb3B5cmlnaHQgKEMpIDIwMTAgTzJCUy5jb20sIHMgci5vLiBKYWt1YiBIYW51cwojIC0tCiMgJElkOiBjel9QdWJsaWNTdXJ2ZXkucG0sdiAxLjYgMjAxMC8wMi8yMiAxMTo1NDo0OCBtYiBFeHAgJAojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6Okxhbmd1YWdlOjpjel9QdWJsaWNTdXJ2ZXk7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7Cgp1c2UgdmFycyBxdygkVkVSU0lPTik7CiRWRVJTSU9OID0gcXcoJFJldmlzaW9uOiAxLjYgJCkgWzFdOwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXknfSAgICA9ICdQcsWvemt1bSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSA9ICdEb3RhenknOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb24nfSAgPSAnRG90YXonOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRmluaXNoJ30gICAgPSAnVWtvbsSNaXQnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnZmluaXNoZWQnfSAgPSAndWtvbsSNZW5vJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1RoaXMgU3VydmV5LUtleSBpcyBpbnZhbGlkISd9CiAgICAgICAgPSAnVGVudG8ga2zDrcSNIGplIG5ldmhvZG7DvSBwcm8gcHLFr3prdW0hJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1RoYW5rIHlvdSBmb3IgeW91ciBmZWVkYmFjay4nfQogICAgICAgID0gJ0TEm2t1amVtZSBWw6FtIHphIHpwxJt0bm91IHZhemJ1JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J05lZWQgdG8gc2VsZWN0IHF1ZXN0aW9uOid9ICA9ICdOdXRubyB2eWJyYXQgZG90YXo6JzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9kYV9BZ2VudFN1cnZleS5wbSAtIHByb3ZpZGVzIGRhIChEYW5pc2gpIGxhbmd1YWdlIHRyYW5zbGF0aW9uCiMgQ29weXJpZ2h0IChDKSAyMDAxLTIwMTAgT1RSUyBBRywgaHR0cDovL290cnMub3JnLwojIENvcHlyaWdodCAoQykgMjAwMS0yMDEwIE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy8KIyAtLQojICRJZDogZGFfQWdlbnRTdXJ2ZXkucG0sdiAxLjEgMjAxMC8wNy8xMiAxMjoyODo1MyB1YiBFeHAgJAojIC0tCiMgVGhpcyBzb2Z0d2FyZSBjb21lcyB3aXRoIEFCU09MVVRFTFkgTk8gV0FSUkFOVFkuIEZvciBkZXRhaWxzLCBzZWUKIyB0aGUgZW5jbG9zZWQgZmlsZSBDT1BZSU5HIGZvciBsaWNlbnNlIGluZm9ybWF0aW9uIChBR1BMKS4gSWYgeW91CiMgZGlkIG5vdCByZWNlaXZlIHRoaXMgZmlsZSwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy9hZ3BsLnR4dC4KIyAtLQoKcGFja2FnZSBLZXJuZWw6Okxhbmd1YWdlOjpkYV9BZ2VudFN1cnZleTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSB2YXJzIHF3KCRWRVJTSU9OKTsKJFZFUlNJT04gPSBxdygkUmV2aXNpb246IDEuMSAkKSBbMV07CgpzdWIgRGF0YSB7CiAgICBteSAkU2VsZiA9IHNoaWZ0OwoKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSd9ID0gJ1VuZGVyc/hnZWxzZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYW5cJ3Qgc2V0IG5ldyBzdGF0dXMhIE5vIHF1ZXN0aW9ucyBkZWZpbmVkLid9CiAgICAgICAgPSAnS2FuIGlra2Ugc+Z0dGUgbnkgc3RhdHVzISBEZXIgZXIgaWtrZSBkZWZpbmVyZXQgbm9nZW4gc3D4cmdzbeVsLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYW5cJ3Qgc2V0IG5ldyBzdGF0dXMhIFF1ZXN0aW9ucyBpbmNvbXBsZXRlLid9CiAgICAgICAgPSAnS2FuIGlra2Ugc+Z0dGUgbnkgc3RhdHVzISBTcPhyZ3Nt5WwgZXIgaWtrZSBhZnNsdXR0ZXQuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N0YXR1cyBjaGFuZ2VkLid9ICA9ICdTdGF0dXMg5m5kcmV0ISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDaGFuZ2UgU3RhdHVzJ30gICAgPSAnxm5kcmUgc3RhdHVzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1NlbnQgcmVxdWVzdHMnfSAgICA9ICdTZW5kdCBmb3Jlc3D4cmdzZWwnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUmVjZWl2ZWQgc3VydmV5cyd9ID0gJ01vZHRhZ2V0IHVuZGVyc/hnZWxzZXInOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnYW5zd2VyZWQnfSAgICAgICAgID0gJ2Jlc3ZhcmV0JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J25vdCBhbnN3ZXJlZCd9ICAgICA9ICdpa2tlIGJlc3ZhcmV0JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleXMnfSAgICAgICAgICA9ICdVbmRlcnP4Z2Vsc2VyJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludmFsaWQnfSAgICAgICAgICA9ICdVZ3lsZGlnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludHJvZHVjdGlvbid9ICAgICA9ICdJbnRyb2R1a3Rpb24nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnSW50ZXJuYWwnfSAgICAgICAgID0gJ0ludGVybic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSAgICAgICAgPSAnU3D4cmdzbeVsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1F1ZXN0aW9uJ30gICAgICAgICA9ICdTcPhyZ3Nt5WwnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUG9zaWJsZSBBbnN3ZXJzJ30gID0gJ011bGlnZSBzdmFyJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1llc05vJ30gICAgICAgICAgICA9ICdKYU5laic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydMaXN0J30gICAgICAgICAgICAgPSAnTGlzdGUnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGV4dGFyZWEnfSAgICAgICAgID0gJ1Rla3N0b21y5WRlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0EgU3VydmV5IE1vZHVsZSd9ICA9ICdFdCB1bmRlcnP4Z2Vsc2VzbW9kdWwnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5IFRpdGxlIGlzIHJlcXVpcmVkISd9CiAgICAgICAgPSAnVW5kZXJz+GdlbHNlc3RpdGVsIGty5nZlcyB1ZGZ5bGR0ISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgSW50cm9kdWN0aW9uIGlzIHJlcXVpcmVkISd9CiAgICAgICAgPSAnVW5kZXJz+GdlbHNlc2ludHJvZHV0aW9uIGty5nZlcyB1ZGZ5bGR0ISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgRGVzY3JpcHRpb24gaXMgcmVxdWlyZWQhJ30KICAgICAgICA9ICdVbmRlcnP4Z2Vsc2VzYmVza3JpdmVsc2Uga3LmdmVzIHVkZnlsZHQhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBOb3RpZmljYXRpb25TZW5kZXIgaXMgcmVxdWlyZWQhJ30KICAgICAgICA9ICdVbmRlcnP4Z2Vsc2Uga3LmdmVyIGF0IGFmc2VuZGVyYWRyZXNzZSBlciB1ZGZ5bGR0ISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgTm90aWZpY2F0aW9uU3ViamVjdCBpcyByZXF1aXJlZCEnfQogICAgICAgID0gJ1VuZGVyc/hnZWxzZSBrcuZ2ZXIgYXQgZW1uZSBlciB1ZGZ5bGR0ISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgTm90aWZpY2F0aW9uQm9keSBpcyByZXF1aXJlZCEnfQogICAgICAgID0gJ1VuZGVyc/hnZWxzZSBrcuZ2ZXIgYXQgdGVrc3RmZWx0ZXQgZXIgdWRmeWxkdCEnOwoKICAgIHJldHVybiAxOwp9CgoxOwo=
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9kYV9QdWJsaWNTdXJ2ZXkucG0gLSBwcm92aWRlcyBkYSAoRGFuaXNoKSBsYW5ndWFnZSB0cmFuc2xhdGlvbgojIENvcHlyaWdodCAoQykgMjAwMS0yMDEwIE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy8KIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxMCBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgLS0KIyAkSWQ6IGRhX1B1YmxpY1N1cnZleS5wbSx2IDEuMSAyMDEwLzA3LzEyIDEyOjI4OjUzIHViIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6TGFuZ3VhZ2U6OmRhX1B1YmxpY1N1cnZleTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSB2YXJzIHF3KCRWRVJTSU9OKTsKJFZFUlNJT04gPSBxdygkUmV2aXNpb246IDEuMSAkKSBbMV07CgpzdWIgRGF0YSB7CiAgICBteSAkU2VsZiA9IHNoaWZ0OwoKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSd9ICAgICAgICAgICAgICAgICAgID0gJ1VuZGVyc/hnZWxzZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSAgICAgICAgICAgICAgICA9ICdTcPhyZ3Nt5WwnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb24nfSAgICAgICAgICAgICAgICAgPSAnU3D4cmdzbeVsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ZpbmlzaCd9ICAgICAgICAgICAgICAgICAgID0gJ0bmcmRpZyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydOZWVkIHRvIHNlbGVjdCBxdWVzdGlvbjonfSA9ICdG+GxnZW5kZSBzcPhyZ3Nt5Wwgc2thbCB1ZGZ5bGRlczonOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnZmluaXNoZWQnfSAgICAgICAgICAgICAgICAgPSAnYWZzbHV0dGV0JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1RoaXMgU3VydmV5LUtleSBpcyBpbnZhbGlkISd9CiAgICAgICAgPSAnRGVubmUgdW5kZXJz+GdlbHNlc274Z2xlIGVyIHVneWxkaWchJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1RoYW5rIHlvdSBmb3IgeW91ciBmZWVkYmFjay4nfQogICAgICAgID0gJ1RhayBmb3IgZGluIGJlc3ZhcmVsc2UuJzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9kZV9BZ2VudFN1cnZleS5wbSAtIHRoZSBkZSBsYW5ndWFnZSBmb3IgQWdlbnRTdXJ2ZXkKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAwOSBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgLS0KIyAkSWQ6IGRlX0FnZW50U3VydmV5LnBtLHYgMS4xOCAyMDA5LzEwLzMwIDA4OjI4OjUyIG1iIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6TGFuZ3VhZ2U6OmRlX0FnZW50U3VydmV5OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIHZhcnMgcXcoJFZFUlNJT04pOwokVkVSU0lPTiA9IHF3KCRSZXZpc2lvbjogMS4xOCAkKSBbMV07CgpzdWIgRGF0YSB7CiAgICBteSAkU2VsZiA9IHNoaWZ0OwoKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSd9ID0gJ1VtZnJhZ2UnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2FuXCd0IHNldCBuZXcgc3RhdHVzISBObyBxdWVzdGlvbnMgZGVmaW5lZC4nfQogICAgICAgID0gJ05ldWVyIFN0YXR1cyBrYW5uIG5pY2h0IGdlc2V0enQgd2VyZGVuISBLZWluZSBGcmFnZW4gZGVmaW5pZXJ0Lic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYW5cJ3Qgc2V0IG5ldyBzdGF0dXMhIFF1ZXN0aW9ucyBpbmNvbXBsZXRlLid9CiAgICAgICAgPSAnTmV1ZXIgU3RhdHVzIGthbm4gbmljaHQgZ2VzZXR6dCB3ZXJkZW4hIEZyYWdlKG4pIHVudm9sbHN05G5kaWcuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N0YXR1cyBjaGFuZ2VkLid9ID0gJ05ldWVyIFN0YXR1cyBha3RpdiEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2hhbmdlIFN0YXR1cyd9ICAgICA9ICdTdGF0dXMg5G5kZXJuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1NlbnQgcmVxdWVzdHMnfSAgID0gJ0dlc2VuZGV0ZSBBbmZyYWdlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydSZWNlaXZlZCBzdXJ2ZXlzJ30gICAgPSAnRXJoYWx0ZW5lIEFudHdvcnRlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydhbnN3ZXJlZCd9ICAgICAgICAgID0gJ2JlYW50d29ydGV0JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J25vdCBhbnN3ZXJlZCd9ICAgICAgPSAnbmljaHQgYmVhbnR3b3J0ZXQnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5cyd9ICAgICAgICAgICA9ICdVbWZyYWdlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnZhbGlkJ30gICAgICAgICAgID0gJ1VuZ/xsdGlnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludHJvZHVjdGlvbid9ICAgICAgPSAnRWlubGVpdHVuZ3N0ZXh0JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludGVybmFsJ30gICAgICAgICAgPSAnSW50ZXJuZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSAgICAgICAgID0gJ0ZyYWdlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbid9ICAgICAgICAgID0gJ0ZyYWdlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1Bvc2libGUgQW5zd2Vycyd9ICAgPSAnTfZnbGljaGUgQW50d29ydGVuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1llc05vJ30gICAgICAgICAgICAgPSAnSmFOZWluJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0xpc3QnfSAgICAgICAgICAgICAgPSAnTGlzdGUnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGV4dGFyZWEnfSAgICAgICAgICA9ICdGcmVpdGV4dCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBIFN1cnZleSBNb2R1bGUnfSAgID0gJ0VpbiBVbWZyYWdlLU1vZHVsJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBUaXRsZSBpcyByZXF1aXJlZCEnfQogICAgICAgID0gJ0JpdHRlIGdlYmVuIFNpZSBlaW5lbiBUaXRlbCBm/HIgZGllIFVtZnJhZ2UgZWluISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgSW50cm9kdWN0aW9uIGlzIHJlcXVpcmVkISd9CiAgICAgICAgPSAnQml0dGUgZ2ViZW4gU2llIGVpbmVuIEVpbmxlaXR1bmdzdGV4dCBlaW4hJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBEZXNjcmlwdGlvbiBpcyByZXF1aXJlZCEnfQogICAgICAgID0gJ0JpdHRlIGdlYmVuIFNpZSBlaW5lIEludGVybmUgQmVzY2hyZWlidW5nIGVpbiEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5IE5vdGlmaWNhdGlvblNlbmRlciBpcyByZXF1aXJlZCEnfQogICAgICAgID0gJ0JpdHRlIGdlYmVuIFNpZSBlaW5lIEFic2VuZGVyLUFkcmVzc2UgZWluISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgTm90aWZpY2F0aW9uU3ViamVjdCBpcyByZXF1aXJlZCEnfQogICAgICAgID0gJ0JpdHRlIGdlYmVuIFNpZSBlaW5lbiBCZXRyZWZmIGVpbiEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5IE5vdGlmaWNhdGlvbkJvZHkgaXMgcmVxdWlyZWQhJ30KICAgICAgICA9ICdCaXR0ZSBnZWJlbiBTaWUgZWluZW4gVGV4dCBlaW4hJzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9kZV9QdWJsaWNTdXJ2ZXkucG0gLSB0aGUgZGUgbGFuZ3VhZ2UgZm9yIFB1YmxpY1N1cnZleQojIENvcHlyaWdodCAoQykgMjAwMS0yMDA5IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy8KIyAtLQojICRJZDogZGVfUHVibGljU3VydmV5LnBtLHYgMS4xMSAyMDA5LzA0LzAyIDE2OjIyOjE5IG1oIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6TGFuZ3VhZ2U6OmRlX1B1YmxpY1N1cnZleTsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSB2YXJzIHF3KCRWRVJTSU9OKTsKJFZFUlNJT04gPSBxdygkUmV2aXNpb246IDEuMTEgJCkgWzFdOwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXknfSAgICA9ICdVbWZyYWdlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1F1ZXN0aW9ucyd9ID0gJ0ZyYWdlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbid9ICA9ICdGcmFnZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydGaW5pc2gnfSAgICA9ICdGZXJ0aWdzdGVsbGVuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J05lZWQgdG8gc2VsZWN0IHF1ZXN0aW9uOid9ICA9ICdGb2xnZW5kZSBGcmFnZSBtdXNzIGF1c2dlZvxsbHQgd2VyZGVuOic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydmaW5pc2hlZCd9ICA9ICdmZXJ0aWdnZXN0ZWxsdCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydUaGlzIFN1cnZleS1LZXkgaXMgaW52YWxpZCEnfQogICAgICAgID0gJ0RpZXNlciBVbWZyYWdlLVNjaGz8c3NlbCBpc3QgbmljaHQgKG1laHIpIGf8bHRpZyEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGhhbmsgeW91IGZvciB5b3VyIGZlZWRiYWNrLid9CiAgICAgICAgPSAnU2llIGhhYmVuIGRpZXNlIFVtZnJhZ2UgYWJnZXNjaGxvc3Nlbi4gVmllbGVuIERhbmsuJzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9lc19BZ2VudFN1cnZleS5wbSAtIHRoZSBlcyBsYW5ndWFnZSBmb3IgQWdlbnRTdXJ2ZXkKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxMCBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgLS0KIyAkSWQ6IGVzX0FnZW50U3VydmV5LnBtLHYgMS4xIDIwMTAvMDgvMTggMDk6MTc6NDUgbWggRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZXNfQWdlbnRTdXJ2ZXk7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7Cgp1c2UgdmFycyBxdygkVkVSU0lPTik7CiRWRVJTSU9OID0gcXcoJFJldmlzaW9uOiAxLjEgJCkgWzFdOwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXknfSA9ICdFbmN1ZXN0YSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYW5cJ3Qgc2V0IG5ldyBzdGF0dXMhIE5vIHF1ZXN0aW9ucyBkZWZpbmVkLid9ID0gJ6FObyBzZSBwdWVkZSBjb25maWd1cmFyIGVsIG51ZXZvIGVzdGFkbyEgTm8gaGF5IHByZWd1bnRhcyBkZWZpbmlkYXMuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhblwndCBzZXQgbmV3IHN0YXR1cyEgUXVlc3Rpb25zIGluY29tcGxldGUuJ30gPSAnoU5vIHNlIHB1ZWRlIGNvbmZpZ3VyYXIgZWwgbnVldm8gZXN0YWRvISBFeGlzdGVuIHByZWd1bnRhcyBpbmNvbXBsZXRhcy4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3RhdHVzIGNoYW5nZWQuJ30gPSAnRWwgZXN0YWRvIGhhIGNhbWJpZG8hJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NoYW5nZSBTdGF0dXMnfSAgICAgPSAnQ2FtYmlvIGRlIGVzdGFkbyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTZW50IHJlcXVlc3RzJ30gICA9ICdFbnZpYXIgc29saWNpdHVkZXMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUmVjZWl2ZWQgc3VydmV5cyd9ICAgID0gJ1NvbGljaXR1ZGVzIHJlY2liaWRhcyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydhbnN3ZXJlZCd9ICAgICAgICAgID0gJ0NvbnRlc3RhZGFzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J25vdCBhbnN3ZXJlZCd9ICAgICAgPSAnTm8gY29udGVzdGFkYXMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5cyd9ICAgICAgICAgICA9ICdFbmN1ZXN0YXMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnSW52YWxpZCd9ICAgICAgICAgICA9ICdJbnbhbGlkYSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnRyb2R1Y3Rpb24nfSAgICAgID0gJ0ludHJvZHVjY2nzbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnRlcm5hbCd9ICAgICAgICAgID0gJ0ludGVybmEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb25zJ30gICAgICAgICA9ICdQcmVndW50YXMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb24nfSAgICAgICAgICA9ICdQcmVndW50YSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydQb3NpYmxlIEFuc3dlcnMnfSAgID0gJ1Bvc2libGVzIHJlc3B1ZXN0YXMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnWWVzTm8nfSAgICAgICAgICAgICA9ICdTaU5vJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0xpc3QnfSAgICAgICAgICAgICAgPSAnTGlzdGEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGV4dGFyZWEnfSAgICAgICAgICA9ICfBcmVhIGRlIHRleHRvJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0EgU3VydmV5IE1vZHVsZSd9ICAgPSAnTfNkdWxvIGRlIGVuY3Vlc3RhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBUaXRsZSBpcyByZXF1aXJlZCEnfSA9ICehU2UgcmVxdWllcmUgZWwgdO10dWxvIHBhcmEgbGEgZW5jdWVzdGEhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBJbnRyb2R1Y3Rpb24gaXMgcmVxdWlyZWQhJ30gPSAnoVNlIHJlcXVpZXJlIGxhIGludHJvZHVjY2nzbiBwYXJhIGxhIGVuY3Vlc3RhISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgRGVzY3JpcHRpb24gaXMgcmVxdWlyZWQhJ30gPSAnoVNlIHJlcXVpZXJlIGxhIGRlc2NyaXBjafNuIHBhcmEgbGEgZW5jdWVzdGEhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBOb3RpZmljYXRpb25TZW5kZXIgaXMgcmVxdWlyZWQhJ30gPSAnoVNlIHJlcXVpZXJlIGVsIHJlbWl0ZW50ZSBkZSBsYSBub3RpZmljYWNp824gcGFyYSBsYSBlbmN1ZXN0YSEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5IE5vdGlmaWNhdGlvblN1YmplY3QgaXMgcmVxdWlyZWQhJ30gPSAnoVNlIHJlcXVpZXJlIGVsIHRlbWEgZGUgbGEgbm90aWZpY2FjafNuIHBhcmEgbGEgZW5jdWVzdGEhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBOb3RpZmljYXRpb25Cb2R5IGlzIHJlcXVpcmVkISd9ID0gJ6FTZSByZXF1aWVyZSBlbCBjb250ZW5pZG8gZGUgbGEgbm90aWZpY2FjafNuIHBhcmEgbGEgZW5jdWVzdGEhJzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9lc19QdWJsaWNTdXJ2ZXkucG0gLSB0aGUgZXMgbGFuZ3VhZ2UgZm9yIFB1YmxpY1N1cnZleQojIENvcHlyaWdodCAoQykgMjAwMS0yMDEwIE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy8KIyAtLQojICRJZDogZXNfUHVibGljU3VydmV5LnBtLHYgMS4xIDIwMTAvMDgvMTggMDk6MTc6NDUgbWggRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZXNfUHVibGljU3VydmV5OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIHZhcnMgcXcoJFZFUlNJT04pOwokVkVSU0lPTiA9IHF3KCRSZXZpc2lvbjogMS4xICQpIFsxXTsKCnN1YiBEYXRhIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5J30gICAgPSAnRW5jdWVzdGEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb25zJ30gPSAnUHJlZ3VudGFzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1F1ZXN0aW9uJ30gID0gJ1ByZWd1bnRhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ZpbmlzaCd9ICAgID0gJ1Rlcm1pbmFyJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J05lZWQgdG8gc2VsZWN0IHF1ZXN0aW9uOid9ICA9ICdOZWNlc2l0YSBzZWxlY2Npb25hciB1bmEgcHJlZ3VudGE6JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J2ZpbmlzaGVkJ30gID0gJ1Rlcm1pbmFkbyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydUaGlzIFN1cnZleS1LZXkgaXMgaW52YWxpZCEnfSA9ICdFbCBj82RpZ28gZGUgZXN0YSBlbmN1ZXN0YSBlcyBpbnbhbGlkbyEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGhhbmsgeW91IGZvciB5b3VyIGZlZWRiYWNrLid9PSAnR3JhY2lhcyBwb3Igc3UgcmV0cm9hbGltZW50YWNp824uJzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9mcl9BZ2VudFN1cnZleS5wbSAtIHRoZSBmciBsYW5ndWFnZSBmb3IgQWdlbnRTdXJ2ZXkKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAwOSBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgLS0KIyAkSWQ6IGZyX0FnZW50U3VydmV5LnBtLHYgMS4xIDIwMDkvMTEvMjAgMTM6NDA6NTIgbWggRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZnJfQWdlbnRTdXJ2ZXk7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7Cgp1c2UgdmFycyBxdygkVkVSU0lPTik7CiRWRVJTSU9OID0gcXcoJFJldmlzaW9uOiAxLjEgJCkgWzFdOwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXknfSA9ICdTb25kYWdlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhblwndCBzZXQgbmV3IFN0YXR1cyEgTm8gUXVlc3Rpb24gZGVmaW5pZWQuJ30gPSAnSW1wb3NzaWJsZSBkXCfpdGFibGlyIHVuIG5vdXZlbCBldGF0ISBBdWN1bmUgcXVlc3Rpb24gblwnZXN0IGTpZmluaWUuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhblwndCBzZXQgbmV3IFN0YXR1cyEgUXVlc3Rpb24ocykgaW5jb21wbGV0ZS4nfSA9ICdJbXBvc3NpYmxlIGRcJ+l0YWJsaXIgdW4gbm91dmVsIOl0YXQhIFF1ZXN0aW9uKHMpIGluY29tcGzodGUocykuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J05ldyBTdGF0dXMgYWt0aXYhJ30gPSAnTm91dmVsIOl0YXQgYWN0aWYhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NoYW5nZSBTdGF0dXMnfSAgICAgPSAnTW9kaWZpZXIgbFwn6XRhdCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTZW5kZWQgUmVxdWVzdHMnfSAgID0gJ0Vudm95ZXIgbGVzIGRlbWFuZGVzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1JlY2VpdmVkIFZvdGVzJ30gICAgPSAnVm90ZXMgcmXndXMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnYW5zd2VyZWQnfSAgICAgICAgICA9ICdy6XBvbmR1JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J25vdCBhbnN3ZXJlZCd9ICAgICAgPSAncGFzIGRlIHLpcG9uc2UnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5cyd9ICAgICAgICAgICA9ICdFbnF16nRlcyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnZhbGlkJ30gICAgICAgICAgID0gJ0ludmFsaWRlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludHJvZHVjdGlvbid9ICAgICAgPSAnSW50cm9kdWN0aW9uJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludGVybmFsJ30gICAgICAgICAgPSAnSW50ZXJuZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSAgICAgICAgID0gJ1F1ZXN0aW9ucyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbid9ICAgICAgICAgID0gJ1F1ZXN0aW9uJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1Bvc2libGUgQW5zd2Vycyd9ICAgPSAnUulwb25zZXMgcG9zc2libGVzJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1llc05vJ30gICAgICAgICAgICAgPSAnT3VpTm9uJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0xpc3QnfSAgICAgICAgICAgICAgPSAnTGlzdGUnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGV4dGFyZWEnfSAgICAgICAgICA9ICdab25lIGRlIHRleHRlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0EgU3VydmV5IE1vZHVsZSd9ICAgPSAnVW4gbW9kdWxlIGRcJ2VucXXqdGUnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5IFRpdGxlIGlzIHJlcXVpcmVkISd9ID0gJ1VuIHRpdHJlIGRlIHNvbmRhZ2UgZXN0IG9ibGlnYXRvaXJlISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgSW50cm9kdWN0aW9uIGlzIHJlcXVpcmVkISd9ID0gJ0xcJ2ludHJvZHVjdGlvbiBkZSBsXCdlbnF16nRlIGVzdCBvYmxpZ2F0b2lyZSEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5IERlc2NyaXB0aW9uIGlzIHJlcXVpcmVkISd9ID0gJ1VuZSBkZXNjcmlwdGlvbiBkZSBsXCdlbnF16nRlIGVzdCBvYmxpZ2F0b2lyZSEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5IE5vdGlmaWNhdGlvblNlbmRlciBpcyByZXF1aXJlZCEnfSA9ICdVbiBleHDpZGl0ZXVyIGRvaXQg6nRyZSBk6WZpbmkhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBOb3RpZmljYXRpb25TdWJqZWN0IGlzIHJlcXVpcmVkISd9ID0gJ0xlIHN1amV0IGRvaXQg6nRyZSByZW1wbGkhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBOb3RpZmljYXRpb25Cb2R5IGlzIHJlcXVpcmVkISd9ID0gJ0lsIGZhdXQgcmVtcGxpciBsZSBjb3JwcyBkdSBtZXNzYWdlISc7CgogICAgcmV0dXJuIDE7Cn0KCjE7Cg==
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9mcl9QdWJsaWNTdXJ2ZXkucG0gLSB0aGUgZnIgbGFuZ3VhZ2UgZm9yIFB1YmxpY1N1cnZleQojIENvcHlyaWdodCAoQykgMjAwMS0yMDA5IE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy8KIyAtLQojICRJZDogZnJfUHVibGljU3VydmV5LnBtLHYgMS4xIDIwMDkvMTEvMjAgMTM6NDA6NTIgbWggRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6ZnJfUHVibGljU3VydmV5OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIHZhcnMgcXcoJFZFUlNJT04pOwokVkVSU0lPTiA9IHF3KCRSZXZpc2lvbjogMS4xICQpIFsxXTsKCnN1YiBEYXRhIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5J30gICAgPSAnUXVlc3Rpb25uYWlyZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSA9ICdRdWVzdGlvbnMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb24nfSAgPSAnUXVlc3Rpb24nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRmluaXNoJ30gICAgPSAnVGVybWluZXInOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnTmVlZCB0byBzZWxlY3QgcXVlc3Rpb246J30gID0gJ0xhIHF1ZXN0aW9uIHN1aXZhbnRlIGRvaXQg6nRyZSByZW1wbGllOic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydmaW5pc2hlZCd9ICA9ICd0ZXJtaW7pJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1RoaXMgU3VydmV5LUtleSBpcyBpbnZhbGlkISd9ID0gJ0xhIGNs6SBkdSBxdWVzdGlvbm5haXJlIGVzdCBpbnZhbGlkZSEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGhhbmsgeW91IGZvciB5b3VyIGZlZWRiYWNrLid9ID0gJ1ZvdXMgYXZleiB0ZXJtaW7pIGNldHRlIGVucXXqdGUuIE1lcmNpIGJlYXVjb3VwLic7CgogICAgcmV0dXJuIDE7Cn0KCjE7Cg==
77u/IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9ubF9BZ2VudFN1cnZleS5wbSAtIHRoZSBubCBsYW5ndWFnZSBmb3IgQWdlbnRTdXJ2ZXkKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxMCBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgLS0KIyAkSWQ6IG5sX0FnZW50U3VydmV5LnBtLHYgMS4zIDIwMTAvMDMvMDIgMDc6NTE6NDYgbWIgRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6bmxfQWdlbnRTdXJ2ZXk7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7Cgp1c2UgdmFycyBxdygkVkVSU0lPTik7CiRWRVJTSU9OID0gcXcoJFJldmlzaW9uOiAxLjMgJCkgWzFdOwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXknfSA9ICdFbnF16nRlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0NhblwndCBzZXQgbmV3IHN0YXR1cyEgTm8gcXVlc3Rpb25zIGRlZmluZWQuJ30KICAgICAgICA9ICdLYW4gc3RhdHVzIG5pZXQgYWFucGFzc2VuISBEZWZpbmllZXIgZWVyc3QgdnJhZ2VuIHZvb3IgZGV6ZSBlbnF16nRlLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDYW5cJ3Qgc2V0IG5ldyBzdGF0dXMhIFF1ZXN0aW9ucyBpbmNvbXBsZXRlLid9CiAgICAgICAgPSAnS2FuIHN0YXR1cyBuaWV0IGFhbnBhc3NlbiEgRXIgemlqbiBpbmNvbXBsZXRlIHZyYWdlbiBpbiBkZXplIGVucXXqdGUuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N0YXR1cyBjaGFuZ2VkLid9ID0gJ1N0YXR1cyBhYW5nZXBhc3QnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnQ2hhbmdlIFN0YXR1cyd9ICAgICA9ICdTdGF0dXMgYWFucGFzc2VuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1NlbnQgcmVxdWVzdHMnfSAgID0gJ1ZlcnpvbmRlbiBlbnF16nRlcyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydSZWNlaXZlZCBzdXJ2ZXlzJ30gICAgPSAnT250dmFuZ2VuIHN0ZW1tZW4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnYW5zd2VyZWQnfSAgICAgICAgICA9ICdiZWFudHdvb3JkJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J25vdCBhbnN3ZXJlZCd9ICAgICAgPSAnbmlldCBiZWFudHdvb3JkJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleXMnfSAgICAgICAgICAgPSAnRW5xdep0ZXMnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnSW52YWxpZCd9ICAgICAgICAgICA9ICdPbmdlbGRpZyc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnRyb2R1Y3Rpb24nfSAgICAgID0gJ0ludHJvZHVjdGllJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludGVybmFsJ30gICAgICAgICAgPSAnSW50ZXJuZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSAgICAgICAgID0gJ1ZyYWdlbic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbid9ICAgICAgICAgID0gJ1ZyYWFnJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1Bvc2libGUgQW5zd2Vycyd9ICAgPSAnTW9nZWxpamtlIGFudHdvb3JkZW4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnWWVzTm8nfSAgICAgICAgICAgICA9ICdqYS9uZWUnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnTGlzdCd9ICAgICAgICAgICAgICA9ICdPdmVyemljaHQnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVGV4dGFyZWEnfSAgICAgICAgICA9ICdWcmlqZSB0ZWtzdCc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydBIFN1cnZleSBNb2R1bGUnfSAgID0gJ0VlbiBlbnF16nRlLW1vZHVsZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgVGl0bGUgaXMgcmVxdWlyZWQhJ30KICAgICAgICA9ICdHZWVmIGVlbiB0aXRlbCBvcCB2b29yIGRlemUgZW5xdcOqdGUuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBJbnRyb2R1Y3Rpb24gaXMgcmVxdWlyZWQhJ30KICAgICAgICA9ICdNYWFrIGVlbiBpbnRyb2R1Y3RpZXRla3N0IHZvb3IgZGV6ZSBlbnF16nRlLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydTdXJ2ZXkgRGVzY3JpcHRpb24gaXMgcmVxdWlyZWQhJ30KICAgICAgICA9ICdHZWVmIGVlbiBvbXNjaHJpanZpbmcgb3Agdm9vciBkZXplIGVucXXqdGUhJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBOb3RpZmljYXRpb25TZW5kZXIgaXMgcmVxdWlyZWQhJ30KICAgICAgICA9ICdWdWwgZWVuIGFkcmVzIGluIHZvb3IgZGUgYWZ6ZW5kZXInOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5IE5vdGlmaWNhdGlvblN1YmplY3QgaXMgcmVxdWlyZWQhJ30KICAgICAgICA9ICdWdWwgZWVuIG9uZGVyd2VycCBpbiB2b29yIGRlIG5vdGlmaWNhdGllJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1N1cnZleSBOb3RpZmljYXRpb25Cb2R5IGlzIHJlcXVpcmVkISd9CiAgICAgICAgPSAnR2VlZiBlZW4gYmVyaWNodHRla3N0IG9wIHZvb3IgZGUgbm90aWZpY2F0aWUnOwoKICAgIHJldHVybiAxOwp9CgoxOwo=
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9ubF9QdWJsaWNTdXJ2ZXkucG0gLSB0aGUgRHV0Y2ggbGFuZ3VhZ2UgZm9yIFB1YmxpY1N1cnZleQojIENvcHlyaWdodCAoQykgMjAwMS0yMDEwIE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy8KIyAtLQojICRJZDogbmxfUHVibGljU3VydmV5LnBtLHYgMS4xIDIwMTAvMDIvMjIgMTE6NTU6MTIgbWIgRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6bmxfUHVibGljU3VydmV5OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIHZhcnMgcXcoJFZFUlNJT04pOwokVkVSU0lPTiA9IHF3KCRSZXZpc2lvbjogMS4xICQpIFsxXTsKCnN1YiBEYXRhIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5J30gICAgPSAnRW5xdep0ZSc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbnMnfSA9ICdWcmFnZW4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb24nfSAgPSAnVnJhYWcnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRmluaXNoJ30gICAgPSAnVm9sdG9vaWVuJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J2ZpbmlzaGVkJ30gID0gJ3ZvbHRvb2lkJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1RoaXMgU3VydmV5LUtleSBpcyBpbnZhbGlkISd9CiAgICAgICAgPSAnRGV6ZSBlbnF16nRlIGlzIG9uZ2VsZGlnLic7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydUaGFuayB5b3UgZm9yIHlvdXIgZmVlZGJhY2suJ30KICAgICAgICA9ICdCZWRhbmt0IHZvb3IgdXcgdGlqZC4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnTmVlZCB0byBzZWxlY3QgcXVlc3Rpb246J30gID0gJ1NlbGVjdGVlciBlZXJzdCBlZW4gdnJhYWc6JzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9ydV9BZ2VudFN1cnZleS5wbSAtIHRoZSBydSBsYW5ndWFnZSBmb3IgQWdlbnRTdXJ2ZXkKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxMCBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgLS0KIyAkSWQ6IHJ1X0FnZW50U3VydmV5LnBtLHYgMS4xIDIwMTAvMDIvMTIgMTA6NDI6MTUgbWggRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6cnVfQWdlbnRTdXJ2ZXk7Cgp1c2Ugc3RyaWN0Owp1c2Ugd2FybmluZ3M7Cgp1c2UgdmFycyBxdygkVkVSU0lPTik7CiRWRVJTSU9OID0gcXcoJFJldmlzaW9uOiAxLjEgJCkgWzFdOwoKc3ViIERhdGEgewogICAgbXkgJFNlbGYgPSBzaGlmdDsKCiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnRyb2R1Y3Rpb24nfSA9ICfC8fLz7+vl7ejlJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J0ludGVybmFsJ30gPSAnwu3z8vDl7e3l5Sc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydDaGFuZ2UgU3RhdHVzJ30gPSAnyOfs5e3o8vwg8fLg8vPxJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1NlbnQgcmVxdWVzdHMnfSA9ICfO8u/w4OLr5e3uIOfg7/Du8e7iJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1JlY2VpdmVkIHN1cnZleXMnfSA9ICfP7uvz9+Xt7iDu8uLl8u7iJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1NlbmQgVGltZSd9ID0gJ8Lw5ez/IO7y7/Dg4uroJzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J1ZvdGUgVGltZSd9ID0gJ8Lw5ez/IO7y4uXy4Cc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydEZXRhaWxzJ30gPSAnz+7k8O7h7e4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnTmV3J30gPSAnze7i++knOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnTWFzdGVyJ30gPSAnzvHt7uLt7uknOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnVmFsaWQnfSA9ICfE5enx8uLo8uXr/O376Sc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydJbnZhbGlkJ30gPSAnzeUg5OXp8fLi6PLl6/zt++knOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnYW5zd2VyZWQnfSA9ICfu8uLl8ujr6Cc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydub3QgYW5zd2VyZWQnfSA9ICft5SDu8uLl8ujr6Cc7CgogICAgcmV0dXJuIDE7Cn0KCjE7Cg==
IyAtLQojIEtlcm5lbC9MYW5ndWFnZS9ydV9QdWJsaWNTdXJ2ZXkucG0gLSB0aGUgcnUgbGFuZ3VhZ2UgZm9yIFB1YmxpY1N1cnZleQojIENvcHlyaWdodCAoQykgMjAwMS0yMDEwIE9UUlMgQUcsIGh0dHA6Ly9vdHJzLm9yZy8KIyAtLQojICRJZDogcnVfUHVibGljU3VydmV5LnBtLHYgMS4xIDIwMTAvMDIvMTIgMTA6NDI6MTUgbWggRXhwICQKIyAtLQojIFRoaXMgc29mdHdhcmUgY29tZXMgd2l0aCBBQlNPTFVURUxZIE5PIFdBUlJBTlRZLiBGb3IgZGV0YWlscywgc2VlCiMgdGhlIGVuY2xvc2VkIGZpbGUgQ09QWUlORyBmb3IgbGljZW5zZSBpbmZvcm1hdGlvbiAoQUdQTCkuIElmIHlvdQojIGRpZCBub3QgcmVjZWl2ZSB0aGlzIGZpbGUsIHNlZSBodHRwOi8vd3d3LmdudS5vcmcvbGljZW5zZXMvYWdwbC50eHQuCiMgLS0KCnBhY2thZ2UgS2VybmVsOjpMYW5ndWFnZTo6cnVfUHVibGljU3VydmV5OwoKdXNlIHN0cmljdDsKdXNlIHdhcm5pbmdzOwoKdXNlIHZhcnMgcXcoJFZFUlNJT04pOwokVkVSU0lPTiA9IHF3KCRSZXZpc2lvbjogMS4xICQpIFsxXTsKCnN1YiBEYXRhIHsKICAgIG15ICRTZWxmID0gc2hpZnQ7CgogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnU3VydmV5J30gICAgPSAnzu/w7vEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUXVlc3Rpb25zJ30gPSAnwu7v8O7x+yc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydRdWVzdGlvbid9ICA9ICfC7u/w7vEnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnUmVzZXQnfSAgICAgPSAnzvfo8fLo8vwnOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnRmluaXNoJ30gICAgPSAnzvLv8ODi6PL8JzsKICAgICRTZWxmLT57VHJhbnNsYXRpb259LT57J2ZpbmlzaGVkJ30gID0gJ+7y7/Dg4uvl7e4nOwogICAgJFNlbGYtPntUcmFuc2xhdGlvbn0tPnsnTmVlZCB0byBzZWxlY3QgcXVlc3Rpb246J30gICAgID0gJ8Tr/yDn4OLl8Pjl7ej/LCDt8+bt7iDu8uLl8ujy/CDt4CDi7u/w7vE6ICc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydUaGlzIFN1cnZleS1LZXkgaXMgaW52YWxpZCEnfSAgPSAnzvjo4e737fvpIOrr/vcg7u/w7vHgISc7CiAgICAkU2VsZi0+e1RyYW5zbGF0aW9ufS0+eydUaGFuayB5b3UgZm9yIHlvdXIgZmVlZGJhY2suJ30gPSAn0e/g8ejh7iDn4CDC4Pgg7vLn++IuJzsKCiAgICByZXR1cm4gMTsKfQoKMTsK
# --
# Kernel/Modules/AgentSurvey.pm - a survey module
# Copyright (C) 2001-2009 OTRS AG, http://otrs.org/
# --
# $Id: AgentSurvey.pm,v 1.37 2009/10/30 08:27:10 mb Exp $
# --
# 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::AgentSurvey;

use strict;
use warnings;

use Kernel::System::Survey;

use vars qw($VERSION);
$VERSION = qw($Revision: 1.37 $) [1];

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

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

    # get common objects
    %{$Self} = %Param;

    # check needed objects
    for my $Object (qw(ParamObject DBObject LayoutObject LogObject ConfigObject)) {
        if ( !$Self->{$Object} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $Object!" );
        }
    }
    $Self->{SurveyObject} = Kernel::System::Survey->new(%Param);

    return $Self;
}

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

    my $Output;

    # ------------------------------------------------------------ #
    # survey
    # ------------------------------------------------------------ #
    if ( $Self->{Subaction} eq 'Survey' ) {

        # get params
        my $SurveyID = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $Message  = $Self->{ParamObject}->GetParam( Param => "Message" );

        # check if survey exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }

        # output header
        $Output = $Self->{LayoutObject}->Header( Title => 'Survey' );
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # output mesages if status was changed
        if ( defined($Message) && $Message eq 'NoQuestion' ) {
            $Output .= $Self->{LayoutObject}->Notify(
                Priority => 'Error',
                Info     => 'Can\'t set new status! No questions defined.',
            );
        }
        elsif ( defined($Message) && $Message eq 'IncompleteQuestion' ) {
            $Output .= $Self->{LayoutObject}->Notify(
                Priority => 'Error',
                Info     => 'Can\'t set new status! Questions incomplete.',
            );
        }
        elsif ( defined($Message) && $Message eq 'StatusSet' ) {
            $Output .= $Self->{LayoutObject}->Notify(
                Priority => 'Notice',
                Info     => 'Status changed.',
            );
        }

        # get all attributes of the survey
        my %Survey = $Self->{SurveyObject}->SurveyGet( SurveyID => $SurveyID );

        # convert the textareas in html (\n --><br>)
        $Survey{Introduction} = $Self->{LayoutObject}->Ascii2Html(
            Text           => $Survey{Introduction},
            HTMLResultMode => 1,
        );
        $Survey{Description} = $Self->{LayoutObject}->Ascii2Html(
            Text           => $Survey{Description},
            HTMLResultMode => 1,
        );

        # get numbers of requests and votes
        my $SendRequest = $Self->{SurveyObject}->CountRequest(
            SurveyID => $SurveyID,
            ValidID  => 'all',
        );
        my $RequestComplete = $Self->{SurveyObject}->CountRequest(
            SurveyID => $SurveyID,
            ValidID  => 0,
        );
        $Survey{SendRequest}     = $SendRequest;
        $Survey{RequestComplete} = $RequestComplete;

        # get selected queues
        my %Queues = $Self->{QueueObject}->GetAllQueues();
        my @QueueList = map { $Queues{$_} } @{ $Survey{Queues} };
        @QueueList = sort { lc $a cmp lc $b } @QueueList;
        my $QueueListString = join q{, }, @QueueList;

        # print the main table.
        $Self->{LayoutObject}->Block(
            Name => 'Survey',
            Data => {
                %Survey,
                QueueListString => $QueueListString,
            },
        );

        # display stats if status Master, Valid or Invalid
        if (
            $Survey{Status}    eq 'Master'
            || $Survey{Status} eq 'Valid'
            || $Survey{Status} eq 'Invalid'
            )
        {
            $Self->{LayoutObject}->Block(
                Name => 'SurveyEditStats',
                Data => {
                    SurveyID => $SurveyID,
                },
            );

            # get all questions of the survey
            my @QuestionList = $Self->{SurveyObject}->QuestionList( SurveyID => $SurveyID );
            for my $Question (@QuestionList) {
                $Self->{LayoutObject}->Block(
                    Name => 'SurveyEditStatsQuestion',
                    Data => $Question,
                );
                my @Answers;

                # generate the answers of the question
                if (
                    $Question->{Type}    eq 'YesNo'
                    || $Question->{Type} eq 'Radio'
                    || $Question->{Type} eq 'Checkbox'
                    )
                {
                    my @AnswerList;

                    # set answers to Yes and No if type was YesNo
                    if ( $Question->{Type} eq 'YesNo' ) {
                        my %Data;
                        $Data{Answer}   = "Yes";
                        $Data{AnswerID} = "Yes";
                        push( @AnswerList, \%Data );
                        my %Data2;
                        $Data2{Answer}   = "No";
                        $Data2{AnswerID} = "No";
                        push( @AnswerList, \%Data2 );
                    }
                    else {

                        # get all answers of a question
                        @AnswerList = $Self->{SurveyObject}->AnswerList(
                            QuestionID => $Question->{QuestionID},
                        );
                    }
                    for my $Row (@AnswerList) {
                        my $CountVote = $Self->{SurveyObject}->CountVote(
                            QuestionID => $Question->{QuestionID},
                            VoteValue  => $Row->{AnswerID},
                        );
                        my $Percent = 0;

                        # calculate the percents
                        if ($RequestComplete) {
                            $Percent = 100 / $RequestComplete * $CountVote;
                            $Percent = sprintf( "%.0f", $Percent );
                        }
                        my %Data;
                        $Data{Answer}        = $Row->{Answer};
                        $Data{AnswerPercent} = $Percent;
                        push( @Answers, \%Data );
                    }
                }
                elsif ( $Question->{Type} eq 'Textarea' ) {
                    my $AnswerNo = $Self->{SurveyObject}->CountVote(
                        QuestionID => $Question->{QuestionID},
                        VoteValue  => '',
                    );
                    my $Percent = 0;

                    # calculate the percents
                    if ($RequestComplete) {
                        $Percent = 100 / $RequestComplete * $AnswerNo;
                        $Percent = sprintf( "%.0f", $Percent );
                    }
                    my %Data;
                    $Data{Answer} = "answered";
                    if ( !$RequestComplete ) {
                        $Data{AnswerPercent} = 0;
                    }
                    else {
                        $Data{AnswerPercent} = 100 - $Percent;
                    }
                    push( @Answers, \%Data );
                    my %Data2;
                    $Data2{Answer}        = "not answered";
                    $Data2{AnswerPercent} = $Percent;
                    push( @Answers, \%Data2 );
                }

                # output all answers of the survey
                for my $Row (@Answers) {
                    $Row->{AnswerPercentTable} = $Row->{AnswerPercent};
                    if ( !$Row->{AnswerPercent} ) {
                        $Row->{AnswerPercentTable} = 1;
                    }
                    $Self->{LayoutObject}->Block(
                        Name => 'SurveyEditStatsAnswer',
                        Data => $Row,
                    );
                }
            }
            if ($RequestComplete) {
                $Self->{LayoutObject}->Block(
                    Name => 'SurveyEditStatsDetails',
                    Data => { SurveyID => $SurveyID },
                );
            }
        }

        # output the possible status
        my %NewStatus;
        if ( $Survey{Status} eq 'New' || $Survey{Status} eq 'Invalid' ) {
            $NewStatus{Master} = 'Master';
            $NewStatus{Valid}  = 'Valid';
        }
        elsif ( $Survey{Status} eq 'Valid' ) {
            $NewStatus{Master}  = 'Master';
            $NewStatus{Invalid} = 'Invalid';
        }
        elsif ( $Survey{Status} eq 'Master' ) {
            $NewStatus{Valid}   = 'Valid';
            $NewStatus{Invalid} = 'Invalid';
        }
        my $NewStatusStr = $Self->{LayoutObject}->OptionStrgHashRef(
            Name => 'NewStatus',
            Data => \%NewStatus,
        );
        $Self->{LayoutObject}->Block(
            Name => 'SurveyStatus',
            Data => { NewStatusStr => $NewStatusStr },
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentSurvey',
            Data         => {%Param},
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }

    # ------------------------------------------------------------ #
    # survey status
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'SurveyStatus' ) {
        my $SurveyID  = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $NewStatus = $Self->{ParamObject}->GetParam( Param => "NewStatus" );

        # check if survey exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }

        # set a new status
        my $StatusSet = $Self->{SurveyObject}->SurveyStatusSet(
            SurveyID  => $SurveyID,
            NewStatus => $NewStatus,
        );
        my $Message = '';
        if ( defined($StatusSet) && $StatusSet eq 'NoQuestion' ) {
            $Message = '&Message=NoQuestion';
        }
        elsif ( defined($StatusSet) && $StatusSet eq 'IncompleteQuestion' ) {
            $Message = '&Message=IncompleteQuestion';
        }
        elsif ( defined($StatusSet) && $StatusSet eq 'StatusSet' ) {
            $Message = '&Message=StatusSet';
        }
        return $Self->{LayoutObject}->Redirect(
            OP => "Action=$Self->{Action}&Subaction=Survey&SurveyID=$SurveyID$Message",
        );
    }

    # ------------------------------------------------------------ #
    # survey edit
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'SurveyEdit' ) {
        my $SurveyID = $Self->{ParamObject}->GetParam( Param => "SurveyID" );

        # check if survey exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }

        # output header
        $Output = $Self->{LayoutObject}->Header( Title => 'Survey' );
        $Output .= $Self->{LayoutObject}->NavigationBar();
        my %Survey = $Self->{SurveyObject}->SurveyGet( SurveyID => $SurveyID );

        # build queue selection
        my %Queues      = $Self->{QueueObject}->GetAllQueues();
        my $QueueString = $Self->{LayoutObject}->BuildSelection(
            Data         => \%Queues,
            Name         => 'Queues',
            SelectedID   => $Survey{Queues},
            Size         => 6,
            Multiple     => 1,
            PossibleNone => 0,
            Sort         => 'AlphanumericValue',
            Translation  => 0,
        );

        # print the main table.
        $Self->{LayoutObject}->Block(
            Name => 'SurveyEdit',
            Data => {
                %Survey,
                QueueString => $QueueString,
            },
        );
        my @List = $Self->{SurveyObject}->QuestionList( SurveyID => $SurveyID );
        if ( $Survey{Status} eq 'New' ) {
            for my $Question (@List) {
                $Self->{LayoutObject}->Block(
                    Name => 'SurveyEditQuestions',
                    Data => $Question,
                );
                my $AnswerCount = $Self->{SurveyObject}->AnswerCount(
                    QuestionID => $Question->{QuestionID},
                );

                if ( $Question->{Type} eq 'Radio' || $Question->{Type} eq 'Checkbox' ) {
                    if ( $AnswerCount < 2 ) {
                        $Self->{LayoutObject}->Block(
                            Name => 'SurveyEditQuestionsIncomplete',
                            Data => $Question,
                        );
                    }
                    else {
                        $Self->{LayoutObject}->Block(
                            Name => 'SurveyEditQuestionsComplete',
                            Data => $Question,
                        );
                    }
                }
                else {
                    $Self->{LayoutObject}->Block(
                        Name => 'SurveyEditQuestionsComplete',
                        Data => $Question,
                    );
                }
            }
            $Self->{LayoutObject}->Block(
                Name => 'SurveyEditNewQuestion',
                Data => { SurveyID => $SurveyID },
            );
        }
        else {
            for my $Question (@List) {
                $Self->{LayoutObject}->Block(
                    Name => 'SurveyEditQuestionsValidOnce',
                    Data => $Question,
                );
            }
        }
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentSurvey',
            Data         => {%Param},
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }

    # ------------------------------------------------------------ #
    # survey save
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'SurveySave' ) {
        my $SurveyID            = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $Title               = $Self->{ParamObject}->GetParam( Param => "Title" );
        my $Introduction        = $Self->{ParamObject}->GetParam( Param => "Introduction" );
        my $Description         = $Self->{ParamObject}->GetParam( Param => "Description" );
        my $NotificationSender  = $Self->{ParamObject}->GetParam( Param => "NotificationSender" );
        my $NotificationSubject = $Self->{ParamObject}->GetParam( Param => "NotificationSubject" );
        my $NotificationBody    = $Self->{ParamObject}->GetParam( Param => "NotificationBody" );
        my @Queues = $Self->{ParamObject}->GetArray( Param => "Queues" );

        # check if survey exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        if (
            $Title
            && $Introduction
            && $Description
            && $NotificationSender
            && $NotificationSubject && $NotificationBody
            )
        {
            $Self->{SurveyObject}->SurveySave(
                SurveyID            => $SurveyID,
                Title               => $Title,
                Introduction        => $Introduction,
                Description         => $Description,
                NotificationSender  => $NotificationSender,
                NotificationSubject => $NotificationSubject,
                NotificationBody    => $NotificationBody,
                Queues              => \@Queues,
                UserID              => $Self->{UserID},
            );
            return $Self->{LayoutObject}->Redirect(
                OP => "Action=$Self->{Action}&Subaction=Survey&SurveyID=$SurveyID#Question"
            );
        }
        else {
            return $Self->{LayoutObject}->Redirect(
                OP => "Action=$Self->{Action}&Subaction=SurveyEdit&SurveyID=$SurveyID",
            );
        }
    }

    # ------------------------------------------------------------ #
    # survey add
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'SurveyAdd' ) {
        $Output = $Self->{LayoutObject}->Header( Title => 'Survey Add' );
        $Output .= $Self->{LayoutObject}->NavigationBar();

        my %Queues      = $Self->{QueueObject}->GetAllQueues();
        my $QueueString = $Self->{LayoutObject}->BuildSelection(
            Data         => \%Queues,
            Name         => 'Queues',
            Size         => 6,
            Multiple     => 1,
            PossibleNone => 0,
            Sort         => 'AlphanumericValue',
            Translation  => 0,
        );

        # print the main table.
        $Self->{LayoutObject}->Block(
            Name => 'SurveyAdd',
            Data => {
                QueueString         => $QueueString,
                NotificationSender  => $Self->{ConfigObject}->Get('Survey::NotificationSender'),
                NotificationSubject => $Self->{ConfigObject}->Get('Survey::NotificationSubject'),
                NotificationBody    => $Self->{ConfigObject}->Get('Survey::NotificationBody'),
            },
        );

        $Output .= $Self->{LayoutObject}->Output( TemplateFile => 'AgentSurvey' );
        $Output .= $Self->{LayoutObject}->Footer();

        return $Output;
    }

    # ------------------------------------------------------------ #
    # survey new
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'SurveyNew' ) {
        my $Title              = $Self->{ParamObject}->GetParam( Param => "Title" );
        my $Introduction       = $Self->{ParamObject}->GetParam( Param => "Introduction" );
        my $Description        = $Self->{ParamObject}->GetParam( Param => "Description" );
        my $NotificationSender = $Self->{ParamObject}->GetParam( Param => "NotificationSender" )
            || '';
        my $NotificationSubject = $Self->{ParamObject}->GetParam( Param => "NotificationSubject" );
        my $NotificationBody    = $Self->{ParamObject}->GetParam( Param => "NotificationBody" );
        my @Queues = $Self->{ParamObject}->GetArray( Param => "Queues" );

        if (
            $Title
            && $Introduction
            && $Description
            && $NotificationSender && $NotificationSubject && $NotificationBody
            )
        {

            my $SurveyID = $Self->{SurveyObject}->SurveyNew(
                Title               => $Title,
                Introduction        => $Introduction,
                Description         => $Description,
                NotificationSender  => $NotificationSender,
                NotificationSubject => $NotificationSubject,
                NotificationBody    => $NotificationBody,
                Queues              => \@Queues,
                UserID              => $Self->{UserID},
            );

            return $Self->{LayoutObject}->Redirect(
                OP => "Action=$Self->{Action}&Subaction=Survey&SurveyID=$SurveyID",
            );
        }

        return $Self->{LayoutObject}->Redirect(
            OP => "Action=$Self->{Action}&Subaction=SurveyAdd",
        );
    }

    # ------------------------------------------------------------ #
    # question add
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'QuestionAdd' ) {
        my $SurveyID = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $Question = $Self->{ParamObject}->GetParam( Param => "Question" );
        my $Type     = $Self->{ParamObject}->GetParam( Param => "Type" );

        # check if survey exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        if ($Question) {
            $Self->{SurveyObject}->QuestionAdd(
                SurveyID => $SurveyID,
                Question => $Question,
                Type     => $Type,
                UserID   => $Self->{UserID},
            );
            $Self->{SurveyObject}->QuestionSort( SurveyID => $SurveyID );
        }
        return $Self->{LayoutObject}->Redirect(
            OP => "Action=$Self->{Action}&Subaction=SurveyEdit&SurveyID=$SurveyID#NewQuestion"
        );
    }

    # ------------------------------------------------------------ #
    # question delete
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'QuestionDelete' ) {
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );

        # check if survey and question exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Self->{SurveyObject}->QuestionDelete(
            SurveyID   => $SurveyID,
            QuestionID => $QuestionID,
        );
        $Self->{SurveyObject}->QuestionSort( SurveyID => $SurveyID );
        return $Self->{LayoutObject}->Redirect(
            OP => "Action=$Self->{Action}&Subaction=SurveyEdit&SurveyID=$SurveyID#Question"
        );
    }

    # ------------------------------------------------------------ #
    # question up
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'QuestionUp' ) {
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );

        # check if survey and question exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Self->{SurveyObject}->QuestionSort( SurveyID => $SurveyID );
        $Self->{SurveyObject}->QuestionUp(
            SurveyID   => $SurveyID,
            QuestionID => $QuestionID,
        );
        return $Self->{LayoutObject}->Redirect(
            OP => "Action=$Self->{Action}&Subaction=SurveyEdit&SurveyID=$SurveyID#Question"
        );
    }

    # ------------------------------------------------------------ #
    # question down
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'QuestionDown' ) {
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );

        # check if survey and question exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Self->{SurveyObject}->QuestionSort( SurveyID => $SurveyID );
        $Self->{SurveyObject}->QuestionDown(
            SurveyID   => $SurveyID,
            QuestionID => $QuestionID,
        );
        return $Self->{LayoutObject}->Redirect(
            OP => "Action=$Self->{Action}&Subaction=SurveyEdit&SurveyID=$SurveyID#Question"
        );
    }

    # ------------------------------------------------------------ #
    # question edit
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'QuestionEdit' ) {
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );

        # check if survey and question exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }

        # output header
        $Output = $Self->{LayoutObject}->Header( Title => 'Question Edit' );
        $Output .= $Self->{LayoutObject}->NavigationBar();
        my %Survey = $Self->{SurveyObject}->SurveyGet( SurveyID => $SurveyID );
        my %Question = $Self->{SurveyObject}->QuestionGet( QuestionID => $QuestionID );

        # print the main table.
        $Self->{LayoutObject}->Block(
            Name => 'QuestionEdit',
            Data => {%Question},
        );
        if ( $Question{Type} eq 'YesNo' ) {
            $Self->{LayoutObject}->Block( Name => 'QuestionEdit1' );
        }
        elsif ( $Question{Type} eq 'Radio' ) {
            my @List = $Self->{SurveyObject}->AnswerList( QuestionID => $QuestionID );
            if ( $Survey{Status} eq 'New' ) {
                for my $Answer2 (@List) {
                    $Answer2->{SurveyID} = $SurveyID;
                    $Self->{LayoutObject}->Block(
                        Name => 'QuestionEdit2',
                        Data => $Answer2,
                    );
                }
                $Self->{LayoutObject}->Block(
                    Name => 'QuestionEdit2b',
                    Data => {%Question},
                );
            }
            else {
                for my $Answer2 (@List) {
                    $Answer2->{SurveyID} = $SurveyID;
                    $Self->{LayoutObject}->Block(
                        Name => 'QuestionEdit2ValidOnce',
                        Data => $Answer2,
                    );
                }
            }
        }
        elsif ( $Question{Type} eq 'Checkbox' ) {
            my @List = $Self->{SurveyObject}->AnswerList( QuestionID => $QuestionID );
            if ( $Survey{Status} eq 'New' ) {
                for my $Answer3 (@List) {
                    $Answer3->{SurveyID} = $SurveyID;
                    $Self->{LayoutObject}->Block(
                        Name => 'QuestionEdit3',
                        Data => $Answer3,
                    );
                }
                $Self->{LayoutObject}->Block(
                    Name => 'QuestionEdit3b',
                    Data => {%Question},
                );
            }
            else {
                for my $Answer3 (@List) {
                    $Answer3->{SurveyID} = $SurveyID;
                    $Self->{LayoutObject}->Block(
                        Name => 'QuestionEdit3ValidOnce',
                        Data => $Answer3,
                    );
                }
            }
        }
        elsif ( $Question{Type} eq 'Textarea' ) {
            $Self->{LayoutObject}->Block( Name => 'QuestionEdit4' );
        }
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentSurvey',
            Data         => {%Param},
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }

    # ------------------------------------------------------------ #
    # question save
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'QuestionSave' ) {
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $Question   = $Self->{ParamObject}->GetParam( Param => "Question" );

        # check if survey and question exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        if ($Question) {
            $Self->{SurveyObject}->QuestionSave(
                QuestionID => $QuestionID,
                SurveyID   => $SurveyID,
                Question   => $Question,
                UserID     => $Self->{UserID},
            );
            return $Self->{LayoutObject}->Redirect(
                OP => "Action=$Self->{Action}&Subaction=SurveyEdit&SurveyID=$SurveyID#Question"
            );
        }
        else {
            return $Self->{LayoutObject}->Redirect(
                OP =>
                    "Action=$Self->{Action}&Subaction=QuestionEdit&SurveyID=$SurveyID&QuestionID=$QuestionID",
            );
        }
    }

    # ------------------------------------------------------------ #
    # answer add
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'AnswerAdd' ) {
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $Answer     = $Self->{ParamObject}->GetParam( Param => "Answer" );

        # check if survey and question exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        if ($Answer) {
            $Self->{SurveyObject}->AnswerAdd(
                SurveyID   => $SurveyID,
                QuestionID => $QuestionID,
                Answer     => $Answer,
                UserID     => $Self->{UserID},
            );
            $Self->{SurveyObject}->AnswerSort( QuestionID => $QuestionID );
        }
        return $Self->{LayoutObject}->Redirect(
            OP =>
                "Action=$Self->{Action}&Subaction=QuestionEdit&SurveyID=$SurveyID&QuestionID=$QuestionID#NewAnswer",
        );
    }

    # ------------------------------------------------------------ #
    # answer delete
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'AnswerDelete' ) {
        my $AnswerID   = $Self->{ParamObject}->GetParam( Param => "AnswerID" );
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );

        # check if survey, question and answer exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            || $Self->{SurveyObject}->ElementExists( ElementID => $AnswerID, Element => 'Answer' )
            ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Self->{SurveyObject}->AnswerDelete(
            QuestionID => $QuestionID,
            AnswerID   => $AnswerID,
        );
        $Self->{SurveyObject}->AnswerSort( QuestionID => $QuestionID );
        return $Self->{LayoutObject}->Redirect(
            OP =>
                "Action=$Self->{Action}&Subaction=QuestionEdit&SurveyID=$SurveyID&QuestionID=$QuestionID#Answer",
        );
    }

    # ------------------------------------------------------------ #
    # answer up
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'AnswerUp' ) {
        my $AnswerID   = $Self->{ParamObject}->GetParam( Param => "AnswerID" );
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );

        # check if survey, question and answer exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            || $Self->{SurveyObject}->ElementExists( ElementID => $AnswerID, Element => 'Answer' )
            ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Self->{SurveyObject}->AnswerSort( QuestionID => $QuestionID );
        $Self->{SurveyObject}->AnswerUp(
            QuestionID => $QuestionID,
            AnswerID   => $AnswerID,
        );
        return $Self->{LayoutObject}->Redirect(
            OP =>
                "Action=$Self->{Action}&Subaction=QuestionEdit&SurveyID=$SurveyID&QuestionID=$QuestionID#Answer",
        );
    }

    # ------------------------------------------------------------ #
    # answer down
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'AnswerDown' ) {
        my $AnswerID   = $Self->{ParamObject}->GetParam( Param => "AnswerID" );
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );

        # check if survey, question and answer exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            || $Self->{SurveyObject}->ElementExists( ElementID => $AnswerID, Element => 'Answer' )
            ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Self->{SurveyObject}->AnswerSort( QuestionID => $QuestionID );
        $Self->{SurveyObject}->AnswerDown(
            QuestionID => $QuestionID,
            AnswerID   => $AnswerID,
        );
        return $Self->{LayoutObject}->Redirect(
            OP =>
                "Action=$Self->{Action}&Subaction=QuestionEdit&SurveyID=$SurveyID&QuestionID=$QuestionID#Answer",
        );
    }

    # ------------------------------------------------------------ #
    # answer edit
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'AnswerEdit' ) {
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $AnswerID   = $Self->{ParamObject}->GetParam( Param => "AnswerID" );

        # check if survey, question and answer exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            || $Self->{SurveyObject}->ElementExists( ElementID => $AnswerID, Element => 'Answer' )
            ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Output = $Self->{LayoutObject}->Header( Title => 'Answer Edit' );
        $Output .= $Self->{LayoutObject}->NavigationBar();
        my %Answer = $Self->{SurveyObject}->AnswerGet( AnswerID => $AnswerID );
        $Answer{SurveyID} = $SurveyID;

        # print the main table.
        $Self->{LayoutObject}->Block(
            Name => 'AnswerEdit',
            Data => {%Answer},
        );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentSurvey',
            Data         => {%Param},
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }

    # ------------------------------------------------------------ #
    # answer save
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'AnswerSave' ) {
        my $AnswerID   = $Self->{ParamObject}->GetParam( Param => "AnswerID" );
        my $QuestionID = $Self->{ParamObject}->GetParam( Param => "QuestionID" );
        my $SurveyID   = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $Answer     = $Self->{ParamObject}->GetParam( Param => "Answer" );

        # check if survey, question and answer exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists(
                ElementID => $QuestionID,
                Element   => 'Question'
            ) ne 'Yes'
            || $Self->{SurveyObject}->ElementExists( ElementID => $AnswerID, Element => 'Answer' )
            ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        if ($Answer) {
            $Self->{SurveyObject}->AnswerSave(
                AnswerID   => $AnswerID,
                QuestionID => $QuestionID,
                Answer     => $Answer,
                UserID     => $Self->{UserID},
            );
            return $Self->{LayoutObject}->Redirect(
                OP =>
                    "Action=$Self->{Action}&Subaction=QuestionEdit&SurveyID=$SurveyID&QuestionID=$QuestionID#Answer"
            );
        }
        else {
            return $Self->{LayoutObject}->Redirect(
                OP =>
                    "Action=$Self->{Action}&Subaction=AnswerEdit&SurveyID=$SurveyID&QuestionID=$QuestionID&AnswerID=$AnswerID"
            );
        }
    }

    # ------------------------------------------------------------ #
    # stats
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'Stats' ) {
        my $SurveyID = $Self->{ParamObject}->GetParam( Param => "SurveyID" );

        # check if survey exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Output = $Self->{LayoutObject}->Header( Title => 'Stats Overview' );
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # print the main table.
        $Self->{LayoutObject}->Block(
            Name => 'Stats',
            Data => { SurveyID => $SurveyID },
        );
        my @List = $Self->{SurveyObject}->VoteList( SurveyID => $SurveyID );
        for my $Vote (@List) {
            $Vote->{SurveyID} = $SurveyID;
            my %Ticket = $Self->{TicketObject}->TicketGet( TicketID => $Vote->{TicketID} );
            $Vote->{TicketNumber} = $Ticket{TicketNumber};
            $Self->{LayoutObject}->Block(
                Name => 'StatsVote',
                Data => $Vote,
            );
        }
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentSurvey',
            Data         => {%Param},
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }

    # ------------------------------------------------------------ #
    # state detail
    # ------------------------------------------------------------ #
    elsif ( $Self->{Subaction} eq 'StatsDetail' ) {
        my $SurveyID  = $Self->{ParamObject}->GetParam( Param => "SurveyID" );
        my $RequestID = $Self->{ParamObject}->GetParam( Param => "RequestID" );

        # check if survey exists
        if (
            $Self->{SurveyObject}->ElementExists( ElementID => $SurveyID, Element => 'Survey' ) ne
            'Yes'
            || $Self->{SurveyObject}->ElementExists( ElementID => $RequestID, Element => 'Request' )
            ne 'Yes'
            )
        {
            return $Self->{LayoutObject}->Redirect( OP => "Action=$Self->{Action}" );
        }
        $Output = $Self->{LayoutObject}->Header( Title => 'Stats Detail' );
        $Output .= $Self->{LayoutObject}->NavigationBar();

        # print the main table.
        $Self->{LayoutObject}->Block(
            Name => 'StatsDetail',
            Data => { SurveyID => $SurveyID },
        );
        my @QuestionList = $Self->{SurveyObject}->QuestionList( SurveyID => $SurveyID );
        for my $Question (@QuestionList) {
            $Self->{LayoutObject}->Block(
                Name => 'StatsDetailQuestion',
                Data => $Question,
            );
            my @Answers;
            if ( $Question->{Type} eq 'Radio' || $Question->{Type} eq 'Checkbox' ) {
                my @AnswerList;
                @AnswerList = $Self->{SurveyObject}->VoteGet(
                    RequestID  => $RequestID,
                    QuestionID => $Question->{QuestionID},
                );
                for my $Row (@AnswerList) {
                    my %Answer = $Self->{SurveyObject}->AnswerGet( AnswerID => $Row->{VoteValue} );
                    my %Data;
                    $Data{Answer} = $Answer{Answer};
                    push( @Answers, \%Data );
                }
            }
            elsif ( $Question->{Type} eq 'YesNo' || $Question->{Type} eq 'Textarea' ) {
                my @List = $Self->{SurveyObject}->VoteGet(
                    RequestID  => $RequestID,
                    QuestionID => $Question->{QuestionID},
                );
                my %Data;
                $Data{Answer} = $List[0]->{VoteValue};
                push( @Answers, \%Data );
            }
            for my $Row (@Answers) {
                $Self->{LayoutObject}->Block(
                    Name => 'StatsDetailAnswer',
                    Data => $Row,
                );
            }
        }
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'AgentSurvey',
            Data         => {%Param},
        );
        $Output .= $Self->{LayoutObject}->Footer();
        return $Output;
    }

    # ------------------------------------------------------------ #
    # show overview
    # ------------------------------------------------------------ #
    $Output = $Self->{LayoutObject}->Header( Title => 'Overview' );
    $Output .= $Self->{LayoutObject}->NavigationBar();

    # print the main table.
    $Self->{LayoutObject}->Block( Name => 'Overview' );
    my @List = $Self->{SurveyObject}->SurveyList();
    for my $SurveyID (@List) {

        # set output class
        if ( $Param{Class} && $Param{Class} eq 'searchpassive' ) {
            $Param{Class} = 'searchactive';
        }
        else {
            $Param{Class} = 'searchpassive';
        }
        my %Survey = $Self->{SurveyObject}->SurveyGet( SurveyID => $SurveyID );
        $Self->{LayoutObject}->Block(
            Name => 'OverviewSurvey',
            Data => { %Survey, %Param },
        );
    }
    $Output .= $Self->{LayoutObject}->Output(
        TemplateFile => 'AgentSurvey',
        Data         => {%Param},
    );
    $Output .= $Self->{LayoutObject}->Footer();
    return $Output;
}

1;

# --
# Kernel/Modules/PublicSurvey.pm - a survey module
# Copyright (C) 2001-2009 OTRS AG, http://otrs.org/
# --
# $Id: PublicSurvey.pm,v 1.19 2009/04/02 16:22:19 mh Exp $
# --
# 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::PublicSurvey;

use strict;
use warnings;

use Kernel::System::Survey;

use vars qw($VERSION);
$VERSION = qw($Revision: 1.19 $) [1];

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

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

    # get common objects
    %{$Self} = %Param;

    # check needed objects
    for my $Object (qw(ParamObject DBObject LayoutObject LogObject ConfigObject UserObject)) {
        if ( !$Self->{$Object} ) {
            $Self->{LayoutObject}->FatalError( Message => "Got no $Object!" );
        }
    }
    $Self->{SurveyObject} = Kernel::System::Survey->new(%Param);

    return $Self;
}

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

    my $Output;

    # ------------------------------------------------------------ #
    # public survey vote
    # ------------------------------------------------------------ #
    if ( $Self->{Subaction} eq 'PublicSurveyVote' ) {
        my $PublicSurveyKey = $Self->{ParamObject}->GetParam( Param => 'PublicSurveyKey' );
        my %Survey = $Self->{SurveyObject}->PublicSurveyGet( PublicSurveyKey => $PublicSurveyKey );
        if ( $Survey{SurveyID} ) {
            my @QuestionList = $Self->{SurveyObject}->QuestionList( SurveyID => $Survey{SurveyID} );
            for my $Question (@QuestionList) {
                if ( $Question->{Type} eq 'YesNo' ) {
                    my $PublicSurveyVote1 = $Self->{ParamObject}->GetParam(
                        Param => "PublicSurveyVote1[$Question->{QuestionID}]"
                    );
                    $Self->{SurveyObject}->PublicAnswerSave(
                        PublicSurveyKey => $PublicSurveyKey,
                        QuestionID      => $Question->{QuestionID},
                        VoteValue       => $PublicSurveyVote1,
                    );
                }
                elsif ( $Question->{Type} eq 'Radio' ) {
                    my $PublicSurveyVote2 = $Self->{ParamObject}->GetParam(
                        Param => "PublicSurveyVote2[$Question->{QuestionID}]"
                    );
                    $Self->{SurveyObject}->PublicAnswerSave(
                        PublicSurveyKey => $PublicSurveyKey,
                        QuestionID      => $Question->{QuestionID},
                        VoteValue       => $PublicSurveyVote2,
                    );
                }
                elsif ( $Question->{Type} eq 'Checkbox' ) {
                    my @AnswerList = $Self->{SurveyObject}->AnswerList(
                        QuestionID => $Question->{QuestionID}
                    );
                    for my $Answer (@AnswerList) {
                        my $PublicSurveyVote3 = $Self->{ParamObject}->GetParam(
                            Param => "PublicSurveyVote3[$Answer->{AnswerID}]"
                        );
                        if ( $PublicSurveyVote3 && $PublicSurveyVote3 eq 'Yes' ) {
                            $Self->{SurveyObject}->PublicAnswerSave(
                                PublicSurveyKey => $PublicSurveyKey,
                                QuestionID      => $Question->{QuestionID},
                                VoteValue       => $Answer->{AnswerID},
                            );
                        }
                    }
                }
                elsif ( $Question->{Type} eq 'Textarea' ) {
                    my $PublicSurveyVote4 = $Self->{ParamObject}->GetParam(
                        Param => "PublicSurveyVote4[$Question->{QuestionID}]"
                    );
                    $Self->{SurveyObject}->PublicAnswerSave(
                        PublicSurveyKey => $PublicSurveyKey,
                        QuestionID      => $Question->{QuestionID},
                        VoteValue       => $PublicSurveyVote4,
                    );
                }
            }
            $Self->{SurveyObject}->PublicSurveyInvalidSet( PublicSurveyKey => $PublicSurveyKey );
        }
        $Output = $Self->{LayoutObject}->CustomerHeader( Title => 'Survey' );

        # print the main table.
        $Self->{LayoutObject}->Block( Name => 'PublicSurveyComplete' );
        $Output .= $Self->{LayoutObject}->Output(
            TemplateFile => 'PublicSurvey',
            Data         => {%Param},
        );
        $Output .= $Self->{LayoutObject}->CustomerFooter();
        return $Output;
    }

    # ------------------------------------------------------------ #
    # show survey
    # ------------------------------------------------------------ #
    my $PublicSurveyKey = $Self->{ParamObject}->GetParam( Param => 'PublicSurveyKey' );
    $Output = $Self->{LayoutObject}->CustomerHeader( Title => 'Survey' );
    my %Survey = $Self->{SurveyObject}->PublicSurveyGet( PublicSurveyKey => $PublicSurveyKey );
    $Survey{Introduction} = $Self->{LayoutObject}->Ascii2Html(
        Text           => $Survey{Introduction},
        HTMLResultMode => 1,
    );
    $Survey{PublicSurveyKey} = $PublicSurveyKey;
    if ( $Survey{SurveyID} > 0 ) {
        $Self->{LayoutObject}->Block(
            Name => 'PublicSurvey',
            Data => {%Survey},
        );
        my @QuestionList = $Self->{SurveyObject}->QuestionList( SurveyID => $Survey{SurveyID} );
        for my $Question (@QuestionList) {
            $Self->{LayoutObject}->Block( Name => 'PublicQuestions' );
            if ( $Question->{Type} eq 'YesNo' ) {
                $Self->{LayoutObject}->Block(
                    Name => 'PublicAnswerYesNo',
                    Data => $Question,
                );
            }
            elsif ( $Question->{Type} eq 'Radio' ) {
                $Self->{LayoutObject}->Block(
                    Name => 'PublicAnswerRadio',
                    Data => $Question,
                );
                my @AnswerList = $Self->{SurveyObject}->AnswerList(
                    QuestionID => $Question->{QuestionID},
                );
                for my $Answer (@AnswerList) {
                    $Self->{LayoutObject}->Block(
                        Name => 'PublicAnswerRadiob',
                        Data => $Answer,
                    );
                }
            }
            elsif ( $Question->{Type} eq 'Checkbox' ) {
                $Self->{LayoutObject}->Block(
                    Name => 'PublicAnswerCheckbox',
                    Data => $Question,
                );
                my @AnswerList = $Self->{SurveyObject}->AnswerList(
                    QuestionID => $Question->{QuestionID},
                );
                for my $Answer (@AnswerList) {
                    $Self->{LayoutObject}->Block(
                        Name => 'PublicAnswerCheckboxb',
                        Data => $Answer,
                    );
                }
            }
            elsif ( $Question->{Type} eq 'Textarea' ) {
                $Self->{LayoutObject}->Block(
                    Name => 'PublicAnswerTextarea',
                    Data => $Question,
                );
            }
        }
    }
    else {
        $Self->{LayoutObject}->Block( Name => 'PublicNoSurvey' );
    }
    $Output .= $Self->{LayoutObject}->Output(
        TemplateFile => 'PublicSurvey',
        Data         => {%Param},
    );
    $Output .= $Self->{LayoutObject}->CustomerFooter();
    return $Output;
}

1;

# --
# AgentSurvey.dtl - provides HTML form for AgentSurvey
# Copyright (C) 2001-2010 OTRS AG, http://otrs.org/
# --
# $Id: AgentSurvey.dtl,v 1.35 2010/04/27 13:05:42 mh Exp $
# --
# 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.
# --

<script language="JavaScript" type="text/javascript">
<!--
function submit_survey() {
    if (document.Survey.Title.value == "") {
        alert('$JSText{"Survey Title is required!"}');
        document.Survey.Title.focus();
        return false;
    }
    else if (document.Survey.Introduction.value == "") {
        alert('$JSText{"Survey Introduction is required!"}');
        document.Survey.Introduction.focus();
        return false;
    }
    else if (document.Survey.Description.value == "") {
        alert('$JSText{"Survey Description is required!"}');
        document.Survey.Description.focus();
        return false;
    }
    else if (document.Survey.NotificationSender.value == "") {
        alert('$JSText{"Survey NotificationSender is required!"}');
        document.Survey.NotificationSender.focus();
        return false;
    }
    else if (document.Survey.NotificationSubject.value == "") {
        alert('$JSText{"Survey NotificationSubject is required!"}');
        document.Survey.NotificationSubject.focus();
        return false;
    }
    else if (document.Survey.NotificationBody.value == "") {
        alert('$JSText{"Survey NotificationBody is required!"}');
        document.Survey.NotificationBody.focus();
        return false;
    }
    else {
        return true;
    }
}
//-->
</script>

<!-- dtl:block:Overview -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
    <tr>
        <td class="mainhead">
            $Env{"Box0"}$Text{"Overview"}: $Text{"Survey"}$Env{"Box1"}
        </td>
    </tr>
    <tr>
        <td class="mainbody" align="center">
            <br>
            <table border="0" width="800" cellspacing="0" cellpadding="3">
                <tr class="contenthead">
                    <td class="contentkey" width="3%">&nbsp;</td>
                    <td class="contentkey">$Text{"Number"}</td>
                    <td class="contentkey">$Text{"Title"}</td>
                    <td class="contentkey">$Text{"Status"}</td>
                    <td class="contentkey" width="18%">$Text{"Created"}</td>
                </tr>
<!-- dtl:block:OverviewSurvey -->
                <tr class="contentbody">
                    <td class="$QData{"Class"}">&nbsp;</td>
                    <td class="$QData{"Class"}">
                        <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=Survey&SurveyID=$QData{"SurveyID"}">$QData{"SurveyNumber"}</a>
                    </td>
                    <td class="$QData{"Class"}">$QData{"Title","60"}</td>
                    <td class="$QData{"Class"}">$Text{"$QData{"Status"}"}</td>
                    <td class="$QData{"Class"}">$TimeLong{"$QData{"CreateTime"}"}</td>
                </tr>
<!-- dtl:block:OverviewSurvey -->
                <tr class="contentfooter">
                    <td colspan="5">&nbsp;</td>
                </tr>
            </table>
            <br>
        </td>
    </tr>
</table>
<!-- dtl:block:Overview -->
<!-- dtl:block:Survey -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
    <tr>
        <td class="mainhead">
            $Env{"Box0"}$Text{"View"}: $Text{"Survey"}$Env{"Box1"}
        </td>
        <td class="mainhead">&nbsp;</td>
    </tr>
    <tr>
        <td class="menu">
            <a href="$Env{"Baselink"}Action=$Env{"Action"}">$Text{"Back"}</a>
<!-- dtl:block:SurveyEditStatsDetails -->
            -&nbsp;<a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=Stats&SurveyID=$QData{"SurveyID"}">$Text{"Stats"}</a>
<!-- dtl:block:SurveyEditStatsDetails -->
        </td>
        <td class="menu">&nbsp;</td>
    </tr>
    <tr>
        <td class="mainbody">
            <br>
            <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                <tr>
                    <td colspan="4" class="contenthead">
                        <table border="0" width="100%" cellspacing="0" cellpadding="0">
                            <tr>
                                <td class="contenthead">$Text{"Survey"}</td>
                            </tr>
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentbody">
                        <table border="0" width="100%">
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey" width="25%">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">$Text{"Number"}:</td>
                                <td class="contentvalue">$QData{"SurveyNumber"}</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">$Text{"Title"}:</td>
                                <td class="contentvalue">$QData{"Title"}</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">$Text{"Introduction"}:</td>
                                <td class="contentvalue">$Data{"Introduction"}</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">$Text{"Queues"}:</td>
                                <td class="contentvalue">$Data{"QueueListString"}</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">$Text{"Internal"}&nbsp;$Text{"Description"}:</td>
                                <td class="contentvalue">$Data{"Description"}</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey" width="25%">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentfooter">
                        <table border="0" align="right" cellspacing="0" cellpadding="0">
                            <tr>
                                <td>
                                    <form action="$Env{"CGIHandle"}" method="post">
                                        <input type="hidden" name="Action" value="$Env{"Action"}">
                                        <input type="hidden" name="Subaction" value="SurveyEdit">
                                        <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                                        <input class="button" type="submit" value="$Text{"Edit"}">
                                    </form>
                                </td>
                            </tr>
                        </table>
                    </td>
                </tr>
            </table>
            <br>
<!-- dtl:block:SurveyEditStats -->
            <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                <tr>
                    <td colspan="4" class="contenthead">$Text{"Stats"} $Text{"Overview"}
                    </td>
                </tr>
                <tr>
                    <td class="contentbody">
                        <table border="0" width="100%">
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
<!-- dtl:block:SurveyEditStatsQuestion -->
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">$QData{"Question","100"}</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">
                                    <table border="0" width="100%" cellspacing="0">
<!-- dtl:block:SurveyEditStatsAnswer -->
                                        <tr>
                                            <td width="50" class="contentkey" align="right">
                                                &nbsp;
                                            </td>
                                            <td class="contentvalue">$Text{"$Data{"Answer"}"}</td>
                                            <td class="contentkey" width="110">
                                                <table border="0" width="100" cellspacing="0" cellpadding="0">
                                                    <tr>
                                                        <td width="$QData{"AnswerPercentTable"}%" bgcolor="#008000">&nbsp;</td>
                                                        <td bordercolor="#DDDDDD">&nbsp;</td>
                                                    </tr>
                                                </table>
                                            </td>
                                            <td class="contentvalue" width="50">$QData{"AnswerPercent"}%</td>
                                        </tr>
<!-- dtl:block:SurveyEditStatsAnswer -->
                                    </table>
                                </td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
<!-- dtl:block:SurveyEditStatsQuestion -->
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentfooter">&nbsp;
                    </td>
                </tr>
            </table>
            <br>
<!-- dtl:block:SurveyEditStats -->
        </td>
        <td width="25%" class="menu">
            <table border="0" align="right" cellspacing="1" cellpadding="0" width="95%">
                <tr>
                    <td class="mainkey">$Text{"Created"}:</td>
                    <td class="mainvalue">$TimeLong{"$Data{"CreateTime"}"}</td>
                </tr>
                <tr>
                    <td class="mainkey">$Text{"Created by"}:</td>
                    <td class="mainvalue">
                        <div title="$Quote{"$Data{"CreateUserLogin"} ($Data{"CreateUserFirstname"} $Data{"CreateUserLastname"})"}">
                            $Quote{"$Data{"CreateUserLogin"}"} ($Quote{"$Data{"CreateUserFirstname"} $Data{"CreateUserLastname"}","20"})
                        </div>
                    </td>
                </tr>
                <tr>
                    <td class="mainkey">$Text{"Changed"}:</td>
                    <td class="mainvalue">$TimeLong{"$Data{"ChangeTime"}"}</td>
                </tr>
                <tr>
                    <td class="mainkey">$Text{"Changed by"}:</td>
                    <td class="mainvalue">
                        <div title="$Quote{"$Data{"CreateUserLogin"} ($Data{"CreateUserFirstname"} $Data{"CreateUserLastname"})"}">
                            $Quote{"$Data{"CreateUserLogin"}"} ($Quote{"$Data{"CreateUserFirstname"} $Data{"CreateUserLastname"}","20"})
                        </div>
                    </td>
                </tr>
                <tr>
                    <td class="mainkey">&nbsp;</td>
                    <td class="mainvalue">&nbsp;</td>
                </tr>
                <tr>
                    <td class="mainkey">$Text{"Status"}:</td>
                    <td class="mainvalue"><font color='red'>$Text{"$QData{"Status"}"}</font></td>
                </tr>
                <tr>
                    <td class="mainkey">$Text{"Change Status"}:</td>
                    <td class="mainvalue">
                        <form action="$Env{"CGIHandle"}" method="post">
                            <input type="hidden" name="Action" value="$Env{"Action"}">
                            <input type="hidden" name="Subaction" value="SurveyStatus">
                            <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
<!-- dtl:block:SurveyStatus -->
                            $Data{"NewStatusStr"}
<!-- dtl:block:SurveyStatus -->
                            <input class="button" type="submit" value="$Text{"Change"}">
                        </form>
                    </td>
                </tr>
                <tr>
                    <td class="mainkey">&nbsp;</td>
                    <td class="mainvalue">&nbsp;</td>
                </tr>
                <tr>
                    <td class="mainkey">&nbsp;</td>
                    <td class="mainvalue">&nbsp;</td>
                </tr>
                <tr>
                    <td class="mainkey">$Text{"Sent requests"}:</td>
                    <td class="mainvalue"><font color='red'>$QData{"SendRequest"}</font></td>
                </tr>
                <tr>
                    <td class="mainkey">$Text{"Received surveys"}:</td>
                    <td class="mainvalue"><font color='red'>$QData{"RequestComplete"}</font></td>
                </tr>
            </table>
        </td>
    </tr>
</table>
<!-- dtl:block:Survey -->
<!-- dtl:block:SurveyEdit -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
    <tr>
        <td class="mainhead">
            $Env{"Box0"}$Text{"Edit"}: $Text{"Survey"}$Env{"Box1"}
        </td>
    </tr>
    <tr>
        <td class="menu">
            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=Survey&SurveyID=$QData{"SurveyID"}">$Text{"Back"}</a>
        </td>
    </tr>
    <tr>
        <td class="mainbody">
            <br>
            <form action="$Env{"CGIHandle"}" method="post" name="Survey">
                <input type="hidden" name="Action" value="$Env{"Action"}">
                <input type="hidden" name="Subaction" value="SurveySave">
                <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                    <tr>
                        <td colspan="4" class="contenthead">
                            <table border="0" width="100%" cellspacing="0" cellpadding="0">
                                <tr>
                                    <td class="contenthead">$Text{"Survey"}</td>
                                </tr>
                            </table>
                        </td>
                    </tr>
                    <tr>
                        <td class="contentbody">
                            <table border="0" width="100%">
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Number"}:</td>
                                    <td class="contentvalue">$QData{"SurveyNumber"}</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Title"}:</td>
                                    <td class="contentvalue"><input type="text" size="70" name="Title" value="$QData{"Title"}"></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Introduction"}:</td>
                                    <td class="contentvalue"><textarea name="Introduction" rows="5" cols="50">$QData{"Introduction"}</textarea></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Sender"}:</td>
                                    <td class="contentvalue"><input type="text" size="70" name="NotificationSender" value="$QData{"NotificationSender"}"></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Subject"}:</td>
                                    <td class="contentvalue"><input type="text" size="70" name="NotificationSubject" value="$QData{"NotificationSubject"}"></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Body"}:</td>
                                    <td class="contentvalue"><textarea name="NotificationBody" rows="12" cols="50">$QData{"NotificationBody"}</textarea></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Queues"}:</td>
                                    <td class="contentvalue">$Data{"QueueString"}</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Internal"}&nbsp;$Text{"Description"}:</td>
                                    <td class="contentvalue"><textarea name="Description" rows="5" cols="50">$QData{"Description"}</textarea></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                            </table>
                        </td>
                    </tr>
                    <tr>
                        <td class="contentfooter">
                            <input class="button" type="submit" value="$Text{"Save"}" onclick="return submit_survey();">
                        </td>
                    </tr>
                </table>
            </form>
            <br>
            <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                <tr>
                    <td colspan="4" class="contenthead">
                        <table border="0" width="100%" cellspacing="0" cellpadding="0">
                            <tr>
                                <td class="contenthead"><a name="Question"></a>$Text{"Questions"}</td>
                                <td class="contenthead" align="right">&nbsp;</td>
                            </tr>
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentbody">
                        <table border="0" width="100%">
                            <tr>
                                <td class="contentbody" width="25">&nbsp;</td>
                                <td class="contentbody">
                                    <table border="0" width="100%">
                                        <tr>
                                            <td class="contentkey" width="25">&nbsp;</td>
                                            <td class="contentkey">&nbsp;</td>
                                        </tr>
<!-- dtl:block:SurveyEditQuestionsValidOnce -->
                                        <tr>
                                            <td class="contentbody">
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=QuestionEdit&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}">$QData{"Question","90"}</a>&nbsp;($Text{"$QData{"Type"}"})
                                            </td>
                                            <td class="contentbody" align="right">
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=QuestionUp&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}"><img border="0" src="$Config{"Frontend::ImagePath"}up-big.png"></a>
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=QuestionDown&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}"><img border="0" src="$Config{"Frontend::ImagePath"}down-big.png"></a>
                                            </td>
                                        </tr>
<!-- dtl:block:SurveyEditQuestionsValidOnce -->
<!-- dtl:block:SurveyEditQuestions -->
                                        <tr>
                                            <td class="contentbody">
<!-- dtl:block:SurveyEditQuestionsComplete -->
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=QuestionEdit&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}">$QData{"Question","70"}</a>&nbsp;($Text{"$QData{"Type"}"})
<!-- dtl:block:SurveyEditQuestionsComplete -->
<!-- dtl:block:SurveyEditQuestionsIncomplete -->
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=QuestionEdit&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}"><font color='red'>$QData{"Question","70"}</font></a>&nbsp;($Text{"$QData{"Type"}"})
<!-- dtl:block:SurveyEditQuestionsIncomplete -->
                                            </td>
                                            <td class="contentbody" align="right">
                                                <table border="0" align="right" cellspacing="0" cellpadding="0">
                                                    <tr>
                                                        <td>
                                                            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=QuestionUp&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}"><img border="0" src="$Config{"Frontend::ImagePath"}up-big.png"></a>
                                                            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=QuestionDown&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}"><img border="0" src="$Config{"Frontend::ImagePath"}down-big.png"></a>&nbsp;&nbsp;
                                                        </td>
                                                        <td>
                                                            <form action="$Env{"CGIHandle"}" method="post">
                                                                <input type="hidden" name="Action" value="$Env{"Action"}">
                                                                <input type="hidden" name="Subaction" value="QuestionDelete">
                                                                <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                                                                <input type="hidden" name="QuestionID" value="$QData{"QuestionID"}">
                                                                <input class="button" type="submit" value="$Text{"Delete"}">
                                                            </form>
                                                        </td>
                                                    </tr>
                                                </table>
                                            </td>
                                        </tr>
<!-- dtl:block:SurveyEditQuestions -->
                                        <tr>
                                            <td class="contentkey" width="25">&nbsp;</td>
                                            <td class="contentkey">&nbsp;</td>
                                        </tr>
                                    </table>
                                </td>
                                <td class="contentbody" width="25">&nbsp;</td>
                            </tr>
<!-- dtl:block:SurveyEditNewQuestion -->
                            <tr>
                                <td class="contentkey" width="25"><a name="NewQuestion"></a>&nbsp;</td>
                                <td class="contentvalue">
                                    <form action="$Env{"CGIHandle"}" method="post">
                                        <input type="hidden" name="Action" value="$Env{"Action"}">
                                        <input type="hidden" name="Subaction" value="QuestionAdd">
                                        <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                                        <table border="0" width="100%" cellspacing="0" cellpadding="0">
                                            <tr>
                                                <td rowspan="4"><input type="text" size="60" name="Question"></td>
                                                <td class="contentvalue"><input type="radio" name="Type" value="YesNo" checked>&nbsp;$Text{"YesNo"}</td>
                                                <td rowspan="4">&nbsp;&nbsp;&nbsp;<input class="button" type="submit" value="$Text{"Add"}"></td>
                                            </tr>
                                            <tr>
                                                <td class="contentvalue"><input type="radio" name="Type" value="Radio">&nbsp;$Text{"Radio"}&nbsp;($Text{"List"})</td>
                                            </tr>
                                            <tr>
                                                <td class="contentvalue"><input type="radio" name="Type" value="Checkbox">&nbsp;$Text{"Checkbox"}&nbsp;($Text{"List"})</td>
                                            </tr>
                                            <tr>
                                                <td class="contentvalue"><input type="radio" name="Type" value="Textarea">&nbsp;$Text{"Textarea"}</td>
                                            </tr>
                                        </table>
                                    </form>
                                </td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
<!-- dtl:block:SurveyEditNewQuestion -->
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentfooter">&nbsp;</td>
                </tr>
            </table>
            <br>
        </td>
    </tr>
</table>
<!-- dtl:block:SurveyEdit -->
<!-- dtl:block:SurveyAdd -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
    <tr>
        <td class="mainhead">
            $Env{"Box0"}$Text{"Add"}: $Text{"Survey"}$Env{"Box1"}
        </td>
    </tr>
    <tr>
        <td class="mainbody">
            <br>
            <form action="$Env{"CGIHandle"}" method="post" name="Survey">
                <input type="hidden" name="Action" value="$Env{"Action"}">
                <input type="hidden" name="Subaction" value="SurveyNew">
                <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                    <tr>
                        <td colspan="4" class="contenthead">
                            <table border="0" width="100%" cellspacing="0" cellpadding="0">
                                <tr>
                                    <td class="contenthead">$Text{"Survey"}</td>
                                </tr>
                            </table>
                        </td>
                    </tr>
                    <tr>
                        <td class="contentbody">
                            <table border="0" width="100%">
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Title"}:</td>
                                    <td class="contentvalue"><input type="text" size="70" name="Title" value=""></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Introduction"}:</td>
                                    <td class="contentvalue"><textarea name="Introduction" rows="5" cols="50">$QData{"Introduction"}</textarea></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Sender"}:</td>
                                    <td class="contentvalue"><input type="text" size="70" name="NotificationSender" value="$QData{"NotificationSender"}"></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Subject"}:</td>
                                    <td class="contentvalue"><input type="text" size="70" name="NotificationSubject" value="$QData{"NotificationSubject"}"></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Body"}:</td>
                                    <td class="contentvalue"><textarea name="NotificationBody" rows="12" cols="50">$QData{"NotificationBody"}</textarea></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Queues"}:</td>
                                    <td class="contentvalue">$Data{"QueueString"}</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Internal"}&nbsp;$Text{"Description"}:</td>
                                    <td class="contentvalue"><textarea name="Description" rows="5" cols="50"></textarea></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                            </table>
                        </td>
                    </tr>
                    <tr>
                        <td class="contentfooter">
                            <input class="button" type="submit" value="$Text{"Save"}" onclick="return submit_survey();">
                        </td>
                    </tr>
                </table>
            </form>
            <br>
        </td>
    </tr>
</table>
<!-- dtl:block:SurveyAdd -->
<!-- dtl:block:QuestionEdit -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
    <tr>
        <td class="mainhead">
            $Env{"Box0"}$Text{"Edit"}: $Text{"Question"}$Env{"Box1"}
        </td>
    </tr>
    <tr>
        <td class="menu">
            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=SurveyEdit&SurveyID=$QData{"SurveyID"}">$Text{"Back"}</a>
        </td>
    </tr>
    <tr>
        <td class="mainbody">
            <br>
            <form action="$Env{"CGIHandle"}" method="post">
                <input type="hidden" name="Action" value="$Env{"Action"}">
                <input type="hidden" name="Subaction" value="QuestionSave">
                <input type="hidden" name="QuestionID" value="$QData{"QuestionID"}">
                <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                    <tr>
                        <td colspan="4" class="contenthead">
                            <table border="0" width="100%" cellspacing="0" cellpadding="0">
                                <tr>
                                    <td class="contenthead">$Text{"Question"}</td>
                                </tr>
                            </table>
                        </td>
                    </tr>
                    <tr>
                        <td class="contentbody">
                            <table border="0" width="100%">
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Question"}:</td>
                                    <td class="contentvalue"><input type="text" size="70" name="Question" value="$QData{"Question"}"></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                            </table>
                        </td>
                    </tr>
                    <tr>
                        <td class="contentfooter">
                            <input class="button" type="submit" value="$Text{"Save"}">
                        </td>
                    </tr>
                </table>
            </form>
            <br>
            <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                <tr>
                    <td colspan="4" class="contenthead">
                        <table border="0" width="100%" cellspacing="0" cellpadding="0">
                            <tr>
                                <td class="contenthead"><a name="Answer"></a>$Text{"Posible Answers"}</td>
                                <td class="contenthead" align="right">&nbsp;</td>
                            </tr>
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentbody">
                        <table border="0" width="100%">
                            <tr>
                                <td class="contentbody" width="25">&nbsp;</td>
                                <td class="contentbody">
                                    <table border="0" width="100%">
                                        <tr>
                                            <td class="contentbody">&nbsp;</td>
                                            <td class="contentbody" align="right">&nbsp;</td>
                                        </tr>
<!-- dtl:block:QuestionEdit1 -->
                                        <tr>
                                            <td class="contentbody"><input type="radio" name="Q1">&nbsp;$Text{"Yes"}</td>
                                            <td class="contentbody" align="right">&nbsp;</td>
                                        </tr>
                                        <tr>
                                            <td class="contentbody"><input type="radio" name="Q1">&nbsp;$Text{"No"}</td>
                                            <td class="contentbody" align="right">&nbsp;</td>
                                        </tr>
<!-- dtl:block:QuestionEdit1 -->
<!-- dtl:block:QuestionEdit2ValidOnce -->
                                        <tr>
                                            <td class="contentbody">
                                                <input type="radio" name="Q1">&nbsp;
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerEdit&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}">
                                                    $QData{"Answer","90"}
                                                </a>
                                            </td>
                                            <td class="contentbody" align="right">
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerUp&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}"><img border="0" src="$Config{"Frontend::ImagePath"}up-big.png"></a>
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerDown&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}"><img border="0" src="$Config{"Frontend::ImagePath"}down-big.png"></a>
                                            </td>
                                        </tr>
<!-- dtl:block:QuestionEdit2ValidOnce -->
<!-- dtl:block:QuestionEdit2 -->
                                        <tr>
                                            <td class="contentbody">
                                                <input type="radio" name="Q1">&nbsp;
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerEdit&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}">$QData{"Answer","70"}</a>
                                            </td>
                                            <td class="contentbody" align="right">
                                                <table border="0" align="right" cellspacing="0" cellpadding="0">
                                                    <tr>
                                                        <td>
                                                            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerUp&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}"><img border="0" src="$Config{"Frontend::ImagePath"}up-big.png"></a>
                                                            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerDown&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}"><img border="0" src="$Config{"Frontend::ImagePath"}down-big.png"></a>&nbsp;&nbsp;
                                                        </td>
                                                        <td>
                                                            <form action="$Env{"CGIHandle"}" method="post">
                                                                <input type="hidden" name="Action" value="$Env{"Action"}">
                                                                <input type="hidden" name="Subaction" value="AnswerDelete">
                                                                <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                                                                <input type="hidden" name="QuestionID" value="$QData{"QuestionID"}">
                                                                <input type="hidden" name="AnswerID" value="$QData{"AnswerID"}">
                                                                <input class="button" type="submit" value="$Text{"Delete"}">
                                                            </form>
                                                        </td>
                                                    </tr>
                                                </table>
                                            </td>
                                        </tr>
<!-- dtl:block:QuestionEdit2 -->
<!-- dtl:block:QuestionEdit2b -->
                                        <tr>
                                            <td class="contentkey"><a name="NewAnswer"></a>&nbsp;</td>
                                            <td class="contentkey" width="25">&nbsp;</td>
                                        </tr>
                                        <tr>
                                            <form action="$Env{"CGIHandle"}" method="post">
                                                <input type="hidden" name="Action" value="$Env{"Action"}">
                                                <input type="hidden" name="Subaction" value="AnswerAdd">
                                                <input type="hidden" name="QuestionID" value="$QData{"QuestionID"}">
                                                <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                                                <td class="contentvalue"><input type="text" size="60" name="Answer"></td>
                                                <td class="contentkey" width="25"><input class="button" type="submit" value="$Text{"Add"}"></td>
                                            </form>
                                        </tr>
<!-- dtl:block:QuestionEdit2b -->
<!-- dtl:block:QuestionEdit3ValidOnce -->
                                        <tr>
                                            <td class="contentbody">
                                                <input type="checkbox" name="Q1">
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerEdit&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}">$QData{"Answer"}</a>
                                            </td>
                                            <td class="contentbody" align="right">
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerUp&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}"><img border="0" src="$Config{"Frontend::ImagePath"}up-big.png"></a>
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerDown&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}"><img border="0" src="$Config{"Frontend::ImagePath"}down-big.png"></a>
                                            </td>
                                        </tr>
<!-- dtl:block:QuestionEdit3ValidOnce -->
<!-- dtl:block:QuestionEdit3 -->
                                        <tr>
                                            <td class="contentbody">
                                                <input type="checkbox" name="Q1">
                                                <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerEdit&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}">$QData{"Answer"}</a>
                                            </td>
                                            <td class="contentbody" align="right">
                                                <table border="0" align="right" cellspacing="0" cellpadding="0">
                                                    <tr>
                                                        <td>
                                                            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerUp&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}"><img border="0" src="$Config{"Frontend::ImagePath"}up-big.png"></a>
                                                            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=AnswerDown&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}&AnswerID=$QData{"AnswerID"}"><img border="0" src="$Config{"Frontend::ImagePath"}down-big.png"></a>&nbsp;&nbsp;
                                                        </td>
                                                        <td>
                                                            <form action="$Env{"CGIHandle"}" method="post">
                                                                <input type="hidden" name="Action" value="$Env{"Action"}">
                                                                <input type="hidden" name="Subaction" value="AnswerDelete">
                                                                <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                                                                <input type="hidden" name="QuestionID" value="$QData{"QuestionID"}">
                                                                <input type="hidden" name="AnswerID" value="$QData{"AnswerID"}">
                                                                <input class="button" type="submit" value="$Text{"Delete"}">
                                                            </form>
                                                        </td>
                                                    </tr>
                                                </table>
                                            </td>
                                        </tr>
<!-- dtl:block:QuestionEdit3 -->
<!-- dtl:block:QuestionEdit3b -->
                                        <tr>
                                            <td class="contentkey"><a name="NewAnswer"></a>&nbsp;</td>
                                            <td class="contentkey" width="25">&nbsp;</td>
                                        </tr>
                                        <tr>
                                            <form action="$Env{"CGIHandle"}" method="post">
                                                <input type="hidden" name="Action" value="$Env{"Action"}">
                                                <input type="hidden" name="Subaction" value="AnswerAdd">
                                                <input type="hidden" name="QuestionID" value="$QData{"QuestionID"}">
                                                <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                                                <td class="contentvalue"><input type="text" size="60" name="Answer"></td>
                                                <td class="contentkey" width="25"><input class="button" type="submit" value="$Text{"Add"}"></td>
                                            </form>
                                        </tr>
<!-- dtl:block:QuestionEdit3b -->
<!-- dtl:block:QuestionEdit4 -->
                                        <tr>
                                            <td class="contentbody"><textarea rows="4" name="Q1" cols="62">$Text{"Example"}&nbsp;$Text{"Textarea"}</textarea></td>
                                            <td class="contentbody" align="right">&nbsp;</td>
                                        </tr>
<!-- dtl:block:QuestionEdit4 -->
                                        <tr>
                                            <td class="contentbody">&nbsp;</td>
                                            <td class="contentbody" align="right">&nbsp;</td>
                                        </tr>
                                    </table>
                                </td>
                                <td class="contentbody" width="25">&nbsp;</td>
                            </tr>
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentfooter">&nbsp;</td>
                </tr>
            </table>
            <br>
        </td>
    </tr>
</table>
<!-- dtl:block:QuestionEdit -->
<!-- dtl:block:AnswerEdit -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
    <tr>
        <td class="mainhead">
            $Env{"Box0"}$Text{"Edit"}: $Text{"Answer"}$Env{"Box1"}
        </td>
    </tr>
    <tr>
        <td class="menu">
            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=QuestionEdit&SurveyID=$QData{"SurveyID"}&QuestionID=$QData{"QuestionID"}">$Text{"Back"}</a>
        </td>
    </tr>
    <tr>
        <td class="mainbody">
            <br>
            <form action="$Env{"CGIHandle"}" method="post">
                <input type="hidden" name="Action" value="$Env{"Action"}">
                <input type="hidden" name="Subaction" value="AnswerSave">
                <input type="hidden" name="AnswerID" value="$QData{"AnswerID"}">
                <input type="hidden" name="QuestionID" value="$QData{"QuestionID"}">
                <input type="hidden" name="SurveyID" value="$QData{"SurveyID"}">
                <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                    <tr>
                        <td colspan="4" class="contenthead">
                            <table border="0" width="100%" cellspacing="0" cellpadding="0">
                                <tr>
                                    <td class="contenthead">$Text{"Answer"}</td>
                                </tr>
                            </table>
                        </td>
                    </tr>
                    <tr>
                        <td class="contentbody">
                            <table border="0" width="100%">
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentvalue">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">$Text{"Answer"}:</td>
                                    <td class="contentvalue"><input type="text" size="60" name="Answer" value="$QData{"Answer"}"></td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                                <tr>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                    <td class="contentkey">&nbsp;</td>
                                    <td class="contentvalue">&nbsp;</td>
                                    <td class="contentkey" width="25">&nbsp;</td>
                                </tr>
                            </table>
                        </td>
                    </tr>
                    <tr>
                        <td class="contentfooter">
                            <input class="button" type="submit" value="$Text{"Save"}">
                        </td>
                    </tr>
                </table>
            </form>
            <br>
        </td>
    </tr>
</table>
<!-- dtl:block:AnswerEdit -->
<!-- dtl:block:Stats -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
    <tr>
        <td class="mainhead">
            $Env{"Box0"}$Text{"Overview"}: $Text{"Stats"}$Env{"Box1"}
        </td>
    </tr>
    <tr>
        <td class="menu">
            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=Survey&SurveyID=$QData{"SurveyID"}">$Text{"Back"}</a>
        </td>
    </tr>
    <tr>
        <td class="mainbody">
            <br>
            <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                <tr>
                    <td colspan="4" class="contenthead">
                        <table border="0" width="100%" cellspacing="0" cellpadding="0">
                            <tr>
                                <td class="contenthead">$Text{"Stats"}</td>
                            </tr>
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentbody">
                        <table border="0" width="100%">
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">$Text{"Send Time"}</td>
                                <td class="contentkey">$Text{"Vote Time"}</td>
                                <td class="contentkey">$Text{"Ticket"}</td>
                                <td class="contentkey" align="center">$Text{"Details"}</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
<!-- dtl:block:StatsVote -->
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentvalue">$TimeLong{"$Data{"SendTime"}"}</td>
                                <td class="contentvalue">$TimeLong{"$Data{"VoteTime"}"}</td>
                                <td class="contentvalue"><a href="$Env{"Baselink"}Action=AgentTicketZoom&TicketID=$QData{"TicketID"}">$QData{"TicketNumber"}</a></td>
                                <td class="contentvalue" align="center">
                                    <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=StatsDetail&SurveyID=$QData{"SurveyID"}&RequestID=$QData{"RequestID"}">x</a>
                                </td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
<!-- dtl:block:StatsVote -->
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentfooter">&nbsp;
                    </td>
                </tr>
            </table>
            <br>
        </td>
    </tr>
</table>
<!-- dtl:block:Stats -->
<!-- dtl:block:StatsDetail -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
    <tr>
        <td class="mainhead">
            $Env{"Box0"}$Text{"Overview"}: $Text{"Survey"}$Env{"Box1"}
        </td>
    </tr>
    <tr>
        <td class="menu">
            <a href="$Env{"Baselink"}Action=$Env{"Action"}&Subaction=Stats&SurveyID=$QData{"SurveyID"}">$Text{"Back"}</a>
        </td>
    </tr>
    <tr>
        <td class="mainbody">
            <br>
            <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
                <tr>
                    <td colspan="4" class="contenthead">
                        <table border="0" width="100%" cellspacing="0" cellpadding="0">
                            <tr>
                                <td class="contenthead">$Text{"Stats"} $Text{"Details"}</td>
                            </tr>
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentbody">
                        <table border="0" width="100%">
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
<!-- dtl:block:StatsDetailQuestion -->
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">$QData{"Question"}</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">
                                    <table border="0" width="100%" cellspacing="0">
<!-- dtl:block:StatsDetailAnswer -->
                                        <tr>
                                            <td width="50" class="contentkey" align="right">
                                                &nbsp;
                                            </td>
                                            <td class="contentvalue">$Text{"$QData{"Answer"}"}</td>
                                        </tr>
<!-- dtl:block:StatsDetailAnswer -->
                                    </table>
                                </td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
                            <tr>
                                <td class="contentkey" width="25">&nbsp;</td>
                                <td class="contentkey">&nbsp;</td>
                                <td class="contentkey" width="25">&nbsp;</td>
                            </tr>
<!-- dtl:block:StatsDetailQuestion -->
                        </table>
                    </td>
                </tr>
                <tr>
                    <td class="contentfooter">&nbsp;
                    </td>
                </tr>
            </table>
            <br>
        </td>
    </tr>
</table>
<!-- dtl:block:StatsDetail -->

# --
# PublicSurvey.dtl - provides HTML form for PublicSurvey
# Copyright (C) 2001-2009 OTRS AG, http://otrs.org/
# --
# $Id: PublicSurvey.dtl,v 1.15 2009/04/02 16:22:19 mh Exp $
# --
# 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.
# --

<!-- dtl:block:PublicSurvey -->
<script language="JavaScript" type="text/javascript">
<!--
function submit_compose() {
    for (i=0;i<3;i++) {
        for (ii=0;ii<100;ii++) {
            if ( document.compose['PublicSurveyVote' + i + '[' + ii + ']'] ) {
                var Ok = 0;
                FieldName = document.compose['PublicSurveyVote' + i + '[' + ii + ']'];
                for (F=0;F<FieldName.length;F++) {
                    if ( FieldName[F].checked ) {
                        Ok = 1;
                    }
                }
                if ( !Ok ) {
                    alert('$JSText{"Need to select question:"}' + i );
                    return false;
                }
            }
        }
    }
    return true;
}
//-->
</script>

<table border="0" width="100%" cellspacing="0" cellpadding="3">
  <tr>
    <td class="mainhead">
      $Text{"Survey"}
    </td>
  </tr>
  <tr>
    <td class="mainbody">
      <br/>
      <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
        <tr>
          <td colspan="4" class="contenthead">
            <table border="0" width="100%" cellspacing="0" cellpadding="0">
              <tr>
                <td class="contenthead">$Text{"Survey"}</td>
                <td class="contenthead" align="right">&nbsp;</td>
              </tr>
            </table>
          </td>
        </tr>
        <tr>
          <td class="contentbody">
            <table border="0" width="100%">
              <tr>
                <td class="contentkey" width="25">&nbsp;</td>
                <td class="contentkey">$Data{"Introduction"}</td>
                <td class="contentkey" width="25">&nbsp;</td>
              </tr>
            </table>
          </td>
        </tr>
        <tr>
          <td class="contentfooter">&nbsp;
          </td>
        </tr>
      </table>
      <br/>
      <form action="$Env{"CGIHandle"}" method="post" name="compose">
        <input type="hidden" name="Action" value="$Env{"Action"}" />
        <input type="hidden" name="Subaction" value="PublicSurveyVote" />
        <input type="hidden" name="PublicSurveyKey" value="$QData{"PublicSurveyKey"}" />
        <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
          <tr>
            <td colspan="4" class="contenthead">$Text{"Questions"}
            </td>
          </tr>
          <tr>
            <td class="contentbody">
              <table border="0" width="100%">
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">&nbsp;</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
<!-- dtl:block:PublicQuestions -->
<!-- dtl:block:PublicAnswerYesNo -->
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">$QData{"Question"}</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">
                    <table border="0" width="100%" cellspacing="0">
                      <tr>
                        <td width="50" class="contentkey" align="right">
                          <input type="radio" name="PublicSurveyVote1[$QData{"QuestionID"}]" value="Yes" />
                        </td>
                        <td class="contentkey">$Text{"Yes"}</td>
                      </tr>
                      <tr>
                        <td width="50" class="contentkey" align="right">
                          <input type="radio" name="PublicSurveyVote1[$QData{"QuestionID"}]" value="No" />
                        </td>
                        <td class="contentkey">$Text{"No"}</td>
                      </tr>
                    </table>
                  </td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">&nbsp;</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
<!-- dtl:block:PublicAnswerYesNo -->
<!-- dtl:block:PublicAnswerRadio -->
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">$QData{"Question"}</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">
                    <table border="0" width="100%" cellspacing="0">
<!-- dtl:block:PublicAnswerRadiob -->
                      <tr>
                        <td width="50" align="right">
                          <input type="radio" name="PublicSurveyVote2[$QData{"QuestionID"}]" value="$QData{"AnswerID"}" />
                        </td>
                        <td>$QData{"Answer"}</td>
                      </tr>
<!-- dtl:block:PublicAnswerRadiob -->
                    </table>
                  </td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">&nbsp;</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
<!-- dtl:block:PublicAnswerRadio -->
<!-- dtl:block:PublicAnswerCheckbox -->
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">$QData{"Question"}</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">
                    <table border="0" width="100%" cellspacing="0">
<!-- dtl:block:PublicAnswerCheckboxb -->
                      <tr>
                        <td width="50" align="right">
                          <input type="checkbox" name="PublicSurveyVote3[$QData{"AnswerID"}]" value="Yes" />
                        </td>
                        <td>$QData{"Answer"}</td>
                      </tr>
<!-- dtl:block:PublicAnswerCheckboxb -->
                    </table>
                  </td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">&nbsp;</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
<!-- dtl:block:PublicAnswerCheckbox -->
<!-- dtl:block:PublicAnswerTextarea -->
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">$QData{"Question"}</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">
                    <table border="0" width="100%" cellspacing="0">
                      <tr>
                        <td width="50" align="right">&nbsp;</td>
                        <td>
                          <textarea rows="4" cols="62" name="PublicSurveyVote4[$QData{"QuestionID"}]"></textarea>
                        </td>
                      </tr>
                    </table>
                  </td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
                <tr>
                  <td class="contentkey" width="25">&nbsp;</td>
                  <td class="contentkey">&nbsp;</td>
                  <td class="contentkey" width="25">&nbsp;</td>
                </tr>
<!-- dtl:block:PublicAnswerTextarea -->
<!-- dtl:block:PublicQuestions -->
              </table>
            </td>
          </tr>
          <tr>
            <td class="contentfooter">
              <input class="button" type="reset" value="$Text{"Reset"}" />&nbsp;
              <input class="button" type="submit" value="$Text{"Finish"}" onclick="return submit_compose();" />
            </td>
          </tr>
        </table>
      </form>
      <br/>
    </td>
  </tr>
</table>
<!-- dtl:block:PublicSurvey -->

<!-- dtl:block:PublicNoSurvey -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
  <tr>
    <td class="mainhead">
      $Text{"Error"}
    </td>
  </tr>
  <tr>
    <td class="mainbody">
      <br/>
      <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
        <tr>
          <td colspan="4" class="contenthead">
            <table border="0" width="100%" cellspacing="0" cellpadding="0">
              <tr>
                <td class="contenthead">$Text{"Survey"} $Text{"invalid"}</td>
                <td class="contenthead" align="right">&nbsp;</td>
              </tr>
            </table>
          </td>
        </tr>
        <tr>
          <td class="contentbody">
            <table border="0" width="100%">
              <tr>
                <td class="contentkey" width="25">&nbsp;</td>
                <td class="contentkey">$Text{"This Survey-Key is invalid!"}</td>
                <td class="contentkey" width="25">&nbsp;</td>
              </tr>
            </table>
          </td>
        </tr>
        <tr>
          <td class="contentfooter">&nbsp;
          </td>
        </tr>
      </table>
      <br/>
    </td>
  </tr>
</table>
<!-- dtl:block:PublicNoSurvey -->

<!-- dtl:block:PublicSurveyComplete -->
<table border="0" width="100%" cellspacing="0" cellpadding="3">
  <tr>
    <td class="mainhead">
      $Text{"Survey"}
    </td>
  </tr>
  <tr>
    <td class="mainbody">
      <br/>
      <table border="0" width="700" align="center" cellspacing="0" cellpadding="4">
        <tr>
          <td colspan="4" class="contenthead">
            <table border="0" width="100%" cellspacing="0" cellpadding="0">
              <tr>
                <td class="contenthead">$Text{"Survey"} $Text{"finished"}</td>
                <td class="contenthead" align="right">&nbsp;</td>
              </tr>
            </table>
          </td>
        </tr>
        <tr>
          <td class="contentbody">
            <table border="0" width="100%">
              <tr>
                <td class="contentkey" width="25">&nbsp;</td>
                <td class="contentkey">$Text{"Thank you for your feedback."}</td>
                <td class="contentkey" width="25">&nbsp;</td>
              </tr>
            </table>
          </td>
        </tr>
        <tr>
          <td class="contentfooter">&nbsp;
          </td>
        </tr>
      </table>
      <br/>
    </td>
  </tr>
</table>
<!-- dtl:block:PublicSurveyComplete -->

# --
# Kernel/System/Survey.pm - all survey funtions
# Copyright (C) 2001-2010 OTRS AG, http://otrs.org/
# --
# $Id: Survey.pm,v 1.50 2010/05/21 12:49:51 mh Exp $
# --
# 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::Survey;

use strict;
use warnings;

use Digest::MD5;
use Kernel::System::CustomerUser;
use Kernel::System::Email;
use Kernel::System::HTMLUtils;
use Kernel::System::Ticket;
use Mail::Address;

use vars qw(@ISA $VERSION);
$VERSION = qw($Revision: 1.50 $) [1];

=head1 NAME

Kernel::System::Survey - survey lib

=head1 SYNOPSIS

All survey functions. E. g. to add survey or and functions.

=head1 PUBLIC INTERFACE

=over 4

=cut

=item new()

create an object

    use Kernel::Config;
    use Kernel::System::Encode;
    use Kernel::System::Log;
    use Kernel::System::Time;
    use Kernel::System::DB;
    use Kernel::System::Main;
    use Kernel::System::User;
    use Kernel::System::Survey;

    my $ConfigObject = Kernel::Config->new();
    my $EncodeObject = Kernel::System::Encode->new(
        ConfigObject => $ConfigObject,
    );
    my $LogObject = Kernel::System::Log->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
    );
    my $TimeObject = Kernel::System::Time->new(
        ConfigObject => $ConfigObject,
        LogObject    => $LogObject,
    );
    my $MainObject = Kernel::System::Main->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
    );
    my $DBObject = Kernel::System::DB->new(
        ConfigObject => $ConfigObject,
        EncodeObject => $EncodeObject,
        LogObject    => $LogObject,
        MainObject   => $MainObject,
    );
    my $UserObject = Kernel::System::User->new(
        ConfigObject => $ConfigObject,
        LogObject    => $LogObject,
        MainObject   => $MainObject,
        TimeObject   => $TimeObject,
        DBObject     => $DBObject,
        EncodeObject => $EncodeObject,
    );
    my $SurveyObject = Kernel::System::Survey->new(
        ConfigObject => $ConfigObject,
        LogObject    => $LogObject,
        TimeObject   => $TimeObject,
        DBObject     => $DBObject,
        MainObject   => $MainObject,
        UserObject   => $UserObject,
    );

=cut

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

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

    # check needed objects
    for my $Object (
        qw(ConfigObject LogObject TimeObject DBObject MainObject EncodeObject UserObject)
        )
    {
        $Self->{$Object} = $Param{$Object} || die "Got no $Object!";
    }

    $Self->{HTMLUtilsObject} = $Param{HTMLUtilsObject}
        || Kernel::System::HTMLUtils->new( %{$Self} );
    $Self->{SendmailObject} = $Param{SendmailObject} || Kernel::System::Email->new( %{$Self} );
    $Self->{CustomerUserObject} = $Param{CustomerUserObject}
        || Kernel::System::CustomerUser->new( %{$Self} );
    $Self->{TicketObject} = $Param{TicketObject} || Kernel::System::Ticket->new( %{$Self} );

    return $Self;
}

=item SurveyList()

to get a array list of all survey items

    my @List = $SurveyObject->SurveyList();

=cut

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

    # get survey list
    $Self->{DBObject}->Prepare(
        SQL => 'SELECT id FROM survey ORDER BY create_time DESC',
    );

    # fetch the results
    my @List;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @List, $Row[0];
    }

    return @List;
}

=item SurveyGet()

to get all attributes of a survey

    my %Survey = $SurveyObject->SurveyGet(
        SurveyID => 123
    );

=cut

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

    # check needed stuff
    if ( !$Param{SurveyID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need SurveyID!',
        );
        return;
    }

    # quote
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # get all attributes of a survey
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id, surveynumber, title, introduction, description,"
            . " notification_sender, notification_subject, notification_body, "
            . " status, create_time, create_by, change_time, change_by "
            . " FROM survey WHERE id = $Param{SurveyID}",
        Limit => 1,
    );

    # fetch the result
    my %Data;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Data{SurveyID}            = $Row[0];
        $Data{SurveyNumber}        = $Row[1];
        $Data{Title}               = $Row[2];
        $Data{Introduction}        = $Row[3];
        $Data{Description}         = $Row[4];
        $Data{NotificationSender}  = $Row[5];
        $Data{NotificationSubject} = $Row[6];
        $Data{NotificationBody}    = $Row[7];
        $Data{Status}              = $Row[8];
        $Data{CreateTime}          = $Row[9];
        $Data{CreateBy}            = $Row[10];
        $Data{ChangeTime}          = $Row[11];
        $Data{ChangeBy}            = $Row[12];
    }

    if ( !%Data ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => "No such SurveyID $Param{SurveyID}!",
        );
        return;
    }

    # set default values
    $Data{NotificationSender}  ||= $Self->{ConfigObject}->Get('Survey::NotificationSender');
    $Data{NotificationSubject} ||= $Self->{ConfigObject}->Get('Survey::NotificationSubject');
    $Data{NotificationBody}    ||= $Self->{ConfigObject}->Get('Survey::NotificationBody');

    # get queues
    $Data{Queues} = $Self->SurveyQueueGet(
        SurveyID => $Param{SurveyID},
    );

    # added CreateBy
    my %CreateUserInfo = $Self->{UserObject}->GetUserData(
        UserID => $Data{CreateBy},
        Cached => 1,
    );
    $Data{CreateUserLogin}     = $CreateUserInfo{UserLogin};
    $Data{CreateUserFirstname} = $CreateUserInfo{UserFirstname};
    $Data{CreateUserLastname}  = $CreateUserInfo{UserLastname};

    # added ChangeBy
    my %ChangeUserInfo = $Self->{UserObject}->GetUserData(
        UserID => $Data{ChangeBy},
        Cached => 1,
    );
    $Data{ChangeUserLogin}     = $ChangeUserInfo{UserLogin};
    $Data{ChangeUserFirstname} = $ChangeUserInfo{UserFirstname};
    $Data{ChangeUserLastname}  = $ChangeUserInfo{UserLastname};

    return %Data;
}

=item SurveyStatusSet()

to set a new survey status (Valid, Invalid, Master)

    $StatusSet = $SurveyObject->SurveyStatusSet(
        SurveyID  => 123,
        NewStatus => 'Master'
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(SurveyID NewStatus)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    $Param{NewStatus} = $Self->{DBObject}->Quote( $Param{NewStatus} );
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # get current status
    $Self->{DBObject}->Prepare(
        SQL   => "SELECT status FROM survey WHERE id = $Param{SurveyID}",
        Limit => 1,
    );

    # fetch the result
    my $Status = '';
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Status = $Row[0];
    }

    # the curent status
    if ( $Status eq 'New' || $Status eq 'Invalid' ) {

        # get the question ids
        $Self->{DBObject}->Prepare(
            SQL   => "SELECT id FROM survey_question WHERE survey_id = $Param{SurveyID}",
            Limit => 1,
        );

        # fetch the result
        my $Quest;
        while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
            $Quest = $Row[0];
        }

        return 'NoQuestion' if !$Quest;

        # get all questions (type radio and checkbox)
        $Self->{DBObject}->Prepare(
            SQL => "SELECT id FROM survey_question"
                . " WHERE survey_id = $Param{SurveyID} AND "
                . "(question_type = 'Radio' OR question_type = 'Checkbox')",
        );

        # fetch the result
        my @QuestionIDs;
        while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
            push( @QuestionIDs, $Row[0] );
        }
        for my $OneID (@QuestionIDs) {

            # get all answer ids of a question
            $Self->{DBObject}->Prepare(
                SQL   => "SELECT COUNT(id) FROM survey_answer WHERE question_id = $OneID",
                Limit => 1,
            );

            # fetch the result
            my $Counter;
            while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
                $Counter = $Row[0];
            }

            return 'IncompleteQuestion' if $Counter < 2;
        }

        # set new status
        if ( $Param{NewStatus} eq 'Master' ) {
            $Self->{DBObject}->Do(
                SQL => "UPDATE survey SET status = 'Valid' WHERE status = 'Master'",
            );
        }
        if ( $Param{NewStatus} eq 'Valid' || $Param{NewStatus} eq 'Master' ) {
            $Self->{DBObject}->Do(
                SQL => "UPDATE survey SET status = '$Param{NewStatus}' "
                    . "WHERE id = $Param{SurveyID}",
            );
            return 'StatusSet';
        }
    }
    elsif ( $Status eq 'Valid' ) {

        # set status Master
        if ( $Param{NewStatus} eq 'Master' ) {
            $Self->{DBObject}->Do(
                SQL => "UPDATE survey SET status = 'Valid' WHERE status = 'Master'",
            );
            $Self->{DBObject}->Do(
                SQL => "UPDATE survey SET status = 'Master' WHERE id = $Param{SurveyID}",
            );
            return 'StatusSet';
        }

        # set status Invalid
        elsif ( $Param{NewStatus} eq 'Invalid' ) {
            $Self->{DBObject}->Do(
                SQL => "UPDATE survey SET status = 'Invalid' WHERE id = $Param{SurveyID}",
            );
            return 'StatusSet';
        }
    }
    elsif ( $Status eq 'Master' ) {

        # set status Valid
        if ( $Param{NewStatus} eq 'Valid' || $Param{NewStatus} eq 'Invalid' ) {
            $Self->{DBObject}->Do(
                SQL => "UPDATE survey SET status = '$Param{NewStatus}' "
                    . "WHERE id = $Param{SurveyID}",
            );
            return 'StatusSet';
        }
    }
}

=item SurveySave()

to update an existing survey

    $SurveyObject->SurveySave(
        UserID              => 1,
        SurveyID            => 4,
        Title               => 'A Title',
        Introduction        => 'The introduction of the survey',
        Description         => 'The internal description of the survey',
        NotificationSender  => 'quality@example.com',
        NotificationSubject => 'Help us with your feedback!',
        NotificationBody    => 'Dear customer...',
        Queues              => [2, 5, 9],  # (optional) survey is valid for these queues
    );

=cut

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

    # check needed stuff
    for my $Argument (
        qw(
        UserID SurveyID Title Introduction Description
        NotificationSender NotificationSubject NotificationBody
        )
        )
    {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # check queues
    if ( $Param{Queues} && ref $Param{Queues} ne 'ARRAY' ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Queues must be an array reference.',
        );
        return;
    }

    # set default value
    $Param{Queues} ||= [];

    # quote
    for my $Argument (
        qw(
        Title Introduction Description
        NotificationSender NotificationSubject NotificationBody
        )
        )
    {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument} );
    }
    for my $Argument (qw(UserID SurveyID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # update the survey
    return if !$Self->{DBObject}->Do(
        SQL => "UPDATE survey SET "
            . "title = '$Param{Title}', "
            . "introduction = '$Param{Introduction}', "
            . "description = '$Param{Description}', "
            . "notification_sender = '$Param{NotificationSender}', "
            . "notification_subject = '$Param{NotificationSubject}', "
            . "notification_body = '$Param{NotificationBody}', "
            . "change_time = current_timestamp, "
            . "change_by = $Param{UserID} "
            . "WHERE id = $Param{SurveyID}",
    );

    # insert new survey-queue relations
    return $Self->SurveyQueueSave(
        SurveyID => $Param{SurveyID},
        QueueIDs => $Param{Queues},
    );
}

=item SurveyNew()

to add a new survey

    my $SurveyID = $SurveyObject->SurveyNew(
        UserID              => 1,
        Title               => 'A Title',
        Introduction        => 'The introduction of the survey',
        Description         => 'The internal description of the survey',
        NotificationSender  => 'quality@example.com',
        NotificationSubject => 'Help us with your feedback!',
        NotificationBody    => 'Dear customer...',
        Queues              => [2, 5, 9],  # (optional) survey is valid for these queues
    );

=cut

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

    # check needed stuff
    for my $Argument (
        qw(
        UserID Title Introduction Description
        NotificationSender NotificationSubject NotificationBody
        )
        )
    {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (
        qw(
        Title Introduction Description
        NotificationSender NotificationSubject NotificationBody
        )
        )
    {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument} );
    }
    $Param{UserID} = $Self->{DBObject}->Quote( $Param{UserID}, 'Integer' );

    # insert a new survey
    $Self->{DBObject}->Do(
        SQL => "INSERT INTO survey (title, introduction, description,"
            . " notification_sender, notification_subject, notification_body,"
            . " status, create_time, create_by, change_time, change_by"
            . ") VALUES ("
            . "'$Param{Title}', "
            . "'$Param{Introduction}', "
            . "'$Param{Description}', "
            . "'$Param{NotificationSender}', "
            . "'$Param{NotificationSubject}', "
            . "'$Param{NotificationBody}', "
            . "'New', "
            . "current_timestamp, "
            . "$Param{UserID}, "
            . "current_timestamp, "
            . "$Param{UserID})",
    );

    # get the id of the survey
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM survey WHERE "
            . "title = '$Param{Title}' AND "
            . "introduction = '$Param{Introduction}' AND "
            . "description = '$Param{Description}' "
            . "ORDER BY id DESC",
        Limit => 1,
    );

    # fetch the result
    my $SurveyID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $SurveyID = $Row[0];
    }

    # set the survey number
    $Self->{DBObject}->Do(
        SQL => "UPDATE survey SET "
            . "surveynumber = '"
            . ( $SurveyID + 10000 ) . "' "
            . "WHERE id = $SurveyID"
    );

    return $SurveyID if !$Param{Queues};
    return $SurveyID if ref $Param{Queues} ne 'ARRAY';

    # insert new survey-queue relations
    $Self->SurveyQueueSave(
        SurveyID => $SurveyID,
        QueueIDs => $Param{Queues},
    );

    return $SurveyID;
}

=item QuestionList()

to get a array list of all question items

    my @List = $SurveyObject->QuestionList(
        SurveyID => 1
    );

=cut

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

    # check needed stuff
    if ( !$Param{SurveyID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need SurveyID!',
        );
        return;
    }

    # quote
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # get all questions of a survey
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id, survey_id, question, question_type "
            . " FROM survey_question WHERE survey_id = $Param{SurveyID} ORDER BY position",
    );

    # fetch the result
    my @List;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        my %Data;
        $Data{QuestionID} = $Row[0];
        $Data{SurveyID}   = $Row[1];
        $Data{Question}   = $Row[2];
        $Data{Type}       = $Row[3];

        push @List, \%Data;
    }

    return @List;
}

=item QuestionAdd()

to add a new question to a survey

    $SurveyObject->QuestionAdd(
        UserID => 1,
        SurveyID => 10,
        Question => 'The Question',
        Type => 'Radio',
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(UserID SurveyID Question Type)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(Question Type)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument} );
    }
    for my $Argument (qw(UserID SurveyID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    return if !$Param{Question};

    # insert a new question
    return $Self->{DBObject}->Do(
        SQL => "INSERT INTO survey_question (survey_id, question, question_type, "
            . "position, create_time, create_by, change_time, change_by) VALUES ("
            . "$Param{SurveyID}, "
            . "'$Param{Question}', "
            . "'$Param{Type}', 255, "
            . "current_timestamp, "
            . "$Param{UserID}, "
            . "current_timestamp, "
            . "$Param{UserID})",
    );
}

=item QuestionDelete()

to delete a question from a survey

    $SurveyObject->QuestionDelete(
        SurveyID => 1,
        QuestionID => 10,
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(SurveyID QuestionID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(SurveyID QuestionID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # delete all answers of a question
    $Self->{DBObject}->Do(
        SQL => "DELETE FROM survey_answer WHERE question_id = $Param{QuestionID}",
    );

    # delete the question
    return $Self->{DBObject}->Do(
        SQL => "DELETE FROM survey_question WHERE "
            . "id = $Param{QuestionID} AND "
            . "survey_id = $Param{SurveyID}",
    );
}

=item QuestionSort()

to sort all questions from a survey

    $SurveyObject->QuestionSort(
        SurveyID => 1,
    );

=cut

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

    # check needed stuff
    if ( !$Param{SurveyID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need SurveyID!'
        );
        return;
    }

    # quote
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # get all question of a survey (sorted by position)
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM survey_question"
            . " WHERE survey_id = $Param{SurveyID} ORDER BY position",
    );

    my @List;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @List, $Row[0];
    }

    my $Counter = 1;
    for my $QuestionID (@List) {
        $Self->{DBObject}->Do(
            SQL => "UPDATE survey_question SET position = $Counter WHERE id = $QuestionID",
        );
    }
    continue {
        $Counter++;
    }

    return 1;
}

=item QuestionUp()

to move a question up

    $SurveyObject->QuestionUp(
        SurveyID => 1,
        QuestionID => 4,
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(SurveyID QuestionID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(SurveyID QuestionID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # get position
    $Self->{DBObject}->Prepare(
        SQL => "SELECT position FROM survey_question"
            . " WHERE id = $Param{QuestionID} AND survey_id = $Param{SurveyID}",
        Limit => 1,
    );

    # fetch the result
    my $Position = 0;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Position = $Row[0];
    }

    return if !$Position < 2;

    my $PositionUp = $Position - 1;

    # get question
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM survey_question"
            . " WHERE survey_id = $Param{SurveyID} AND position = $PositionUp",
        Limit => 1,
    );

    # fetch the result
    my $QuestionIDDown;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $QuestionIDDown = $Row[0];
    }

    return if !$QuestionIDDown;

    # update position
    $Self->{DBObject}->Do(
        SQL => "UPDATE survey_question SET "
            . "position = $Position "
            . "WHERE id = $QuestionIDDown",
    );

    # update position
    return $Self->{DBObject}->Do(
        SQL => "UPDATE survey_question SET "
            . "position = $PositionUp "
            . "WHERE id = $Param{QuestionID}",
    );
}

=item QuestionDown()

to move a question down

    $SurveyObject->QuestionDown(
        SurveyID => 1,
        QuestionID => 4,
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(SurveyID QuestionID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(SurveyID QuestionID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # get position
    $Self->{DBObject}->Prepare(
        SQL => "SELECT position FROM survey_question"
            . " WHERE id = $Param{QuestionID} AND survey_id = $Param{SurveyID}",
        Limit => 1,
    );

    # fetch the result
    my $Position;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Position = $Row[0];
    }

    return if !$Position;

    my $PositionDown = $Position + 1;

    # get question
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM survey_question"
            . " WHERE survey_id = $Param{SurveyID} AND position = $PositionDown",
        Limit => 1,
    );

    # fetch the result
    my $QuestionIDUp;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $QuestionIDUp = $Row[0];
    }

    return if !$QuestionIDUp;

    # update position
    $Self->{DBObject}->Do(
        SQL => "UPDATE survey_question SET "
            . "position = $Position "
            . "WHERE id = $QuestionIDUp",
    );

    # update position
    return $Self->{DBObject}->Do(
        SQL => "UPDATE survey_question SET "
            . "position = $PositionDown "
            . "WHERE id = $Param{QuestionID}",
    );
}

=item QuestionGet()

to get all attributes of a question

    my %Question = $SurveyObject->QuestionGet(
        QuestionID => 123
    );

=cut

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

    # check needed stuff
    if ( !$Param{QuestionID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need QuestionID!',
        );
        return;
    }

    # quote
    $Param{QuestionID} = $Self->{DBObject}->Quote( $Param{QuestionID}, 'Integer' );

    # get question
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id, survey_id, question, question_type, position, "
            . "create_time, create_by, change_time, change_by "
            . "FROM survey_question WHERE id = $Param{QuestionID}",
        Limit => 1,
    );

    # fetch the result
    my %Data;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Data{QuestionID} = $Row[0];
        $Data{SurveyID}   = $Row[1];
        $Data{Question}   = $Row[2];
        $Data{Type}       = $Row[3];
        $Data{Position}   = $Row[4];
        $Data{CreateTime} = $Row[5];
        $Data{CreateBy}   = $Row[6];
        $Data{ChangeTime} = $Row[7];
        $Data{ChangeBy}   = $Row[8];
    }

    return %Data;
}

=item QuestionSave()

to update an existing question

    $SurveyObject->QuestionSave(
        UserID => 1,
        QuestionID => 4,
        SurveyID => 3,
        Question => 'The Question',
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(UserID QuestionID SurveyID Question)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(Question)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument} );
    }
    for my $Argument (qw(UserID QuestionID SurveyID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # update question
    return $Self->{DBObject}->Do(
        SQL => "UPDATE survey_question SET "
            . "question = '$Param{Question}', "
            . "change_time = current_timestamp, "
            . "change_by = $Param{UserID} "
            . "WHERE id = $Param{QuestionID} "
            . "AND survey_id = $Param{SurveyID}",
    );
}

=item QuestionCount()

to count all questions of a survey

    my $CountQuestion = $SurveyObject->QuestionCount(
        SurveyID => 123
    );

=cut

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

    # check needed stuff
    if ( !$Param{SurveyID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need SurveyID!',
        );
        return;
    }

    # quote
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # count questions
    $Self->{DBObject}->Prepare(
        SQL   => "SELECT COUNT(id) FROM survey_question WHERE survey_id = $Param{SurveyID}",
        Limit => 1,
    );

    # fetch the result
    my $CountQuestion;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $CountQuestion = $Row[0];
    }

    return $CountQuestion;
}

=item AnswerList()

to get a array list of all answer items

    my @List = $SurveyObject->AnswerList(
        QuestionID => 1
    );

=cut

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

    # check needed stuff
    if ( !$Param{QuestionID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need QuestionID!',
        );
        return;
    }

    # quote
    $Param{QuestionID} = $Self->{DBObject}->Quote( $Param{QuestionID}, 'Integer' );

    # get answer list
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id, question_id, answer "
            . " FROM survey_answer WHERE question_id = $Param{QuestionID} ORDER BY position",
    );

    # fetcht the result
    my @List;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        my %Data;
        $Data{AnswerID}   = $Row[0];
        $Data{QuestionID} = $Row[1];
        $Data{Answer}     = $Row[2];

        push @List, \%Data;
    }

    return @List;
}

=item AnswerAdd()

to add a new answer to a question

    $SurveyObject->AnswerAdd(
        UserID => 1,
        QuestionID => 10,
        Answer => 'The Answer',
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(UserID QuestionID Answer)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(Answer)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument} );
    }
    for my $Argument (qw(UserID QuestionID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    return if !$Param{Answer};

    # insert answer
    return $Self->{DBObject}->Do(
        SQL => "INSERT INTO survey_answer (question_id, answer, position, "
            . "create_time, create_by, change_time, change_by) VALUES ("
            . "$Param{QuestionID}, "
            . "'$Param{Answer}', 255, "
            . "current_timestamp, "
            . "$Param{UserID}, "
            . "current_timestamp, "
            . "$Param{UserID})",
    );
}

=item AnswerDelete()

to delete a answer from a question

    $SurveyObject->AnswerDelete(
        QuestionID => 10,
        AnswerID => 4,
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(QuestionID AnswerID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(QuestionID AnswerID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # delete answer
    return $Self->{DBObject}->Do(
        SQL => "DELETE FROM survey_answer WHERE "
            . "id = $Param{AnswerID} AND question_id = $Param{QuestionID}",
    );
}

=item AnswerSort()

to sort all answers from a question

    $SurveyObject->AnswerSort(
        QuestionID => 1,
    );

=cut

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

    # check needed stuff
    if ( !$Param{QuestionID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need QuestionID!',
        );
        return;
    }

    # quote
    $Param{QuestionID} = $Self->{DBObject}->Quote( $Param{QuestionID}, 'Integer' );

    # get answer list
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM survey_answer"
            . " WHERE question_id = $Param{QuestionID} ORDER BY position",
    );

    # fetch the result
    my @List;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @List, $Row[0];
    }

    my $Counter = 1;
    for my $AnswerID (@List) {

        # update position
        $Self->{DBObject}->Do(
            SQL => "UPDATE survey_answer SET position = $Counter WHERE id = $AnswerID",
        );
    }
    continue {
        $Counter++;
    }

    return 1;
}

=item AnswerUp()

to move a answer up

    $SurveyObject->AnswerUp(
        QuestionID => 4,
        AnswerID => 1,
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(QuestionID AnswerID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(QuestionID AnswerID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # get position
    $Self->{DBObject}->Prepare(
        SQL => "SELECT position FROM survey_answer"
            . " WHERE id = $Param{AnswerID} AND question_id = $Param{QuestionID}",
        Limit => 1,
    );

    # fetch the result
    my $Position;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Position = $Row[0];
    }

    return if !$Position < 2;

    my $PositionUp = $Position - 1;

    # get answer
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM survey_answer"
            . " WHERE question_id = $Param{QuestionID} AND position = $PositionUp",
        Limit => 1,
    );

    # fetch the result
    my $AnswerIDDown;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $AnswerIDDown = $Row[0];
    }

    return if !$AnswerIDDown;

    # update position
    $Self->{DBObject}->Do(
        SQL => "UPDATE survey_answer SET position = $Position WHERE id = $AnswerIDDown",
    );

    # update position
    return $Self->{DBObject}->Do(
        SQL => "UPDATE survey_answer SET "
            . "position = $PositionUp "
            . "WHERE id = $Param{AnswerID}",
    );
}

=item AnswerDown()

to move a answer down

    $SurveyObject->AnswerDown(
        QuestionID => 4,
        AnswerID => 1,
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(QuestionID AnswerID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(QuestionID AnswerID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # get position
    $Self->{DBObject}->Prepare(
        SQL => "SELECT position FROM survey_answer"
            . " WHERE id = $Param{AnswerID} AND question_id = $Param{QuestionID}",
        Limit => 1,
    );

    # fetch the result
    my $Position;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Position = $Row[0];
    }

    return if !$Position;

    my $PositionDown = $Position + 1;

    # get answer
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id FROM survey_answer"
            . " WHERE question_id = $Param{QuestionID} AND position = $PositionDown",
        Limit => 1,
    );

    # fetch the result
    my $AnswerIDUp;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $AnswerIDUp = $Row[0];
    }

    return if !$AnswerIDUp;

    # update position
    $Self->{DBObject}->Do(
        SQL => "UPDATE survey_answer SET position = $Position WHERE id = $AnswerIDUp",
    );

    # update position
    return $Self->{DBObject}->Do(
        SQL => "UPDATE survey_answer SET "
            . "position = $PositionDown "
            . "WHERE id = $Param{AnswerID}",
    );
}

=item AnswerGet()

to get all attributes of a answer

    my %Answer = $SurveyObject->AnswerGet(
        AnswerID => 123
    );

=cut

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

    # check needed stuff
    if ( !$Param{AnswerID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need QuestionID!',
        );
        return;
    }

    # quote
    $Param{AnswerID} = $Self->{DBObject}->Quote( $Param{AnswerID}, 'Integer' );

    # get answer
    $Self->{DBObject}->Prepare(
        SQL =>
            "SELECT id, question_id, answer, position, create_time, create_by, change_time, change_by "
            . "FROM survey_answer WHERE id = $Param{AnswerID}",
        Limit => 1,
    );

    # fetch the result
    my %Data;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Data{AnswerID}   = $Row[0];
        $Data{QuestionID} = $Row[1];
        $Data{Answer}     = $Row[2];
        $Data{Position}   = $Row[3];
        $Data{CreateTime} = $Row[4];
        $Data{CreateBy}   = $Row[5];
        $Data{ChangeTime} = $Row[6];
        $Data{ChangeBy}   = $Row[7];
    }

    return %Data;
}

=item AnswerSave()

to update an existing answer

    $SurveyObject->AnswerSave(
        UserID => 1,
        AnswerID => 6,
        QuestionID => 4,
        Answer => 'The Answer',
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(UserID AnswerID QuestionID Answer)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(Answer)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument} );
    }
    for my $Argument (qw(UserID AnswerID QuestionID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    return if !$Param{Answer};

    # update answer
    return $Self->{DBObject}->Do(
        SQL => "UPDATE survey_answer SET "
            . "answer = '$Param{Answer}', "
            . "change_time = current_timestamp, "
            . "change_by = $Param{UserID} "
            . "WHERE id = $Param{AnswerID} "
            . "AND question_id = $Param{QuestionID}",
    );
}

=item AnswerCount()

to count all answers of a question

    my $CountAnswer = $SurveyObject->AnswerCount(
        QuestionID => 123
    );

=cut

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

    # check needed stuff
    if ( !$Param{QuestionID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need QuestionID!',
        );
        return;
    }

    # quote
    $Param{QuestionID} = $Self->{DBObject}->Quote( $Param{QuestionID}, 'Integer' );

    # count answers
    $Self->{DBObject}->Prepare(
        SQL   => "SELECT COUNT(id) FROM survey_answer WHERE question_id = $Param{QuestionID}",
        Limit => 1,
    );

    # fetch the result
    my $CountAnswer;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $CountAnswer = $Row[0];
    }

    return $CountAnswer;
}

=item VoteList()

to get a array list of all vote items

    my @List = $SurveyObject->VoteList(
        SurveyID => 1
    );

=cut

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

    # check needed stuff
    if ( !$Param{SurveyID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need SurveyID!',
        );
        return;
    }

    # quote
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # get vote list
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id, ticket_id, send_time, vote_time "
            . "FROM survey_request WHERE survey_id = $Param{SurveyID} "
            . "AND valid_id = 0 ORDER BY vote_time DESC",
    );

    # fetch the result
    my @List;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        my %Data;
        $Data{RequestID} = $Row[0];
        $Data{TicketID}  = $Row[1];
        $Data{SendTime}  = $Row[2];
        $Data{VoteTime}  = $Row[3];

        push @List, \%Data;
    }

    return @List;
}

=item VoteGet()

to get all attributes of a vote

    my @Vote = $SurveyObject->VoteGet(
        RequestID => 13,
        QuestionID => 23
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(RequestID QuestionID)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(RequestID QuestionID)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument}, 'Integer' );
    }

    # get vote
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id, vote_value FROM survey_vote"
            . " WHERE request_id = $Param{RequestID} AND question_id = $Param{QuestionID}",
        Limit => 1,
    );

    # fetch the result
    my @List;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        my %Data;
        $Data{RequestID} = $Row[0];
        $Data{VoteValue} = $Row[1] || '-';

        push @List, \%Data;
    }

    return @List;
}

=item CountVote()

to count all votes of a survey

    my $CountVote = $SurveyObject->CountVote(
        QuestionID => 123,
        VoteValue => 'The Value',
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(QuestionID VoteValue)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    $Param{VoteValue} = $Self->{DBObject}->Quote( $Param{VoteValue} );
    $Param{QuestionID} = $Self->{DBObject}->Quote( $Param{QuestionID}, 'Integer' );

    # count votes
    $Self->{DBObject}->Prepare(
        SQL => "SELECT COUNT(vote_value) FROM survey_vote WHERE "
            . "question_id = $Param{QuestionID} AND vote_value = '$Param{VoteValue}'",
        Limit => 1,
    );

    # fetch the result
    my $CountVote;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $CountVote = $Row[0];
    }

    return $CountVote;
}

=item CountRequest()

to count all requests of a survey

    my $CountRequest = $SurveyObject->CountRequest(
        QuestionID => 123,
        ValidID => 0,       # (0|1|all)
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(SurveyID ValidID)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # count requests
    my $SQL = "SELECT COUNT(id) FROM survey_request WHERE survey_id = $Param{SurveyID}";

    # add valid part
    if ( !$Param{ValidID} ) {
        $SQL .= " AND valid_id = 0";
    }
    elsif ( $Param{ValidID} eq 1 ) {
        $SQL .= " AND valid_id = 1";
    }

    # ask database
    $Self->{DBObject}->Prepare(
        SQL   => $SQL,
        Limit => 1,
    );

    # fetch the result
    my $CountRequest;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $CountRequest = $Row[0];
    }

    return $CountRequest;
}

=item ElementExists()

exists an survey-, question-, answer- or request-element

    my $CountRequest = $SurveyObject->ElementExists(
        ID => 123,           # SurveyID, QuestionID, AnswerID, RequestID
        Element => 'Survey'  # Survey, Question, Answer, Request
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(ElementID Element)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    $Param{Element} = $Self->{DBObject}->Quote( $Param{Element} );
    $Param{ElementID} = $Self->{DBObject}->Quote( $Param{ElementID}, 'Integer' );

    my %LookupTable = (
        Survey   => 'survey',
        Question => 'survey_question',
        Answer   => 'survey_answer',
        Request  => 'survey_request',
    );

    # count element
    $Self->{DBObject}->Prepare(
        SQL   => "SELECT COUNT(id) FROM $LookupTable{$Param{Element}} WHERE id = $Param{ElementID}",
        Limit => 1,
    );

    # fetch the result
    my $ElementExists = 'No';
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        if ( $Row[0] ) {
            $ElementExists = 'Yes';
        }
    }

    return $ElementExists;
}

=item RequestSend()

to send a request to a customer (if master survey is set)

    $SurveyObject->RequestSend(
        TicketID => 123,
    );

=cut

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

    # check needed stuff
    if ( !$Param{TicketID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need TicketID!',
        );
        return;
    }

    # create PublicSurveyKey
    my $md5 = Digest::MD5->new();
    $md5->add( $Self->{TimeObject}->SystemTime() . int( rand(999999999) ) );
    my $PublicSurveyKey = $md5->hexdigest;

    # find master survey
    $Self->{DBObject}->Prepare(
        SQL   => "SELECT id FROM survey WHERE status = 'Master'",
        Limit => 1,
    );

    # fetch the result
    my $SurveyID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $SurveyID = $Row[0];
    }

    # return, no master survey found
    return if !$SurveyID;

    # get the survey
    my %Survey = $Self->SurveyGet(
        SurveyID => $SurveyID,
    );
    my $Subject = $Survey{NotificationSubject};
    my $Body    = $Survey{NotificationBody};

    # fix new lines
    $Body =~ s/(\n\r|\r\r\n|\r\n)/\n/g;

    # ticket data
    my %Ticket = $Self->{TicketObject}->TicketGet(
        TicketID => $Param{TicketID},
    );

    for my $Data ( keys %Ticket ) {
        if ( defined $Ticket{$Data} ) {
            $Subject =~ s/<OTRS_TICKET_$Data>/$Ticket{$Data}/gi;
            $Body    =~ s/<OTRS_TICKET_$Data>/$Ticket{$Data}/gi;
        }
    }

    # check if ticket is in a send queue
    if ( $Survey{Queues} && ref $Survey{Queues} eq 'ARRAY' && @{ $Survey{Queues} } ) {
        my $Found;

        QUEUE:
        for my $QueueID ( @{ $Survey{Queues} } ) {
            next QUEUE if $Ticket{QueueID} != $QueueID;
            $Found = 1;
            last QUEUE;
        }

        return if !$Found;
    }

    # cleanup
    $Subject =~ s/<OTRS_TICKET_.+?>/-/gi;
    $Body    =~ s/<OTRS_TICKET_.+?>/-/gi;

    # replace config options
    $Subject =~ s{<OTRS_CONFIG_(.+?)>}{$Self->{ConfigObject}->Get($1)}egx;
    $Body    =~ s{<OTRS_CONFIG_(.+?)>}{$Self->{ConfigObject}->Get($1)}egx;

    # cleanup
    $Subject =~ s/<OTRS_CONFIG_.+?>/-/gi;
    $Body    =~ s/<OTRS_CONFIG_.+?>/-/gi;

    # get customer data and replace it with <OTRS_CUSTOMER_DATA_...
    my %CustomerUser;
    if ( $Ticket{CustomerUserID} ) {
        %CustomerUser = $Self->{CustomerUserObject}->CustomerUserDataGet(
            User => $Ticket{CustomerUserID},
        );

        # replace customer stuff with tags
        for my $Data ( keys %CustomerUser ) {
            next if !$CustomerUser{$Data};

            $Subject =~ s/<OTRS_CUSTOMER_DATA_$Data>/$CustomerUser{$Data}/gi;
            $Body    =~ s/<OTRS_CUSTOMER_DATA_$Data>/$CustomerUser{$Data}/gi;
        }
    }

    # cleanup all not needed <OTRS_CUSTOMER_DATA_ tags
    $Subject =~ s/<OTRS_CUSTOMER_DATA_.+?>/-/gi;
    $Body    =~ s/<OTRS_CUSTOMER_DATA_.+?>/-/gi;

    # replace key
    $Subject =~ s/<OTRS_PublicSurveyKey>/$PublicSurveyKey/gi;
    $Body    =~ s/<OTRS_PublicSurveyKey>/$PublicSurveyKey/gi;

    my $ToString = $CustomerUser{UserEmail};

    if ( !$ToString ) {
        my %Article = $Self->{TicketObject}->ArticleLastCustomerArticle(
            TicketID => $Param{TicketID},
        );
        $ToString = $Article{From};
    }

    # parse the to string
    my $To;
    for my $ToParser ( Mail::Address->parse($ToString) ) {
        $To = $ToParser->address();
    }

    # return if no to is found
    return if !$To;

    # check if it's a valid email addedss (min is needed)
    return if $To !~ /@/;

    # konvert to lower cases
    $To = lc $To;

    # check if not survey should be send
    my $SendNoSurveyRegExp = $Self->{ConfigObject}->Get('Survey::SendNoSurveyRegExp');

    return if $SendNoSurveyRegExp && $To =~ /$SendNoSurveyRegExp/i;

    # quote
    $To = $Self->{DBObject}->Quote($To);

    # check if a survey is sent in the last time
    my $SendPeriod = $Self->{ConfigObject}->Get('Survey::SendPeriod');
    if ($SendPeriod) {
        my $LastSentTime = 0;

        # get send time
        $Self->{DBObject}->Prepare(
            SQL => "SELECT send_time FROM survey_request WHERE LOWER(send_to) = '$To' "
                . "ORDER BY send_time DESC",
            Limit => 1,
        );

        # fetch the result
        while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
            $LastSentTime = $Row[0];
        }
        if ($LastSentTime) {
            my $Now = $Self->{TimeObject}->SystemTime();
            $LastSentTime = $Self->{TimeObject}->TimeStamp2SystemTime( String => $LastSentTime );

            return if ( $LastSentTime + $SendPeriod * 60 * 60 * 24 ) > $Now;
        }
    }

    # insert request
    $Param{TicketID} = $Self->{DBObject}->Quote( $Param{TicketID}, 'Integer' );
    $Self->{DBObject}->Do(
        SQL => "INSERT INTO survey_request "
            . " (ticket_id, survey_id, valid_id, public_survey_key, send_to, send_time) "
            . " VALUES ($Param{TicketID}, $SurveyID, 1, '"
            . $Self->{DBObject}->Quote($PublicSurveyKey) . "', "
            . "'$To', current_timestamp)",
    );

    # log action on ticket
    $Self->{TicketObject}->HistoryAdd(
        TicketID     => $Param{TicketID},
        CreateUserID => 1,
        HistoryType  => 'Misc',
        Name         => "Sent customer survey to '$To'.",
    );

    # get charset
    my $Charset = $Self->{ConfigObject}->Get('DefaultCharset') || 'uft-8';

    # convert body to html
    $Body = $Self->{HTMLUtilsObject}->ToHTML(
        String => $Body,
    );

    # prepare html links
    $Self->{HTMLUtilsObject}->LinkQuote(
        String => \$Body,
    );

    # complete html document
    $Body = $Self->{HTMLUtilsObject}->DocumentComplete(
        String  => $Body,
        Charset => $Charset,
    );

    # send survey
    return $Self->{SendmailObject}->Send(
        From     => $Survey{NotificationSender},
        To       => $To,
        Subject  => $Subject,
        MimeType => 'text/html',
        Charset  => $Charset,
        Body     => $Body,
    );
}

=item PublicSurveyGet()

to get all public attributes of a survey

    my %PublicSurvey = $SurveyObject->PublicSurveyGet(
        PublicSurveyKey => 'Aw5de3Xf5qA',
    );

=cut

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

    # check needed stuff
    if ( !defined $Param{PublicSurveyKey} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need SurveyID!',
        );
        return;
    }

    # quote
    $Param{PublicSurveyKey} = $Self->{DBObject}->Quote( $Param{PublicSurveyKey} );

    # get request
    $Self->{DBObject}->Prepare(
        SQL => "SELECT survey_id FROM survey_request "
            . "WHERE public_survey_key = '$Param{PublicSurveyKey}' AND valid_id = 1",
        Limit => 1,
    );

    # fetch the result
    my $SurveyID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $SurveyID = $Row[0];
    }

    return () if !$SurveyID;

    # get survey
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id, surveynumber, title, introduction "
            . "FROM survey WHERE id = $SurveyID AND (status = 'Master' OR status = 'Valid')",
        Limit => 1,
    );

    # fetch the result
    my %Data;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $Data{SurveyID}     = $Row[0];
        $Data{SurveyNumber} = $Row[1];
        $Data{Title}        = $Row[2];
        $Data{Introduction} = $Row[3];
    }

    return %Data;
}

=item PublicAnswerSave()

to save a public vote

    $SurveyObject->PublicAnswerSave(
        PublicSurveyKey => 'aVkdE82Dw2qw6erCda',
        QuestionID => 4,
        VoteValue => 'The Value',
    );

=cut

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

    # check needed stuff
    for my $Argument (qw(PublicSurveyKey QuestionID VoteValue)) {
        if ( !defined $Param{$Argument} ) {
            $Self->{LogObject}->Log(
                Priority => 'error',
                Message  => "Need $Argument!",
            );
            return;
        }
    }

    # quote
    for my $Argument (qw(PublicSurveyKey VoteValue)) {
        $Param{$Argument} = $Self->{DBObject}->Quote( $Param{$Argument} );
    }
    $Param{QuestionID} = $Self->{DBObject}->Quote( $Param{QuestionID}, 'Integer' );

    # get request
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id "
            . " FROM survey_request WHERE public_survey_key = '$Param{PublicSurveyKey}' AND valid_id = 1",
        Limit => 1,
    );

    # fetch the result
    my $RequestID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $RequestID = $Row[0];
    }

    return if !$RequestID;

    # insert vote
    return $Self->{DBObject}->Do(
        SQL => "INSERT INTO survey_vote (request_id, question_id, vote_value, create_time) VALUES ("
            . "$RequestID, "
            . "$Param{QuestionID}, "
            . "'$Param{VoteValue}', "
            . "current_timestamp)",
    );
}

=item PublicSurveyInvalidSet()

to set a request invalid

    $SurveyObject->PublicSurveyInvalidSet(
        PublicSurveyKey => 'aVkdE82Dw2qw6erCda',
    );

=cut

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

    # check needed stuff
    if ( !$Param{PublicSurveyKey} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need SurveyID!'
        );
        return;
    }

    # quote
    $Param{PublicSurveyKey} = $Self->{DBObject}->Quote( $Param{PublicSurveyKey} );

    # get request
    $Self->{DBObject}->Prepare(
        SQL => "SELECT id "
            . " FROM survey_request WHERE public_survey_key = '$Param{PublicSurveyKey}'",
        Limit => 1,
    );

    # fetch the result
    my $RequestID;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        $RequestID = $Row[0];
    }

    return if !$RequestID;

    # update request
    return $Self->{DBObject}->Do(
        SQL => "UPDATE survey_request SET "
            . "valid_id = 0, "
            . "vote_time = current_timestamp "
            . "WHERE id = $RequestID",
    );
}

=item SurveyQueueSave()

add a survey_queue relation

my $Result = $SurveyObject->SurveyQueueSave(
    SurveyID => 3,
    QueueIDs => [1, 7],
);

=cut

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

    # check needed stuff
    for my $Argument (qw(SurveyID QueueIDs)) {
        if ( !$Param{$Argument} ) {
            $Self->{LogObject}->Log( Priority => 'error', Message => "Need $Argument!" );
            return;
        }
    }

    # quote
    for my $QueueID ( @{ $Param{QueueIDs} } ) {
        $QueueID = $Self->{DBObject}->Quote( $QueueID, 'Integer' );
    }
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # remove all existing relations
    $Self->{DBObject}->Do(
        SQL => "DELETE FROM survey_queue WHERE survey_id = $Param{SurveyID}",
    );

    # add all survey_queue relations to database
    for my $QueueID ( @{ $Param{QueueIDs} } ) {

        # add survey_queue relation to database
        return if !$Self->{DBObject}->Do(
            SQL => "INSERT INTO survey_queue"
                . " (survey_id, queue_id) VALUES"
                . " ($Param{SurveyID}, $QueueID)",
        );
    }

    return 1;
}

=item SurveyQueueGet()

get a survey_queue relation as an array reference

my $QueuesRef = $SurveyObject->SurveyQueueGet(
    SurveyID => 3,
);

=cut

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

    # check needed stuff
    if ( !$Param{SurveyID} ) {
        $Self->{LogObject}->Log(
            Priority => 'error',
            Message  => 'Need SurveyID!',
        );
        return;
    }

    # quote
    $Param{SurveyID} = $Self->{DBObject}->Quote( $Param{SurveyID}, 'Integer' );

    # get queue ids from database
    $Self->{DBObject}->Prepare(
        SQL => "SELECT queue_id FROM survey_queue"
            . " WHERE survey_id = $Param{SurveyID} ORDER BY queue_id ASC",
    );

    # fetch the result
    my @QueueList;
    while ( my @Row = $Self->{DBObject}->FetchrowArray() ) {
        push @QueueList, $Row[0];
    }

    return \@QueueList;
}

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 http://www.gnu.org/licenses/agpl.txt.

=head1 VERSION

$Revision: 1.50 $ $Date: 2010/05/21 12:49:51 $

=cut

IyAtLQojIEtlcm5lbC9TeXN0ZW0vVGlja2V0L0V2ZW50L1N1cnZleVNlbmRSZXF1ZXN0LnBtIC0gc2VuZCBzdXJ2ZXkgcmVxdWVzdHMKIyBDb3B5cmlnaHQgKEMpIDIwMDEtMjAxMCBPVFJTIEFHLCBodHRwOi8vb3Rycy5vcmcvCiMgLS0KIyAkSWQ6IFN1cnZleVNlbmRSZXF1ZXN0LnBtLHYgMS4xNCAyMDEwLzA1LzIxIDEyOjQ5OjUyIG1oIEV4cCAkCiMgLS0KIyBUaGlzIHNvZnR3YXJlIGNvbWVzIHdpdGggQUJTT0xVVEVMWSBOTyBXQVJSQU5UWS4gRm9yIGRldGFpbHMsIHNlZQojIHRoZSBlbmNsb3NlZCBmaWxlIENPUFlJTkcgZm9yIGxpY2Vuc2UgaW5mb3JtYXRpb24gKEFHUEwpLiBJZiB5b3UKIyBkaWQgbm90IHJlY2VpdmUgdGhpcyBmaWxlLCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzL2FncGwudHh0LgojIC0tCgpwYWNrYWdlIEtlcm5lbDo6U3lzdGVtOjpUaWNrZXQ6OkV2ZW50OjpTdXJ2ZXlTZW5kUmVxdWVzdDsKCnVzZSBzdHJpY3Q7CnVzZSB3YXJuaW5nczsKCnVzZSBLZXJuZWw6OlN5c3RlbTo6U3VydmV5OwoKdXNlIHZhcnMgcXcoJFZFUlNJT04pOwokVkVSU0lPTiA9IHF3KCRSZXZpc2lvbjogMS4xNCAkKSBbMV07CgpzdWIgbmV3IHsKICAgIG15ICggJFR5cGUsICVQYXJhbSApID0gQF87CgogICAgIyBhbGxvY2F0ZSBuZXcgaGFzaCBmb3Igb2JqZWN0CiAgICBteSAkU2VsZiA9IHt9OwogICAgYmxlc3MoICRTZWxmLCAkVHlwZSApOwoKICAgICMgY2hlY2sgbmVlZGVkIG9iamVjdHMKICAgIGZvciBteSAkT2JqZWN0ICgKICAgICAgICBxdyhDb25maWdPYmplY3QgVGlja2V0T2JqZWN0IExvZ09iamVjdCBVc2VyT2JqZWN0IERCT2JqZWN0IE1haW5PYmplY3QgVGltZU9iamVjdCBFbmNvZGVPYmplY3QpCiAgICAgICAgKQogICAgewogICAgICAgICRTZWxmLT57JE9iamVjdH0gPSAkUGFyYW17JE9iamVjdH0gfHwgZGllICJHb3Qgbm8gJE9iamVjdCEiOwogICAgfQogICAgJFNlbGYtPntTdXJ2ZXlPYmplY3R9ID0gS2VybmVsOjpTeXN0ZW06OlN1cnZleS0+bmV3KCAleyRTZWxmfSApOwoKICAgIHJldHVybiAkU2VsZjsKfQoKc3ViIFJ1biB7CiAgICBteSAoICRTZWxmLCAlUGFyYW0gKSA9IEBfOwoKICAgICMgY2hlY2sgbmVlZGVkIHN0dWZmCiAgICBmb3IgbXkgJEFyZ3VtZW50IChxdyhUaWNrZXRJRCBFdmVudCBDb25maWcpKSB7CiAgICAgICAgaWYgKCAhJFBhcmFteyRBcmd1bWVudH0gKSB7CiAgICAgICAgICAgICRTZWxmLT57TG9nT2JqZWN0fS0+TG9nKAogICAgICAgICAgICAgICAgUHJpb3JpdHkgPT4gJ2Vycm9yJywKICAgICAgICAgICAgICAgIE1lc3NhZ2UgID0+ICJOZWVkICRBcmd1bWVudCEiLAogICAgICAgICAgICApOwogICAgICAgICAgICByZXR1cm47CiAgICAgICAgfQogICAgfQoKICAgICMgZ2V0IHRpY2tldCBkYXRhCiAgICBteSAlVGlja2V0ID0gJFNlbGYtPntUaWNrZXRPYmplY3R9LT5UaWNrZXRHZXQoCiAgICAgICAgVGlja2V0SUQgPT4gJFBhcmFte1RpY2tldElEfSwKICAgICk7CgogICAgcmV0dXJuIDEgaWYgJFRpY2tldHtTdGF0ZVR5cGV9IG5lICdjbG9zZWQnOwoKICAgICMgc2VuZCBhbHNvIHN1cnZleSByZXF1ZXN0IG9uIHRpY2tldCBjcmVhdGlvbiAob24gZmlyc3QgYXJ0aWNsZSkKICAgIGlmICggJFBhcmFte0V2ZW50fSBlcSAnQXJ0aWNsZUNyZWF0ZScgKSB7CgogICAgICAgIG15IEBBcnRpY2xlSW5kZXggPSAkU2VsZi0+e1RpY2tldE9iamVjdH0tPkFydGljbGVJbmRleCgKICAgICAgICAgICAgVGlja2V0SUQgPT4gJFBhcmFte1RpY2tldElEfSwKICAgICAgICApOwoKICAgICAgICByZXR1cm4gMSBpZiBzY2FsYXIgQEFydGljbGVJbmRleCAhPSAxOwogICAgfQoKICAgICMgc2VuZCByZXF1ZXN0CiAgICAkU2VsZi0+e1N1cnZleU9iamVjdH0tPlJlcXVlc3RTZW5kKAogICAgICAgIFRpY2tldElEID0+ICRQYXJhbXtUaWNrZXRJRH0sCiAgICApOwoKICAgIHJldHVybiAxOwp9CgoxOwo=
iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAIAAAE80cv6AAAABnRSTlMA/wD/AP83WBt9AAAACXBIWXMAAAsSAAALEgHS3X78AAAACXRFWHRDb21tZW50AACJKo0GAAAEyUlEQVR4nI2UeVCTRxjGFzqOrUPFCiMOU6tQ69gySoFyqG2xSusYQc4A7QhBBOQsVoFgyow4IJp4FERsCaBQIAGD3AkhnCHJlwQSIISiNZiQBJBaBBISQsjxNalY20qPZ94/dt5959nd3767AH4hsCmKmNRcq9VqgWMiIeVUrt4VgJezd0Y1aF6yeVTW+WDp0EbzyDaaSIKeOjVZubRuZgjU5tTWmJoirjKWNJAms20+Hqh3+ZNHWwhy1Qz+q0B8/jiuXnS0b8uZwhafbCb4pmGqkKfKGU5l81gHLzDAxc6Fm5Ayf3lDBM1Jj4kBqO8689vG4IjtutOINiTypV9HJGrVnyedHZQ/G5LPYTmXyVJKwWA+R/zUlFTr9OYKqwhCMkFewlbgIYUfIQM7tymU+WZ5PYfcP3kwi26usEYRisgi+sQyaUjr3WMZMgR8mCC4wcUAw4n2rpzDHsAd01k8vNQk090b117haEdR7xJCwklfIPToKL0baEEcAysGo3JF/zwUOiM1MMDoabHiBlr9A9Ym8arA2MwCXzY7JH9WxiW2SslkGQXXnS+YmuNIZlcrYm6Isgnipv7ZHTc9Dnfb+XRvsb29Pu6avKprZl6jM1c4pVJNRy1lKy62qM5PWn879dbZigTqwFQoDlJqf+fxCaa9YEB19ydNFlV1WZB2ZTgz6L73inYlrZyver4KpnowjzLNlmuP38X784E/Dzi3A5VSmfsjREdFNnm5A+9cqJCtNF0/tkedJduRp7COHdnWTavuTYiDP7Ds3roO5HbP1Yi0zXJdiUCNvVFV6fjGE95IX0oSvNuCaQsUEglA4Wg59/gVvY8yiYJWZzs42P7h3o2wkyXDFignJsz7UCzrzEC1Zqa/SmT87RbwR4BuAxal0rWZLojGSe4eCrH4JdM1SRuNhq5HHTUCAkVErhUSm4WNGu3SP15LQfuDcxWCuO95qML+YBwrCMcKu87YVeAZ2RuexIpOYZ9MYp2MZUTturUnuZTie4mbiOefxnOLaOManWHVwuoEcVtkb+BlQc/PKp502RRcyUrGfY5rvb3/IPhKCAL54EAfcCi0Popu2BvHOnKes/8shMiFFpZ1qxbWkQTXDNopwnR2xzyuT3GVocjpmk+uWwgtr8WO+eKnP78x7hdav7+RS5qeWMWDrhz6GNOrXNa/sEDVoK7TrjUJax5qoDkje95IkRkyaBCi3RPJdkSyHUKgnQF9u/c0WF2oT5WJZZLHovgSzr7URl5xqfCH4vnRUWAXU3Msj55eN1k/oiYNL9YOLTYJ1TiaIqg56vRj8LUUxI+DsBHwGRP4UDY/eCLQTM9UHj4CJcUbsmJhd2uuHQBvx9WdqhJjWYuFAyr88JIpbvFUWKYSTVFmt2NuQ86XWj+80uV3vTOlrDSn3OsAPSnBgIk29Y3ppTFtABUZClzTW3Bd06bNs+ZhgQYe0cDQAkydNN4Z1RVdxRtO7tR9+Q7Nwap4uwPz3BkDGgW//5rpi2PYgJZjvgqxxMwik9B/Ir/LPb3W/Vy1Z1r1vnSCV1q1ZyYJga6+6XlI6LTBiNgEf/o67GEBOwGdG6BvBm3IUPXML//RWn9ocXKqIyyMbb9u8j3Qs3U9NTx8USb/e2v9u8X/0W/kgfZfFJgyAAAAAABJRU5ErkJggg==
# --
# Survey.t - Survey tests
# Copyright (C) 2001-2010 OTRS AG, http://otrs.org/
# --
# $Id: Survey.t,v 1.15 2010/06/02 15:40:48 mh Exp $
# --
# 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);

use Kernel::System::CustomerUser;
use Kernel::System::Email;
use Kernel::System::Survey;
use Kernel::System::Ticket;
use Kernel::System::User;

$Self->{UserObject}         = Kernel::System::User->new( %{$Self} );
$Self->{CustomerUserObject} = Kernel::System::CustomerUser->new( %{$Self} );
$Self->{SendmailObject}     = Kernel::System::Email->new( %{$Self} );
$Self->{TicketObject}       = Kernel::System::Ticket->new( %{$Self} );
$Self->{SurveyObject}       = Kernel::System::Survey->new( %{$Self} );

# save original sendmail config
my $SendmailModule = $Self->{ConfigObject}->Get('SendmailModule');

# set config to not send emails
$Self->{ConfigObject}->Set(
    Key   => 'SendmailModule',
    Value => 'Kernel::System::Email::DoNotSendEmail',
);

# create survey
my %SurveyData = (
    Title               => 'A Title',
    Introduction        => 'The introduction of the survey',
    Description         => 'The internal description of the survey',
    NotificationSender  => 'quality@example.com',
    NotificationSubject => 'Help us with your feedback! ÄÖÜ',
    NotificationBody    => 'Dear customer... äöü',
);
my $SurveyID = $Self->{SurveyObject}->SurveyNew(
    UserID => 1,
    %SurveyData,
);
$Self->True(
    $SurveyID,
    "SurveyNew()",
);

for ( 1 .. 3 ) {
    my $QuestionAdd = $Self->{SurveyObject}->QuestionAdd(
        UserID   => 1,
        SurveyID => $SurveyID,
        Question => 'The Question',
        Type     => 'Radio',
    );
}
my @List = $Self->{SurveyObject}->QuestionList(
    SurveyID => $SurveyID,
);
for my $Question (@List) {
    for ( 1 .. 3 ) {
        $Self->{SurveyObject}->AnswerAdd(
            UserID     => 1,
            QuestionID => $Question->{QuestionID},
            Answer     => 'The Answer',
        );
    }
}

my $StatusSet = $Self->{SurveyObject}->SurveyStatusSet(
    SurveyID  => $SurveyID,
    NewStatus => 'Master'
);
$Self->Is(
    $StatusSet,
    'StatusSet',
    "SurveyStatusSet()",
);

my %SurveyGet = $Self->{SurveyObject}->SurveyGet(
    SurveyID => $SurveyID,
);

for my $Key ( sort keys %SurveyGet ) {
    next if !defined $SurveyData{$Key};
    $Self->Is(
        $SurveyGet{$Key},
        $SurveyData{$Key},
        "SurveyGet()",
    );
}

my @Tests = (
    {
        Name                 => '#1 try',
        'Survey::SendPeriod' => 100,
        Ticket               => {
            Title        => 'Some Ticket Title',
            Queue        => 'Raw',
            Lock         => 'unlock',
            Priority     => '3 normal',
            State        => 'open',
            CustomerNo   => '123465',
            CustomerUser => 'customer@example.com',
            OwnerID      => 1,
            UserID       => 1,
        },
        Article => {
            ArticleType    => 'email-external',
            SenderType     => 'customer',
            From           => 'Some Customer <some@example.com>',
            To             => 'Some To <to@example.com>',
            Subject        => 'Some Subject',
            Body           => 'the message text',
            MessageID      => '<asdasdasd.123@example.com>',
            ContentType    => 'text/plain; charset=ISO-8859-15',
            HistoryType    => 'OwnerUpdate',
            HistoryComment => 'Some free text!',
            UserID         => 1,
            NoAgentNotify => 1,    # if you don't want to send agent notifications
        },
        Result => [
            1,
            0,
        ],
    },
    {
        Name                 => '#2 try',
        'Survey::SendPeriod' => 100,
        Ticket               => {
            Title        => 'Some Ticket Title',
            Queue        => 'Raw',
            Lock         => 'unlock',
            Priority     => '3 normal',
            State        => 'open',
            CustomerNo   => '123465',
            CustomerUser => 'customer@example.com',
            OwnerID      => 1,
            UserID       => 1,
        },
        Article => {
            ArticleType    => 'email-external',
            SenderType     => 'customer',
            From           => 'Some Customer <SOME@example.com>',
            To             => 'Some To <to@example.com>',
            Subject        => 'Some Subject',
            Body           => 'the message text',
            MessageID      => '<asdasdasd.123@example.com>',
            ContentType    => 'text/plain; charset=ISO-8859-15',
            HistoryType    => 'OwnerUpdate',
            HistoryComment => 'Some free text!',
            UserID         => 1,
            NoAgentNotify => 1,    # if you don't want to send agent notifications
        },
        Result => [
            0,
            0,
        ],
    },
    {
        Name                 => '#3 try',
        'Survey::SendPeriod' => 100,
        Ticket               => {
            Title        => 'Some Ticket Title',
            Queue        => 'Raw',
            Lock         => 'unlock',
            Priority     => '3 normal',
            State        => 'open',
            CustomerNo   => '123465',
            CustomerUser => 'customer@example.com',
            OwnerID      => 1,
            UserID       => 1,
        },
        Article => {
            ArticleType    => 'email-external',
            SenderType     => 'customer',
            From           => 'SOME@example.com',
            To             => 'Some To <to@example.com>',
            Subject        => 'Some Subject',
            Body           => 'the message text',
            MessageID      => '<asdasdasd.123@example.com>',
            ContentType    => 'text/plain; charset=ISO-8859-15',
            HistoryType    => 'OwnerUpdate',
            HistoryComment => 'Some free text!',
            UserID         => 1,
            NoAgentNotify => 1,    # if you don't want to send agent notifications
        },
        Result => [
            0,
            0,
        ],
    },
    {
        Name                 => '#4 try',
        Sleep                => 80,
        'Survey::SendPeriod' => 1 / 24 / 60,
        Ticket               => {
            Title        => 'Some Ticket Title',
            Queue        => 'Raw',
            Lock         => 'unlock',
            Priority     => '3 normal',
            State        => 'open',
            CustomerNo   => '123465',
            CustomerUser => 'customer@example.com',
            OwnerID      => 1,
            UserID       => 1,
        },
        Article => {
            ArticleType    => 'email-external',
            SenderType     => 'customer',
            From           => 'SOME@example.com',
            To             => 'Some To <to@example.com>',
            Subject        => 'Some Subject',
            Body           => 'the message text',
            MessageID      => '<asdasdasd.123@example.com>',
            ContentType    => 'text/plain; charset=ISO-8859-15',
            HistoryType    => 'OwnerUpdate',
            HistoryComment => 'Some free text!',
            UserID         => 1,
            NoAgentNotify => 1,    # if you don't want to send agent notifications
        },
        Result => [
            1,
            0,
        ],
    },
    {
        Name                 => '#5 try',
        Sleep                => 20,
        'Survey::SendPeriod' => 1 / 24 / 60,
        Ticket               => {
            Title        => 'Some Ticket Title',
            Queue        => 'Raw',
            Lock         => 'unlock',
            Priority     => '3 normal',
            State        => 'open',
            CustomerNo   => '123465',
            CustomerUser => 'customer@example.com',
            OwnerID      => 1,
            UserID       => 1,
        },
        Article => {
            ArticleType    => 'email-external',
            SenderType     => 'customer',
            From           => 'SOME@example.com',
            To             => 'Some To <to@example.com>',
            Subject        => 'Some Subject',
            Body           => 'the message text',
            MessageID      => '<asdasdasd.123@example.com>',
            ContentType    => 'text/plain; charset=ISO-8859-15',
            HistoryType    => 'OwnerUpdate',
            HistoryComment => 'Some free text!',
            UserID         => 1,
            NoAgentNotify => 1,    # if you don't want to send agent notifications
        },
        Result => [
            0,
            0,
        ],
    },
    {
        Name   => '#6 try',
        Ticket => {
            Title        => 'Some Ticket Title',
            Queue        => 'Raw',
            Lock         => 'unlock',
            Priority     => '3 normal',
            State        => 'open',
            CustomerNo   => '123465',
            CustomerUser => 'customer@example.com',
            OwnerID      => 1,
            UserID       => 1,
        },
        Article => {
            ArticleType    => 'email-external',
            SenderType     => 'customer',
            From           => 'My Name',
            To             => 'Some To <to@example.com>',
            Subject        => 'Some Subject',
            Body           => 'the message text',
            MessageID      => '<asdasdasd.123@example.com>',
            ContentType    => 'text/plain; charset=ISO-8859-15',
            HistoryType    => 'OwnerUpdate',
            HistoryComment => 'Some free text!',
            UserID         => 1,
            NoAgentNotify => 1,    # if you don't want to send agent notifications
        },
        Result => [
            0,
            0,
        ],
    },
);

for my $Test (@Tests) {
    if ( $Test->{'Survey::SendPeriod'} ) {
        $Self->{ConfigObject}->Set(
            Key   => 'Survey::SendPeriod',
            Value => $Test->{'Survey::SendPeriod'},
        );
    }
    if ( $Test->{Sleep} ) {
        sleep $Test->{Sleep};
    }
    my $TicketID = $Self->{TicketObject}->TicketCreate(
        %{ $Test->{Ticket} },
    );
    my $ArticleID = $Self->{TicketObject}->ArticleCreate(
        TicketID => $TicketID,
        %{ $Test->{Article} },
    );

    # send survey first time
    my ( $HeaderRef, $BodyRef ) = $Self->{SurveyObject}->RequestSend(
        TicketID => $TicketID,
    );

    # check if survey got sent
    if ( $Test->{Result}->[0] ) {
        $Self->True(
            ${$HeaderRef},
            "$Test->{Name} RequestSend() - survey got sent",
        );

        ${$HeaderRef} =~ m{ ^ Subject: [ ] ( .+? ) \n \S+: [ ] }xms;
        $Self->Is(
            $1,
            'Help us with your feedback! =?UTF-8?Q?=C3=84=C3=96=C3=9C?=',
            "$Test->{Name} Test special characters in email subject",
        );

        # define mail body
        my $Mailbody1 = "This is a multi-part message in MIME format...

------------=_MESSAGEID
Content-Type: text/plain; charset=\"utf-8\"
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable

Dear customer... =C3=A4=C3=B6=C3=BC=

------------=_MESSAGEID
Content-Type: text/html; charset=\"utf-8\"
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable

<html><head><meta http-equiv=3D\"Content-Type\" content=3D\"text/html; charset=
=3Dutf-8\"/></head><body style=3D\"font-family:Geneva,Helvetica,Arial,sans-se=
rif; font-size: 12px;\">Dear customer... =C3=A4=C3=B6=C3=BC</body></html>=

------------=_MESSAGEID--
";

        # copy mail body
        my $Mailbody2 = ${$BodyRef};

        # prepare mail body
        $Mailbody2 =~ s{ \d{8,12} - \d{3,6} - \d{1,3} }{MESSAGEID}xmsg;

        $Self->Is(
            $Mailbody2,
            $Mailbody1,
            "$Test->{Name} Test special characters in email body",
        );
    }
    else {
        $Self->False(
            ${$HeaderRef},
            "$Test->{Name} RequestSend() - no survey got sent",
        );
    }

    # send survey second time
    ( $HeaderRef, $BodyRef ) = $Self->{SurveyObject}->RequestSend(
        TicketID => $TicketID,
    );

    # check if survey got sent
    if ( $Test->{Result}->[1] ) {
        $Self->True(
            ${$HeaderRef},
            "$Test->{Name} 2 RequestSend() - survey got sent",
        );
    }
    else {
        $Self->False(
            ${$HeaderRef},
            "$Test->{Name} 2 RequestSend() - no survey got sent",
        );
    }

    my $Delete = $Self->{TicketObject}->TicketDelete(
        TicketID => $TicketID,
        UserID   => 1,
    );
}

$Self->{DBObject}->Do(
    SQL => "DELETE FROM survey_request WHERE send_to LIKE '\%\@example.com\%'",
);

# restore original sendmail config
$Self->{ConfigObject}->Set(
    Key   => 'SendmailModule',
    Value => $SendmailModule,
);

1;
