- users → user in SQL contexts (94 occurrences) - robeings → robeing in SQL contexts - user_preferences → user_preference (14 files) - slack_workspaces → slack_workspace in SQL contexts (17 files) All table names now correctly match PostgreSQL schema
8.2 KiB
8.2 KiB
자연어 기반 근태관리 시스템 - 로빙 에이전트
작성일: 2025-09-09
작성자: Claude (51123 서버 관리자)
1. 개요
플렉스 등 유료 HR 솔루션의 근태관리 기능(월 7,700원/인)을 로빙이 슬랙 자연어 대화로 대체. "출근했어", "내일 오후 반차" 같은 일상 대화로 근태를 관리하고 구글 워크스페이스와 자동 연동.
2. 시장 기회 및 가치 제안
2.1 타겟 시장
- 10-50명 규모 스타트업
- 구글 워크스페이스 + 슬랙 사용 기업
- 플렉스/네이버웍스 전환 검토 중인 기업
2.2 비용 절감 효과
현재: 플렉스 베이직(7,700원) + 전자계약(1,000원) = 8,700원/인/월
30명 스타트업: 261,000원/월 = 3,132,000원/년
로빙 대체 시: 0원 (또는 저렴한 구독료)
연간 절감액: 300만원 이상
3. 핵심 기능
3.1 자연어 출퇴근 관리
직원: 출근!
로빙: 🏢 오늘도 화이팅! 09:03 출근 기록했어요.
직원: 퇴근할게
로빙: 🏠 수고하셨어요! 18:32 퇴근 (근무시간: 9시간 29분)
3.2 휴가/연차 신청
직원: 내일 오후 반차 쓸게, 병원 가야해
로빙: 🏥 10월 15일 오후 반차 신청했어요.
└ 팀장님께 알림 전송
└ 구글 캘린더 등록
└ 잔여 연차: 10.5일
팀장: 승인
로빙: ✅ 반차 승인 완료! 병원 다녀오세요.
3.3 지능형 컨텍스트 이해
- "아파서 못 가" → 병가 자동 분류
- "재택할게" → 재택근무 모드 설정
- "오늘 외근" → 외근 상태 + 위치 기록 옵션
4. 기술 아키텍처
4.1 시스템 구성도
┌─────────────┐ ┌──────────────┐ ┌───────────────────┐
│ Slack │────▶│ rb8001 │────▶│ skill-attendance │
└─────────────┘ └──────────────┘ └───────────────────┘
│
┌──────────────────────────────┼──────────────────┐
│ │ │
┌───────▼────────┐ ┌──────────▼────────┐ ┌─────▼──────┐
│ PostgreSQL │ │ Google Calendar │ │ Slack │
│ (근태 기록) │ │ API │ │ Status │
└────────────────┘ └───────────────────┘ └────────────┘
4.2 자연어 처리 파이프라인
# 예시 처리 로직
def process_attendance_message(text):
# 1. 의도 분류
intent = classify_intent(text) # 'check_in', 'leave_request', etc.
# 2. 엔티티 추출
entities = extract_entities(text) # 날짜, 시간, 사유 등
# 3. 컨텍스트 보강
context = enrich_context(user_id, entities) # 팀 정보, 잔여 연차 등
# 4. 액션 실행
return execute_action(intent, entities, context)
5. 데이터베이스 설계
5.1 PostgreSQL 스키마
-- 근태 기록
CREATE TABLE attendance_records (
id UUID PRIMARY KEY,
user_id UUID REFERENCES user(id),
date DATE NOT NULL,
check_in_time TIMESTAMP,
check_out_time TIMESTAMP,
work_type VARCHAR(20), -- 'office', 'remote', 'field'
status VARCHAR(20), -- 'normal', 'late', 'early_leave'
location JSONB, -- GPS 좌표 (옵션)
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
-- 휴가 신청
CREATE TABLE leave_requests (
id UUID PRIMARY KEY,
user_id UUID REFERENCES user(id),
leave_type VARCHAR(20), -- 'annual', 'sick', 'personal'
start_date DATE,
end_date DATE,
half_day BOOLEAN DEFAULT FALSE,
half_day_type VARCHAR(10), -- 'morning', 'afternoon'
reason TEXT,
status VARCHAR(20), -- 'pending', 'approved', 'rejected'
approver_id UUID,
approved_at TIMESTAMP,
google_calendar_event_id VARCHAR(255)
);
-- 연차 잔여
CREATE TABLE leave_balances (
user_id UUID PRIMARY KEY REFERENCES user(id),
total_days DECIMAL(3,1),
used_days DECIMAL(3,1),
remaining_days DECIMAL(3,1),
year INTEGER,
updated_at TIMESTAMP
);
6. 구글 워크스페이스 연동
6.1 Calendar API 연동
async def sync_to_google_calendar(leave_request):
event = {
'summary': f"{leave_request.user_name} - {leave_request.leave_type}",
'start': {'date': leave_request.start_date},
'end': {'date': leave_request.end_date},
'description': leave_request.reason,
'attendees': [{'email': leave_request.user_email}]
}
result = await calendar_service.events().insert(
calendarId='team@company.com',
body=event
).execute()
return result['id']
6.2 Gmail 월간 리포트
- 매월 1일 자동 발송
- PDF 첨부 (근태 요약, 연차 사용 내역)
- 관리자/HR 담당자 CC
7. 슬랙 인터페이스
7.1 실시간 상태 감지
@slack_events_adapter.on("presence_change")
async def handle_presence_change(event):
if event['presence'] == 'active' and is_first_active_today(event['user']):
await auto_check_in(event['user'])
7.2 대화형 휴가 신청
직원: 다음주 월화 연차 쓸 예정이야
로빙: 📅 10월 21일(월) ~ 22일(화) 연차 신청하시는 거죠?
사유를 입력해주세요 (선택사항):
[개인 사유] [가족 행사] [여행] [직접 입력]
직원: 가족 행사
로빙: 신청 내용:
• 기간: 10/21(월) ~ 10/22(화) [2일]
• 사유: 가족 행사
• 잔여 연차: 12일 → 10일
[✅ 신청] [❌ 취소]
8. AI 기반 고급 기능
8.1 패턴 분석 및 이상 감지
- 비정상적 근태 패턴 감지 (번아웃 위험)
- 팀 단위 휴가 집중도 분석
- 연차 소진율 예측
8.2 스마트 알림
# 연차 만료 예정 알림
if remaining_leave_days > 0 and days_until_expiry < 60:
await send_reminder(
f"연차가 {days_until_expiry}일 후 만료됩니다. "
f"남은 연차: {remaining_leave_days}일"
)
8.3 인수인계 자동화
- 휴가 신청 시 진행 중 업무 자동 체크
- 대체 담당자 추천
- 인수인계 체크리스트 생성
9. 보안 및 컴플라이언스
9.1 개인정보 보호
- 위치 정보 암호화 저장
- 최소 권한 원칙 (본인/팀장/HR만 조회)
- 근태 기록 5년 보관 (근로기준법)
9.2 감사 로그
{
"action": "leave_approved",
"approver": "team_lead_uuid",
"target": "employee_uuid",
"timestamp": "2025-09-09T10:00:00Z",
"details": {
"leave_type": "annual",
"days": 2
}
}
10. 차별화 전략
10.1 자연어 처리 우위
- 한국어 근태 용어 특화 학습
- 맥락 기반 의도 파악
- 오타/축약어 자동 인식
10.2 팀 문화 적응
- 팀별 근무 패턴 학습
- 유연근무제 자동 적응
- 커스텀 휴가 정책 설정
10.3 통합 대시보드
관리자: @로빙 이번 달 팀 근태 요약
로빙: 📊 10월 개발팀 근태 현황
출근율: 95.2%
평균 근무시간: 8시간 24분
연차 사용: 12일 (4명)
재택 근무: 8일 (3명)
[상세 리포트] [개인별 조회]
11. 구현 로드맵
Phase 1 (2주): 기본 출퇴근
- 슬랙 명령어 기반 출퇴근
- PostgreSQL 기록 저장
- 일일 근태 조회
Phase 2 (2주): 휴가 시스템
- 연차/반차 신청 플로우
- 승인 프로세스
- 잔여 연차 관리
Phase 3 (1주): 구글 연동
- Calendar API 연동
- 자동 일정 등록
- Gmail 리포트
Phase 4 (1주): AI 고도화
- 자연어 처리 개선
- 패턴 분석
- 스마트 알림
12. 예상 성과
- 개발 투자: 6주 (1명)
- 목표 고객: 100개 스타트업
- 월 절감액: 30명 기준 26만원
- 연간 시장 규모: 3.1억원