国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

55 lines
110KB

  1. <module>
  2. <baseinfo>
  3. name=畅言评论模块
  4. team=织梦团队
  5. time=2014-02-17
  6. email=tianya@desdev.cn
  7. url=http://www.dedecms.com
  8. hash=606c658db048ea7328ffe1c7ae2a732f
  9. indexname=
  10. indexurl=
  11. ismember=0
  12. autosetup=1
  13. autodel=1
  14. lang=utf-8
  15. moduletype=soft
  16. </baseinfo>
  17. <systemfile>
  18. <menustring>
  19. PG06dG9wIG5hbWU9J+eVheiogOivhOiuuicgZGlzcGxheT0nYmxvY2snPg0KPG06aXRlbSBuYW1lPSfnlYXoqIDmqKHlnZcnIGxpbms9J2NoYW5neWFuX21haW4ucGhwJyByYW5rPSdzeXNfRmVlZGJhY2snIHRhcmdldD0nbWFpbicvPg0KPG06aXRlbSBuYW1lPSfor4TorrrnrqHnkIYnIGxpbms9J2NoYW5neWFuX21haW4ucGhwP2RvcG9zdD1tYW5hZ2UnIHJhbms9J3N5c19GZWVkYmFjaycgdGFyZ2V0PSdtYWluJy8+DQo8bTppdGVtIG5hbWU9J+aVsOaNrue7n+iuoScgbGluaz0nY2hhbmd5YW5fbWFpbi5waHA/ZG9wb3N0PXN0YXQnIHJhbms9J3N5c19GZWVkYmFjaycgdGFyZ2V0PSdtYWluJy8+DQo8bTppdGVtIG5hbWU9J+WvvOWFpeWvvOWHuicgbGluaz0nY2hhbmd5YW5fbWFpbi5waHA/ZG9wb3N0PWltcG9ydCcgcmFuaz0nc3lzX0ZlZWRiYWNrJyB0YXJnZXQ9J21haW4nLz4NCjxtOml0ZW0gbmFtZT0n55WF6KiA6K6+572uJyBsaW5rPSdjaGFuZ3lhbl9tYWluLnBocD9kb3Bvc3Q9c2V0dGluZycgcmFuaz0nc3lzX0ZlZWRiYWNrJyB0YXJnZXQ9J21haW4nLz4NCjwvbTp0b3A+
  20. </menustring>
  21. <readme>
  22. PHAgc3R5bGU9J2xpbmUtaGVpZ2h0OjE1MCUnPjxkaXYgc3R5bGU9J3BhZGRpbmctbGVmdDoyMHB4O2xpbmUtaGVpZ2h0OjE1MCUnPjxiciAvPg0KPHA+54mI5p2D5omA5pyJIChjKTIwMDMtMjAxMe+8jERlZGVDbXMuY29tIOS/neeVmeaJgOacieadg+WIqeOAgiA8L3A+PGJyIC8+DQo8cD7mhJ/osKLmgqjpgInmi6nnu4fmoqblhoXlrrnnrqHnkIbns7vnu5/vvIjku6XkuIvnroDnp7BEZWRlQ21z77yJ77yMRGVkZUNtc+aYr+ebruWJjeWbveWGheacgOW8uuWkp+OAgeacgOeos+WumueahOS4reWwj+Wei+mXqOaIt+e9keermeW7uuiuvuino+WGs+aWueahiOS5i+S4gO+8jOWxheS6jiBQSFAgKyBNeVNRTCDnmoTmioDmnK/lvIDlj5HvvIzlhajpg6jmupDnoIHlvIDmlL7jgIJEZWRlQ21zIOeahOWumOaWuee9keWdgOaYr++8miB3d3cuZGVkZWNtcy5jb20gIOS6pOa1geiuuuWdm++8miBiYnMuZGVkZWNtcy5jb208L3A+PGJyIC8+DQo8cD7kuLrkuobkvb/kvaDmraPnoa7lubblkIjms5XnmoTkvb/nlKjmnKzova/ku7bvvIzor7fkvaDlnKjkvb/nlKjliY3liqHlv4XpmIXor7vmuIXmpZrkuIvpnaLnmoTljY/orq7mnaHmrL7vvJo8L3A+PGJyIC8+DQo8cD48c3Ryb25nPuS4gOOAgeacrOaOiOadg+WNj+iurumAgueUqOS4lOS7hemAgueUqOS6jiBEZWRlQ21zIDUueC54IOeJiOacrO+8jERlZGVDbXPlrpjmlrnlr7nmnKzmjojmnYPljY/orq7nmoTmnIDnu4jop6Pph4rmnYPjgIIgPC9zdHJvbmc+PC9wPjxiciAvPg0KPHA+PHN0cm9uZz7kuozjgIHljY/orq7orrjlj6/nmoTmnYPliKkgPC9zdHJvbmc+PGJyIC8+PGJyIC8+DQogIDHjgIHmgqjlj6/ku6XlnKjlrozlhajpgbXlrojmnKzmnIDnu4jnlKjmiLfmjojmnYPljY/orq7nmoTln7rnoYDkuIrvvIzlsIbmnKzova/ku7blupTnlKjkuo7pnZ7llYbkuJrnlKjpgJTvvIzogIzkuI3lv4XmlK/ku5jova/ku7bniYjmnYPmjojmnYPotLnnlKjjgIIgPGJyIC8+PGJyIC8+DQogIDLjgIHmgqjlj6/ku6XlnKjljY/orq7op4TlrprnmoTnuqbmnZ/lkozpmZDliLbojIPlm7TlhoXkv67mlLkgRGVkZUNtcyDmupDku6PnoIHmiJbnlYzpnaLpo47moLzku6XpgILlupTmgqjnmoTnvZHnq5nopoHmsYLjgIIgPGJyIC8+PGJyIC8+DQogIDPjgIHmgqjmi6XmnInkvb/nlKjmnKzova/ku7bmnoTlu7rnmoTnvZHnq5nlhajpg6jlhoXlrrnmiYDmnInmnYPvvIzlubbni6znq4vmib/mi4XkuI7ov5nkupvlhoXlrrnnmoTnm7jlhbPms5XlvovkuYnliqHjgIIgPGJyIC8+PGJyIC8+DQo044CB6I635b6X5ZWG5Lia5o6I5p2D5LmL5ZCO77yM5oKo5Y+v5Lul5bCG5pys6L2v5Lu25bqU55So5LqO5ZWG5Lia55So6YCU77yM5ZCM5pe25L6d5o2u5omA6LSt5Lmw55qE5o6I5p2D57G75Z6L5Lit56Gu5a6a55qE5oqA5pyv5pSv5oyB5YaF5a6577yM6Ieq6LSt5Lmw5pe25Yi76LW377yM5Zyo5oqA5pyv5pSv5oyB5pyf6ZmQ5YaF5oul5pyJ6YCa6L+H5oyH5a6a55qE5pa55byP6I635b6X5oyH5a6a6IyD5Zu05YaF55qE5oqA5pyv5pSv5oyB5pyN5Yqh44CC5ZWG5Lia5o6I5p2D55So5oi35Lqr5pyJ5Y+N5pig5ZKM5o+Q5Ye65oSP6KeB55qE5p2D5Yqb77yM55u45YWz5oSP6KeB5bCG6KKr5L2c5Li66aaW6KaB6ICD6JmR77yM5L2G5rKh5pyJ5LiA5a6a6KKr6YeH57qz55qE5om/6K+65oiW5L+d6K+B44CCIDwvcD48YnIgLz4NCjxwPjxzdHJvbmc+5LqM44CB5Y2P6K6u6KeE5a6a55qE57qm5p2f5ZKM6ZmQ5Yi2IDwvc3Ryb25nPjxiciAvPjxiciAvPg0KICAx44CB5pyq6I635ZWG5Lia5o6I5p2D5LmL5YmN77yM5LiN5b6X5bCG5pys6L2v5Lu255So5LqO5ZWG5Lia55So6YCU77yI5YyF5ous5L2G5LiN6ZmQ5LqO5LyB5Lia572R56uZ44CB57uP6JCl5oCn572R56uZ44CB5Lul6JCl5Yip5Li655uu55qE5oiW5a6e546w55uI5Yip55qE572R56uZ77yJ44CC6LSt5Lmw5ZWG5Lia5o6I5p2D6K+355m76ZmGIGJicy5kZWRlY21zLmNvbSDkuobop6PmnIDmlrDor7TmmI7jgIIgPGJyIC8+PGJyIC8+DQogIDLjgIHmnKrnu4/lrpjmlrnorrjlj6/vvIzkuI3lvpflr7nmnKzova/ku7bmiJbkuI7kuYvlhbPogZTnmoTllYbkuJrmjojmnYPov5vooYzlh7rnp5/jgIHlh7rllK7jgIHmirXmirzmiJblj5HmlL7lrZDorrjlj6/or4HjgIIgPGJyIC8+PGJyIC8+DQogIDPjgIHkuI3nrqHkvaDnmoTnvZHnq5nmmK/lkKbmlbTkvZPkvb/nlKggRGVkZUNtcyDvvIzov5jmmK/pg6jku73moI/nm67kvb/nlKggRGVkZUNtc++8jOWcqOS9oOS9v+eUqOS6hiBEZWRlQ21zIOeahOe9keermeS4u+mhteS4iuW/hemhu+WKoOS4iiBEZWRlQ21zIOWumOaWuee9keWdgCh3d3cuZGVkZWNtcy5jb20p55qE6ZO+5o6l44CCIDxiciAvPjxiciAvPg0KICA044CB5pyq57uP5a6Y5pa56K645Y+v77yM56aB5q2i5ZyoIERlZGVDbXMg55qE5pW05L2T5oiW5Lu75L2V6YOo5YiG5Z+656GA5LiK5Lul5Y+R5bGV5Lu75L2V5rS+55Sf54mI5pys44CB5L+u5pS554mI5pys5oiW56ys5LiJ5pa554mI5pys55So5LqO6YeN5paw5YiG5Y+R44CCIDxiciAvPjxiciAvPg0KNeOAgeWmguaenOaCqOacquiDvemBteWuiOacrOWNj+iurueahOadoeasvu+8jOaCqOeahOaOiOadg+Wwhuiiq+e7iOatou+8jOaJgOiiq+iuuOWPr+eahOadg+WIqeWwhuiiq+aUtuWbnu+8jOW5tuaJv+aLheebuOW6lOazleW+i+i0o+S7u+OAgiA8L3A+PGJyIC8+DQo8cD48c3Ryb25nPuS4ieOAgeaciemZkOaLheS/neWSjOWFjei0o+WjsOaYjiA8L3N0cm9uZz48YnIgLz48YnIgLz4NCiAgMeOAgeacrOi9r+S7tuWPiuaJgOmZhOW4pueahOaWh+S7tuaYr+S9nOS4uuS4jeaPkOS+m+S7u+S9leaYjuehrueahOaIlumakOWQq+eahOi1lOWBv+aIluaLheS/neeahOW9ouW8j+aPkOS+m+eahOOAgiA8YnIgLz48YnIgLz4NCiAgMuOAgeeUqOaIt+WHuuS6juiHquaEv+iAjOS9v+eUqOacrOi9r+S7tu+8jOaCqOW/hemhu+S6huino+S9v+eUqOacrOi9r+S7tueahOmjjumZqe+8jOWcqOWwmuacqui0reS5sOS6p+WTgeaKgOacr+acjeWKoeS5i+WJje+8jOaIkeS7rOS4jeaJv+ivuuWvueWFjei0ueeUqOaIt+aPkOS+m+S7u+S9leW9ouW8j+eahOaKgOacr+aUr+aMgeOAgeS9v+eUqOaLheS/ne+8jOS5n+S4jeaJv+aLheS7u+S9leWboOS9v+eUqOacrOi9r+S7tuiAjOS6p+eUn+mXrumimOeahOebuOWFs+i0o+S7u+OAgiA8YnIgLz48YnIgLz4NCiAgM+OAgeeUteWtkOaWh+acrOW9ouW8j+eahOaOiOadg+WNj+iuruWmguWQjOWPjOaWueS5pumdouetvue9sueahOWNj+iuruS4gOagt++8jOWFt+acieWujOWFqOeahOWSjOetieWQjOeahOazleW+i+aViOWKm+OAguaCqOS4gOaXpuW8gOWni+ehruiupOacrOWNj+iuruW5tuWuieijhSBEZWRlQ21z77yM5Y2z6KKr6KeG5Li65a6M5YWo55CG6Kej5bm25o6l5Y+X5pys5Y2P6K6u55qE5ZCE6aG55p2h5qy+77yM5Zyo5Lqr5pyJ5LiK6L+w5p2h5qy+5o6I5LqI55qE5p2D5Yqb55qE5ZCM5pe277yM5Y+X5Yiw55u45YWz55qE57qm5p2f5ZKM6ZmQ5Yi244CC5Y2P6K6u6K645Y+v6IyD5Zu05Lul5aSW55qE6KGM5Li677yM5bCG55u05o6l6L+d5Y+N5pys5o6I5p2D5Y2P6K6u5bm25p6E5oiQ5L615p2D77yM5oiR5Lus5pyJ5p2D6ZqP5pe257uI5q2i5o6I5p2D77yM6LSj5Luk5YGc5q2i5o2f5a6z77yM5bm25L+d55WZ6L+956m255u45YWz6LSj5Lu755qE5p2D5Yqb44CCIDxiciAvPjxiciAvPg0KNOOAgeWmguaenOacrOi9r+S7tuW4puacieWFtuWug+i9r+S7tueahOaVtOWQiEFQSeekuuiMg+S+i+WtkOWMhe+8jOi/meS6m+aWh+S7tueJiOadg+S4jeWxnuS6juacrOi9r+S7tuWumOaWue+8jOW5tuS4lOi/meS6m+aWh+S7tuaYr+ayoee7j+i/h+aOiOadg+WPkeW4g+eahO+8jOivt+WPguiAg+ebuOWFs+i9r+S7tueahOS9v+eUqOiuuOWPr+WQiOazleeahOS9v+eUqOOAgjwvcD48YnIgLz4NCjxwPuWNj+iuruWPkeW4g+aXtumXtO+8miAgMjAwN+W5tDEy5pyIMeaXpSBCeSBEZWRlQ21zLmNvbTwvcD48YnIgLz4NCjxwPjwvcD48L3A+
  23. </readme>
  24. <setupsql40>
  25. RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNAX19wbHVzX2NoYW5neWFuX3NldHRpbmdgOw0KQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNAX19wbHVzX2NoYW5neWFuX3NldHRpbmdgICgNCiAgYHNrZXlgIHZhcmNoYXIoMjU1KSBOT1QgTlVMTCBERUZBVUxUICcnLA0KICBgc3ZhbHVlYCB0ZXh0IE5PVCBOVUxMLA0KICBgc3RpbWVgIGludCgxMCkgTk9UIE5VTEwsDQogIFBSSU1BUlkgS0VZIChgc2tleWApDQopIFRZUEU9TXlJU0FNOw0KSU5TRVJUIElOVE8gYCNAX19wbHVzX2NoYW5neWFuX3NldHRpbmdgIChgc2tleWAsIGBzdmFsdWVgLCBgc3RpbWVgKSBWQUxVRVMNCignYXBwaWQnLCAnMCcsIDApLA0KKCdpZCcsICcwJywgMCksDQooJ2lzdl9pZCcsICcwJywgMCksDQooJ3VzZXInLCAnMCcsIDApLA0KKCdwd2QnLCAnMCcsIDApOw==
  26. </setupsql40>
  27. <delsql>
  28. RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNAX19wbHVzX2NoYW5neWFuX3NldHRpbmdgOw0KRFJPUCBUQUJMRSBJRiBFWElTVFMgYCNAX19wbHVzX2NoYW5neWFuX2ltcG9ydGlkc2A7DQpEUk9QIFRBQkxFIElGIEVYSVNUUyBgI0BfX3BsdXNfY2hhbmd5YW5faW5zZXJ0aWRzYDs=
  29. </delsql>
  30. <setup>
  31. </setup>
  32. <uninstall>
  33. </uninstall>
  34. <oldfilelist>
  35. ../include/helpers/changyan.helper.php
  36. ../include/taglib/changyan.lib.php
  37. changyan_main.php
  38. </oldfilelist>
  39. </systemfile>
  40. <modulefiles>
  41. <file type='file' name='../include/helpers/changyan.helper.php'>
  42. <?php if(!defined('DEDEINC')) exit('dedecms');

