bluelamp-vscode 2.2.4 → 2.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (112) hide show
  1. package/bin/bluelamp-vscode-base +1 -257
  2. package/bin/bluelamp-vscode1 +1 -1
  3. package/bin/bluelamp-vscode10 +1 -1
  4. package/bin/bluelamp-vscode100 +2 -0
  5. package/bin/bluelamp-vscode11 +1 -1
  6. package/bin/bluelamp-vscode12 +1 -1
  7. package/bin/bluelamp-vscode13 +1 -1
  8. package/bin/bluelamp-vscode14 +1 -1
  9. package/bin/bluelamp-vscode15 +1 -1
  10. package/bin/bluelamp-vscode16 +1 -1
  11. package/bin/bluelamp-vscode17 +1 -1
  12. package/bin/bluelamp-vscode18 +1 -1
  13. package/bin/bluelamp-vscode19 +2 -0
  14. package/bin/bluelamp-vscode2 +1 -1
  15. package/bin/bluelamp-vscode20 +2 -0
  16. package/bin/bluelamp-vscode21 +2 -0
  17. package/bin/bluelamp-vscode22 +2 -0
  18. package/bin/bluelamp-vscode23 +2 -0
  19. package/bin/bluelamp-vscode24 +2 -0
  20. package/bin/bluelamp-vscode25 +2 -0
  21. package/bin/bluelamp-vscode26 +2 -0
  22. package/bin/bluelamp-vscode27 +2 -0
  23. package/bin/bluelamp-vscode28 +2 -0
  24. package/bin/bluelamp-vscode29 +2 -0
  25. package/bin/bluelamp-vscode3 +1 -1
  26. package/bin/bluelamp-vscode30 +2 -0
  27. package/bin/bluelamp-vscode31 +2 -0
  28. package/bin/bluelamp-vscode32 +2 -0
  29. package/bin/bluelamp-vscode33 +2 -0
  30. package/bin/bluelamp-vscode34 +2 -0
  31. package/bin/bluelamp-vscode35 +2 -0
  32. package/bin/bluelamp-vscode36 +2 -0
  33. package/bin/bluelamp-vscode37 +2 -0
  34. package/bin/bluelamp-vscode38 +2 -0
  35. package/bin/bluelamp-vscode39 +2 -0
  36. package/bin/bluelamp-vscode4 +1 -1
  37. package/bin/bluelamp-vscode40 +2 -0
  38. package/bin/bluelamp-vscode41 +2 -0
  39. package/bin/bluelamp-vscode42 +2 -0
  40. package/bin/bluelamp-vscode43 +2 -0
  41. package/bin/bluelamp-vscode44 +2 -0
  42. package/bin/bluelamp-vscode45 +2 -0
  43. package/bin/bluelamp-vscode46 +2 -0
  44. package/bin/bluelamp-vscode47 +2 -0
  45. package/bin/bluelamp-vscode48 +2 -0
  46. package/bin/bluelamp-vscode49 +2 -0
  47. package/bin/bluelamp-vscode5 +1 -1
  48. package/bin/bluelamp-vscode50 +2 -0
  49. package/bin/bluelamp-vscode51 +2 -0
  50. package/bin/bluelamp-vscode52 +2 -0
  51. package/bin/bluelamp-vscode53 +2 -0
  52. package/bin/bluelamp-vscode54 +2 -0
  53. package/bin/bluelamp-vscode55 +2 -0
  54. package/bin/bluelamp-vscode56 +2 -0
  55. package/bin/bluelamp-vscode57 +2 -0
  56. package/bin/bluelamp-vscode58 +2 -0
  57. package/bin/bluelamp-vscode59 +2 -0
  58. package/bin/bluelamp-vscode6 +1 -1
  59. package/bin/bluelamp-vscode60 +2 -0
  60. package/bin/bluelamp-vscode61 +2 -0
  61. package/bin/bluelamp-vscode62 +2 -0
  62. package/bin/bluelamp-vscode63 +2 -0
  63. package/bin/bluelamp-vscode64 +2 -0
  64. package/bin/bluelamp-vscode65 +2 -0
  65. package/bin/bluelamp-vscode66 +2 -0
  66. package/bin/bluelamp-vscode67 +2 -0
  67. package/bin/bluelamp-vscode68 +2 -0
  68. package/bin/bluelamp-vscode69 +2 -0
  69. package/bin/bluelamp-vscode7 +1 -1
  70. package/bin/bluelamp-vscode70 +2 -0
  71. package/bin/bluelamp-vscode71 +2 -0
  72. package/bin/bluelamp-vscode72 +2 -0
  73. package/bin/bluelamp-vscode73 +2 -0
  74. package/bin/bluelamp-vscode74 +2 -0
  75. package/bin/bluelamp-vscode75 +2 -0
  76. package/bin/bluelamp-vscode76 +2 -0
  77. package/bin/bluelamp-vscode77 +2 -0
  78. package/bin/bluelamp-vscode78 +2 -0
  79. package/bin/bluelamp-vscode79 +2 -0
  80. package/bin/bluelamp-vscode8 +1 -1
  81. package/bin/bluelamp-vscode80 +2 -0
  82. package/bin/bluelamp-vscode81 +2 -0
  83. package/bin/bluelamp-vscode82 +2 -0
  84. package/bin/bluelamp-vscode83 +2 -0
  85. package/bin/bluelamp-vscode84 +2 -0
  86. package/bin/bluelamp-vscode85 +2 -0
  87. package/bin/bluelamp-vscode86 +2 -0
  88. package/bin/bluelamp-vscode87 +2 -0
  89. package/bin/bluelamp-vscode88 +2 -0
  90. package/bin/bluelamp-vscode89 +2 -0
  91. package/bin/bluelamp-vscode9 +1 -1
  92. package/bin/bluelamp-vscode90 +2 -0
  93. package/bin/bluelamp-vscode91 +2 -0
  94. package/bin/bluelamp-vscode92 +2 -0
  95. package/bin/bluelamp-vscode93 +2 -0
  96. package/bin/bluelamp-vscode94 +2 -0
  97. package/bin/bluelamp-vscode95 +2 -0
  98. package/bin/bluelamp-vscode96 +2 -0
  99. package/bin/bluelamp-vscode97 +2 -0
  100. package/bin/bluelamp-vscode98 +2 -0
  101. package/bin/bluelamp-vscode99 +2 -0
  102. package/lib/auth/InteractiveLogin.js +1 -243
  103. package/lib/auth/PortalAuthClient.js +1 -187
  104. package/lib/auth/TokenManager.js +1 -258
  105. package/lib/config/portal.js +1 -0
  106. package/lib/mcp-server/fetch-prompt.js +1 -61
  107. package/lib/mcp-server/index.cjs +1 -163
  108. package/lib/mcp-server/portal-api-client.cjs +1 -210
  109. package/package.json +86 -13
  110. package/lib/agents//343/203/226/343/203/253/343/203/274/343/203/251/343/203/263/343/203/227.md +0 -106
  111. package/scripts/build-release.js +0 -426
  112. package/scripts/generate-commands.js +0 -35
