summaryrefslogtreecommitdiff
path: root/lib/dolce/crypto-utils-legacy.ts
blob: 6bec9bca6b05a243b38e8db4f6ddb5da963b3efc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/**
 * DOLCE 파일 다운로드용 DES 암호화 유틸리티
 * crypto-js 사용 (OpenSSL 독립적, 순수 JavaScript 구현)
 */

import CryptoJS from "crypto-js";

// 암호화 키 (8바이트 ASCII)
const DES_KEY_STRING = "4fkkdijg";

/**
 * DES ECB 모드로 문자열 암호화
 * C# DESCryptoServiceProvider와 호환
 */
export function encryptDES(plainText: string): string {
  try {
    // UTF-8 문자열을 WordArray로 변환
    const message = CryptoJS.enc.Utf8.parse(plainText);
    
    // ASCII 키를 WordArray로 변환 (8바이트)
    const key = CryptoJS.enc.Latin1.parse(DES_KEY_STRING);
    
    // DES ECB 암호화 (PKCS7 패딩 자동)
    const encrypted = CryptoJS.DES.encrypt(message, key, {
      mode: CryptoJS.mode.ECB,
      padding: CryptoJS.pad.Pkcs7,
    });
    
    // Base64 인코딩된 결과
    const base64 = encrypted.toString();
    
    // + 문자를 ||| 로 변환 (C# 호환)
    return base64.replace(/\+/g, "|||");
  } catch (error) {
    console.error("DES 암호화 실패:", error);
    throw new Error(`암호화 중 오류가 발생했습니다: ${error}`);
  }
}

/**
 * DES ECB 모드로 문자열 복호화
 */
export function decryptDES(encryptedText: string): string {
  try {
    // ||| 를 + 로 복원
    const restored = encryptedText.replace(/\|\|\|/g, "+");
    
    // ASCII 키를 WordArray로 변환
    const key = CryptoJS.enc.Latin1.parse(DES_KEY_STRING);
    
    // DES ECB 복호화
    const decrypted = CryptoJS.DES.decrypt(restored, key, {
      mode: CryptoJS.mode.ECB,
      padding: CryptoJS.pad.Pkcs7,
    });
    
    // UTF-8 문자열로 변환
    const plainText = decrypted.toString(CryptoJS.enc.Utf8);
    
    // null 바이트 제거 (혹시 모를 패딩 잔여물)
    return plainText.replace(/\0+$/, "");
  } catch (error) {
    console.error("DES 복호화 실패:", error);
    throw new Error(`복호화 중 오류가 발생했습니다: ${error}`);
  }
}

/**
 * DOLCE 파일 다운로드용 암호화 키 생성
 */
export function createDolceDownloadKey(
  fileId: string,
  userId: string,
  fileName: string
): string {
  const plainText = `${fileId}↔${userId}↔${fileName}`;
  return encryptDES(plainText);
}

/**
 * 테스트용: 암호화/복호화 검증
 */
export function testDESEncryption(testString: string): {
  original: string;
  encrypted: string;
  decrypted: string;
  match: boolean;
} {
  const encrypted = encryptDES(testString);
  const decrypted = decryptDES(encrypted);
  
  return {
    original: testString,
    encrypted,
    decrypted,
    match: testString === decrypted,
  };
}