define('CHANGYAN_API_AES', 'http://changyan.api.dedecms.com/');
define('CHANGYAN_API_REG', 'http://changyan.kuaizhan.com/admin/api/open/reg');
define('CHANGYAN_API_AUTOREG', 'http://changyan.kuaizhan.com/admin/api/open/auto-reg');
define('CHANGYAN_API_LOGIN', 'http://changyan.kuaizhan.com/admin/api/open/validate');
define('CHANGYAN_API_SETCOOKIE', 'http://changyan.kuaizhan.com/admin/api/open/set-cookie');
define('CHANGYAN_API_ISNEW', 'http://changyan.kuaizhan.com/admin/api/recent-comment-topics');
define('CHANGYAN_API_LATESTS', 'http://changyan.kuaizhan.com/api/2/comment/latests');
define('CHANGYAN_API_RECENT', 'http://changyan.kuaizhan.com/admin/api/recent-comment-topics');
define('CHANGYAN_API_CODE', 'http://changyan.kuaizhan.com/admin/api/open/get-code');
define('CHANGYAN_API_ADDSITE', 'http://changyan.kuaizhan.com/admin/api/open/add-isv');
define('CHANGYAN_API_CHANGE_ISV', 'http://changyan.kuaizhan.com/change-isv/');
define('CHANGYAN_API_CHECK_LOGIN', 'http://changyan.kuaizhan.com/check-login');
define('CHANGYAN_API_GETAPPKEY', 'http://changyan.kuaizhan.com/ admin/api/open/get-appkey');
define('CHANGYAN_API_COMMENTS', 'http://changyan.sohu.com/api/2/topic/comments');
define('CHANGYAN_API_TOPICCOMMENTS', 'http://changyan.sohu.com/api/2/topic/load');
define('CHANGYAN_API_IMPORT', 'http://changyan.kuaizhan.com/admin/api/import/comment');
define('CHANGYAN_API_GETISVS', 'http://changyan.kuaizhan.com/admin/api/open/get-isvs');
define('CHANGYAN_API_GETISVS_JSONP', 'http://changyan.kuaizhan.com/admin/api/open/get-isvs-jsonp');
define('CHANGYAN_API_BINDACC', 'http://changyan.kuaizhan.com/admin/api/open/mod-opinfo');
define('CHANGYAN_API_FORGET_PWD', 'http://changyan.kuaizhan.com/platform/forget-pwd');

define('CHANGYAN_CLIENT_ID', 'caqXYIe32');
define('CHANGYAN_CLIENT_KEY', 'bcb585628b59584891ff5897be888c45');

define('CHANGYAN_JQUERY_SRC', '<script>window.jQuery || document.write(unescape(\'%3Cscript src="http://changyan.api.dedecms.com/assets/js/jquery.min.js"%3E%3C/script%3E\'))</script>');

define('CHANGYAN_VER', '0.0.11');

$GLOBALS['update_sqls']=array(
    '0.0.2'=>array(
        "INSERT INTO `#@__plus_changyan_setting` (`skey`, `svalue`, `stime`) VALUES ('last_export', '0', 0);",
        "INSERT INTO `#@__plus_changyan_setting` (`skey`, `svalue`, `stime`) VALUES ('last_import', '0', 0);",
        "INSERT INTO `#@__plus_changyan_setting` (`skey`, `svalue`, `stime`) VALUES ('version', '0.0.2', 0);",
        "INSERT INTO `#@__plus_changyan_setting` (`skey`, `svalue`, `stime`) VALUES ('isv_app_key', '0', 0);",
        "CREATE TABLE `#@__plus_changyan_insertids` (`id` INT(10) NOT NULL AUTO_INCREMENT,
            `aid` INT(10) NULL DEFAULT '0',
            `comment_id` INT(12) NULL DEFAULT '0',
            PRIMARY KEY (`id`),
            UNIQUE INDEX `comment_id` (`comment_id`)
        )
        TYPE=MyISAM;",
        "CREATE TABLE `#@__plus_changyan_importids` (`id` INT(10) NOT NULL AUTO_INCREMENT,
            `aid` INT(10) NULL DEFAULT '0',
            `feedback_id` INT(12) NULL DEFAULT '0',
            PRIMARY KEY (`id`),
            UNIQUE INDEX `feedback_id` (`feedback_id`)
        )
        TYPE=MyISAM;",
    ),
    '0.0.3'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.3' WHERE `skey`='version';",
    ),
    '0.0.4'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.4' WHERE `skey`='version';",
    ),
    '0.0.5'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.5' WHERE `skey`='version';",
    ),
    '0.0.6'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.6' WHERE `skey`='version';",
    ),
    '0.0.7'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.7' WHERE `skey`='version';",
    ),
    '0.0.8'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.8' WHERE `skey`='version';",
    ),
    '0.0.9'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.9' WHERE `skey`='version';",
    ),
    '0.0.10'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.10' WHERE `skey`='version';",
    ),
    '0.0.11'=>array(
        "UPDATE `#@__plus_changyan_setting` SET `svalue`='0.0.11' WHERE `skey`='version';",
    ),
);

helper('cache');

function changyan_clearcache()
{
    $prefix = 'changyan';
    $key = 'code';
    DelCache($prefix, $key);
}

function changyan_mchStrCode($string, $operation = 'ENCODE') 
{
    $key_length = 4;
    $expiry = 0;
    $key = md5($GLOBALS['cfg_cookie_encode']);
    $fixedkey = md5($key);
    $egiskeys = md5(substr($fixedkey, 16, 16));
    $runtokey = $key_length ? ($operation == 'ENCODE' ? substr(md5(microtime(true)), -$key_length) : substr($string, 0, $key_length)) : '';
    $keys = md5(substr($runtokey, 0, 16) . substr($fixedkey, 0, 16) . substr($runtokey, 16) . substr($fixedkey, 16));
    $string = $operation == 'ENCODE' ? sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$egiskeys), 0, 16) . $string : base64_decode(substr($string, $key_length));

    $i = 0; $result = '';
    $string_length = strlen($string);
    for ($i = 0; $i < $string_length; $i++){
        $result .= chr(ord($string{$i}) ^ ord($keys{$i % 32}));
    }
    if($operation == 'ENCODE') {
        return $runtokey . str_replace('=', '', base64_encode($result));
    } else {
        if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$egiskeys), 0, 16)) {
            return substr($result, 26);
        } else {
            return '';
        }
    }
}

function changyan_Quote_replace($quote)
{
    $quote = str_replace('{quote}','',$quote);
    $quote = str_replace('{title}','',$quote);
    $quote = str_replace('{/title}','',$quote);
    $quote = str_replace('&lt;br/&gt;',"\n\r",$quote);
    $quote = str_replace('&lt;', '', $quote);
    $quote = str_replace('&gt;', '', $quote);
    $quote = str_replace('{content}','',$quote);
    $quote = str_replace('{/content}','',$quote);
    $quote = str_replace('{/quote}','',$quote);
    return $quote;
}


//更新配置函数
function changyan_ReWriteConfig()
{
    global $dsql;
    $configfile = DEDEDATA.'/config.cache.inc.php';
    if(!is_writeable($configfile))
    {
        echo "配置文件'{$configfile}'不支持写入，无法修改系统配置参数！";
        exit();
    }
    $fp = fopen($configfile,'w');
    flock($fp,3);
    fwrite($fp,"<"."?php\r\n");
    $dsql->SetQuery("SELECT `varname`,`type`,`value`,`groupid` FROM `#@__sysconfig` ORDER BY aid ASC ");
    $dsql->Execute();
    while($row = $dsql->GetArray())
    {
        if($row['type']=='number')
        {
            if($row['value']=='') $row['value'] = 0;
            fwrite($fp,"\${$row['varname']} = ".$row['value'].";\r\n");
        }
        else
        {
            fwrite($fp,"\${$row['varname']} = '".str_replace("'",'',$row['value'])."';\r\n");
        }
    }
    fwrite($fp,"?".">");
    fclose($fp);
}

function changyan_http_send($url, $limit=0, $post='', $cookie='', $timeout=15)
{
    $return = '';
    $matches = parse_url($url);
    $scheme = $matches['scheme'];
    $host = $matches['host'];
    $path = $matches['path'] ? $matches['path'].(@$matches['query'] ? '?'.$matches['query'] : '') : '/';
    $port = !empty($matches['port']) ? $matches['port'] : 80;

    if (function_exists('curl_init') && function_exists('curl_exec')) {
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $scheme.'://'.$host.':'.$port.$path);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
        if ($post) {
            curl_setopt($ch, CURLOPT_POST, 1);
            $content = is_array($post) ? http_build_query($post) : $post;
            curl_setopt($ch, CURLOPT_POSTFIELDS, urldecode($content));
        }
        if ($cookie) {
            curl_setopt($ch, CURLOPT_COOKIE, $cookie);
        }
        curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
        curl_setopt($ch, CURLOPT_TIMEOUT, 900);
        $data = curl_exec($ch);
        $status = curl_getinfo($ch);
        $errno = curl_errno($ch);
        curl_close($ch);
        if ($errno || $status['http_code'] != 200) {
            return;
        } else {
            return !$limit ? $data : substr($data, 0, $limit);
        }
    }

    if ($post) {
        $content = is_array($port) ? urldecode(http_build_query($post)) : $post;
        $out = "POST $path HTTP/1.0\r\n";
        $header = "Accept: */*\r\n";
        $header .= "Accept-Language: zh-cn\r\n";
        $header .= "Content-Type: application/x-www-form-urlencoded\r\n";
        $header .= "User-Agent: ".@$_SERVER['HTTP_USER_AGENT']."\r\n";
        $header .= "Host: $host:$port\r\n";
        $header .= 'Content-Length: '.strlen($content)."\r\n";
        $header .= "Connection: Close\r\n";
        $header .= "Cache-Control: no-cache\r\n";
        $header .= "Cookie: $cookie\r\n\r\n";
        $out .= $header.$content;
    } else {
        $out = "GET $path HTTP/1.0\r\n";
        $header = "Accept: */*\r\n";
        $header .= "Accept-Language: zh-cn\r\n";
        $header .= "User-Agent: ".@$_SERVER['HTTP_USER_AGENT']."\r\n";
        $header .= "Host: $host:$port\r\n";
        $header .= "Connection: Close\r\n";
        $header .= "Cookie: $cookie\r\n\r\n";
        $out .= $header;
    }

    $fpflag = 0;
    $fp = false;
    if (function_exists('fsocketopen')) {
        $fp = fsocketopen($host, $port, $errno, $errstr, $timeout);
    }
    if (!$fp) {
        $context = stream_context_create(array(
            'http' => array(
                'method' => $post ? 'POST' : 'GET',
                'header' => $header,
                'content' => $content,
                'timeout' => $timeout,
            ),
        ));
        $fp = @fopen($scheme.'://'.$host.':'.$port.$path, 'b', false, $context);
        $fpflag = 1;
    }

    if (!$fp) {
        return '';
    } else {
        stream_set_blocking($fp, true);
        stream_set_timeout($fp, $timeout);
        @fwrite($fp, $out);
        $status = stream_get_meta_data($fp);
        if (!$status['timed_out']) {
            while (!feof($fp) && !$fpflag) {
                if (($header = @fgets($fp)) && ($header == "\r\n" ||  $header == "\n")) {
                    break;
                }
            }
            if ($limit) {
                $return = stream_get_contents($fp, $limit);
            } else {
                $return = stream_get_contents($fp);
            }
        }
        @fclose($fp);
        return $return;
    }
}

