<?php require_once '/home/www/GNU/_PAGE/head.php'; ?>
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>AI MANUAL - 시스템 관제 센터</title>
<!-- 웹 폰트 및 아이콘 로드 -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
<link href="https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Noto+Sans+KR:wght@300;400;700&family=JetBrains+Mono:wght@400;700&display=swap" rel="stylesheet">
<style>
/* 변수 설정 */
:root {
--aim-neon-green: #00ff88;
--aim-neon-blue: #00d2ff;
--aim-gold: #f1c40f;
--aim-bg-deep: #050505;
--aim-card-bg: rgba(13, 17, 23, 0.7);
--aim-border-glow: rgba(0, 255, 136, 0.3);
--aim-border-line: rgba(255, 255, 255, 0.08);
}
/* [구조 유지] 전체 배경 스타일 */
body {
background-color: var(--aim-bg-deep);
color: #e1e1e1;
font-family: 'Noto Sans KR', sans-serif;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
align-items: center;
min-height: 100vh;
overflow-x: hidden;
background-image: radial-gradient(circle at 50% 0%, #1a1f35 0%, #050505 100%);
}
/* 로딩 시퀀스 */
#aim-system-loader {
position: fixed; top: 0; left: 0; width: 100%; height: 100%;
background: #000; display: flex; flex-direction: column;
justify-content: center; align-items: center; z-index: 99999;
transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.aim-quantum-spinner {
width: 60px; height: 60px;
border: 2px solid rgba(0, 255, 136, 0.1);
border-top: 2px solid var(--aim-neon-green);
border-radius: 50%;
animation: aim-spin 1s cubic-bezier(0.5, 0, 0.5, 1) infinite;
margin-bottom: 20px;
box-shadow: 0 0 15px var(--aim-neon-green);
}
@keyframes aim-spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
.aim-main-content-wrap {
opacity: 0;
transform: translateY(30px);
transition: all 0.8s cubic-bezier(0.2, 1, 0.3, 1);
width: 100%;
max-width: 100%;
padding: 80px 50px;
box-sizing: border-box;
}
.aim-main-content-wrap.aim-is-active { opacity: 1; transform: translateY(0); }
.aim-header-banner {
border-bottom: 1px solid var(--aim-border-line);
padding-bottom: 40px;
margin-bottom: 60px;
text-align: center;
width: 100%;
}
.aim-header-banner h1 {
font-family: 'Orbitron', sans-serif;
color: var(--aim-neon-green);
font-size: 3.5rem;
margin: 0;
letter-spacing: 12px;
text-shadow: 0 0 20px rgba(0, 255, 136, 0.4);
font-weight: 900;
}
.aim-header-banner p {
font-family: 'JetBrains Mono', monospace;
color: #555;
font-size: 1rem;
margin-top: 15px;
text-transform: uppercase;
letter-spacing: 3px;
}
.aim-manual-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 30px;
width: 100%;
}
.aim-nav-card {
background: var(--aim-card-bg);
backdrop-filter: blur(20px);
border: 1px solid var(--aim-border-line);
padding: 45px 35px;
border-radius: 24px;
text-decoration: none;
transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
display: flex;
flex-direction: column;
gap: 20px;
position: relative;
overflow: hidden;
box-shadow: 0 10px 30px rgba(0,0,0,0.3);
cursor: pointer;
}
.aim-nav-card::after {
content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 2px;
background: linear-gradient(90deg, transparent, var(--aim-neon-green), transparent);
opacity: 0; transition: opacity 0.3s;
}
.aim-nav-card:hover {
border-color: var(--aim-neon-green);
background: rgba(30, 30, 45, 0.85);
transform: translateY(-15px);
box-shadow: 0 30px 60px rgba(0, 0, 0, 0.7), 0 0 20px rgba(0, 255, 136, 0.1);
}
.aim-nav-card:hover::after { opacity: 1; }
.aim-nav-card h2 {
margin: 0;
color: #fff;
font-family: 'Orbitron', sans-serif;
font-size: 1.6rem;
display: flex;
align-items: center;
gap: 15px;
}
.aim-nav-card h2 i { color: var(--aim-gold); transition: all 0.3s; }
.aim-nav-card:hover h2 i { transform: rotate(-10deg) scale(1.15); color: var(--aim-neon-green); text-shadow: 0 0 10px var(--aim-neon-green); }
.aim-nav-card p {
margin: 0;
color: #94a3b8;
line-height: 1.7;
font-size: 0.95rem;
font-weight: 300;
}
.aim-source-tag {
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
color: var(--aim-neon-blue);
background: rgba(0, 210, 255, 0.08);
padding: 6px 12px;
border-radius: 8px;
align-self: flex-start;
border: 1px solid rgba(0, 210, 255, 0.15);
font-weight: 600;
display: flex;
align-items: center;
gap: 8px;
}
/* 팝업 모달 스타일 */
.aim-modal-overlay {
position: fixed; top: 0; left: 0; width: 100%; height: 100%;
background: rgba(0, 0, 0, 0.85);
backdrop-filter: blur(10px);
z-index: 100000;
display: none;
justify-content: center;
align-items: center;
}
.aim-modal-content {
background: #0d1117;
border: 1px solid var(--aim-neon-blue);
width: 90%; max-width: 800px;
border-radius: 20px;
padding: 40px;
position: relative;
box-shadow: 0 0 50px rgba(0, 210, 255, 0.2);
animation: aim-modal-up 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
@keyframes aim-modal-up { from { opacity: 0; transform: translateY(50px); } to { opacity: 1; transform: translateY(0); } }
.aim-modal-close {
position: absolute; top: 20px; right: 20px;
color: #666; font-size: 1.5rem; cursor: pointer; transition: 0.2s;
}
.aim-modal-close:hover { color: var(--aim-neon-green); }
.aim-modal-title {
font-family: 'Orbitron', sans-serif;
font-size: 1.5rem; color: var(--aim-neon-blue);
margin-bottom: 25px; border-bottom: 1px solid #222; padding-bottom: 15px;
}
.aim-code-block {
background: #050505; border: 1px solid #222;
padding: 20px; border-radius: 10px; font-family: 'JetBrains Mono', monospace;
font-size: 0.9rem; line-height: 1.8; color: #aaa;
margin-bottom: 15px; position: relative;
}
.aim-code-keyword { color: var(--aim-neon-green); }
.aim-code-path { color: var(--aim-neon-blue); }
/* 복사 버튼 스타일 */
.aim-copy-trigger {
position: absolute; top: 15px; right: 15px;
background: #111; color: #555; border: 1px solid #333;
padding: 4px 10px; font-size: 10px; border-radius: 4px;
cursor: pointer; transition: 0.2s; font-family: 'Orbitron', sans-serif;
}
.aim-copy-trigger:hover { background: var(--aim-neon-green); color: #000; border-color: var(--aim-neon-green); }
.aim-ai-link-btn {
display: flex; align-items: center; justify-content: space-between;
background: rgba(255, 255, 255, 0.03);
border: 1px solid #333; padding: 20px 30px; border-radius: 12px;
margin-bottom: 12px; text-decoration: none; transition: 0.3s;
}
.aim-ai-link-btn:hover {
background: rgba(0, 210, 255, 0.1); border-color: var(--aim-neon-blue);
transform: translateX(10px);
}
.aim-ai-link-btn span { font-family: 'Orbitron', sans-serif; color: #fff; font-weight: bold; }
.aim-ai-link-btn i { color: var(--aim-neon-blue); }
/* 반응형 대응 */
@media (max-width: 1200px) {
.aim-manual-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 800px) {
.aim-manual-grid { grid-template-columns: 1fr; }
.aim-main-content-wrap { padding: 40px 20px; }
.aim-header-banner h1 { font-size: 2.2rem; letter-spacing: 4px; }
}
</style>
</head>
<body>
<!-- 로딩 화면 -->
<div id="aim-system-loader">
<div class="aim-quantum-spinner"></div>
<div style="color:var(--aim-neon-green); font-family: 'Orbitron'; letter-spacing:5px; font-size: 0.85rem; font-weight: 700;">PROTOCOL_INITIALIZING...</div>
</div>
<!-- 메인 컨텐츠 -->
<div class="aim-main-content-wrap" id="aim-main-container">
<div class="aim-header-banner">
<h1>WORK OLD BOY</h1>
<p>Terminal Core & Database Command Protocol</p>
</div>
<div class="aim-manual-grid">
<!-- 블록 1: Server Information -->
<div class="aim-nav-card" onclick="aimShowModal('server')">
<div class="aim-source-tag"><i class="fa-solid fa-code-branch"></i> Server Information</div>
<h2><i class="fa-solid fa-server"></i> Server Basic Info</h2>
<p>사이트의 기본정보 및 필수 환경 설정을 확인합니다.<br>DB 연결 정보, 핸들러 설정, 그누보드 연동 데이터 및 데몬 시스템의 물리적 경로 프로토콜 및 작업 시 필요한 정보를 관제합니다.</p>
</div>
<!-- 블록 2: AI Work -->
<div class="aim-nav-card" onclick="aimShowModal('ai')">
<div class="aim-source-tag"><i class="fa-solid fa-code-branch"></i> AI Work</div>
<h2><i class="fa-solid fa-brain"></i> AI Self-employment</h2>
<p>효율적인 코딩 및 관제를 위한 AI 연동 허브입니다. ChatGPT, Gemini 및 Google AI Studio로 즉시 연결되어 인공지능 보조 프로토콜을 수행합니다.</p>
</div>
<!-- 블록 3: About Oldboy (Directory Manual) -->
<a href="<?php echo G5_URL; ?>/_PAGE/library/manual_ai/directory_structure.php" class="aim-nav-card" target="_blank">
<div class="aim-source-tag"><i class="fa-solid fa-code-branch"></i> About Oldboy</div>
<h2><i class="fa-solid fa-folder-tree"></i> Directory Manual</h2>
<p>전체 서버 파일 시스템의 계층 구조를 시각화합니다. AI 연동 작업 시 필요한 각 노드의 절대 경로를 즉시 확인하고 복사하여 작업 효율을 극대화합니다.</p>
</a>
<!-- 블록 4: About Maria (Database Manual) -->
<a href="<?php echo G5_URL; ?>/_PAGE/library/manual_ai/db_structure.php" class="aim-nav-card" target="_blank">
<div class="aim-source-tag"><i class="fa-solid fa-microchip"></i> About Maria</div>
<h2><i class="fa-solid fa-database"></i> Database Manual</h2>
<p>upbit_data 클러스터의 실시간 데이터 스키마 설계도입니다. 테이블 인덱스 무결성과 컬럼별 상세 주석 데이터를 분석하여 정밀한 쿼리 설계를 지원합니다.</p>
</a>
<!-- 블록 5: Directory Tree -->
<a href="<?php echo G5_URL; ?>/_PAGE/structure/directory/directory_tree.php" class="aim-nav-card" target="_blank">
<div class="aim-source-tag"><i class="fa-solid fa-microchip"></i> Directory Tree</div>
<h2><i class="fa-solid fa-network-wired"></i> Site Servers</h2>
<p>사이트 서버 구조를 모니터링 탐색합니다. 트리형 구조를 통해 각 디렉토리의 물리적 위치와 권한 상태를 직관적으로 파악합니다.</p>
</a>
<!-- 블록 6: SQL Tree -->
<a href="<?php echo G5_URL; ?>/_PAGE/structure/mysql/SQL_tree.php" class="aim-nav-card" target="_blank">
<div class="aim-source-tag"><i class="fa-solid fa-microchip"></i> SQL Tree</div>
<h2><i class="fa-solid fa-table-list"></i> Maria DB</h2>
<p>Maria DB SQL 구조를 트리형 계층으로 모니터링합니다. 테이블 간의 관계와 스키마 설계 흐름을 시각적으로 탐색합니다.</p>
</a>
<!-- 블록 7: Data Back -->
<a href="<?php echo G5_URL; ?>" class="aim-nav-card" target="_blank">
<div class="aim-source-tag"><i class="fa-solid fa-microchip"></i> SQL_tree.php</div>
<h2><i class="fa-solid fa-floppy-disk"></i> Data Back</h2>
<p>Data Back : 각종 데이터 백업 프로토콜입니다. 게시판(BOARD), 원천 데이터(DATA), DB 클러스터 및 핵심 소스 파일을 보존합니다.</p>
</a>
</div>
</div>
<!-- 서버 정보 팝업 모달 -->
<div id="aim-modal-server" class="aim-modal-overlay" onclick="aimCloseModal('server')">
<div class="aim-modal-content" onclick="event.stopPropagation()">
<i class="fa-solid fa-xmark aim-modal-close" onclick="aimCloseModal('server')"></i>
<div class="aim-modal-title">SERVER CONFIGURATION LOG</div>
<div class="aim-code-block">
<button class="aim-copy-trigger" onclick="aimCopyToClipboard('/home/www/DB/db_upbit.php\n$db_upbit = $pdo;', this)">COPY</button>
<span class="aim-code-keyword"># 업비트 DB 정보 파일 경로</span><br>
PATH: <span class="aim-code-path">/home/www/DB/db_upbit.php</span><br>
HANDLER: <span class="aim-code-keyword">$db_upbit = $pdo;</span> <span style="color:#555;">// ★ UPBIT 전용 DB 핸들러</span>
</div>
<div class="aim-code-block">
<button class="aim-copy-trigger" onclick="aimCopyToClipboard('/home/www/DB/db_gnu.php\nreturn $pdo_gnu;', this)">COPY</button>
<span class="aim-code-keyword"># 그누보드 DB 정보 파일 경로</span><br>
PATH: <span class="aim-code-path">/home/www/DB/db_gnu.php</span><br>
HANDLER: <span class="aim-code-keyword">return $pdo_gnu;</span>
</div>
<div class="aim-code-block">
<button class="aim-copy-trigger" onclick="aimCopyToClipboard('/home/www/DB/key_upbit_trade.php\n$UPBIT_ACCESS_KEY / $UPBIT_SECRET_KEY', this)">COPY</button>
<span class="aim-code-keyword"># 업비트 개인 키 경로</span><br>
PATH: <span class="aim-code-path">/home/www/DB/key_upbit_trade.php</span><br>
KEYS: <span class="aim-code-keyword">$UPBIT_ACCESS_KEY / $UPBIT_SECRET_KEY</span>
</div>
</div>
</div>
<!-- AI 작업 팝업 모달 -->
<div id="aim-modal-ai" class="aim-modal-overlay" onclick="aimCloseModal('ai')">
<div class="aim-modal-content" onclick="event.stopPropagation()">
<i class="fa-solid fa-xmark aim-modal-close" onclick="aimCloseModal('ai')"></i>
<div class="aim-modal-title">AI ASSISTANT HUB</div>
<a href="https://chat.openai.com" target="_blank" class="aim-ai-link-btn">
<span><i class="fa-solid fa-bolt-lightning mr-3"></i> OPEN AI : CHATGPT</span>
<i class="fa-solid fa-chevron-right"></i>
</a>
<a href="https://gemini.google.com" target="_blank" class="aim-ai-link-btn">
<span><i class="fa-solid fa-wand-magic-sparkles mr-3"></i> GOOGLE : GEMINI</span>
<i class="fa-solid fa-chevron-right"></i>
</a>
<a href="https://aistudio.google.com/" target="_blank" class="aim-ai-link-btn">
<span><i class="fa-solid fa-code mr-3"></i> GOOGLE : AI STUDIO</span>
<i class="fa-solid fa-chevron-right"></i>
</a>
</div>
</div>
<script>
// 팝업 열기 함수
function aimShowModal(type) {
document.getElementById('aim-modal-' + type).style.display = 'flex';
}
// 팝업 닫기 함수
function aimCloseModal(type) {
document.getElementById('aim-modal-' + type).style.display = 'none';
}
// 클립보드 복사 함수
function aimCopyToClipboard(text, btn) {
navigator.clipboard.writeText(text).then(() => {
const originalText = btn.innerHTML;
btn.innerHTML = '<i class="fa-solid fa-check"></i> COPIED';
btn.style.backgroundColor = 'var(--aim-neon-green)';
btn.style.color = '#000';
setTimeout(() => {
btn.innerHTML = originalText;
btn.style.backgroundColor = '';
btn.style.color = '';
}, 1500);
}).catch(err => {
console.error('복사 실패:', err);
});
}
window.addEventListener('load', () => {
const loader = document.getElementById('aim-system-loader');
const container = document.getElementById('aim-main-container');
setTimeout(() => {
loader.style.opacity = '0';
setTimeout(() => {
loader.style.display = 'none';
container.classList.add('aim-is-active');
}, 600);
}, 800);
});
// ESC 키로 팝업 닫기
window.addEventListener('keydown', (e) => {
if (e.key === 'Escape') {
aimCloseModal('server');
aimCloseModal('ai');
}
});
</script>
</body>
</html>
<?php require_once '/home/www/GNU/_PAGE/tail.php'; ?>