mirror of
https://github.com/pezkuwichain/pezkuwi-wallet-android.git
synced 2026-04-22 09:08:03 +00:00
Initial commit: Pezkuwi Wallet Android
Security hardened release: - Code obfuscation enabled (minifyEnabled=true, shrinkResources=true) - Sensitive files excluded (google-services.json, keystores) - Branch.io key moved to BuildConfig placeholder - Updated dependencies: OkHttp 4.12.0, Gson 2.10.1, BouncyCastle 1.77 - Comprehensive ProGuard rules for crypto wallet - Navigation 2.7.7, Lifecycle 2.7.0, ConstraintLayout 2.1.4
This commit is contained in:
Executable
+72
@@ -0,0 +1,72 @@
|
||||
import os
|
||||
import sys
|
||||
import re
|
||||
from datetime import datetime, timezone
|
||||
import requests
|
||||
|
||||
|
||||
ALLOWED_SEVERITIES = {"Major", "Critical", "Normal"}
|
||||
|
||||
# Matches: "Release severity: <value>" (case-insensitive, flexible spaces)
|
||||
SEVERITY_LINE_RE = re.compile(r"^release\s+severity\s*:\s*(.+)$", re.IGNORECASE)
|
||||
|
||||
|
||||
def parse_base_params(comment_link: str) -> None:
|
||||
if not comment_link:
|
||||
print("COMMENT_LINK is not set. Provide a valid PR comment API URL in env var COMMENT_LINK.")
|
||||
sys.exit(1)
|
||||
|
||||
env_file = os.getenv("GITHUB_ENV")
|
||||
if not env_file:
|
||||
print("GITHUB_ENV is not set. This script expects GitHub Actions environment.")
|
||||
sys.exit(1)
|
||||
|
||||
try:
|
||||
resp = requests.get(comment_link, timeout=10)
|
||||
resp.raise_for_status()
|
||||
payload = resp.json()
|
||||
except requests.RequestException as e:
|
||||
print(f"Failed to fetch PR comment: {e}")
|
||||
sys.exit(1)
|
||||
except ValueError:
|
||||
print("Response is not valid JSON.")
|
||||
sys.exit(1)
|
||||
|
||||
body = payload.get("body")
|
||||
if not isinstance(body, str) or not body.strip():
|
||||
print("PR comment body is empty. Add 'Release severity: Major | Critical | Normal'.")
|
||||
sys.exit(1)
|
||||
|
||||
lines = [line.strip() for line in body.splitlines()]
|
||||
|
||||
severity_raw = ""
|
||||
|
||||
for line in lines:
|
||||
m = SEVERITY_LINE_RE.match(line)
|
||||
if m:
|
||||
severity_raw = m.group(1).strip()
|
||||
break
|
||||
|
||||
if not severity_raw:
|
||||
print("Release severity is missing. Add a line 'Release severity: Major | Critical | Normal'.")
|
||||
sys.exit(1)
|
||||
|
||||
if severity_raw not in ALLOWED_SEVERITIES:
|
||||
print(f"Invalid severity '{severity_raw}'. Allowed values: Major, Critical, Normal.")
|
||||
sys.exit(1)
|
||||
|
||||
severity = severity_raw
|
||||
|
||||
time_iso = datetime.now(timezone.utc).strftime("%Y-%m-%dT%H:%M:%SZ")
|
||||
|
||||
try:
|
||||
with open(env_file, "a", encoding="utf-8") as f:
|
||||
f.write(f"TIME={time_iso}\n")
|
||||
f.write(f"SEVERITY={severity}\n")
|
||||
except OSError as e:
|
||||
print(f"Failed to write to GITHUB_ENV: {e}")
|
||||
sys.exit(1)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
parse_base_params(os.getenv("COMMENT_LINK"))
|
||||
Reference in New Issue
Block a user