function changyan_autoCharset($msg,$type='out')
{
    global $cfg_soft_lang;
    if ($cfg_soft_lang=='gb2312') {
        if($type=='out') return gb2utf8($msg);
        else return utf82gb($msg);
    } 
    return $msg;
}

function changyan_gen_sign($user)
{
    global $cfg_version,$dsql;
    $phpv = phpversion();
    $sp_os = PHP_OS;
    $mysql_ver = $dsql->GetVersion();
    $nurl = $_SERVER['HTTP_HOST'];
    if( preg_match("#[a-z\-]{1,}\.[a-z]{2,}#i",$nurl) ) {
        $nurl = urlencode($nurl);
    }
    else {
        $nurl = "test";
    }
    $aes_url=CHANGYAN_API_AES.'?key='.CHANGYAN_CLIENT_KEY.'&input='.$user."&version={$cfg_version}&formurl={$nurl}&phpver={$phpv}&os={$sp_os}&mysqlver={$mysql_ver}&cyver=".CHANGYAN_VER;
    return changyan_http_send($aes_url);
}

function changyan_bind_account($new_user,$new_pwd, $errorinfo='')
{
    $old_user = changyan_get_setting('user');
    $old_password=changyan_mchStrCode(changyan_get_setting('pwd'), 'DECODE') ;
    $sign=changyan_gen_sign($old_user);
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'old_user'=>$old_user, 
        'old_password'=>$old_password, 
        'new_user'=>$new_user, 
        'new_password'=>$new_pwd, 
        'sign'=>$sign);
    $rs=json_decode(changyan_http_send(CHANGYAN_API_BINDACC.'?'.http_build_query($paramsArr)),TRUE);
    if(!isset($rs['status'])) return FALSE;
    if($rs['status']==0)
    {
        $new_pwd = changyan_mchStrCode($new_pwd, 'ENCODE');
        changyan_set_setting('user', $new_user);
        changyan_set_setting('pwd', $new_pwd);
        changyan_set_setting('isv_app_key', '');
        $isv_app_key = changyan_get_isv_app_key();
        changyan_clearcache();
        return TRUE;
    } else {
        $errorinfo = $rs['msg'];
        return FALSE;
    }
}

function changyan_hmacsha1($data, $key) {
    return hash_hmac('sha1', $data, $key);
}

function changyan_get_isvs()
{
    $user = changyan_get_setting('user');
    $sign=changyan_gen_sign($user);
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'user'=>$user, 
        'sign'=>$sign);
    $rs=json_decode(changyan_http_send(CHANGYAN_API_GETISVS.'?'.http_build_query($paramsArr)),TRUE);
    if(isset($rs['isvs'])) return json_decode($rs['isvs'],TRUE);
    else return FALSE;
}

function changyan_get_isvs_jsonp()
{
    $appid = changyan_get_setting('appid');
    $user = changyan_get_setting('user');
    $sign=changyan_gen_sign($user);
    $client_id=CHANGYAN_CLIENT_ID;
    $jsonp_url=CHANGYAN_API_GETISVS_JSONP;
    return <<<EOT
<script type="text/javascript">
$.ajax({  
        type: "get",  
        url: "{$jsonp_url}",  
        dataType: "jsonp",  
        data: {
            client_id: '{$client_id}',
            user: '{$user}',
            sign: '{$sign}'
        },
        jsonp: "callback",
        jsonpCallback: "success_jsonpCallback",
        success: function(data){  
            isvs = eval(eval(data)["isvs"]);
            var db_appid='{$appid}';
            var isvsContent='';
            $.each(isvs, function(i,item){
                var appId=item.appId;
                var appKey=item.appKey;
                var name=item.name;
                var id=item.id;
                var url=item.url;
                var checkedstr='';
                if(db_appid==appId) checkedstr=' checked';
                option_html = '<p><input type="radio" name="appInfo" id="appInfo'+id+'" value="'+appId+'|'+appKey+'"'+checkedstr+'> <label for="appInfo'+id+'">'+name+' ['+appId+' | '+url+']</label></p>';
                isvsContent = isvsContent + option_html;
            });
            $("#isvsContent").html(isvsContent);
        },
        error: function(data){
            isvsContent = "没有获取到当前登录账号所对应的APPID信息，请检查是否正确安装畅言模块。";
            $("#isvsContent").html(isvsContent);
        },        
          
    });
</script>
EOT;
}

function changyan_get_isv_app_key()
{
    global $client_id;
    $isv_app_key=changyan_get_setting('isv_app_key');
    if (!empty($isv_app_key)) {
        return $isv_app_key;
    } else {
        return FALSE;
    } //接口下线，直接通过设定appinfo接口
    $user = changyan_get_setting('user');
    
    if (!empty($isv_app_key)) {
        return $isv_app_key;
    }
    $isv_app_key='';
    $sign=changyan_gen_sign($user);
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'user'=>$user, 
        'user_appid'=>$client_id,
        'sign'=>$sign);
    $rs=changyan_http_send(CHANGYAN_API_GETAPPKEY.'?'.http_build_query($paramsArr));
    $rs = json_decode($rs,TRUE);
    if (isset($rs['isv_app_key'])) {
        $isv_app_key=$rs['isv_app_key'];
    }
    changyan_set_setting('isv_app_key', $isv_app_key);
    return $isv_app_key;
}

function changyan_get_comments($client_id, $topic_id)
{
    $result=array();
    $paramsArr=array(
        'client_id'=>$client_id, 
        'style'=>'floor', 
        'order_by'=>'time_asc', 
        'page_no'=>1, 
        'page_size'=>100, 
        'topic_id'=>$topic_id);
    $rs=changyan_http_send(CHANGYAN_API_COMMENTS.'?'.http_build_query($paramsArr));
    $rs = json_decode($rs,TRUE);
    return $rs;
}

function changyan_list_sort_by($list, $field, $sortby='asc') 
{
   if(is_array($list)){
       $refer = $resultSet = array();
       foreach ($list as $i => $data)
           $refer[$i] = &$data[$field];
       switch ($sortby) {
           case 'asc': // 正向排序
                asort($refer);
                break;
           case 'desc':// 逆向排序
                arsort($refer);
                break;
           case 'nat': // 自然排序
                natcasesort($refer);
                break;
       }
       foreach ( $refer as $key=> $val)
           $resultSet[] = &$list[$key];
       return $resultSet;
   }
   return false;
}

function changyan_insert_comments($comment,$aid,$title)
{
    global $dsql;
    if (!isset($comment['comments'])) return FALSE;
    $dsql->SetQuery("SELECT comment_id FROM `#@__plus_changyan_insertids` WHERE aid={$aid}");
    $dsql->Execute('dd');
    $comment_ids=array();
    while($arr = $dsql->GetArray('dd'))
    {
        $comment_ids[] = $arr['comment_id'];
    }
    $i=0;
    foreach ($comment['comments'] as $comment) 
    {
        $content = '';
        if (in_array($comment['comment_id'], $comment_ids)) continue;
        if (count($comment['comments'])>0) {
            $comment['comments'] = changyan_list_sort_by($comment['comments'], 'create_time','desc');
            foreach ($comment['comments'] as $c) {
                $c['content'] = changyan_autoCharset($c['content'], 'in');
                $content = '{quote}{content}'.$content.$c['content'].'{/content}{title}'.
                    $c['passport']['nickname'].' 的原帖：{/title}{/quote}';
            }
        }
        $aid=intval($aid);
        $typeid=0;
        $username=changyan_autoCharset($comment['passport']['nickname'], 'in');
        $arctitle=changyan_autoCharset($title, 'in');
        $ip=$comment['ip'];
        $comment_id=$comment['comment_id'];
        $ischeck=1;
        $dtime= intval($comment['create_time'] / 1000 ) ;
        $msg = $content.changyan_autoCharset($comment['content'], 'in') ;
        $inquery = "INSERT INTO `#@__feedback`(`aid`,`typeid`,`username`,`arctitle`,`ip`,`ischeck`,`dtime`, `mid`,`bad`,`good`,`ftype`,`face`,`msg`)
                           VALUES ('$aid','$typeid','$username','$arctitle','$ip','$ischeck','$dtime', '0','0','0','feedback','','$msg'); ";
        $rs = $dsql->ExecuteNoneQuery($inquery);
        $feedback_id = $dsql->GetLastID();
        $inquery = "INSERT INTO `#@__plus_changyan_importids`(`aid`,`feedback_id`) VALUES ('{$aid}','{$feedback_id}')";
        $rs = $dsql->ExecuteNoneQuery($inquery);
        $inquery = "INSERT INTO `#@__plus_changyan_insertids`(`aid`,`comment_id`) VALUES ('$aid','$comment_id')";
        $rs = $dsql->ExecuteNoneQuery($inquery);
        $i++;
    }

    return $i;
   // return $comment;
}

function changyan_check_islogin()
{
    global $dopost;
    $jquery_url = CHANGYAN_API_AES."assets/js/jquery.min.js";
    $changyan_login=CHANGYAN_API_CHECK_LOGIN;
    echo <<<EOT
<script type="text/javascript" src="{$jquery_url}"></script>
<script type="text/javascript">
(function($){
    $.ajax({
        type: "GET",
        url: "{$changyan_login}",
        dataType : 'jsonp',
        jsonpCallback:"callfunc",
        success: function(msg){
            if(!msg.success){
                window.location.href='?dopost=logout&nomsg=yes&forward={$dopost}';
            }
        }
    });
})(jQuery)
</script>    
EOT;
    //exit;
}

function changyan_get_recent($appid,$date)
{
    $date = urlencode($date);
    $recent_url=CHANGYAN_API_RECENT."/?appId={$appid}&date={$date}";
    return json_decode(changyan_http_send($recent_url),TRUE);
}

function changyan_latests($client_id,$pagesize=20,$order='hot')
{
    $latests_url=CHANGYAN_API_LATESTS."/?client_id={$client_id}&size={$pagesize}&order_by={$order}";
    return json_decode(changyan_http_send($latests_url),TRUE);
}

function changyan_getcode($client_id, $user, $is_mobile, $sign, $appid="")
{
    $getcode_url=CHANGYAN_API_CODE."/?client_id={$client_id}&user={$user}&is_mobile={$is_mobile}&sign={$sign}&user_appid={$appid}";
    return json_decode(changyan_http_send($getcode_url),TRUE);
}

function changyan_get_topic_comments($client_id, $sid, $url)
{
    $get_topic_comments_url=CHANGYAN_API_TOPICCOMMENTS."/?client_id={$client_id}&topic_source_id={$sid}&topic_url={$url}";
    return json_decode(changyan_http_send($get_topic_comments_url),TRUE);
}
function changyan_islogin()
{
    return empty($_SESSION['changyan'])? FALSE : TRUE;
}

function changyan_get_setting($skey, $time=false, $real=false)
{
    global $dsql;
    static $setting = array();
    $skey=addslashes($skey);
    if (empty($setting[$skey]) || $real) {
        $row = $dsql->GetOne("SELECT * FROM `#@__plus_changyan_setting` WHERE skey='{$skey}'");
        $setting[$skey]['svalue']=$row['svalue'];
        $setting[$skey]['stime']=$row['stime'];
    }
    if (!isset($setting[$skey])) return $time ? array() : null;
    return $time ? $setting[$skey] : $setting[$skey]['svalue'];
}

function changyan_set_setting($skey, $svalue)
{
    global $dsql;
    $stime=time();
    $skey=addslashes($skey);
    $svalue=addslashes($svalue);
    $sql="UPDATE `#@__plus_changyan_setting` SET svalue='{$svalue}',stime='{$stime}' WHERE skey='{$skey}' ";
    $dsql->ExecuteNoneQuery($sql);
}

