mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-05-18 06:43:05 +08:00
Translate everything-claude-code repository to Japanese including: - 17 root documentation files - 60 agent documentation files - 80 command documentation files - 99 rule files across 18 language directories (common, angular, arkts, cpp, csharp, dart, fsharp, golang, java, kotlin, perl, php, python, ruby, rust, swift, typescript, web) - 199 skill documentation files Total: 455 files translated to Japanese with: - Consistent terminology glossary applied throughout - YAML field names preserved in English (name, description, etc.) - Code blocks and examples untouched (comments translated) - Markdown structure and relative links preserved - Professional translation maintaining technical accuracy This translation expands ECC accessibility to Japanese-speaking developers and teams. Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
3.7 KiB
3.7 KiB
paths
| paths | ||
|---|---|---|
|
Kotlin セキュリティ
このファイルは common/security.md を Kotlin および Android/KMP 固有のコンテンツで拡張します。
シークレット管理
- API キー、トークン、認証情報をソースコードにハードコードしない
- ローカル開発のシークレットには
local.properties(git で無視)を使用する - リリースビルドには CI シークレットから生成される
BuildConfigフィールドを使用する - ランタイムのシークレット保存には
EncryptedSharedPreferences(Android)または Keychain(iOS)を使用する
// BAD
val apiKey = "sk-abc123..."
// GOOD — BuildConfig から(ビルド時に生成)
val apiKey = BuildConfig.API_KEY
// GOOD — ランタイム時にセキュアストレージから
val token = secureStorage.get("auth_token")
ネットワークセキュリティ
- HTTPS のみを使用する — クリアテキストをブロックするため
network_security_config.xmlを設定する - 機密性の高いエンドポイントには OkHttp の
CertificatePinnerまたは Ktor 相当で証明書ピンニングを行う - すべての HTTP クライアントにタイムアウトを設定する — デフォルト(無限の場合がある)のまま放置しない
- すべてのサーバーレスポンスを使用前に検証・サニタイズする
<!-- res/xml/network_security_config.xml -->
<network-security-config>
<base-config cleartextTrafficPermitted="false" />
</network-security-config>
入力検証
- 処理や API 送信前にすべてのユーザー入力を検証する
- Room/SQLDelight にはパラメータ化クエリを使用する — ユーザー入力を SQL に連結しない
- パストラバーサルを防ぐためユーザー入力のファイルパスをサニタイズする
// BAD — SQL インジェクション
@Query("SELECT * FROM items WHERE name = '$input'")
// GOOD — パラメータ化
@Query("SELECT * FROM items WHERE name = :input")
fun findByName(input: String): List<ItemEntity>
データ保護
- Android では機密性の高いキーバリューデータに
EncryptedSharedPreferencesを使用する - 明示的なフィールド名で
@Serializableを使用する — 内部プロパティ名を漏洩させない - 不要になった機密データはメモリからクリアする
- シリアライズされたクラスの名前マングリングを防ぐため
@Keepまたは ProGuard ルールを使用する
認証
- トークンはプレーンな SharedPreferences ではなくセキュアストレージに保存する
- 適切な 401/403 ハンドリングでトークンリフレッシュを実装する
- ログアウト時にすべての認証状態をクリアする(トークン、キャッシュされたユーザーデータ、Cookie)
- 機密性の高い操作にはバイオメトリクス認証(
BiometricPrompt)を使用する
ProGuard / R8
- すべてのシリアライズされたモデル(
@Serializable、Gson、Moshi)の Keep ルール - リフレクションベースのライブラリ(Koin、Retrofit)の Keep ルール
- リリースビルドをテストする — 難読化はシリアライズを無言で壊す可能性がある
WebView セキュリティ
- 明示的に必要でない限り JavaScript を無効にする:
settings.javaScriptEnabled = false - WebView にロードする前に URL を検証する
- 機密データにアクセスする
@JavascriptInterfaceメソッドを公開しない WebViewClient.shouldOverrideUrlLoading()を使用してナビゲーションを制御する