zioinfo-mail/zioinfo/js/string.js
DESKTOP-TKLFCPR\ython e228faabf5 feat(itsm): G-1~G-12 확장 기능 + 하네스/봇/설치스크립트 구현
G-1: 메신저 Webhook Relay + _send_to_room 실제 httpx 호출 구현
G-2: POST /api/tasks/bulk SR 대량작업 엔드포인트 (최대 100건)
G-3: 라이선스 만료 알림 스케줄러 (매일 09:00 KST)
G-4: 체험판 upgrade_banner 필드 + license.py 배너 로직
G-5: core/auto_rca.py + incidents/problem auto-rca 엔드포인트
G-6: core/deploy_impact.py + vibe impact-analysis 엔드포인트
G-7: core/ticket_classifier.py + SR 생성 시 AI 분류 + ai-suggestion API
G-8: VulnPatchRecord 모델 + vuln_scan 패치추적 4개 엔드포인트
G-9: core/jira_sync.py + gateway Jira/Confluence 연동 엔드포인트
G-10: core/push_notify.py + routers/push.py + PushSubscription 모델
G-11: approvals 다중승인 (위임/서명/기한초과/마감연장)
G-12: alembic.ini + migrations/ + cicd/migrate_to_postgres.sh

하네스: guardia-orchestrator 확장기능 Phase 반영
봇명령어: /sr /status /license /bulk 슬래시 명령어 추가
설치스크립트: setup/ (Ubuntu, CentOS, RHEL, Windows) --test 옵션 포함

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-29 18:18:52 +09:00

139 lines
3.2 KiB
JavaScript

/*-------------------------------------------------------------------+
* 1. 파일명: string.js
* 2. 설 명: JavaScript의 String 객체가 제공하지 못하는 추가함수를 정의한다.
* 3. 의존성: 없음
* 4. 작성자:
* 5. 작성일: 2006.10.10.
-------------------------------------------------------------------*/
/**
* 문자열의 양 끝 빈 문자열을 제거한다.
*/
function trim(str) {
if ( str == null || typeof(str) == "undefined" ) return null;
/* 문자열이 아니면 문자열로 변경한다. */
if ( typeof(str) != "string" ) str = new String(str);
return str.replace(/(^\s+)|(\s+$)/g, "");
}
/**
* 문자열의 Byte 수를 돌려 준다. 영문자는 1byte, 한글은 일단 2byte로 계산한다.
* UTF-8로 하면 3byte로 해야 하는데....
*/
function countByte(str) {
if ( str == null || typeof(str) == "undefined" ) return 0;
if ( typeof(str) != "string" ) str = new String(str);
var byteCount = 0;
for ( var i = 0; i < str.length; i++ ) {
byteCount += ( str.charCodeAt(i) <= 255 ? 1 : 2 );
}
return byteCount;
}
/**
* 주어진 값의 폭이 전체 폭보다 작은 만큼 왼쪽에
* 패팅문자로 채운 문자열을 돌려 준다.
*
* @param value 패딩될 값.
* @param maxWidth 패딩되었을 때 전체 폭. 글자 수가 아님에 주의한다.
* @param padChar 패딩할 때 사용될 문자. 없으면 공백문자(" ")가 사용된다.
*/
function padLeft(value, maxWidth, padChar) {
var padStr = makePadStr(value, maxWidth, padChar);
return padStr + value;
}
/**
* 주어진 값의 폭이 전체 폭보다 작은 만큼 오른쪽에
* 패팅문자로 채운 문자열을 돌려 준다.
*
* @param value 패딩될 값.
* @param maxWidth 패딩되었을 때 전체 폭. 글자 수가 아님에 주의한다.
* @param padChar 패딩할 때 사용될 문자. 없으면 공백문자(" ")가 사용된다.
*/
function padRight(value, maxWidth, padChar) {
var padStr = makePadStr(value, maxWidth, padChar);
return value + padStr;
}
/**
* 주어진 값의 폭이 전체 폭보다 작은 만큼 패팅문자로
* 채울 문자열을 만들어 돌려 준다.
*
* @param value 패딩될 값.
* @param maxWidth 패딩되었을 때 전체 폭. 글자 수가 아님에 주의한다.
* @param padChar 패딩할 때 사용될 문자. 없으면 공백문자(" ")가 사용된다.
*/
function makePadStr(value, maxWidth, padChar) {
/* 값이 없으면 빈 문자열을 사용한다. */
if ( value == null || value == undefined ) value = "";
/* 패팅 문자가 없으면 공백문자 */
if ( padChar == null || padChar == undefined ) padChar = " ";
/* 패딩될 수를 구한다. */
var paddedWidth = maxWidth - countByte(value);
var padStr = "";
for (var i = 0; i < paddedWidth; i++ ) {
padStr += padChar;
}
return padStr;
}
/**
* 문자열에 들어 있는 특정한 문자를 지운다.
*
* @param removedChar 지워질 문자열.
*/
function removeChar(str, removedChar) {
if ( typeof(str) == "undefined" || str == null ) return str;
if ( typeof(removedChar) == "undefined" || removedChar == null ) return str;
if ( typeof(str) != "string" ) str = new String(str);
var regExp = new RegExp(removedChar, "g");
return str.replace(regExp, "");
}
/**
* Text형 입력폼 값을 양쪽에 있는 공백문자를 제거한다.
*
* @param obj Text형 입력폼 객체
*/
function trimObj(obj) {
obj.value = trim(obj.value);
}
/**
* Text형 입력폼의 값에서 슬래쉬('/')를 제거하여
* 다시 Text형 입력폼의 값으로 세팅한다.
*
* @param obj Text형 입력폼 객체
* @param ch 제거할 문자.
*/
function removeCharObj(obj, ch) {
obj.value = removeChar(obj.value, ch);
}