function changyan_addsite($user, $isv_name, $url)
{
    $sign=changyan_gen_sign($user);
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'user'=>$user, 
        'isv_name'=>$isv_name,
        'url'=>$url,
        'sign'=>$sign);
    $rs=changyan_http_send(CHANGYAN_API_ADDSITE,0,$paramsArr);
    return json_decode($rs, TRUE);
}

function changyan_forget_pwd($mail,&$error_msg='')
{
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'mail'=>$mail);
    $rs=json_decode(changyan_http_send(CHANGYAN_API_FORGET_PWD,0,$paramsArr), TRUE);
    if(!$rs['success'])
    {
        $error_msg=$rs['msg'];
        return FALSE;
    }
    return TRUE;
}

?>

  43. </file>
  44. <file type='file' name='../include/taglib/changyan.lib.php'>
  45. 77u/PD9waHAgICBpZighZGVmaW5lZCgnREVERUlOQycpKSBleGl0KCdSZXF1ZXN0IEVycm9yIScpOw0KDQpoZWxwZXIoJ2NoYW5neWFuJyk7DQpoZWxwZXIoJ2NhY2hlJyk7DQokR0xPQkFMU1snY2hhbmd5YW5fY291bnRfanMnXSA9IGlzc2V0KCRHTE9CQUxTWydjaGFuZ3lhbl9jb3VudF9qcyddKT8gJEdMT0JBTFNbJ2NoYW5neWFuX2NvdW50X2pzJ10gOiBGQUxTRTsNCmZ1bmN0aW9uIGxpYl9jaGFuZ3lhbigmJGN0YWcsJiRyZWZPYmopDQp7DQogICAgZ2xvYmFsICRkc3FsLCAkZW52czsNCiAgICAvL+WxnuaAp+WkhOeQhg0KICAgICRhdHRsaXN0PSJ0eXBlfGNvZGUsY29uZmlnfCxjbGFzc3xfREVERUNZLHN0eWxlfCI7DQogICAgRmlsbEF0dHNEZWZhdWx0KCRjdGFnLT5DQXR0cmlidXRlLT5JdGVtcywkYXR0bGlzdCk7DQogICAgZXh0cmFjdCgkY3RhZy0+Q0F0dHJpYnV0ZS0+SXRlbXMsIEVYVFJfU0tJUCk7DQogICAgDQogICAgJHJldmFsPSIiOw0KICAgIA0KICAgIGlmKCAhJGRzcWwtPklzVGFibGUoIiNAX19wbHVzX2NoYW5neWFuX3NldHRpbmciKSApIHJldHVybiAn5rKh5a6J6KOF55WF6KiA5qih5Z2XJzsNCiAgICANCiAgICAkY2xpZW50X2lkPWNoYW5neWFuX2dldF9zZXR0aW5nKCdhcHBpZCcpOw0KICAgIGlmKGVtcHR5KCRjbGllbnRfaWQpKSByZXR1cm4gJ+WwmuacquazqOWGjOeVheiogOW4kOWPt++8jOivt+WIsOWQjuWPsOazqOWGjCc7DQogICAgDQogICAgaWYoJHR5cGU9PSdjb2RlJyBPUiAkdHlwZT09J2NvZGUyJykNCiAgICB7DQogICAgICAgICRyZXZhbC49IjxkaXYgY2xhc3M9J3skY2xhc3N9JyBzdHlsZT0neyRzdHlsZX0nPiI7DQogICAgICAgICRwcmVmaXggPSAnY2hhbmd5YW4nOw0KICAgICAgICAka2V5ID0gJ2NvZGUnOw0KICAgICAgICAkcm93ID0gR2V0Q2FjaGUoJHByZWZpeCwgJGtleSk7DQoNCiAgICAgICAgaWYoIWlzX2FycmF5KCRyb3cpKQ0KICAgICAgICB7DQogICAgICAgICAgICAkYXBwaWQ9Y2hhbmd5YW5fZ2V0X3NldHRpbmcoJ2FwcGlkJyk7DQogICAgICAgICAgICAkdXNlcj1jaGFuZ3lhbl9nZXRfc2V0dGluZygndXNlcicpOw0KICAgICAgICAgICAgJHNpZ249Y2hhbmd5YW5fZ2VuX3NpZ24oJHVzZXIpOw0KICAgICAgICAgICAgJHJlc3VsdCA9IGNoYW5neWFuX2dldGNvZGUoQ0hBTkdZQU5fQ0xJRU5UX0lELCAkdXNlciwgZmFsc2UsICRzaWduLCAkYXBwaWQpOw0KICAgICAgICAgICAgaWYgKCAkcmVzdWx0WydzdGF0dXMnXSA9PSAxKQ0KICAgICAgICAgICAgew0KICAgICAgICAgICAgICAgIHJldHVybiAn5pyq6I635Y+W55WF6KiA5Luj56CB77yM6ZSZ6K+v5raI5oGv77yaJy4kcmVzdWx0Wydtc2cnXTsNCiAgICAgICAgICAgIH0NCiAgICAgICAgICAgICRyb3dbJ3JldmFsJ10gPSBkZWRlX2h0bWxzcGVjaWFsY2hhcnMoJHJlc3VsdFsnY29kZSddKTsNCiAgICAgICAgICAgIFNldENhY2hlKCRwcmVmaXgsICRrZXksICRyb3csIDYwKjYwKjEpOw0KICAgICAgICB9DQogICAgICAgIA0KICAgICAgICBpZighZW1wdHkoJGNvbmZpZykpDQogICAgICAgIHsNCiAgICAgICAgICAgICRjb25maWdfYXJyID0gYXJyYXkoKTsNCiAgICAgICAgICAgICRjb25maWdzID0gZXhwbG9kZSgnLCcsICRjb25maWcpOw0KICAgICAgICAgICAgaWYoY291bnQoJGNvbmZpZ3MpPjApDQogICAgICAgICAgICB7DQogICAgICAgICAgICAgICAgZm9yZWFjaCgkY29uZmlncyBhcyAkYykgew0KICAgICAgICAgICAgICAgICAgICAkaXRlbSA9IGV4cGxvZGUoJzonLCAkYyk7DQogICAgICAgICAgICAgICAgICAgICRjb25maWdfYXJyWyRpdGVtWzBdXSA9ICRpdGVtWzFdOw0KICAgICAgICAgICAgICAgIH0NCiAgICAgICAgICAgIH0NCiAgICAgICAgICAgICRjb25maWdfc3RyID0ganNvbl9lbmNvZGUoJGNvbmZpZ19hcnIpOw0KICAgICAgICAgICAgJHJldmFsIC49IDw8PEVPVA0KPHNjcmlwdD4NCiAgICB2YXJfY29uZmlnPXskY29uZmlnX3N0cn07DQo8L3NjcmlwdD4NCkVPVDsNCiAgICAgICAgfQ0KICAgICAgICAkcmV2YWwgLj0gaHRtbHNwZWNpYWxjaGFyc19kZWNvZGUoJHJvd1sncmV2YWwnXSk7DQogICAgICAgICRyZXZhbD1zdHJfcmVwbGFjZSgiaWQ9J1NPSFVDUyciLCAiaWQ9J1NPSFVDUycgc2lkPSd7JHJlZk9iai0+QXJjSUR9JyIsICRyZXZhbCk7DQogICAgICAgIGlmKCR0eXBlPT0nY29kZTInKSAkcmV2YWw9cHJlZ19yZXBsYWNlKCIjd2luZG93LlNDU19OT19JRlJBTUVbIF0/PVsgXT90cnVlOyNpIiwgIiIsICRyZXZhbCk7DQogICAgICAgICRyZXZhbD1zdHJfcmVwbGFjZSgiPHNjcmlwdD4iLCAiPC9kaXY+PHNjcmlwdD4iLCAkcmV2YWwpOw0KICAgIH0gZWxzZWlmKCR0eXBlPT0nY291bnQnKSB7DQogICAgICAgIGlmKCEkR0xPQkFMU1snY2hhbmd5YW5fY291bnRfanMnXSkgJHJldmFsLj0iPHNjcmlwdCB0eXBlPVwidGV4dC9qYXZhc2NyaXB0XCIgc3JjPVwiaHR0cDovL2Fzc2V0cy5jaGFuZ3lhbi5zb2h1LmNvbS91cGxvYWQvcGx1Z2lucy9wbHVnaW5zLmNvdW50LmpzXCI+PC9zY3JpcHQ+IjsNCiAgICAgICAgJHJldmFsLj0iPGEgaHJlZj1cIiNTT0hVQ1NcIiBpZD1cImNoYW5neWFuX2NvdW50X3VuaXRcIj48L2E+IjsNCiAgICAgICAgJEdMT0JBTFNbJ2NoYW5neWFuX2NvdW50X2pzJ10gPSBUUlVFOw0KICAgIH0NCiAgICANCiAgICByZXR1cm4gJHJldmFsOw0KfQ0K
  46. </file>
  47. <file type='file' name='changyan_main.php'>
  48. <?php
//@session_start();
require_once(dirname(__FILE__)."/config.php");
require_once(DEDEINC."/oxwindow.class.php");

helper('changyan');

if(empty($dopost)) $dopost = '';
if(empty($action)) $action = '';
if(empty($nocheck)) $nocheck = '';
if(empty($forward)) $forward = '';

$_SESSION['changyan'] = !empty($_SESSION['changyan'])? $_SESSION['changyan'] : 0;
$_SESSION['user'] = !empty($_SESSION['user'])? $_SESSION['user'] : '';

$appid=$client_id=changyan_get_setting('appid');

if ($dopost=='blank') {
    exit;
}

if ($cfg_feedback_forbid=='N' AND !empty($client_id)) {
    $dsql->ExecuteNoneQuery("UPDATE `#@__sysconfig` SET `value`='Y' WHERE `varname`='cfg_feedback_forbid';");
    changyan_ReWriteConfig();
    ShowMsg("已经禁用DedeCMS默认评论，开启畅言评论！","?");
    exit();
}

//auto update
$version=changyan_get_setting('version');

if(empty($_SESSION['user']) AND empty($nocheck))
{
    $db_user = changyan_get_setting('user');
    $db_pwd=changyan_mchStrCode(changyan_get_setting('pwd'), 'DECODE');

    if(!empty($db_user) AND !empty($db_pwd))
    {
        header('Location:?dopost=quick_login&nocheck=yes&forward='.$forward);
        exit();
    } elseif (empty($db_user) AND empty($db_pwd)) {
        ShowMsg("系统未绑定畅言账号，我们将自动为您分配一个初始账号，请耐心等待……","?dopost=autoreg&nocheck=yes");
        exit();
        //header('Location:?dopost=autoreg&nocheck=yes');
        //exit();
    } else {
        changyan_set_setting('pwd', '');
    }
}

if (empty($version)) $version = '0.0.1';
if (version_compare($version, CHANGYAN_VER, '<')) {
    $mysql_version = $dsql->GetVersion(TRUE);
    
    foreach ($update_sqls as $ver => $sqls) {
        if (version_compare($ver, $version,'<')) {
            continue;
        }
        foreach ($sqls as $sql) {
            $sql = preg_replace("#ENGINE=MyISAM#i", 'TYPE=MyISAM', $sql);
            $sql41tmp = 'ENGINE=MyISAM DEFAULT CHARSET='.$cfg_db_language;
            
            if($mysql_version >= 4.1)
            {
                $sql = preg_replace("#TYPE=MyISAM#i", $sql41tmp, $sql);
            }
            $dsql->ExecuteNoneQuery($sql);
        }
        changyan_set_setting('version', $ver);
        $version=changyan_get_setting('version');
    }
    $isv_app_key = changyan_get_isv_app_key();
}

