|
|
|
@@ -69,32 +69,81 @@ elif [[ "$PLATFORM" == "gitea" ]]; then
|
|
|
|
|
|
|
|
|
|
|
|
API_URL="https://${HOST}/api/v1/repos/${OWNER}/${REPO}/pulls/${PR_NUMBER}"
|
|
|
|
API_URL="https://${HOST}/api/v1/repos/${OWNER}/${REPO}/pulls/${PR_NUMBER}"
|
|
|
|
|
|
|
|
|
|
|
|
GITEA_API_TOKEN=$(get_gitea_token "$HOST" || true)
|
|
|
|
declare -a TOKEN_CANDIDATES=()
|
|
|
|
|
|
|
|
add_token_candidate() {
|
|
|
|
|
|
|
|
local candidate="$1"
|
|
|
|
|
|
|
|
[[ -z "$candidate" ]] && return 0
|
|
|
|
|
|
|
|
local existing
|
|
|
|
|
|
|
|
for existing in "${TOKEN_CANDIDATES[@]:-}"; do
|
|
|
|
|
|
|
|
[[ "$existing" == "$candidate" ]] && return 0
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
TOKEN_CANDIDATES+=("$candidate")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if [[ -n "$GITEA_API_TOKEN" ]]; then
|
|
|
|
add_token_candidate "${GITEA_TOKEN:-}"
|
|
|
|
RAW=$(curl -sS -H "Authorization: token $GITEA_API_TOKEN" "$API_URL")
|
|
|
|
add_token_candidate "$(get_gitea_token "$HOST" || true)"
|
|
|
|
else
|
|
|
|
|
|
|
|
RAW=$(curl -sS "$API_URL")
|
|
|
|
# Git HTTPS credentials often contain a valid Gitea API token even when a
|
|
|
|
|
|
|
|
# Mosaic credential-source entry is stale. Try them as a fallback before
|
|
|
|
|
|
|
|
# falling back to an unauthenticated request.
|
|
|
|
|
|
|
|
CREDS_FILE="$HOME/.git-credentials"
|
|
|
|
|
|
|
|
if [[ -f "$CREDS_FILE" ]]; then
|
|
|
|
|
|
|
|
while IFS= read -r credential_token; do
|
|
|
|
|
|
|
|
add_token_candidate "$credential_token"
|
|
|
|
|
|
|
|
done < <(grep -F "$HOST" "$CREDS_FILE" 2>/dev/null | sed -n 's#https\?://[^@]*:\([^@/]*\)@.*#\1#p')
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
RAW=""
|
|
|
|
|
|
|
|
HTTP_STATUS=""
|
|
|
|
|
|
|
|
if [[ ${#TOKEN_CANDIDATES[@]} -gt 0 ]]; then
|
|
|
|
|
|
|
|
for GITEA_API_TOKEN in "${TOKEN_CANDIDATES[@]}"; do
|
|
|
|
|
|
|
|
RESPONSE_FILE=$(mktemp)
|
|
|
|
|
|
|
|
HTTP_STATUS=$(curl -sS -o "$RESPONSE_FILE" -w '%{http_code}' -H "Authorization: token $GITEA_API_TOKEN" "$API_URL" || true)
|
|
|
|
|
|
|
|
RAW=$(cat "$RESPONSE_FILE")
|
|
|
|
|
|
|
|
rm -f "$RESPONSE_FILE"
|
|
|
|
|
|
|
|
[[ "$HTTP_STATUS" =~ ^2 ]] && break
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ ! "$HTTP_STATUS" =~ ^2 ]]; then
|
|
|
|
|
|
|
|
RESPONSE_FILE=$(mktemp)
|
|
|
|
|
|
|
|
HTTP_STATUS=$(curl -sS -o "$RESPONSE_FILE" -w '%{http_code}' "$API_URL" || true)
|
|
|
|
|
|
|
|
RAW=$(cat "$RESPONSE_FILE")
|
|
|
|
|
|
|
|
rm -f "$RESPONSE_FILE"
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ ! "$HTTP_STATUS" =~ ^2 ]]; then
|
|
|
|
|
|
|
|
ERROR_MESSAGE=$(printf '%s' "$RAW" | python3 -c 'import json, sys
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
|
|
|
data=json.load(sys.stdin)
|
|
|
|
|
|
|
|
except Exception:
|
|
|
|
|
|
|
|
data={}
|
|
|
|
|
|
|
|
print(data.get("message") or data.get("error") or "unknown error")')
|
|
|
|
|
|
|
|
echo "Error: failed to fetch Gitea PR #$PR_NUMBER from $HOST/$OWNER/$REPO (HTTP $HTTP_STATUS): $ERROR_MESSAGE" >&2
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# Normalize Gitea response to match our expected schema
|
|
|
|
# Normalize Gitea response to match our expected schema
|
|
|
|
METADATA=$(echo "$RAW" | python3 -c "
|
|
|
|
METADATA=$(echo "$RAW" | python3 -c "
|
|
|
|
import json, sys
|
|
|
|
import json, sys
|
|
|
|
data = json.load(sys.stdin)
|
|
|
|
data = json.load(sys.stdin)
|
|
|
|
|
|
|
|
head = data.get('head') or {}
|
|
|
|
|
|
|
|
base = data.get('base') or {}
|
|
|
|
|
|
|
|
user = data.get('user') or {}
|
|
|
|
normalized = {
|
|
|
|
normalized = {
|
|
|
|
'number': data.get('number'),
|
|
|
|
'number': data.get('number') or data.get('index'),
|
|
|
|
'title': data.get('title'),
|
|
|
|
'title': data.get('title'),
|
|
|
|
'body': data.get('body', ''),
|
|
|
|
'body': data.get('body', ''),
|
|
|
|
'state': data.get('state'),
|
|
|
|
'state': data.get('state'),
|
|
|
|
'author': data.get('user', {}).get('login', ''),
|
|
|
|
'author': user.get('login', ''),
|
|
|
|
'headRefName': data.get('head', {}).get('ref', ''),
|
|
|
|
'headRefName': head.get('ref') or head.get('label', '').split(':')[-1],
|
|
|
|
'baseRefName': data.get('base', {}).get('ref', ''),
|
|
|
|
'baseRefName': base.get('ref') or base.get('label', '').split(':')[-1],
|
|
|
|
'labels': [l.get('name', '') for l in data.get('labels', [])],
|
|
|
|
'labels': [l.get('name', '') for l in data.get('labels', [])],
|
|
|
|
'assignees': [a.get('login', '') for a in data.get('assignees', [])],
|
|
|
|
'assignees': [a.get('login', '') for a in data.get('assignees', [])],
|
|
|
|
'milestone': data.get('milestone', {}).get('title', '') if data.get('milestone') else '',
|
|
|
|
'milestone': data.get('milestone', {}).get('title', '') if data.get('milestone') else '',
|
|
|
|
'createdAt': data.get('created_at', ''),
|
|
|
|
'createdAt': data.get('created_at', ''),
|
|
|
|
'updatedAt': data.get('updated_at', ''),
|
|
|
|
'updatedAt': data.get('updated_at', ''),
|
|
|
|
'url': data.get('html_url', ''),
|
|
|
|
'url': data.get('html_url') or data.get('url', ''),
|
|
|
|
'isDraft': data.get('draft', False),
|
|
|
|
'isDraft': data.get('draft', False),
|
|
|
|
'mergeable': data.get('mergeable'),
|
|
|
|
'mergeable': data.get('mergeable'),
|
|
|
|
'diffUrl': data.get('diff_url', ''),
|
|
|
|
'diffUrl': data.get('diff_url', ''),
|
|
|
|
|