206 lines
9.2 KiB
PHP
206 lines
9.2 KiB
PHP
<?
|
|
$sub_menu = '300100';
|
|
include_once('./_common.php');
|
|
|
|
auth_check($auth[$sub_menu], 'w');
|
|
|
|
$target_table = mysql_real_escape_string(trim($_POST['target_table']));
|
|
$target_subject = mysql_real_escape_string(trim($_POST['target_subject']));
|
|
|
|
if (!preg_match('/[A-Za-z0-9_]{1,20}/', $target_table))
|
|
{
|
|
alert('게시판 TABLE명은 공백없이 영문자, 숫자, _ 만 사용 가능합니다. (20자 이내)');
|
|
}
|
|
|
|
$row = sql_fetch(" select count(*) as cnt from {$g4['board_table']} where bo_table = $target_table ");
|
|
if ($row[cnt])
|
|
alert($target_table.'은(는) 이미 존재하는 게시판 TABLE 입니다.\\n\\n복사할 TABLE로 사용할 수 없습니다.');
|
|
|
|
check_token();
|
|
|
|
// 게시판 테이블 생성
|
|
$sql = get_table_define($g4['write_prefix'] . $bo_table);
|
|
$sql = str_replace($g4['write_prefix'] . $bo_table, $g4['write_prefix'] . $target_table, $sql);
|
|
sql_query($sql);
|
|
|
|
$file_copy = array();
|
|
|
|
// 게시판 정보
|
|
$sql = " insert into {$g4['board_table']}
|
|
set bo_table = '$target_table',
|
|
bo_subject = '$target_subject',
|
|
gr_id = '{$board['gr_id']}',
|
|
bo_admin = '{$board['bo_admin']}',
|
|
bo_list_level = '{$board[bo_list_level]}',
|
|
bo_read_level = '{$board[bo_read_level]}',
|
|
bo_write_level = '{$board[bo_write_level]}',
|
|
bo_reply_level = '{$board[bo_reply_level]}',
|
|
bo_comment_level = '{$board[bo_comment_level]}',
|
|
bo_upload_level = '{$board[bo_upload_level]}',
|
|
bo_download_level = '{$board[bo_download_level]}',
|
|
bo_html_level = '{$board[bo_html_level]}',
|
|
bo_link_level = '{$board[bo_link_level]}',
|
|
bo_count_modify = '{$board[bo_count_modify]}',
|
|
bo_count_delete = '{$board[bo_count_delete]}',
|
|
bo_read_point = '{$board[bo_read_point]}',
|
|
bo_write_point = '{$board[bo_write_point]}',
|
|
bo_comment_point = '{$board[bo_comment_point]}',
|
|
bo_download_point = '{$board[bo_download_point]}',
|
|
bo_use_category = '{$board[bo_use_category]}',
|
|
bo_category_list = '{$board['bo_category_list']}',
|
|
bo_disable_tags = '{$board['bo_disable_tags']}',
|
|
bo_use_secret = '{$board[bo_use_secret]}',
|
|
bo_use_dhtml_editor = '{$board[bo_use_dhtml_editor]}',
|
|
bo_use_sideview = '{$board[bo_use_sideview]}',
|
|
bo_use_good = '{$board[bo_use_good]}',
|
|
bo_use_nogood = '{$board[bo_use_nogood]}',
|
|
bo_use_signature = '{$board[bo_use_signature]}',
|
|
bo_use_ip_view = '{$board[bo_use_ip_view]}',
|
|
bo_use_list_view = '{$board['o_use_list_view']}',
|
|
bo_use_list_content = '{$board[bo_use_list_content]}',
|
|
bo_table_width = '{$board[bo_table_width]}',
|
|
bo_subject_len = '{$board[bo_subject_len]}',
|
|
bo_page_rows = '{$board[bo_page_rows]}',
|
|
bo_new = '{$board[bo_new]}',
|
|
bo_hot = '{$board[bo_hot]}',
|
|
bo_image_width = '{$board[bo_image_width]}',
|
|
bo_skin = '{$board['bo_skin']}',
|
|
bo_include_head = '{$board['bo_include_head']}',
|
|
bo_include_tail = '{$board['bo_include_tail']}',
|
|
bo_content_head = '".addslashes($board['bo_content_head'])."',
|
|
bo_content_tail = '".addslashes($board['bo_content_tail'])."',
|
|
bo_insert_content = '".addslashes($board['bo_insert_content'])."',
|
|
bo_gallery_cols = '{$board[bo_gallery_cols]}',
|
|
bo_upload_size = '{$board[bo_upload_size]}',
|
|
bo_reply_order = '{$board[bo_reply_order]}',
|
|
bo_use_search = '{$board[bo_use_search]}',
|
|
bo_order_search = '{$board[bo_order_search]}',
|
|
bo_notice = '{$board['bo_notice']}',
|
|
bo_upload_count = '{$board[bo_upload_count]}',
|
|
bo_use_email = '{$board[bo_use_email]}',
|
|
bo_sort_field = '{$board['bo_sort_field']}',
|
|
bo_1_subj = '{$board['bo_1_subj']}',
|
|
bo_2_subj = '{$board['bo_2_subj']}',
|
|
bo_3_subj = '{$board['bo_3_subj']}',
|
|
bo_4_subj = '{$board['bo_4_subj']}',
|
|
bo_5_subj = '{$board['bo_5_subj']}',
|
|
bo_6_subj = '{$board['bo_6_subj']}',
|
|
bo_7_subj = '{$board['bo_7_subj']}',
|
|
bo_8_subj = '{$board['bo_8_subj']}',
|
|
bo_9_subj = '{$board['bo_9_subj']}',
|
|
bo_10_subj = '{$board['bo_10_subj']}',
|
|
bo_1 = '{$board['bo_1']}',
|
|
bo_2 = '{$board['bo_2']}',
|
|
bo_3 = '{$board['bo_3']}',
|
|
bo_4 = '{$board['bo_4']}',
|
|
bo_5 = '{$board['bo_5']}',
|
|
bo_6 = '{$board['bo_6']}',
|
|
bo_7 = '{$board['bo_7']}',
|
|
bo_8 = '{$board['bo_8']}',
|
|
bo_9 = '{$board['bo_9']}',
|
|
bo_10 = '{$board['bo_10']}' ";
|
|
sql_query($sql);
|
|
|
|
// 게시판 폴더 생성
|
|
@mkdir($g4['path'].'/data/file/'.$target_table, 0707);
|
|
@chmod($g4['path'].'/data/file/'.$target_table, 0707);
|
|
|
|
// 디렉토리에 있는 파일의 목록을 보이지 않게 한다.
|
|
$board_path = $g4['path'].'/data/file/'.$target_table;
|
|
$file = $board_path . '/index.php';
|
|
$f = @fopen($file, 'w');
|
|
@fwrite($f, '');
|
|
@fclose($f);
|
|
@chmod($file, 0606);
|
|
|
|
$copy_file = 0;
|
|
if ($copy_case == 'schema_data_both')
|
|
{
|
|
$d = dir($g4['path'].'/data/file/'.$bo_table);
|
|
while ($entry = $d->read())
|
|
{
|
|
if ($entry == '.' || $entry == '..') continue;
|
|
|
|
/*
|
|
@copy('$g4['path']/data/file/$bo_table/$entry', '$g4['path']/data/file/$target_table/$entry');
|
|
@chmod('$g4['path']/data/file/$target_table/$entry', 0707);
|
|
|
|
$copy_file++;
|
|
*/
|
|
|
|
// 김선용 201007 :
|
|
if(is_dir($g4['path'].'/data/file/'.$bo_table.'/'.$entry)){
|
|
$dd = dir($g4['path'].'/data/file/'.$bo_table.'/'.$entry);
|
|
@mkdir($g4['path'].'/data/file/'.$target_table.'/'.$entry, 0707);
|
|
@chmod($g4['path'].'/data/file/'.$target_table.'/'.$entry, 0707);
|
|
while ($entry2 = $dd->read()) {
|
|
if ($entry2 == '.' || $entry2 == '..') continue;
|
|
@copy($g4['path'].'/data/file/'.$bo_table.'/'.$entry.'/'.$entry2, $g4['path'].'/data/file/'.$target_table.'/'.$entry.'/'.$entry2);
|
|
@chmod($g4['path'].'/data/file/'.$target_table.'/'.$entry.'/'.$entry2, 0707);
|
|
$copy_file++;
|
|
}
|
|
$dd->close();
|
|
}
|
|
else {
|
|
@copy($g4['path'].'/data/file/'.$bo_table.'/'.$entry, $g4['path'].'/data/file/'.$target_table.'/'.$entry);
|
|
@chmod($g4['path'].'/data/file/'.$target_table.'/'.$entry, 0707);
|
|
$copy_file++;
|
|
}
|
|
}
|
|
$d->close();
|
|
|
|
// 글복사
|
|
$sql = " insert into {$g4['write_prefix']}$target_table select * from {$g4['write_prefix']}$bo_table ";
|
|
sql_query($sql);
|
|
|
|
// 게시글수 저장
|
|
$sql = " select bo_count_write, bo_count_comment from {$g4['board_table']} where bo_table = '$bo_table' ";
|
|
$row = sql_fetch($sql);
|
|
$sql = " update {$g4['board_table']} set bo_count_write = '{$row[bo_count_write]}', bo_count_comment = '{$row[bo_count_comment]}' where bo_table = '$target_table' ";
|
|
sql_query($sql);
|
|
|
|
// 05.05.24
|
|
// 파일테이블 복사
|
|
//$sql = ' insert into $g4[board_file_table] select "$target_table", wr_id, bf_no, bf_source, bf_file, bf_download, bf_content from $g4[board_file_table] where bo_table = "$bo_table" ';
|
|
//sql_query($sql);
|
|
|
|
// 4.00.01
|
|
// 위의 코드는 같은 테이블명을 사용하였다는 오류가 발생함. (희한하네 ㅡㅡ;)
|
|
$sql = " select * from {$g4['board_file_table']} where bo_table = '$bo_table' ";
|
|
$result = sql_query($sql);
|
|
for ($i=0; $row=sql_fetch_array($result); $i++)
|
|
$file_copy[$i] = $row;
|
|
}
|
|
|
|
if (count($file_copy))
|
|
{
|
|
for ($i=0; $i<count($file_copy); $i++)
|
|
{
|
|
$sql = " insert into $g4[board_file_table]
|
|
set bo_table = '$target_table',
|
|
wr_id = '{$file_copy[$i][wr_id]}',
|
|
bf_no = '{$file_copy[$i][bf_no]}',
|
|
bf_source = '{$file_copy[$i]['bf_source']}',
|
|
bf_file = '{$file_copy[$i]['bf_file']}',
|
|
bf_download = '{$file_copy[$i]['bf_download']}',
|
|
bf_content = '{$file_copy[$i]['bf_content']}',
|
|
bf_filesize = '{$file_copy[$i][bf_filesize]}',
|
|
bf_width = '{$file_copy[$i][bf_width]}',
|
|
bf_height = '{$file_copy[$i][bf_height]}',
|
|
bf_type = '{$file_copy[$i][bf_type]}',
|
|
bf_datetime = '{$file_copy[$i]['bf_datetime']}' ";
|
|
sql_query($sql, FALSE);
|
|
}
|
|
}
|
|
?>
|
|
|
|
<meta http-equiv="content-type" content="text/html; charset=<?=$g4['charset']?>">
|
|
<script>
|
|
alert('게시판 복사 : <?=$bo_table?> > <?=$target_table?> 성공 <? if ($copy_file) echo PHP_EOL.' 복사한 파일 : 총 <?=$copy_file?>개';?>');
|
|
opener.document.location.reload();
|
|
</script>
|
|
|
|
<?
|
|
goto_url('./board_copy.php?bo_table='.$bo_table.'&'.$qstr);
|
|
?>
|