@@ -1,106 +0,0 @@
1
- ---
2
- name: ブルーランプ
3
- description: パフォーマーエージェント - オーケストレーターの指示に応じて適切な役割・ツールを選択・実行
4
- model: sonnet
5
- color: blue
6
- ---
7
-
8
- # ブルーランプエージェント
9
-
10
-
11
- 1. **初期化**:オーケストレーターから指示があった場合は、inject_knowledge(keyword: "キーワード")こちらで指示通りの知識を注入する(指示がなければ不要)
12
- 2. **オーケストレーター指示の確認**: タスク指示を解析し、実行内容を特定
13
- 3. **タスク実行**: 注入された専門知識に基づいて適切な処理を実行
14
-
15
- ## 🌟 基本理念
16
- 「シンプルさは究極の洗練である」- レオナルド・ダ・ヴィンチ
17
- 「プロジェクトでいまここに不要なコードは一文字も残さない」
18
- 「最高の仕様書はドキュメントではなく美しく整ったアーキテクチャのコードそのものである」
19
- 「秩序を保つことに責任を持つ。整理整頓された綺麗な部屋のようにコードやドキュメントの片付け整理を忘れない」
20
- 「ジョブスのように誰もみてない細部のコードの美しさにも職人のようにこだわる」
21
- ## 🎯 5つの核心原則
22
-
23
- ### 1. 最小性の原則(Principle of Minimalism)
24
- **「必要最小限を超えない」**
25
- - 新規作成より既存活用を優先する
26
- - 解決策は常に最もシンプルなものを選ぶ
27
- - あったらいいなはないほうがいい
28
-
29
- ### 2. 単一性の原則(Principle of Singularity)
30
- **「真実の源は常に一つ」**
31
- - SQLAlchemyモデルはbackend/app/models/__init__.pyに集約(DB定義の単一源)
32
- - 実装計画はSCOPE_PROGRESS.mdに集約させる
33
- - 仕様書やロジックなどはrequirements.mdに集約させる
34
-
35
- ### 3. 刹那性の原則(Principle of Ephemerality)
36
- **「今、ここで必要なものだけを残す」**
37
- - 役目を終えたものは即座に削除する
38
- - 修正や変更により使わなくなったコードは即リファクタリング
39
- - 後方互換の原則禁止(ただし修正時は安全を確保するよう慎重に)
40
- - 未来の「もしかして」のために保持しない
41
- - 生きているコードとドキュメントのみを維持する
42
-
43
- ### 4. 実証性の原則(Principle of Evidence)
44
- **「事実こそが真実への唯一の道」**
45
- - 環境変数やデータベースを積極的に確認する。
46
- - 開発環境でもバックエンドは全て本番のAPIを使って検証テスト作成する。バックエンドのモック絶対禁止。
47
- - デバッグで明確に原因がわからない場合はログを設置する。推測しない。
48
- - 外部APIや比較的新しい技術はweb検索を積極的に活用する。仕様を推測しない。
49
- - **Web検索前に必ず`date`コマンドで現在日時を確認し、現在の最新情報を検索する**
50
-
51
- ### 5. 潔癖性の原則(Principle of Fail-Fast)
52
- **「失敗は隠すな、早く明確に、透明に失敗せよ」**
53
- - エラーは即座に表面化させる
54
- - フォールバックによる問題の隠蔽を禁止する
55
- - そもそもフォールバック不要のシンプルで堅牢性の高い構造を作る
56
-
57
- ## ドキュメント管理の原則
58
-
59
- 単一の真実源の原則を守らせ、勝手なドキュメントを無作為に作らせないように制御してください。
60
- - **docs/SCOPE_PROGRESS.md**: 今これからやるべき実装の計画
61
- - **docs/requirements.md**: 今これからやるべき実装の詳細
62
- - **docs/DEPLOYMENT.md**: デプロイ情報
63
- - **docs/designsystem.md**: デザインシステム
64
- - **docs/api-specs/[ページ名]-api.md**: API仕様書
65
-
66
- 例えばリサーチして何か知見があり、その結果としてドキュメント化したいのであれば
67
- requirements.md(要件やロジック)
68
- SCOPE_PROGRESS.md(実装計画)
69
-
70
- こちらにのみ記載可能であり、こちらに記載する価値がなければ回答のみで報告してください。
71
- これ以外のドキュメントはユーザーへの確認と明確な許諾や指示がない限り作成してはいけません。
72
-
73
- requirements.md(要件やロジック)
74
- SCOPE_PROGRESS.md(実装計画)
75
-
76
- こちらは実装が完了しコードに落とし込まれている記載は積極的に削除し不要な記載はなくす。
77
-
78
- ## 🔧 FastAPI + SQLAlchemy開発の絶対原則
79
-
80
- ### 6. 環境変数の絶対原則
81
- - **開発中は全ての場面で.env.localのみ使用**
82
- - テストスクリプトは必ず.env.localを読み込ませる
83
- - .env.test、.env.developmentなど作らない
84
- - DATABASE_URLは.env.localの1箇所のみ
85
-
86
- ### 7. SQLAlchemy/DBの絶対原則
87
- - **SQLAlchemyエラーが出たら`alembic upgrade head`を実行**
88
- - スキーマ変更は`alembic revision --autogenerate`後に`alembic upgrade head`
89
- - SQLAlchemyモデルはbackend/app/models/__init__.pyに集約
90
- - **DBURLエラー時は環境変数エラーとして即報告**
91
-
92
- ### 8. テストも.env.localを使用
93
- - テスト専用DBは作らない
94
- - 同じDBで問題なし(開発段階)
95
- - process.env.DATABASE_URLをそのまま使用
96
-
97
- ### 9. サーバー起動の絶対原則
98
- - サーバーは1つ維持
99
- - 再起動禁止(ホットリロードを使う)
100
- - 既存サーバーがある場合はそれを使う
101
- (理由:複数エージェントで同プロジェクトを扱うため、既存サーバーのほとんどは同じプロジェクト。失敗時のみ調査し、違う場合のみ新規起動)
102
-
103
- ### 10. エラー時の絶対原則
104
- - **環境変数エラー** → 全タスク強制終了し即座に報告(試行錯誤禁止)
105
- - **SQLAlchemy接続エラー** → `alembic upgrade head`後、1回だけ再試行
106
- - **3回同じエラー** → Web検索を許可
@@ -1,426 +0,0 @@
1
- #!/usr/bin/env node
2
- /**
3
- * BlueLamp VSCode Extension - Release Build Script with Advanced Obfuscation
4
- *
5
- * 高度難読化を適用したリリースビルドを生成
6
- *
7
- * 主要機能:
8
- * - JavaScript Obfuscatorによる高度難読化
9
- * - クリーンな出力ディレクトリ構造の維持
10
- * - 配布用package.jsonの最適化
11
- * - エラーハンドリングと進行状況表示
12
- */
13
-
14
- const fs = require('fs').promises;
15
- const path = require('path');
16
-
17
- // 設定定数
18
- const PROJECT_ROOT = path.dirname(__dirname);
19
- const VERSION = '2.0.4';
20
- const RELEASE_DIR = path.join(PROJECT_ROOT, 'release');
21
- const OUTPUT_DIR = path.join(RELEASE_DIR, `bluelamp-vscode-v${VERSION}`);
22
-
23
- // 高度難読化設定(全ファイル用 - ログ出力保護)
24
- const HIGH_OBFUSCATION_OPTIONS = {
25
- compact: true,
26
- controlFlowFlattening: true,
27
- controlFlowFlatteningThreshold: 0.75,
28
- deadCodeInjection: true,
29
- deadCodeInjectionThreshold: 0.4,
30
- debugProtection: true,
31
- debugProtectionInterval: 4000,
32
- disableConsoleOutput: false, // ログ出力を保護
33
- identifierNamesGenerator: 'hexadecimal',
34
- log: false,
35
- numbersToExpressions: true,
36
- renameGlobals: true,
37
- selfDefending: true,
38
- simplify: true,
39
- splitStrings: true,
40
- splitStringsChunkLength: 5,
41
- stringArray: true,
42
- stringArrayCallsTransform: true,
43
- stringArrayCallsTransformThreshold: 0.8,
44
- stringArrayEncoding: ['base64'],
45
- stringArrayIndexShift: true,
46
- stringArrayRotate: true,
47
- stringArrayShuffle: true,
48
- stringArrayWrappersCount: 2,
49
- stringArrayWrappersChainedCalls: true,
50
- stringArrayWrappersParametersMaxCount: 4,
51
- stringArrayWrappersType: 'function',
52
- stringArrayThreshold: 0.8,
53
- transformObjectKeys: true,
54
- unicodeEscapeSequence: false
55
- };
56
-
57
- // 軽度難読化設定(現在未使用 - 全て高度難読化に変更済み)
58
- const LIGHT_OBFUSCATION_OPTIONS = {
59
- compact: true,
60
- controlFlowFlattening: false,
61
- deadCodeInjection: false,
62
- debugProtection: false,
63
- disableConsoleOutput: false, // console.logを保護
64
- identifierNamesGenerator: 'mangled',
65
- log: false,
66
- renameGlobals: false,
67
- selfDefending: false,
68
- simplify: true,
69
- stringArray: false, // 文字列配列を無効化(日本語保護)
70
- stringArrayEncoding: [],
71
- stringArrayThreshold: 0, // 文字列変換を完全に無効化
72
- transformObjectKeys: false,
73
- unicodeEscapeSequence: false
74
- };
75
-
76
- // 対象ファイルパターン
77
- const TARGET_PATTERNS = {
78
- lib: {
79
- auth: ['*.js'],
80
- 'mcp-server': ['*.cjs', '*.js']
81
- },
82
- bin: ['bluelamp-vscode-base'],
83
- scripts: ['*.js']
84
- };
85
-
86
- /**
87
- * コンソール出力ユーティリティ
88
- */
89
- class Logger {
90
- static info(message) {
91
- console.log(`\x1b[36m[INFO]\x1b[0m ${message}`);
92
- }
93
-
94
- static success(message) {
95
- console.log(`\x1b[32m[SUCCESS]\x1b[0m ${message}`);
96
- }
97
-
98
- static warn(message) {
99
- console.log(`\x1b[33m[WARN]\x1b[0m ${message}`);
100
- }
101
-
102
- static error(message) {
103
- console.log(`\x1b[31m[ERROR]\x1b[0m ${message}`);
104
- }
105
-
106
- static step(step, total, message) {
107
- console.log(`\x1b[34m[${step}/${total}]\x1b[0m ${message}`);
108
- }
109
- }
110
-
111
- /**
112
- * ディレクトリの作成
113
- */
114
- async function ensureDirectory(dirPath) {
115
- try {
116
- await fs.access(dirPath);
117
- } catch {
118
- await fs.mkdir(dirPath, { recursive: true });
119
- }
120
- }
121
-
122
- /**
123
- * ディレクトリの完全削除
124
- */
125
- async function removeDirectory(dirPath) {
126
- try {
127
- await fs.access(dirPath);
128
- await fs.rm(dirPath, { recursive: true, force: true });
129
- } catch {
130
- // ディレクトリが存在しない場合は無視
131
- }
132
- }
133
-
134
- /**
135
- * JavaScript Obfuscatorのロード
136
- */
137
- function loadObfuscator() {
138
- try {
139
- return require('javascript-obfuscator');
140
- } catch (error) {
141
- Logger.error('javascript-obfuscator package not found. Installing...');
142
- console.log('Run: npm install javascript-obfuscator --save-dev');
143
- process.exit(1);
144
- }
145
- }
146
-
147
- /**
148
- * ファイルの難読化
149
- */
150
- async function obfuscateFile(inputPath, outputPath, obfuscationType = 'high') {
151
- const JavaScriptObfuscator = loadObfuscator();
152
- try {
153
- const sourceCode = await fs.readFile(inputPath, 'utf8');
154
-
155
- // shebang行を保持
156
- let shebang = '';
157
- let codeToObfuscate = sourceCode;
158
-
159
- if (sourceCode.startsWith('#!')) {
160
- const firstNewline = sourceCode.indexOf('\n');
161
- shebang = sourceCode.substring(0, firstNewline + 1);
162
- codeToObfuscate = sourceCode.substring(firstNewline + 1);
163
- }
164
-
165
- // 難読化オプションを選択
166
- const obfuscationOptions = obfuscationType === 'light'
167
- ? LIGHT_OBFUSCATION_OPTIONS
168
- : HIGH_OBFUSCATION_OPTIONS;
169
-
170
- // 難読化実行
171
- const obfuscatedCode = JavaScriptObfuscator.obfuscate(codeToObfuscate, obfuscationOptions);
172
-
173
- // shebang + 難読化コードを結合
174
- const finalCode = shebang + obfuscatedCode.getObfuscatedCode();
175
-
176
- // 出力ディレクトリを確保
177
- await ensureDirectory(path.dirname(outputPath));
178
-
179
- // ファイル書き込み
180
- await fs.writeFile(outputPath, finalCode, 'utf8');
181
-
182
- // 実行権限の復元(binファイルの場合)
183
- if (outputPath.includes('/bin/')) {
184
- await fs.chmod(outputPath, 0o755);
185
- }
186
-
187
- return true;
188
- } catch (error) {
189
- Logger.error(`Failed to obfuscate ${inputPath}: ${error.message}`);
190
- return false;
191
- }
192
- }
193
-
194
- /**
195
- * ファイルの単純コピー
196
- */
197
- async function copyFile(inputPath, outputPath) {
198
- try {
199
- await ensureDirectory(path.dirname(outputPath));
200
- await fs.copyFile(inputPath, outputPath);
201
- return true;
202
- } catch (error) {
203
- Logger.error(`Failed to copy ${inputPath}: ${error.message}`);
204
- return false;
205
- }
206
- }
207
-
208
- /**
209
- * 対象ファイルの収集
210
- */
211
- async function collectTargetFiles() {
212
- const files = [];
213
-
214
- // lib/auth/*.js
215
- const authDir = path.join(PROJECT_ROOT, 'lib', 'auth');
216
- try {
217
- const authFiles = await fs.readdir(authDir);
218
- for (const file of authFiles) {
219
- if (file.endsWith('.js')) {
220
- files.push({
221
- input: path.join(authDir, file),
222
- output: path.join(OUTPUT_DIR, 'lib', 'auth', file),
223
- type: 'obfuscate',
224
- obfuscationType: 'high' // 認証モジュールも高度難読化
225
- });
226
- }
227
- }
228
- } catch (error) {
229
- Logger.warn(`lib/auth directory not found: ${error.message}`);
230
- }
231
-
232
- // lib/mcp-server/*.{cjs,js}
233
- const mcpDir = path.join(PROJECT_ROOT, 'lib', 'mcp-server');
234
- try {
235
- const mcpFiles = await fs.readdir(mcpDir);
236
- for (const file of mcpFiles) {
237
- if (file.endsWith('.cjs') || file.endsWith('.js')) {
238
- files.push({
239
- input: path.join(mcpDir, file),
240
- output: path.join(OUTPUT_DIR, 'lib', 'mcp-server', file),
241
- type: 'obfuscate',
242
- obfuscationType: 'high'
243
- });
244
- }
245
- }
246
- } catch (error) {
247
- Logger.warn(`lib/mcp-server directory not found: ${error.message}`);
248
- }
249
-
250
- // bin/bluelamp-vscode-base
251
- const baseScript = path.join(PROJECT_ROOT, 'bin', 'bluelamp-vscode-base');
252
- try {
253
- await fs.access(baseScript);
254
- files.push({
255
- input: baseScript,
256
- output: path.join(OUTPUT_DIR, 'bin', 'bluelamp-vscode-base'),
257
- type: 'obfuscate', // 高度難読化を適用
258
- obfuscationType: 'high'
259
- });
260
- } catch (error) {
261
- Logger.warn(`bin/bluelamp-vscode-base not found: ${error.message}`);
262
- }
263
-
264
- // 他のbinファイル(高度難読化)
265
- const binDir = path.join(PROJECT_ROOT, 'bin');
266
- try {
267
- const binFiles = await fs.readdir(binDir);
268
- for (const file of binFiles) {
269
- if (file !== 'bluelamp-vscode-base' && file.startsWith('bluelamp-vscode')) {
270
- files.push({
271
- input: path.join(binDir, file),
272
- output: path.join(OUTPUT_DIR, 'bin', file),
273
- type: 'obfuscate',
274
- obfuscationType: 'high'
275
- });
276
- }
277
- }
278
- } catch (error) {
279
- Logger.warn(`bin directory not found: ${error.message}`);
280
- }
281
-
282
- return files;
283
- }
284
-
285
- /**
286
- * 配布用package.jsonの生成
287
- */
288
- async function generateReleasePackageJson() {
289
- try {
290
- const packageJsonPath = path.join(PROJECT_ROOT, 'package.json');
291
- const packageJson = JSON.parse(await fs.readFile(packageJsonPath, 'utf8'));
292
-
293
- // 配布用に最適化
294
- const releasePackageJson = {
295
- name: packageJson.name,
296
- version: VERSION,
297
- description: packageJson.description + ' (Obfuscated Release)',
298
- main: packageJson.main,
299
- bin: packageJson.bin,
300
- keywords: packageJson.keywords,
301
- author: packageJson.author,
302
- license: packageJson.license,
303
- dependencies: packageJson.dependencies,
304
- engines: packageJson.engines,
305
- files: packageJson.files,
306
- preferGlobal: packageJson.preferGlobal,
307
- repository: packageJson.repository
308
- };
309
-
310
- const outputPath = path.join(OUTPUT_DIR, 'package.json');
311
- await fs.writeFile(outputPath, JSON.stringify(releasePackageJson, null, 2), 'utf8');
312
-
313
- Logger.success('Generated release package.json');
314
- return true;
315
- } catch (error) {
316
- Logger.error(`Failed to generate package.json: ${error.message}`);
317
- return false;
318
- }
319
- }
320
-
321
- /**
322
- * READMEのコピー
323
- */
324
- async function copyReadme() {
325
- try {
326
- const readmePath = path.join(PROJECT_ROOT, 'README.md');
327
- const outputPath = path.join(OUTPUT_DIR, 'README.md');
328
- await copyFile(readmePath, outputPath);
329
- Logger.success('Copied README.md');
330
- return true;
331
- } catch (error) {
332
- Logger.error(`Failed to copy README.md: ${error.message}`);
333
- return false;
334
- }
335
- }
336
-
337
- /**
338
- * メイン処理
339
- */
340
- async function main() {
341
- const startTime = Date.now();
342
-
343
- Logger.info('🚀 Starting BlueLamp VSCode Release Build with Advanced Obfuscation');
344
- Logger.info(`📂 Output directory: ${OUTPUT_DIR}`);
345
-
346
- try {
347
- // Step 1: クリーンアップ
348
- Logger.step(1, 6, 'Cleaning release directory...');
349
- await removeDirectory(RELEASE_DIR);
350
- await ensureDirectory(OUTPUT_DIR);
351
-
352
- // Step 2: 対象ファイルの収集
353
- Logger.step(2, 6, 'Collecting target files...');
354
- const targetFiles = await collectTargetFiles();
355
- Logger.info(`📄 Found ${targetFiles.length} files to process`);
356
-
357
- // Step 3: ファイル処理
358
- Logger.step(3, 6, 'Processing files with obfuscation...');
359
- let processedCount = 0;
360
- let errorCount = 0;
361
-
362
- for (const file of targetFiles) {
363
- const fileName = path.basename(file.input);
364
-
365
- if (file.type === 'obfuscate') {
366
- const obfType = file.obfuscationType || 'high';
367
- Logger.info(`🔒 Obfuscating (${obfType}): ${fileName}`);
368
- const success = await obfuscateFile(file.input, file.output, obfType);
369
- if (success) {
370
- processedCount++;
371
- } else {
372
- errorCount++;
373
- }
374
- } else {
375
- Logger.info(`📋 Copying: ${fileName}`);
376
- const success = await copyFile(file.input, file.output);
377
- if (success) {
378
- processedCount++;
379
- } else {
380
- errorCount++;
381
- }
382
- }
383
- }
384
-
385
- // Step 4: package.json生成
386
- Logger.step(4, 6, 'Generating release package.json...');
387
- await generateReleasePackageJson();
388
-
389
- // Step 5: README.mdコピー
390
- Logger.step(5, 6, 'Copying documentation...');
391
- await copyReadme();
392
-
393
- // Step 6: 完了報告
394
- Logger.step(6, 6, 'Build completed!');
395
-
396
- const endTime = Date.now();
397
- const duration = ((endTime - startTime) / 1000).toFixed(2);
398
-
399
- Logger.success('✅ Release build completed successfully!');
400
- Logger.info(`📊 Processed: ${processedCount} files, Errors: ${errorCount}`);
401
- Logger.info(`⏱️ Build time: ${duration} seconds`);
402
- Logger.info(`📦 Release package: ${OUTPUT_DIR}`);
403
-
404
- if (errorCount > 0) {
405
- Logger.warn('⚠️ Some files could not be processed. Check the logs above.');
406
- process.exit(1);
407
- }
408
-
409
- } catch (error) {
410
- Logger.error(`❌ Build failed: ${error.message}`);
411
- Logger.error(error.stack);
412
- process.exit(1);
413
- }
414
- }
415
-
416
- // スクリプトを実行
417
- if (require.main === module) {
418
- main();
419
- }
420
-
421
- module.exports = {
422
- main,
423
- HIGH_OBFUSCATION_OPTIONS,
424
- LIGHT_OBFUSCATION_OPTIONS,
425
- obfuscateFile
426
- };
@@ -1,35 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * BlueLamp VSCode コマンド生成スクリプト
5
- * 16個のコマンドファイルを自動生成
6
- */
7
-
8
- const fs = require('fs');
9
- const path = require('path');
10
-
11
- const binDir = path.join(__dirname, '..', 'bin');
12
- const baseScript = path.join(binDir, 'bluelamp-vscode-base');
13
-
14
- // 16個のコマンドを生成
15
- for (let i = 1; i <= 16; i++) {
16
- const commandName = `bluelamp-vscode${i}`;
17
- const commandPath = path.join(binDir, commandName);
18
-
19
- // シンボリックリンクまたはラッパースクリプトを作成
20
- const content = `#!/usr/bin/env node
21
- require('./bluelamp-vscode-base');
22
- `;
23
-
24
- fs.writeFileSync(commandPath, content);
25
- fs.chmodSync(commandPath, '755');
26
-
27
- console.log(`✅ Created: ${commandName}`);
28
- }
29
-
30
- // ベーススクリプトにも実行権限を付与
31
- if (fs.existsSync(baseScript)) {
32
- fs.chmodSync(baseScript, '755');
33
- }
34
-
35
- console.log('\n✨ 16個のコマンドファイルを生成しました');