if($dopost=='reg')
{
    $msg = <<<EOT
<table width="98%" border="0" cellspacing="1" cellpadding="1">
  <tbody>
    <tr>
      <td height="30" colspan="2" style="color:#999"><strong><a href="http://changyan.kuaizhan.com/?fromdedecms" target="_blank" style="color:blue">畅言</a></strong>是一个简单而强大的社会化评论及聚合平台。用户可以直接用自己的社会化网络账户在第三方网站发表评论，并且一键评论同步至社交网络将网站内容和自己的评论分享给好友。增加第三方网站用户活跃度，调动好友参与评论，帮助网站实现社会化网络优化，有效提升网站社会化流量！</td>
    </tr>
    <tr>
      <td height="30" colspan="2" style="color:#999"></td>
    </tr>
    <tr>
      <td width="16%" height="30">邮箱：</td>
      <td width="84%" style="text-align:left;"><input name="user" type="text" id="user" size="16" style="width:200px" /></td>
    </tr>
    <tr>
      <td height="30">密码：</td>
      <td style="text-align:left;"><input name="pwd" type="password" id="pwd" size="16" style="width:200px">
        <span style="color:#999">&nbsp;请输入数字、字母或常用符号</span></td>
    </tr>
    <tr>
      <td height="30">确认密码：</td>
      <td style="text-align:left;"><input name="repwd" type="password" id="repwd" size="16" style="width:200px">
        &nbsp;</td>
    </tr>
    <tr>
      <td width="16%" height="30">网站名称：</td>
      <td width="84%" style="text-align:left;"><input name="isv_name" type="text" id="isv_name" size="16" style="width:200px" value="{$cfg_webname}" /><span style="color:#999">&nbsp; 为方便您管理站点评论，建议更改站点名称</span></td>
    </tr>
    <tr>
      <td width="16%" height="30">网站地址：</td>
      <td width="84%" style="text-align:left;"><input name="url" type="text" id="url" size="16" style="width:200px" value="{$cfg_basehost}" /><span style="color:#999">&nbsp; 例如：http://www.dedecms.com</span></td>
    </tr>
  </tbody>
</table>
EOT;

    $wintitle = '注册畅言帐号：';
    $wecome_info = '<a href="?">畅言评论模块</a> 》注册帐号';
    $win = new OxWindow();
    $win->Init('?','js/blank.js','POST');
    $win->AddHidden('dopost','doreg');
    $win->AddHidden('nocheck','yes');
    $win->AddTitle($wintitle);
    $win->AddMsgItem($msg);
    $winform = $win->GetWindow('ok', '&nbsp;', false);
    $win->Display();

} elseif ($dopost=='doreg') {
    $user = empty($user)? '' : $user;
    $pwd = empty($pwd)? '' : $pwd;
    $repwd = empty($repwd)? '' : $repwd;
    $isv_name = empty($isv_name)? '' : $isv_name;
    $url = empty($url)? '' : $url;
    
    if(!preg_match("#^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"])*$#",$url))
    {
        ShowMsg("请填写正确的网址格式",-1);
        exit();
    }
    
    if(empty($isv_name) OR empty($url))
    {
        ShowMsg("您需要填写正确的站点信息，请重新填写",-1);
        exit();
    }
    if(empty($user) OR empty($pwd) OR empty($repwd))
    {
        ShowMsg("您需要填写E-mail和密码，请重新填写",-1);
        exit();
    }
    if(!CheckEmail($user))
    {
        ShowMsg("您的E-mail格式错误，请重新填写",-1);
        exit();
    }
    if($pwd != $repwd)
    {
        ShowMsg("填写两次密码不同，请返回重新输入！",-1);
        exit();
    }
    $sign=changyan_gen_sign($user);
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'user'=>changyan_autoCharset($user), 
        'password'=>$pwd, 
        'isv_name'=>changyan_autoCharset($isv_name), 
        'url'=>$url, 
        'sign'=>$sign);
    $rs=changyan_http_send(CHANGYAN_API_REG,0,$paramsArr);
    $result=json_decode($rs,TRUE);
    $errorinfo['appid not exist']='client_id不存在';
    $errorinfo['sign error']='签名验证失败';
    $errorinfo['user name exist']='注册用户已经存在';
    if($result['status']==0)
    {
        // 保存appid,id信息
        changyan_set_setting('user', $user);
        changyan_set_setting('appid', $result['appid']);
        changyan_set_setting('id', $result['id']);
        changyan_set_setting('isv_id', $result['isv_id']);
        changyan_clearcache();
        ShowMsg("您已经成功注册，现在进行登录！",'?');
        exit();
    } else {
        ShowMsg("无法正常注册，错误信息：".$errorinfo[$result['msg']], -1);
        exit();
    }
} elseif ($dopost=='autoreg') {
    $step = empty($step)? 0 : $step;
    $db_user = changyan_get_setting('user');
    if(!empty($db_user)) die('Error:User name is not empty!');
    $chars='abcdefghigklmnopqrstuvwxwyABCDEFGHIGKLMNOPQRSTUVWXWY0123456789';
    $sign=changyan_gen_sign(CHANGYAN_CLIENT_ID);
    $url = $_SERVER['SERVER_NAME'];
    $isv_name = cn_substr($cfg_webname,20);
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'isv_name'=>changyan_autoCharset($isv_name), 
        'url'=>'http://'.$url, 
        'sign'=>$sign);

    $rs=changyan_http_send(CHANGYAN_API_AUTOREG,0,$paramsArr);
    //var_dump($rs);exit;
    $result=json_decode($rs,TRUE);
    if($result['status']==0)
    {
        // 保存appid,id信息
        changyan_set_setting('user', $result['user']);
        changyan_set_setting('appid', $result['appid']);
        changyan_set_setting('id', $result['id']);
        changyan_set_setting('isv_app_key', $result['isv_app_key']);
        changyan_set_setting('isv_id', $result['isv_id']);
        changyan_clearcache();
        $passwd = changyan_mchStrCode($result['passwd'], 'ENCODE');
        changyan_set_setting('pwd', $passwd);
        header('Location:?');
        exit();
    } else {
        if($step > 10)
        {
            ShowMsg("无法自动分配账号，请手动进行注册！",'?dopost=reg&nocheck=yes');
            exit();
        }
        $step++;
        header('Location:?dopost=autoreg&nocheck=yes&i='.$step);
        exit();
    }
    
} elseif ($dopost=='bind') {
    $type = empty($type)? 'reg' : $type;
    if($action=='do')
    {
        if($type!='reg') $repwd=$pwd;
        if(empty($user) OR empty($pwd) OR empty($repwd))
        {
            ShowMsg("您需要填写E-mail和密码，请重新填写",-1);
            exit();
        }
        if(!CheckEmail($user))
        {
            ShowMsg("您的E-mail格式错误，请重新填写",-1);
            exit();
        }
        if($pwd != $repwd)
        {
            ShowMsg("填写两次密码不同，请返回重新输入！",-1);
            exit();
        }
        if($type=='reg')
        {
            $errorInfo='';
            if(changyan_bind_account($user, $pwd, $errorInfo))
            {
                ShowMsg("绑定成功，下面进行账号切换……！","?dopost=quick_login&nocheck=yes");
                exit();
            } else {
                ShowMsg("账号未绑定成功，请检查您输入的信息是否有误：{$errorInfo}！",-1);
                exit();
            }
        } else {
            //var_dump("Location:?dopost=login&user={$user}&pwd={$pwd}");exit;
            header("Location:?dopost=login&user={$user}&pwd={$pwd}&clear=yes");
            exit();
        }
        exit();
    }
    if($type=='reg')
    {
        $table = <<<EOT
            <tr>
            <td height="30">绑定类型：</td>
            <td style="text-align:left;"><input name="radio" type="radio" id="newreg" value="newreg" onclick="window.location.href='?dopost=bind&type=reg'" checked>
            <label for="newreg">新创建账号</label>
            <input type="radio" name="radio" id="login" value="login" onclick="window.location.href='?dopost=bind&type=login'" >
             <label for="login">已经有畅言账号</label>
            <input type='hidden' name='type' value='reg'></td>
          </tr>
            <tr>
              <td width="16%" height="30">系统分配账号：</td>
              <td width="84%" style="text-align:left;">{$_SESSION['user']}</td>
            </tr>
            <tr>
              <td width="16%" height="30">邮箱：</td>
              <td width="84%" style="text-align:left;"><input name="user" type="text" id="user" size="16" style="width:200px" /></td>
            </tr>
            <tr>
              <td height="30">密码：</td>
              <td style="text-align:left;"><input name="pwd" type="password" id="pwd" size="16" style="width:200px">
                <span style="color:#999">&nbsp;请输入数字、字母或常用符号</span></td>
            </tr>
            <tr>
              <td height="30">确认密码：</td>
              <td style="text-align:left;"><input name="repwd" type="password" id="repwd" size="16" style="width:200px">
                &nbsp;</td>
            </tr>
EOT;
    } else {
        $table = <<<EOT
            <tr>
            <td height="30">绑定类型：</td>
            <td style="text-align:left;"><input name="radio" type="radio" id="newreg" value="newreg" onclick="window.location.href='?dopost=bind&type=reg'">
            <label for="newreg">新创建账号</label>
            <input type="radio" name="radio" id="login" value="login" onclick="window.location.href='?dopost=bind&type=login'" checked>
            <label for="login">已经有畅言账号</label><input type='hidden' name='type' value='login'></td>
          </tr>
            <tr>
              <td width="16%" height="30">系统分配账号：</td>
              <td width="84%" style="text-align:left;">{$_SESSION['user']}</td>
            </tr>
            <tr>
              <td width="16%" height="30">邮箱：</td>
              <td width="84%" style="text-align:left;"><input name="user" type="text" id="user" size="16" style="width:200px" /></td>
            </tr>
            <tr>
              <td height="30">密码：</td>
              <td style="text-align:left;"><input name="pwd" type="password" id="pwd" size="16" style="width:200px">
                <span style="color:#999">&nbsp;请输入数字、字母或常用符号</span></td>
            </tr>
EOT;
    }
    $msg = <<<EOT
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset={$cfg_soft_lang}">
<title>绑定畅言帐号：</title>
<link rel="stylesheet" type="text/css" href="{$cfg_plus_dir}/img/base.css">
</head>
<body background='{$cfg_plus_dir}/img/allbg.gif' leftmargin="8" topmargin='8'>
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#DFF9AA">
  <tr>
    <td height="28" style="border:1px solid #DADADA" background='{$cfg_plus_dir}/img/wbg.gif'>&nbsp;<b>◇<a href="?">畅言评论模块</a> 》绑定帐号</b></td>
  </tr>
  <tr>
  
  <td width="100%" height="80" style="padding-top:5px" bgcolor='#ffffff'>
  
  <script language='javascript'>
function CheckSubmit(){
	return true; 
}
</script>
  <form name='myform' method='POST' onSubmit='return CheckSubmit();' action='?'>
  
  <input type='hidden' name='dopost' value='bind'>
  <input type='hidden' name='action' value='do'>
  <input type='hidden' name='nocheck' value='yes'>
  <table width='100%'  border='0' cellpadding='3' cellspacing='1' bgcolor='#DADADA'>
    <tr bgcolor='#DADADA'>
      <td colspan='2' background='{$cfg_plus_dir}/img/wbg.gif' height='26'><font color='#666600'><b>绑定畅言帐号：</b></font></td>
    </tr>
    <tr bgcolor='#FFFFFF'>
      <td colspan='2'  height='100'><table width="98%" border="0" cellspacing="1" cellpadding="1">
          <tbody>
            <tr>
              <td height="30" colspan="2" style="color:#999"><strong><a href="http://changyan.kuaizhan.com/?fromdedecms" target="_blank" style="color:blue">畅言</a></strong>是一个简单而强大的社会化评论及聚合平台。用户可以直接用自己的社会化网络账户在第三方网站发表评论，并且一键评论同步至社交网络将网站内容和自己的评论分享给好友。增加第三方网站用户活跃度，调动好友参与评论，帮助网站实现社会化网络优化，有效提升网站社会化流量！</td>
            </tr>
            <tr>
              <td height="30" colspan="2" style="color:#999"></td>
            </tr>
           {$table}
          </tbody>
        </table></td>
    </tr>
    <tr>
      <td colspan='2' bgcolor='#F9FCEF'><table width='270' border='0' cellpadding='0' cellspacing='0'>
          <tr align='center' height='28'>
            <td width='90'><input name='imageField1' type='image' class='np' src='{$cfg_plus_dir}/img/button_ok.gif' width='60' height='22' border='0' /></td>
            <td width='90'><a href='?'><img src='/plus/img/button_back.gif' width='60' height='22' border='0' /></a></td>
            <td width='90'></td>
          </tr>
        </table></td>
    </tr>
  </table>
  </td>
  </tr>
</table>
<p align="center"> <br>
  <br>
</p>
</body>
</html>
EOT;
    echo $msg;
    exit();
} elseif ($dopost=='quick_login')
{
    $clear = empty($clear)? '' : $clear;
    if(empty($forward)) $forward = '';
    $user = changyan_get_setting('user');
    $pwd=changyan_mchStrCode(changyan_get_setting('pwd'), 'DECODE') ;
    $sign=changyan_gen_sign($user);
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'user'=>$user, 
        'password'=>$pwd, 
        'sign'=>$sign);
    $rs=changyan_http_send(CHANGYAN_API_LOGIN,0,$paramsArr);
    $result=json_decode($rs,TRUE);
    if($result['status']==0)
    {
        if(!empty($clear)) changyan_set_setting('isv_id', '');
        //$appid = changyan_get_setting('appid');
        $isv_id = changyan_get_setting('isv_id');
        $isvs = changyan_get_isvs();
        $isv_in = FALSE;
        if(!empty($isv_id) ) foreach($isvs as $isv){ if($isv['id']==$isv_id) $isv_in=TRUE; }
        $_SESSION['changyan']=$result['token'];
        $_SESSION['user']=$user;
        if(!$isv_in)
        {
            ShowMsg("尚未设置站点APP信息，请进行配置……",'?dopost=change_appinfo');
            exit();
        } else {
            header('Location:?forward='.$forward);
            exit();
        }
    } else {
        changyan_set_setting('pwd', '');
        header('Location:?');
        exit();
    }
} elseif ($dopost=='login') {
    $user = empty($user)? '' : $user;
    $pwd = empty($pwd)? '' : $pwd;
    $clear = empty($clear)? '' : $clear;
    //$rmpwd = empty($rmpwd)? '' : $rmpwd;
    if(empty($user) OR empty($pwd))
    {
        ShowMsg("您需要填写E-mail和密码，请重新填写",-1);
        exit();
    }
    if(!CheckEmail($user))
    {
        ShowMsg("您的E-mail格式错误，请重新填写",-1);
        exit();
    }
    
    $sign=changyan_gen_sign($user);
    $paramsArr=array(
        'client_id'=>CHANGYAN_CLIENT_ID, 
        'user'=>$user, 
        'password'=>$pwd, 
        'sign'=>$sign);
    $rs=changyan_http_send(CHANGYAN_API_LOGIN,0,$paramsArr);
    $result=json_decode($rs,TRUE);
    if($result['status']==1)
    {
        ShowMsg("无法登录，请检查您的帐号信息是否填写正确！",-1);
        exit();
    } elseif ($result['status']==0)
    {
        $db_user = changyan_get_setting('user');

        if($db_user != $user)
        {
            changyan_set_setting('user', $user);
            changyan_set_setting('isv_app_key', '');
            $isv_app_key = changyan_get_isv_app_key();
        }
        if(!empty($clear)) changyan_set_setting('isv_id', '');
        $isv_id = changyan_get_setting('isv_id');
        $isvs = changyan_get_isvs();
        $isv_in = FALSE;
        if(!empty($isv_id)) foreach($isvs as $isv){ if($isv['id']==$isv_id) $isv_in=TRUE; }
        $_SESSION['changyan']=$result['token'];
        $_SESSION['user']=$user;
        $login_url=CHANGYAN_API_SETCOOKIE.'?client_id='.CHANGYAN_CLIENT_ID.'&token='.$result['token'];
        
        $pwd = changyan_mchStrCode($pwd, 'ENCODE');
        
        changyan_set_setting('pwd', $pwd);
        
        echo <<<EOT
<iframe src="{$login_url}" scrolling="no" width="0" height="0" style="border:none"></iframe>
EOT;
        if(!$isv_in)
        {
            ShowMsg("尚未设置站点APP信息，请进行配置……",'?dopost=change_appinfo');
            exit();
        } else {
            header('Location:?');
            exit();
        }
    } else {
        ShowMsg("无法登录，未知错误！",-1);
        exit();
    }
} elseif ($dopost=='changeisv') {
    $isv_id = intval($isv_id);
    $changge_isv_url = CHANGYAN_API_CHANGE_ISV.$isv_id;
    $isv_app_key = changyan_get_isv_app_key();
    echo <<<EOT
<iframe src="{$changge_isv_url}" scrolling="no" width="0" height="0" style="border:none"></iframe>
EOT;
    ShowMsg("成功切换站点！",'?');
    exit();
} elseif ($dopost=='isnew') {
    $rs=changyan_http_send(CHANGYAN_API_ISNEW.'/?appId='.$client_id.'&date='.urlencode( date('Y-m-d h:i:s')));
    $result=json_decode($rs,TRUE);
    if(count($result['topics'])>0) exit('true');
    else exit('false');
} elseif ($dopost=='latests') {
    $latests = changyan_latests($client_id);
    $data = array();
    if(count($latests['comments']) > 0)
    {
        foreach($latests['comments'] as $k => $v)
        {
            $data[] = array(
                'nickname'=>$v['passport']['nickname'],
                'content'=>$v['content'],
                'topic_title'=>$v['topic_title'],
                'topic_url'=>$v['topic_url'],
            );
        }
    }
    echo json_encode($latests);
    exit;
} elseif ($dopost=='getcode') {
    if(!changyan_islogin())
    {
        ShowMsg("您尚未登录畅言，请先登录后继续使用……！",'?');
        exit();
    }
    changyan_check_islogin();
    $user=changyan_get_setting('user');
    $sign=changyan_gen_sign($user);
    $result = changyan_getcode(CHANGYAN_CLIENT_ID, $user, false, $sign);
    $code = dede_htmlspecialchars($result['code']);
    $msg = <<<EOT
<style type='text/css'>
pre {
width:50%;
display: block;
padding: 9.5px;
margin: 0 0 10px;
font-size: 13px;
line-height: 20px;
word-break: break-all;
word-wrap: break-word;
white-space: pre;
white-space: pre-wrap;
background-color: #f5f5f5;
border: 1px solid #ccc;
border: 1px solid rgba(0,0,0,0.15);
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
}
</style>
<p>DedeCMS标签代码（将代码插入到模板页面对应位置即可）：</p>
<pre id="iframe" style="height:50px;">   
{dede:changyan/}     
</pre>
<p>Javascript代码（将代码插入到模板页面对应位置即可）：</p>
<pre id="iframe" style="height:150px;">   
{$code}         
</pre>
EOT;

    $wintitle = '畅言评论管理';
    $wecome_info = '<a href="?">畅言评论模块</a> 》获取代码';
    $win = new OxWindow();
    $win->AddTitle($wintitle);
    $win->AddMsgItem($msg);
    $winform = $win->GetWindow('hand', '&nbsp;', false);
    $win->Display();
    
} elseif ($dopost=='addsite') {
    if($action=='do')
    {
        $isv_name = empty($isv_name)? '' : $isv_name;
        $url = empty($url)? '' : $url;
        if(!preg_match("#^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"])*$#",$url))
        {
            ShowMsg("请填写正确的网址格式",-1);
            exit();
        }
        if(empty($isv_name) OR empty($url))
        {
            ShowMsg("您需要填写正确的站点信息，请重新填写",-1);
            exit();
        }
        $user=changyan_get_setting('user');
        $sign=changyan_gen_sign($user);
        $paramsArr=array(
            'user'=>$user, 
            'client_id'=>CHANGYAN_CLIENT_ID, 
            'isv_name'=>changyan_autoCharset($isv_name), 
            'url'=>$url, 
            'sign'=>$sign);
        $rs=changyan_http_send(CHANGYAN_API_ADDSITE,0,$paramsArr);
        $result=json_decode($rs,TRUE);
        if($result['status']==1)
        {
            ShowMsg("无法添加站点，请检查您的站点信息是否填写正确！",-1);
            exit();
        } else {
            changyan_set_setting('appid', $result['appid']);
            changyan_set_setting('id', $result['id']);
            changyan_set_setting('isv_id', $result['isv_id']);
            changyan_set_setting('isv_app_key', $result['isv_app_key']);
            $_SESSION['changyan']=$result['token'];
            changyan_clearcache();
            $isv_id = intval($result['isv_id']);
            $login_url=CHANGYAN_API_SETCOOKIE.'?client_id='.CHANGYAN_CLIENT_ID.'&token='.$result['token'];
            echo <<<EOT
<iframe src="{$login_url}" scrolling="no" width="0" height="0" style="border:none"></iframe>
EOT;
            ShowMsg("成功添加站点信息，进行站点切换……",'?dopost=changeisv&isv_id='.$isv_id,0,3000);
            exit;
        }
    } else {
        echo <<<EOT
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset={$cfg_soft_lang}">
<title>添加畅言站点：</title>
<link rel="stylesheet" type="text/css" href="{$cfg_plus_dir}/img/base.css">
</head>
<body background='{$cfg_plus_dir}/img/allbg.gif' leftmargin="8" topmargin='8'>
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#DFF9AA">
  <tr>
    <td height="28" style="border:1px solid #DADADA" background='{$cfg_plus_dir}/img/wbg.gif'>&nbsp;<b>◇<a href="?">畅言评论模块</a> 》添加畅言站点</b></td>
  </tr>
  <tr>
  
  <td width="100%" height="80" style="padding-top:5px" bgcolor='#ffffff'>
  
  <script language='javascript'>
function CheckSubmit(){
	return true; 
}
</script>
  <form name='myform' method='POST' onSubmit='return CheckSubmit();' action='?'>
  <input type='hidden' name='dopost' value='addsite'>
  <input type='hidden' name='action' value='do'>
  <table width='100%'  border='0' cellpadding='3' cellspacing='1' bgcolor='#DADADA'>
    <tr bgcolor='#DADADA'>
      <td colspan='2' background='{$cfg_plus_dir}/img/wbg.gif' height='26'><font color='#666600'><b>添加畅言站点：</b></font></td>
    </tr>
    <tr bgcolor='#FFFFFF'>
      <td colspan='2'  height='100'><table width="98%" border="0" cellspacing="1" cellpadding="1">
  <tbody>
    <tr>
      <td height="30" colspan="2" style="color:#999"><strong><a href="http://changyan.kuaizhan.com/?fromdedecms" target="_blank" style="color:blue">畅言</a></strong>是一个简单而强大的社会化评论及聚合平台。用户可以直接用自己的社会化网络账户在第三方网站发表评论，并且一键评论同步至社交网络将网站内容和自己的评论分享给好友。增加第三方网站用户活跃度，调动好友参与评论，帮助网站实现社会化网络优化，有效提升网站社会化流量！</td>
    </tr>
    <tr>
      <td height="30" colspan="2" style="color:#999"></td>
    </tr>
    <tr>
      <td width="16%" height="30">网站名称：</td>
      <td width="84%" style="text-align:left;"><input name="isv_name" type="text" id="isv_name" size="16" style="width:200px" value="{$cfg_webname}" /><span style="color:#999">&nbsp; 为方便您管理站点评论，建议更改站点名称</span></td>
    </tr>
    <tr>
      <td width="16%" height="30">网站地址：</td>
      <td width="84%" style="text-align:left;"><input name="url" type="text" id="url" size="16" style="width:200px" value="{$cfg_basehost}" /><span style="color:#999">&nbsp; 例如：http://www.dedecms.com</span></td>
    </tr>
  </tbody>
</table></td>
    </tr>
    <tr>
      <td colspan='2' bgcolor='#F9FCEF'><table width='270' border='0' cellpadding='0' cellspacing='0'>
          <tr align='center' height='28'>
            <td width='90'><input name='imageField1' type='image' class='np' src='{$cfg_plus_dir}/img/button_ok.gif' width='60' height='22' border='0' /></td>
            <td width='90'><a href='#'><img class='np' src='{$cfg_plus_dir}/img/button_reset.gif' width='60' height='22' border='0' onClick='this.form.reset();return false;' /></a></td>
            <td><a href='?dopost=change_appinfo'><img src='{$cfg_plus_dir}/img/button_back.gif' width='60' height='22' border='0'/></a></td>
          </tr>
        </table></td>
    </tr>
  </table>
  </td>
  </tr>
</table>
<p align="center"> <br>
  <br>
</p>
</body>
</html>
EOT;
    }
} elseif ($dopost=='manage' OR $dopost=='stat' OR $dopost=='setting'
OR $dopost=="import")
{
    if(!changyan_islogin())
    {
        ShowMsg("您尚未登录畅言，请先登录后继续使用……！",'?');
        exit();
    }
    changyan_check_islogin();
    $addstyle='scrolling="no" ';
    $type='audit';
    $appid=changyan_get_setting('appid');
    if($dopost=='manage') $type='audit';
    elseif($dopost=='stat') $type='stat';
    $ptitle = '畅言评论管理';

    $manage_url="http://changyan.kuaizhan.com/audit/comments/TOAUDIT/1";
    $addstr='';
    if($dopost=='setting') 
    {
        $ptitle = "畅言设置";
        $manage_url="http://changyan.kuaizhan.com/setting/basic";
        
    } elseif ($dopost=='stat')
    {
        $ptitle = "数据统计";
        $manage_url="http://changyan.kuaizhan.com/stat-data/comment";
    } elseif ($dopost=='import')
    {
        $ptitle = "畅言工具";
        $export_str=$import_str='';
        $manage_url="?dopost=blank";
        $last_import=changyan_get_setting('last_import');
        $last_export=changyan_get_setting('last_export');
        if (empty($last_export)) {
            $export_str = '<font color="red">尚未备份，建议备份！</font>';
        } else {
            $export_time = date('Y-m-d H:i:s', $last_export);
            $export_str = '<font color="#666">最后备份日期：'.$export_time.'</font>';
        }
        if (empty($last_import)) {
            $import_str = '<font color="red">尚未导出DedeCMS评论到畅言！</font>';
        } else {
            $import_time = date('Y-m-d H:i:s', $last_import);
            $import_str = '<font color="#666">最后导出日期：'.$import_time.'</font>';
        }
        $addstr=<<<EOT
        <tr bgcolor='#FFFFFF'>
          <td colspan='2' height='30px' style='padding:20px'>
          <script type="text/javascript">
          function isgo(url,msg) {
              if(confirm(msg)) window.location.href=url;
              else return false;
          }
          </script>
          <input type="button" size="14" onclick="return isgo('?dopost=changyan_to_dedecms','是否导出畅言到DedeCMS评论？');" value="导出畅言到DedeCMS评论"> 
           <span style="color:#999">将畅言模块中的数据导出备份到DedeCMS数据库中</span>  {$export_str}
          <br /><br />
          <input type="button" size="14" onclick="return isgo('?dopost=dedecms_to_changyan','是否导入DedeCMS评论到畅言？');" value="导入DedeCMS评论到畅言">
           <span style="color:#999">将DedeCMS评论数据导入到畅言模块中</span> {$import_str}
          </td>
        </tr>
EOT;
    }
    $addstyle='scrolling="auto" ';
    $account_str = preg_match("#@dedecms$#",$_SESSION['user'])? "<a href='?dopost=bind' style='color:blue'>[绑定账号]</a>" :
    "<a href='?dopost=logout' style='color:blue'>[切换账号]</a>";
    echo <<<EOT
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset={$cfg_soft_lang}">
<title>{$ptitle}</title>
<link rel="stylesheet" type="text/css" href="css/base.css">
</head>
<body background='images/allbg.gif' leftmargin="8" topmargin='8'>
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#DFF9AA" height="100%">
  <tr>
    <td height="28" style="border:1px solid #DADADA" background='images/wbg.gif'>
    
    <div style="float:left">&nbsp;<b>◇<a href="?">畅言评论模块</a> 》{$ptitle}</b></div>
    <div style="float:right;margin-right:20px;">您好：{$_SESSION['user']} {$account_str}</div>
    </td>
  </tr>
  <tr>
    <td width="100%" height="100%" valign="top" bgcolor='#ffffff' style="padding-top:5px"><table width='100%'  border='0' cellpadding='3' cellspacing='1' bgcolor='#DADADA' height="100%">
        <tr bgcolor='#DADADA'>
          <td colspan='2' background='images/wbg.gif' height='26'><font color='#666600'><b>{$ptitle}</b></font></td>
        </tr>
        {$addstr}
        <tr bgcolor='#FFFFFF'>
          <td colspan='2' height='100%' style='padding:20px'><br/><iframe src="{$manage_url}" {$addstyle} width="100%" height="100%" style="border:none"></iframe></td>
        </tr>
        <tr>
          <td bgcolor='#F5F5F5'>&nbsp;</td>
        </tr>
      </table></td>
  </tr>
</table>
<p align="center"> <br>
  <br>
</p>
</body>
</html>

EOT;
} elseif ($dopost=='dedecms_to_changyan') {
    if(!changyan_islogin())
    {
        ShowMsg("您尚未登录畅言，请先登录后继续使用……！",'?');
        exit();
    }
    $isv_app_key = changyan_get_isv_app_key();
    $start = isset($start)? intval($start) : 0;
    $pagesize=1;
    $sql = "SELECT count(*) as dd FROM `#@__feedback` group by aid order by aid asc limit {$start},{$pagesize}";
    $rr = $dsql->GetOne($sql);
    if($rr['dd']==0)
    {
        changyan_set_setting('last_import', time());
        ShowMsg('全部导出完成！','javascript:;');
        exit;
    }
    $sql = "SELECT aid FROM `#@__feedback` group by aid order by aid asc limit {$start},{$pagesize}";
    $dsql->SetQuery($sql);
    $dsql->Execute('dd');
    $result=array();
    while($arr = $dsql->GetArray('dd'))
    {
        $feedArr=array();
        $arctRow = $dsql->GetOne("SELECT * FROM `#@__arctiny` WHERE id={$arr['aid']}");
        if($arctRow['channel']==0) $arctRow['channel']=1;
        $cid = $arctRow['channel'];
        $chRow = $dsql->GetOne("SELECT * FROM `#@__channeltype` WHERE id='$cid' ");
        $row=array();
        if ($chRow['issystem']!= -1) {
            $sql = "SELECT arc.*,tp.reid,tp.typedir,tp.typename,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart,
            tp.moresite,tp.siteurl,tp.sitepath,ch.addtable
            FROM `#@__archives` arc
                     LEFT JOIN `#@__arctype` tp on tp.id=arc.typeid
                      LEFT JOIN `#@__channeltype` as ch on arc.channel = ch.id
                      WHERE arc.id='{$arr['aid']}' ";
            $row = $dsql->GetOne($sql);
        } else {
            if($chRow['addtable']!='')
            {
                $sql = "SELECT arc.*,tp.typedir,tp.typename,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart,
            tp.moresite,tp.siteurl,tp.sitepath FROM `{$chRow['addtable']}` arc  
            LEFT JOIN `#@__arctype` tp ON arc.typeid=tp.id
                WHERE `aid` = '{$arr['aid']}'";
                $addTableRow = $dsql->GetOne($sql);
                if(is_array($addTableRow))
                {
                    $row['id']=$addTableRow['aid'];
                    $row['title']=$addTableRow['title'];
                    $row['typeid']=$addTableRow['typeid'];
                    $row['mid']=$addTableRow['mid'];
                    $row['senddate']=$addTableRow['senddate'];
                    $row['channel']=$addTableRow['channel'];
                    $row['arcrank']=$addTableRow['arcrank'];
                    $row['senddate']=$addTableRow['senddate'];
                    $row['typedir']=$addTableRow['typedir'];
                    $row['isdefault']=$addTableRow['isdefault'];
                    $row['defaultname']=$addTableRow['defaultname'];
                    $row['ispart']=$addTableRow['ispart'];
                    $row['namerule2']=$addTableRow['namerule2'];
                    $row['moresite']=$addTableRow['moresite'];
                    $row['siteurl']=$addTableRow['siteurl'];
                    $row['sitepath']=$addTableRow['sitepath'];
                }
            }
        }
        $row['filename'] = $row['arcurl'] = GetFileUrl($row['id'],$row['typeid'],$row['senddate'],$row['title'],1,
        0,$row['namerule'],$row['typedir'],0,'',$row['moresite'],$row['siteurl'],$row['sitepath']);
        $row['title']=changyan_autoCharset($row['title']);
        
        $feedArr['title']=$row['title'];
        $feedArr['url']=$cfg_basehost.$row['arcurl'];
        $feedArr['ttime']= date('Y-m-d h:m:s',  $row['senddate']);
        $feedArr['sourceid']=$arr['aid'];
        $feedArr['parentid']=0;
        $feedArr['categoryid']=$row['typeid'];
        $feedArr['ownerid']=$row['mid'];
        $feedArr['metadata']='';

        $dsql->SetQuery("SELECT feedback_id FROM `#@__plus_changyan_importids` WHERE aid={$arr['aid']}");
        $dsql->Execute('dd');
        $feedback_ids=array();
        while($farr = $dsql->GetArray('dd'))
        {
            $feedback_ids[] = $farr['feedback_id'];
        }
        
        $squery="SELECT * FROM `#@__feedback` WHERE aid={$arr['aid']} order by dtime asc;";
        $dsql->SetQuery($squery);
        $dsql->Execute('xx');
        while($fRow = $dsql->GetArray('xx'))
        {
            if (in_array($fRow['id'], $feedback_ids)) continue;
            $feedArr['comments'][]=array(
                'cmtid'=>$fRow['id'],
                'ctime'=>date('Y-m-d h:m:s',  $fRow['dtime']),
                'content'=>changyan_Quote_replace(changyan_autoCharset($fRow['msg'])),
                'replyid'=>0,
                'spcount'=>$fRow['good'],
                'opcount'=>$fRow['bad'],
                'user'=>array(
                    'userid'=>$fRow['mid'],
                    'nickname'=>changyan_autoCharset($fRow['username']),
                    'usericon'=>'',
                    'userurl'=>'',
                )
            );
            $inquery = "INSERT INTO `#@__plus_changyan_importids`(`aid`,`feedback_id`) VALUES ('{$arr['aid']}','{$fRow['id']}')";
            $rs = $dsql->ExecuteNoneQuery($inquery);
        }
        if (count($feedArr['comments'])<1) {
            continue;
        }

        $content=json_encode($feedArr);
        $md5 = changyan_hmacsha1($content, $isv_app_key);

        $paramsArr=array(
            'appid'=>$client_id, 
            'md5'=>$md5, 
            'jsondata'=>$content);
        $rs=changyan_http_send(CHANGYAN_API_IMPORT,0,$paramsArr);
    }
    
    $start =$start+$pagesize;
    $end =$start+$pagesize;
    ShowMsg("成功导出评论数据，接下来导入[{$start}-{$end}]的评论数据","?dopost=dedecms_to_changyan&start={$start}");
    //echo json_encode($result);
    exit();
} elseif ($dopost=='changyan_to_dedecms') {
    if(!changyan_islogin())
    {
        ShowMsg("您尚未登录畅言，请先登录后继续使用……！",'?');
        exit();
    }
    $last_export=changyan_get_setting('last_export');
    if (empty($last_export)) {
        $start_date='2014-01-01 00:00:00';
    } else {
        $start_date= date('Y-m-d H:i:s',$last_export);
    }
    //$start_date='2014-01-01 00:00:00';
    $recent = changyan_get_recent($client_id, $start_date);
    //var_dump($recent);exit;
    if (count($recent['topics'])<=0) {
        ShowMsg("没有发现新的评论内容需要导出！",-1);
        exit();
    }
    $exports=array();
    foreach ($recent['topics'] as $topic) {
        $exports[]=array(
            'topic_id'=>$topic['topic_id'],
            'aid'=>$topic['topic_source_id'],
            'title'=>$topic['topic_title'],
        );
    }
    foreach ($exports as $export) {
        changyan_insert_comments(changyan_get_comments(changyan_get_setting('appid'),$export['topic_id']),$export['aid'],$export['title']);
    }
    changyan_set_setting('last_export', time());
    ShowMsg("成功备份畅言评论到DedeCMS系统！","?dopost=import");
    exit();
} elseif ($dopost=='change_appinfo') {
    if ($action=='do') {
        if (empty($appInfo)) {
            ShowMsg("请选择正确的AppID信息！",-1);
            exit();
        }
        list($appid,$isv_app_key)=explode('|',$appInfo);
        changyan_set_setting('appid',$appid);
        changyan_set_setting('isv_app_key',$isv_app_key);
        $user=changyan_get_setting('user');
        $sign=changyan_gen_sign($user);
        $result = changyan_getcode(CHANGYAN_CLIENT_ID, $user, false, $sign,$appid);
        $isv_id = $result['isv_id'];
        
        changyan_set_setting('isv_id',$isv_id);
        changyan_clearcache();
        $isv_id = intval($isv_id);
        $changge_isv_url = CHANGYAN_API_CHANGE_ISV.$isv_id;
        echo <<<EOT
<iframe src="{$changge_isv_url}" scrolling="no" width="0" height="0" style="border:none"></iframe>
EOT;
        ShowMsg("成功设置新的AppID及APPKEY！",'?',0,3000);
        exit();
    }
    $isvstr="<p> 选择您需要设置的APPID：</p>";
    $msg = <<<EOT
<table width="98%" border="0" cellspacing="1" cellpadding="1">
  <tbody>
    <tr>
      <td colspan="2" id="isvsContent">
      </td>
    </tr>
  </tbody>
</table>
EOT;
    $jquery_src =  CHANGYAN_JQUERY_SRC;
    $isvs_jsonp = changyan_get_isvs_jsonp();
    echo <<<EOT
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset={$cfg_soft_lang}">
<title>畅言评论管理</title>
<link rel="stylesheet" type="text/css" href="{$cfg_plus_dir}/img/base.css">
{$jquery_src}
{$isvs_jsonp}
</head>
<body background='{$cfg_plus_dir}/img/allbg.gif' leftmargin="8" topmargin='8'>
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#DFF9AA">
  <tr>
    <td height="28" style="border:1px solid #DADADA" background='{$cfg_plus_dir}/img/wbg.gif'>&nbsp;<b><a href="?">◇畅言评论模块 </a> 》配置APP信息</b></td>
  </tr>
  <tr>
  <td width="100%" height="80" style="padding-top:5px" bgcolor='#ffffff'>
  <script language='javascript'>
function CheckSubmit(){
	return true; 
}
</script>
  <form name='myform' method='POST' onSubmit='return CheckSubmit();' action='?'>
  
  <input type='hidden' name='dopost' value='change_appinfo'>
  <input type='hidden' name='action' value='do'>
  <table width='100%'  border='0' cellpadding='3' cellspacing='1' bgcolor='#DADADA'>
    <tr bgcolor='#DADADA'>
      <td colspan='2' background='{$cfg_plus_dir}/img/wbg.gif' height='26'><font color='#666600'><b>畅言评论管理</b></font></td>
    </tr>
    <tr bgcolor='#FFFFFF'>
      <td colspan='2'  height='100'>
      {$msg}
      </td>
    </tr>
    <tr>
      <td colspan='2' bgcolor='#F9FCEF'><table width='270' border='0' cellpadding='0' cellspacing='0'>
          <tr align='center' height='28'>
            <td width='90'><input name='imageField1' type='image' class='np' src='{$cfg_plus_dir}/img/button_ok.gif' width='60' height='22' border='0' /></td>
            <td width='90'><a href='?dopost=addsite' style="color:blue">创建APP ID</a></td>
            <td><a href='?' style="color:blue">返回上一页</a></td>
          </tr>
        </table></td>
    </tr>
  </table>
  </td>
  </tr>
</table>
<p align="center"> <br>
  <br>
</p>
</body>
</html>
EOT;
} elseif ($dopost=='checkupdate')
{
    $get_latest_ver = changyan_http_send(CHANGYAN_API_AES.'index.php?c=welcome&m=get_latest_ver');
    if(version_compare($get_latest_ver, CHANGYAN_VER,'>'))
    {
        ShowMsg("检查到有最新版本，请前去下载！<br /><a href='http://bbs.dedecms.com/650203.html' target='_blank' style='color:blue'>点击前去下载</a> <a href='?' >返回</a>","javascript:;");
        exit();
    } else {
        ShowMsg("<p>当前为最新版本，无须下载更新！</p> <p><a href='?' >返回上一页</a></p>","javascript:;");
        exit();
    }
    exit();
} elseif ($dopost=='clearcache')
{
    changyan_clearcache();
    ShowMsg("成功清空标签缓存！","?");
    exit();
} elseif ($dopost=='logout')
{
    echo <<<EOT
<iframe src="http://changyan.kuaizhan.com/logout" scrolling="no" width="0" height="0"></iframe>
EOT;
    $_SESSION['changyan'] = 0;
    $_SESSION['user'] = '';
    
    unset($_SESSION['changyan']);
    unset($_SESSION['user']);
    if($nomsg)
    {
        header('Location:?forward='.$forward);
        exit;
    } else {
        changyan_set_setting('pwd', '');
    }
    ShowMsg("成功退出畅言！",'?');
    exit();
} elseif($dopost=='forget-pwd')
{
    if($action=='do')
    {
        $user = empty($user)? '' : $user;
        if(empty($user) AND !CheckEmail($user))
        {
            ShowMsg("请填写正确格式的E-mail！",-1);
            exit();
        }
        $error_msg='';
        if(changyan_forget_pwd($user, $error_msg))
        {
            ShowMsg("<p>成功发送密码找回邮件，请登录[{$user}]查收！</p><p><a href='?' >返回上一页</a></p>",'javascript:;');
        } else {
            ShowMsg("密码找回错误：{$error_msg}！",-1);
        }
        exit;
    }
    $user = changyan_get_setting('user');
    $msg = <<<EOT
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset={$cfg_soft_lang}">
<title>畅言评论管理</title>
<link rel="stylesheet" type="text/css" href="{$cfg_plus_dir}/img/base.css">
</head>
<body background='{$cfg_plus_dir}/img/allbg.gif' leftmargin="8" topmargin='8'>
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#DFF9AA">
  <tr>
    <td height="28" style="border:1px solid #DADADA" background='{$cfg_plus_dir}/img/wbg.gif'>&nbsp;<b>◇<a href="?">畅言评论模块 </a> 》找回密码</b></td>
  </tr>
  <tr>
  
  <td width="100%" height="80" style="padding-top:5px" bgcolor='#ffffff'>
  
  <script language='javascript'>
function CheckSubmit(){
    return true; 
}
</script>
  <form name='myform' method='POST' onSubmit='return CheckSubmit();' action='?'>
  
  <input type='hidden' name='dopost' value='forget-pwd'>
  <input type='hidden' name='action' value='do'>
  <table width='100%'  border='0' cellpadding='3' cellspacing='1' bgcolor='#DADADA'>
    <tr bgcolor='#DADADA'>
      <td colspan='2' background='{$cfg_plus_dir}/img/wbg.gif' height='26'><font color='#666600'><b>畅言评论管理</b></font></td>
    </tr>
    <tr bgcolor='#FFFFFF'>
      <td colspan='2'  height='100'><table width="98%" border="0" cellspacing="1" cellpadding="1">
          <tbody>
            <tr>
              <td width="16%" height="30">邮箱：</td>
              <td width="84%" style="text-align:left;"><input name="user" type="text" id="user" size="16" style="width:200px" value="{$user}" />
                请填写您的注册邮箱</td>
            </tr>
          </tbody>
        </table></td>
    </tr>
    <tr>
      <td colspan='2' bgcolor='#F9FCEF'><table width='100%' border='0' cellpadding='0' cellspacing='0'>
          <tr align='center' height='28'>
            <td width='16%'></td>
            <td width='84%' style="text-align: left;"><input name='imageField1' type='image' class='np' src='{$cfg_plus_dir}/img/button_ok.gif' width='60' height='22' border='0' /></td>
            <td></td>
          </tr>
        </table></td>
    </tr>
  </table>
  </td>
  </tr>
</table>
</body>
</html>
EOT;
    echo $msg;
    exit;
} else {
    $user = changyan_get_setting('user');
    $changyan_ver = CHANGYAN_VER;
    if(empty($user)) $user='';
    $msg = <<<EOT
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset={$cfg_soft_lang}">
<title>畅言评论管理</title>
<link rel="stylesheet" type="text/css" href="{$cfg_plus_dir}/img/base.css">
</head>
<body background='{$cfg_plus_dir}/img/allbg.gif' leftmargin="8" topmargin='8'>
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#DFF9AA">
  <tr>
    <td height="28" style="border:1px solid #DADADA" background='{$cfg_plus_dir}/img/wbg.gif'>&nbsp;<b>◇畅言评论模块 》</b></td>
  </tr>
  <tr>
  
  <td width="100%" height="80" style="padding-top:5px" bgcolor='#ffffff'>
  
  <script language='javascript'>
function CheckSubmit(){
    return true; 
}
</script>
  <form name='myform' method='POST' onSubmit='return CheckSubmit();' action='?'>
  
  <input type='hidden' name='dopost' value='login'>
  <table width='100%'  border='0' cellpadding='3' cellspacing='1' bgcolor='#DADADA'>
    <tr bgcolor='#DADADA'>
      <td colspan='2' background='{$cfg_plus_dir}/img/wbg.gif' height='26'><font color='#666600'><b>畅言评论管理</b></font></td>
    </tr>
    <tr bgcolor='#FFFFFF'>
      <td colspan='2'  height='100'><table width="98%" border="0" cellspacing="1" cellpadding="1">
          <tbody>
            <tr>
              <td width="16%" height="30">版本：</td>
              <td width="84%" style="text-align:left;"><span style='color:black'><iframe name='stafrm' src='http://changyan.api.dedecms.com/index.php?c=welcome&m=new_ver&ver={$changyan_ver}&siteurl={$siteurl2}&feedback_total={$feedback_total}' frameborder='0' id='stafrm' width='98%' height='22'></iframe></span></td>
            </tr>
            <tr>
              <td width="16%" height="30">邮箱：</td>
              <td width="84%" style="text-align:left;"><input name="user" type="text" id="user" size="16" style="width:200px" value="{$user}" />
                <a href="?dopost=reg" style="color:blue">免费注册</a> ，获取专业的评论服务</td>
            </tr>
            <tr>
              <td height="30">密码：</td>
              <td style="text-align:left;"><input name="pwd" type="password" id="pwd" size="16" style="width:200px">
               <a href="?dopost=forget-pwd" style="color:blue">忘记密码</a> &nbsp; </td>
            </tr>
            <!--<tr>
      <td height="30">记住密码：</td>
      <td style="text-align:left;"><input type="checkbox" name="rmpwd" id="rmpwd" />
        <label for="rmpwd">下次登录不用再输入（不推荐）</label></td>
    </tr>-->
          </tbody>
        </table></td>
    </tr>
    <tr>
      <td colspan='2' bgcolor='#F9FCEF'><table width='100%' border='0' cellpadding='0' cellspacing='0'>
          <tr align='center' height='28'>
            <td width='16%'></td>
            <td width='84%' style="text-align: left;"><input name='imageField1' type='image' class='np' src='{$cfg_plus_dir}/img/button_ok.gif' width='60' height='22' border='0' /></td>
            <td></td>
          </tr>
        </table></td>
    </tr>
  </table>
  </td>
  </tr>
</table>
</body>
</html>
EOT;
    if(changyan_islogin())
    {
        $changyan_ver = CHANGYAN_VER;
        $login_url=CHANGYAN_API_SETCOOKIE.'?client_id='.CHANGYAN_CLIENT_ID.'&token='.$_SESSION['changyan'];
        $login_str = <<<EOT
<iframe src="{$login_url}" scrolling="no" width="0" height="0" style="border:none"></iframe>
EOT;
        
        $isv_app_key = changyan_get_setting('isv_app_key');
        $isv_id = changyan_get_setting('isv_id');
        $isv_id = intval($isv_id);
        $changge_isv_url = CHANGYAN_API_CHANGE_ISV.$isv_id;
        $isv_app_key = changyan_get_isv_app_key();
        $siteurl2 = urlencode($cfg_basehost);
        $rowcount = $dsql->GetOne("SELECT COUNT(*) AS dd FROM `#@__feedback`");
        $feedback_total = isset($rowcount['dd'])? $rowcount['dd'] : 0;
        $change_isv_id = <<<EOT
<div id="change_isv"></div>
<script type="text/javascript">
setTimeout(function(){var change_isv_div = document.getElementById("change_isv");change_isv_div.innerHTML='<iframe src="{$changge_isv_url}" scrolling="no" width="0" height="0" style="border:none"></iframe>';},100);
</script>
EOT;
        if(!empty($forward))
        {
            echo <<<EOT
            <div style="font-size: 12px;padding: 20px;border: 1px solid #DDD;">畅言模块自动登录中，请耐心等待……</div>
{$login_str}
{$change_isv_id}
<script type="text/javascript">
setTimeout(function(){window.location.href='?dopost={$forward}';},500);
</script>
EOT;
            exit();
        }
        $account_str = preg_match("#@dedecms$#",$_SESSION['user'])? "<a href='?dopost=bind' style='color:blue'>[绑定账号]</a> <font color='red'>为了保证您的评论安全，建议绑定账号</font>" :
        "<a href='?dopost=logout' style='color:blue'>[切换账号]</a>";
        $msg = <<<EOT
<table width="98%" border="0" cellspacing="1" cellpadding="1">
  <tbody>
    <tr>
      <td width="16%" height="30">登录用户：</td>
      <td width="84%" style="text-align:left;">{$_SESSION['user']} {$account_str} <!--<a href='?dopost=logout' style='color:blue'>[退出]</a>--></td>
    </tr>
    <tr>
      <td width="16%" height="30">畅言模块版本：</td>
      <td width="84%" style="text-align:left;"><span style='color:black'><iframe name='stafrm' src='http://changyan.api.dedecms.com/index.php?c=welcome&m=new_ver&ver={$changyan_ver}&siteurl={$siteurl2}&feedback_total={$feedback_total}' frameborder='0' id='stafrm' width='98%' height='22'></iframe></span></td>
    </tr>
    <tr>
      <td width="16%" height="30">App ID：</td>
      <td width="84%" style="text-align:left;"><input class="input-xlarge" type="text" value="{$client_id}" disabled="disabled/" style="width:260px"> <a href='?dopost=change_appinfo' style='color:blue'>[修改]</a> <span style="color:#999">&nbsp;APP ID用于切换不同的站点</span></td>
    </tr>
    <tr>
      <td width="16%" height="30">APP Key：</td>
      <td width="84%" style="text-align:left;"><input class="input-xlarge" type="text" value="{$isv_app_key}" disabled="disabled/" style="width:260px">  </td>
    </tr>
    <tr>
      <td height="30" colspan="2">您已成功登录畅言！您可以进行以下操作：</td>
    </tr>
    <tr>
      <td height="30" colspan="2">
      <a href='?dopost=manage' style='color:blue'>[评论管理]</a> 
      <a href='?dopost=stat' style='color:blue'>[数据统计]</a> 
      <a href='?dopost=import' style='color:blue'>[导入导出]</a> 
      <a href='?dopost=clearcache' style='color:blue'>[清空缓存]</a> 
      <a href='?dopost=setting' style='color:blue'>[畅言设置]</a> 
      </td>
    </tr>
<tr>
      <td height="30" colspan="2">
   <hr>
   使用说明：<br>
   在对应模板中使用标签：<font color="red">{dede:changyan/}</font>，直接进行调用即可，样式设定可点击<a href='?dopost=setting' style='color:blue'>[畅言设置]</a> 进行设置。
  <hr>
  功能说明：<br>
  <b>[评论管理]</b>审核、删除评论信息，敏感词管理，用户禁言操作；<br>
 <b>[数据统计]</b>站点评论信息数据全方位统计；<br>
 <b>[导入导出]</b>评论信息数据导入/导出，建议用户定期导出备份；<br>
 <b>[清空缓存]</b>清空畅言评论标签缓存，如果更改登录账号建议清空缓存再生成；<br>
 <b>[畅言设置]</b>畅言评论相关设定；<br><br>
<hr>
    </tr>
    <tr>
      <td height="30" colspan="2" style="color:#999"><strong>畅言</strong>是一个简单友好的社会化评论及聚合系统。畅言评论系统可以保证您网站的评论安全，让您的网站远离垃圾评论；用户可以使用自己的社交账户在您的网站发表评论，并且一键同步至社交网络，为您的网站带来更多流量。</td>
    </tr>
  </tbody>
</table>
{$login_str}
{$change_isv_id}
EOT;
        $wintitle = '畅言评论管理';
        $wecome_info = '畅言评论模块 》';
        $win = new OxWindow();
        $win->AddTitle($wintitle);
        $win->AddMsgItem($msg);
        $winform = $win->GetWindow('hand', '&nbsp;', false);
        $win->Display();
        exit;
    } else {
        unset($_SESSION['changyan']);
        unset($_SESSION['user']);
        echo $msg;
    }
}
?>

  49. </file>
  50. </modulefiles>
  51. </module>