DiscuzX/upload/source/plugin/qqconnect/install.php

195 lines
6.1 KiB
PHP

<?php
/**
* [Discuz!] (C)2001-2099 Comsenz Inc.
* This is NOT a freeware, use is subject to license terms
*
* $Id: install.php 33885 2013-08-27 06:28:19Z nemohou $
*/
if(!defined('IN_DISCUZ')) {
exit('Access Denied');
}
$connect = C::t('common_setting')->fetch('connect', true);
$sql = <<<EOF
CREATE TABLE IF NOT EXISTS pre_common_member_connect (
`uid` mediumint(8) unsigned NOT NULL default '0',
`conuin` char(40) NOT NULL default '',
`conuinsecret` char(16) NOT NULL default '',
`conopenid` char(32) NOT NULL default '',
`conisfeed` tinyint(1) unsigned NOT NULL default '0',
`conispublishfeed` tinyint(1) unsigned NOT NULL default '0',
`conispublisht` tinyint(1) unsigned NOT NULL default '0',
`conisregister` tinyint(1) unsigned NOT NULL default '0',
`conisqzoneavatar` tinyint(1) unsigned NOT NULL default '0',
`conisqqshow` tinyint(1) unsigned NOT NULL default '0',
`conuintoken` char(32) NOT NULL DEFAULT '',
PRIMARY KEY (`uid`),
KEY `conuin` (`conuin`),
KEY `conopenid` (`conopenid`)
) ENGINE=MyISAM;
CREATE TABLE IF NOT EXISTS pre_connect_feedlog (
flid mediumint(8) unsigned NOT NULL AUTO_INCREMENT,
tid mediumint(8) unsigned NOT NULL DEFAULT '0',
uid mediumint(8) unsigned NOT NULL DEFAULT '0',
publishtimes mediumint(8) unsigned NOT NULL DEFAULT '0',
lastpublished int(10) unsigned NOT NULL DEFAULT '0',
dateline int(10) unsigned NOT NULL DEFAULT '0',
`status` tinyint(1) NOT NULL DEFAULT '1',
PRIMARY KEY (flid),
UNIQUE KEY tid (tid)
) ENGINE=MyISAM;
CREATE TABLE IF NOT EXISTS pre_connect_postfeedlog (
flid mediumint(8) unsigned NOT NULL AUTO_INCREMENT,
pid int(10) unsigned NOT NULL DEFAULT '0',
uid mediumint(8) unsigned NOT NULL DEFAULT '0',
publishtimes mediumint(8) unsigned NOT NULL DEFAULT '0',
lastpublished int(10) unsigned NOT NULL DEFAULT '0',
dateline int(10) unsigned NOT NULL DEFAULT '0',
`status` tinyint(1) NOT NULL DEFAULT '1',
PRIMARY KEY (flid),
UNIQUE KEY pid (pid)
) ENGINE=MyISAM;
CREATE TABLE IF NOT EXISTS pre_connect_memberbindlog (
mblid mediumint(8) unsigned NOT NULL AUTO_INCREMENT,
uid mediumint(8) unsigned NOT NULL DEFAULT '0',
uin char(40) NOT NULL,
`type` tinyint(1) NOT NULL DEFAULT '0',
dateline int(10) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (mblid),
KEY uid (uid),
KEY uin (uin),
KEY dateline (dateline)
) ENGINE=MyISAM;
CREATE TABLE IF NOT EXISTS pre_connect_tthreadlog (
twid char(16) NOT NULL,
tid mediumint(8) unsigned NOT NULL DEFAULT '0',
conopenid char(32) NOT NULL,
pagetime int(10) unsigned DEFAULT '0',
lasttwid char(16) DEFAULT NULL,
nexttime int(10) unsigned DEFAULT '0',
updatetime int(10) unsigned DEFAULT '0',
dateline int(10) unsigned DEFAULT '0',
PRIMARY KEY (twid),
KEY nexttime (tid,nexttime),
KEY updatetime (tid,updatetime)
) ENGINE=MyISAM;
CREATE TABLE IF NOT EXISTS pre_common_uin_black (
uin char(40) NOT NULL,
uid mediumint(8) unsigned NOT NULL DEFAULT '0',
dateline int(10) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (uin),
UNIQUE KEY uid (uid)
) ENGINE=MyISAM;
CREATE TABLE IF NOT EXISTS pre_common_connect_guest (
`conopenid` char(32) NOT NULL default '',
`conuin` char(40) NOT NULL default '',
`conuinsecret` char(16) NOT NULL default '',
`conqqnick` char(100) NOT NULL default '',
`conuintoken` char(32) NOT NULL DEFAULT '',
PRIMARY KEY (conopenid)
) TYPE=MyISAM;
CREATE TABLE IF NOT EXISTS `pre_connect_disktask` (
`taskid` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '任务ID',
`aid` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '附件ID',
`uid` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '用户ID',
`openid` char(32) NOT NULL DEFAULT '' COMMENT 'openId',
`filename` varchar(255) NOT NULL DEFAULT '' COMMENT '附件名称',
`verifycode` char(32) NOT NULL DEFAULT '' COMMENT '下载验证码',
`status` smallint(6) unsigned NOT NULL DEFAULT '0' COMMENT '下载状态',
`dateline` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '添加任务的时间',
`downloadtime` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '下载完成时间',
`extra` text COMMENT '保留字段',
PRIMARY KEY (`taskid`),
KEY `openid` (`openid`),
KEY `status` (`status`)
) TYPE=MyISAM COMMENT='网盘下载任务表';
REPLACE INTO pre_common_setting VALUES ('regconnect', '1');
EOF;
runquery($sql);
$needCreateGroup = true;
if ($connect['feed']) {
$group = C::t('common_usergroup')->fetch($connect['guest_groupid']);
if ($group) {
$needCreateGroup = false;
}
} else {
$connect = array (
'allow' => '1',
'feed' =>
array (
'allow' => '1',
'group' => '0',
),
't' =>
array (
'allow' => '1',
'group' => '0',
'reply' => 1,
'reply_showauthor' => 1,
),
'like_allow' => '1',
'like_qq' => '',
'turl_allow' => '1',
'turl_qq' => '',
'like_url' => '',
'register_birthday' => '0',
'register_gender' => '0',
'register_uinlimit' => '',
'register_rewardcredit' => '1',
'register_addcredit' => '',
'register_groupid' => '0',
'register_regverify' => '1',
'register_invite' => '0',
'newbiespan' => '',
'turl_code' => '',
'mblog_app_key' => 'abc',
);
}
if ($needCreateGroup) {
include DISCUZ_ROOT . 'source/language/lang_admincp_cloud.php';
$name = $extend_lang['connect_guest_group_name'];
$userGroupData = array(
'type' => 'special',
'grouptitle' => $name,
'allowvisit' => 1,
'color' => '',
'stars' => '',
);
$newGroupId = C::t('common_usergroup')->insert($userGroupData, true);
$dataField = array(
'groupid' => $newGroupId,
'allowsearch' => 2,
'readaccess' => 1,
'allowgetattach' => 1,
'allowgetimage' => 1,
);
C::t('common_usergroup_field')->insert($dataField);
$connect['guest_groupid'] = $newGroupId;
updatecache('usergroups');
}
$https = json_decode(dfsockopen('https://graph.qq.com/user/get_user_info'));
$connect['oauth2'] = $https->ret == -1 ? 1 : 0;
C::t('common_setting')->update('connect', serialize($connect));
updatecache('setting');
$finish = true;