Skip to main content

Core utilities and models for keynet packages

Project description

keynet-core

Keynet 패키지들의 핵심 유틸리티와 공통 모델

설치

pip install keynet-core

주요 기능

🔧 공통 유틸리티

  • 환경 변수 관리
  • 설정 파일 처리
  • 로깅 설정

📦 공유 모델

  • 데이터 검증 모델
  • API 응답 모델
  • 설정 스키마

🔌 의존성

  • 최소한의 의존성 유지
  • 다른 Keynet 패키지의 기반

🔒 Security Features

자동 민감정보 마스킹 (Automatic Sensitive Data Redaction)

keynet-core는 stdout/stderr에 출력되는 민감정보를 자동으로 마스킹합니다.

보호되는 정보:

  • AWS Access Keys (AKIA...)
  • KEYNET_ prefix credentials (KEYNET_minio, KEYNET_storage 등)
  • Passwords, tokens, API keys (key=value 형태, 최소 3자)
  • Private keys (PEM format)
  • MLflow URIs with credentials
  • 환경변수 (AWS_, MLFLOW_, RABBIT_, KEYNET_, APP_API_KEY 등)

자동 활성화:

keynet-core를 설치하면 자동으로 redaction이 활성화됩니다:

pip install keynet-core
# Python 시작 시 자동으로 redaction 활성화!
# import 순서와 무관하게 보호됨
import os

# 환경변수 형태로 출력하면 자동 마스킹
os.environ["AWS_ACCESS_KEY_ID"] = "KEYNET_myaccess"
print(f"AWS_ACCESS_KEY_ID={os.getenv('AWS_ACCESS_KEY_ID')}")
# 출력: AWS_ACCESS_KEY_ID=***ENV_VAR_xxxx***

# KEYNET_ prefix 사용 시 명시적 감지
print("Using credential: KEYNET_myaccess")
# 출력: Using credential: ***KEYNET_KEY_xxxx***

권장사항: KEYNET_ Prefix 사용

개발 환경에서 MinIO credential에 KEYNET_ prefix를 사용하세요:

export AWS_ACCESS_KEY_ID=KEYNET_myaccess
export AWS_SECRET_ACCESS_KEY=KEYNET_mysecret
  • ✅ 자동 감지 보장
  • ✅ keynet 프로젝트 credential임을 명시

예외 메시지 sanitization:

from keynet_core.security import sanitize_exception

try:
    raise ValueError("Error: AWS_ACCESS_KEY_ID=AKIAIOSFODNN7EXAMPLE")
except ValueError as e:
    sanitized = sanitize_exception(e)
    print(sanitized)
    # 출력: Error: AWS_ACCESS_KEY_ID=***ENV_VAR_xxxx***

디버깅 시 비활성화:

export KEYNET_DISABLE_REDACTION=1
python train.py

사용 예제

from keynet_core import Config, check_env

# 환경 변수 검증
if check_env():
    print("필수 환경 변수 설정 완료")

# 설정 로드
config = Config()
print(f"MLflow URI: {config.mlflow_tracking_uri}")

API 문서

자세한 API 문서는 GitHub Wiki 참조

라이선스

MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

keynet_core-0.8.1.tar.gz (29.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

keynet_core-0.8.1-py3-none-any.whl (26.8 kB view details)

Uploaded Python 3

File details

Details for the file keynet_core-0.8.1.tar.gz.

File metadata

  • Download URL: keynet_core-0.8.1.tar.gz
  • Upload date:
  • Size: 29.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.28.1

File hashes

Hashes for keynet_core-0.8.1.tar.gz
Algorithm Hash digest
SHA256 27848ba312d00db540471a859459e3c004e75ac60e9aa5624146b3f799684a4b
MD5 823731eb1e1bd7dc6608c0eafc6f4467
BLAKE2b-256 0618b440b3c3fd5a58949e2956e52ca9f78d6641eed7a0a0186e7a8ebb8949ad

See more details on using hashes here.

File details

Details for the file keynet_core-0.8.1-py3-none-any.whl.

File metadata

  • Download URL: keynet_core-0.8.1-py3-none-any.whl
  • Upload date:
  • Size: 26.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.28.1

File hashes

Hashes for keynet_core-0.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a109646c2bfb61d8a14d03b99f59fdc966f6872ea238b5d19f28e340c8e74e9b
MD5 58bb1e82d57c308e1d868953fbc6c147
BLAKE2b-256 e856956f21f5c33e9aae5f2f4aadb8484d05b4674afbd3a5314191decb4e5c2d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page