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.
142 lines
4.6 KiB
142 lines
4.6 KiB
<?php
|
|
namespace Api\Controller;
|
|
use Think\Controller;
|
|
class OpenController extends BaseController {
|
|
|
|
//根据内容更新项目
|
|
public function updateItem(){
|
|
$api_key = I("api_key");
|
|
$api_token = I("api_token");
|
|
$cat_name = I("cat_name")?I("cat_name"):'';
|
|
$cat_name_sub = I("cat_name_sub");
|
|
$page_title = I("page_title");
|
|
$page_content = I("page_content");
|
|
$s_number = I("s_number") ? I("s_number") : 99;
|
|
|
|
$item_id = D("ItemToken")->check($api_key , $api_token);
|
|
if (!$item_id) {
|
|
//没验证通过
|
|
$this->sendError(10306);
|
|
return false;
|
|
}
|
|
|
|
//兼容之前的cat_name_sub参数
|
|
if ($cat_name_sub) {
|
|
$cat_name = $cat_name .'/'.$cat_name_sub ;
|
|
}
|
|
|
|
$page_id = D("Page")->update_by_content($item_id,$page_title,$page_content,$cat_name,$s_number);
|
|
|
|
if ($page_id) {
|
|
$ret = D("Page")->where(" page_id = '$page_id' ")->find();
|
|
$this->sendResult($ret);
|
|
}else{
|
|
$this->sendError(10101);
|
|
}
|
|
}
|
|
|
|
//根据shell上报的数据库结构信息生成数据字典
|
|
public function updateDbItem(){
|
|
$api_key = I("api_key");
|
|
$api_token = I("api_token");
|
|
$table_info = I("table_info");
|
|
$table_detail = I("table_detail");
|
|
$s_number = I("s_number") ? I("s_number") : 99;
|
|
$cat_name = I("cat_name") ? I("cat_name") : '';
|
|
header( 'Content-Type:text/html;charset=utf-8 ');
|
|
$cat_name = str_replace(PHP_EOL, '', $cat_name);
|
|
$item_id = D("ItemToken")->check($api_key , $api_token);
|
|
if (!$item_id) {
|
|
//没验证通过
|
|
echo "api_key或者api_token不匹配\n";
|
|
return false;
|
|
}
|
|
$table_info = str_replace("_this_and_change_", "&", $table_info);
|
|
$table_detail = str_replace("_this_and_change_", "&", $table_detail);
|
|
$tables = $this->_analyze_db_structure_to_array($table_info ,$table_detail);
|
|
if (!empty($tables)) {
|
|
foreach ($tables as $key => $value) {
|
|
$page_title = $value['table_name'] ;
|
|
$page_content = $value['markdown'] ;
|
|
$result = D("Page")->update_by_content($item_id,$page_title,$page_content,$cat_name,$s_number);
|
|
}
|
|
}
|
|
|
|
if (!empty($result)) {
|
|
echo "成功\n";
|
|
}else{
|
|
echo "失败\n";
|
|
}
|
|
|
|
//$this->_record_log();
|
|
|
|
}
|
|
|
|
//通过注释生成api文档
|
|
public function fromComments(){
|
|
R("FromComments/generate");
|
|
}
|
|
|
|
|
|
private function _analyze_db_structure_to_array($table_info , $table_detail){
|
|
$tables = array();
|
|
|
|
//解析table_info
|
|
$array = explode("\n", $table_info);
|
|
if(!empty($array)){
|
|
foreach ($array as $key => $value) {
|
|
if ($key == 0) {
|
|
continue;
|
|
}
|
|
$array2 = explode("\t", $value);
|
|
$table_name = str_replace(PHP_EOL, '', $array2[0]);
|
|
$tables[$array2[0]] = array(
|
|
"table_name" => $table_name ,
|
|
"table_comment" => $array2[1] ,
|
|
);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
//解析table_detail
|
|
$array = explode("\n", $table_detail);
|
|
if(!empty($array)){
|
|
foreach ($array as $key => $value) {
|
|
if ($key == 0) {
|
|
continue;
|
|
}
|
|
$array2 = explode("\t", $value);
|
|
|
|
$tables[$array2[0]]['columns'][$array2[1]] = array(
|
|
"column_name" => $array2[1] ,
|
|
"default" => $array2[2] ,
|
|
"is_nullable" => $array2[3] ,
|
|
"column_type" => $array2[4] ,
|
|
"column_comment" => $array2[5] ? $array2[5] : '无' ,
|
|
);
|
|
|
|
}
|
|
}
|
|
|
|
|
|
//生成markdown内容放在数组里
|
|
if (!empty($tables)) {
|
|
foreach ($tables as $key => $value) {
|
|
$markdown = '';
|
|
$markdown .= "- {$value['table_comment']} \n \n" ;
|
|
$markdown .= "|字段|类型|允许空|默认|注释| \n ";
|
|
$markdown .= "|:---- |:------- |:--- |----|------ | \n ";
|
|
foreach ($value['columns'] as $key2 => $value2) {
|
|
$markdown .= "|{$value2['column_name']} |{$value2['column_type']} |{$value2['is_nullable']} | {$value2['default']} | {$value2['column_comment']} | \n ";
|
|
}
|
|
|
|
$tables[$key]['markdown'] = $markdown ;
|
|
|
|
}
|
|
}
|
|
return $tables;
|
|
}
|
|
|
|
|
|
}
|