updated radicle again
This commit is contained in:
parent
0d32c6edb2
commit
5721262240
2 changed files with 21 additions and 40 deletions
|
@ -1 +1 @@
|
||||||
91c7e471421b756dcb7edfbda2e6168a0490a586
|
0d32c6edb204b92180b753119e8364c3dccd71da
|
||||||
|
|
|
@ -2,9 +2,6 @@
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
IFS=$'\n\t'
|
IFS=$'\n\t'
|
||||||
|
|
||||||
# ╭───────────────────────────────╮
|
|
||||||
# │ Config & Paths │
|
|
||||||
# ╰───────────────────────────────╯
|
|
||||||
PROJECT_NAME=$(basename "$(pwd)")
|
PROJECT_NAME=$(basename "$(pwd)")
|
||||||
DEFAULT_NAME="Mark Randall Havens"
|
DEFAULT_NAME="Mark Randall Havens"
|
||||||
DEFAULT_EMAIL="mark.r.havens@gmail.com"
|
DEFAULT_EMAIL="mark.r.havens@gmail.com"
|
||||||
|
@ -23,7 +20,6 @@ info() { echo -e "\e[1;34m[INFO]\e[0m $*"; }
|
||||||
warn() { echo -e "\e[1;33m[WARN]\e[0m $*"; }
|
warn() { echo -e "\e[1;33m[WARN]\e[0m $*"; }
|
||||||
error() { echo -e "\e[1;31m[ERROR]\e[0m $*" >&2; exit 1; }
|
error() { echo -e "\e[1;31m[ERROR]\e[0m $*" >&2; exit 1; }
|
||||||
|
|
||||||
# Git check
|
|
||||||
command -v git >/dev/null || {
|
command -v git >/dev/null || {
|
||||||
sudo apt update && sudo apt install -y git || error "Failed to install Git"
|
sudo apt update && sudo apt install -y git || error "Failed to install Git"
|
||||||
}
|
}
|
||||||
|
@ -35,20 +31,15 @@ EMAIL=$(git config --global user.email || true)
|
||||||
git config --global user.email "$DEFAULT_EMAIL"
|
git config --global user.email "$DEFAULT_EMAIL"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Radicle CLI install
|
|
||||||
if [ ! -x "$RAD_BIN" ]; then
|
if [ ! -x "$RAD_BIN" ]; then
|
||||||
sudo apt install -y curl jq unzip || error "Missing dependencies"
|
sudo apt install -y curl jq unzip || error "Missing dependencies"
|
||||||
curl -sSf https://radicle.xyz/install | sh || error "Radicle install failed"
|
curl -sSf https://radicle.xyz/install | sh || error "Radicle install failed"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export PATH="$HOME/.radicle/bin:$PATH"
|
export PATH="$HOME/.radicle/bin:$PATH"
|
||||||
if ! grep -Fxq "$RAD_PATH_LINE" "$PROFILE_FILE"; then
|
grep -Fxq "$RAD_PATH_LINE" "$PROFILE_FILE" || echo "$RAD_PATH_LINE" >> "$PROFILE_FILE"
|
||||||
echo "$RAD_PATH_LINE" >> "$PROFILE_FILE"
|
|
||||||
fi
|
|
||||||
|
|
||||||
command -v rad >/dev/null || error "Radicle CLI unavailable"
|
command -v rad >/dev/null || error "Radicle CLI unavailable"
|
||||||
|
|
||||||
# Identity & backup
|
|
||||||
mkdir -p "$(dirname "$RAD_BACKUP")"
|
mkdir -p "$(dirname "$RAD_BACKUP")"
|
||||||
if [ ! -f "$RAD_KEYS" ]; then
|
if [ ! -f "$RAD_KEYS" ]; then
|
||||||
if [ -f "$RAD_BACKUP" ]; then
|
if [ -f "$RAD_BACKUP" ]; then
|
||||||
|
@ -59,25 +50,15 @@ if [ ! -f "$RAD_KEYS" ]; then
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Start Radicle node
|
|
||||||
pgrep -f "rad node start" >/dev/null || {
|
pgrep -f "rad node start" >/dev/null || {
|
||||||
nohup rad node start > /dev/null 2>&1 &
|
nohup rad node start > /dev/null 2>&1 &
|
||||||
sleep 3
|
sleep 3
|
||||||
}
|
}
|
||||||
|
|
||||||
# Git init
|
[ -d .git ] || { git init && git add . && git commit -m "Initial commit"; }
|
||||||
if [ ! -d .git ]; then
|
|
||||||
git init
|
|
||||||
git add .
|
|
||||||
git commit -m "Initial commit"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Register Radicle project
|
rad projects | grep -q "$PROJECT_NAME" || rad init --name "$PROJECT_NAME" --description "Radicle sovereign repo for $PROJECT_NAME" || warn "Repo may already exist"
|
||||||
if ! rad projects | grep -q "$PROJECT_NAME"; then
|
|
||||||
rad init --name "$PROJECT_NAME" --description "Radicle sovereign repo for $PROJECT_NAME" || warn "Repo may already exist"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Push commit
|
|
||||||
CURRENT_BRANCH=$(git symbolic-ref --short HEAD)
|
CURRENT_BRANCH=$(git symbolic-ref --short HEAD)
|
||||||
CURRENT_COMMIT=$(git rev-parse HEAD)
|
CURRENT_COMMIT=$(git rev-parse HEAD)
|
||||||
LAST_PUSHED_COMMIT=$(cat "$PUSH_STATE_FILE" 2>/dev/null || echo "none")
|
LAST_PUSHED_COMMIT=$(cat "$PUSH_STATE_FILE" 2>/dev/null || echo "none")
|
||||||
|
@ -90,22 +71,23 @@ if [[ "$CURRENT_COMMIT" != "$LAST_PUSHED_COMMIT" ]]; then
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Robust metadata parsing
|
# 🛡 Safe JSON fallback
|
||||||
RAD_SELF=$(rad self --json 2>/dev/null || echo '{}')
|
RAD_SELF=$(rad self --json 2>/dev/null || echo '{}')
|
||||||
|
if echo "$RAD_SELF" | jq empty >/dev/null 2>&1; then
|
||||||
PROJECT_ID=$(echo "$RAD_SELF" | jq -r '.projectId // empty')
|
PROJECT_ID=$(echo "$RAD_SELF" | jq -r '.projectId // empty')
|
||||||
PEER_ID=$(echo "$RAD_SELF" | jq -r '.peerId // empty')
|
PEER_ID=$(echo "$RAD_SELF" | jq -r '.peerId // empty')
|
||||||
REMOTE_SERVERS=$(rad node status 2>/dev/null | grep 'connected to' || echo "Unavailable")
|
|
||||||
|
|
||||||
if [[ -n "$PROJECT_ID" ]]; then
|
|
||||||
PROJECT_SLUG="${PROJECT_ID#rad:}"
|
|
||||||
RAD_GATEWAY_URL="https://app.radicle.network/$PROJECT_SLUG"
|
|
||||||
else
|
else
|
||||||
RAD_GATEWAY_URL=""
|
warn "rad self output is not valid JSON"
|
||||||
|
PROJECT_ID=""
|
||||||
|
PEER_ID=""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Metadata
|
REMOTE_SERVERS=$(rad node status 2>/dev/null | grep 'connected to' || echo "Unavailable")
|
||||||
|
RAD_GATEWAY_URL=""
|
||||||
|
[[ -n "$PROJECT_ID" ]] && RAD_GATEWAY_URL="https://app.radicle.network/${PROJECT_ID#rad:}"
|
||||||
|
|
||||||
|
# 📦 Metadata
|
||||||
TIMESTAMP=$(date '+%Y-%m-%d %H:%M:%S')
|
TIMESTAMP=$(date '+%Y-%m-%d %H:%M:%S')
|
||||||
DEFAULT_BRANCH=$(git symbolic-ref --short HEAD)
|
|
||||||
REPO_PATH=$(pwd)
|
REPO_PATH=$(pwd)
|
||||||
LATEST_SHA=$(git rev-parse HEAD)
|
LATEST_SHA=$(git rev-parse HEAD)
|
||||||
LAST_COMMIT_MSG=$(git log -1 --pretty=format:"%s")
|
LAST_COMMIT_MSG=$(git log -1 --pretty=format:"%s")
|
||||||
|
@ -131,7 +113,7 @@ LOCAL_IP=$(hostname -I | awk '{print $1}')
|
||||||
CPU_MODEL=$(grep -m1 'model name' /proc/cpuinfo | cut -d: -f2 | sed 's/^ //')
|
CPU_MODEL=$(grep -m1 'model name' /proc/cpuinfo | cut -d: -f2 | sed 's/^ //')
|
||||||
RAM_GB=$(awk '/MemTotal/ {printf "%.2f", $2/1024/1024}' /proc/meminfo)
|
RAM_GB=$(awk '/MemTotal/ {printf "%.2f", $2/1024/1024}' /proc/meminfo)
|
||||||
|
|
||||||
# Markdown Artifact
|
# 🧾 Markdown output
|
||||||
cat > "$MARKDOWN_FILE" <<EOF
|
cat > "$MARKDOWN_FILE" <<EOF
|
||||||
# 🔗 Radicle Repository Link
|
# 🔗 Radicle Repository Link
|
||||||
|
|
||||||
|
@ -139,7 +121,7 @@ cat > "$MARKDOWN_FILE" <<EOF
|
||||||
- **Project ID**: \`$PROJECT_ID\`
|
- **Project ID**: \`$PROJECT_ID\`
|
||||||
- **Peer ID**: \`$PEER_ID\`
|
- **Peer ID**: \`$PEER_ID\`
|
||||||
- **Local Repo Path**: \`$REPO_PATH\`
|
- **Local Repo Path**: \`$REPO_PATH\`
|
||||||
- **Default Branch**: \`$DEFAULT_BRANCH\`
|
- **Default Branch**: \`$CURRENT_BRANCH\`
|
||||||
- **Timestamp**: \`$TIMESTAMP\`
|
- **Timestamp**: \`$TIMESTAMP\`
|
||||||
- **Public Gateway URL**: [${RAD_GATEWAY_URL:-Unavailable}](${RAD_GATEWAY_URL:-#})
|
- **Public Gateway URL**: [${RAD_GATEWAY_URL:-Unavailable}](${RAD_GATEWAY_URL:-#})
|
||||||
|
|
||||||
|
@ -202,12 +184,11 @@ $REMOTE_SERVERS
|
||||||
_Auto-generated by \`gitfield-radicle\` push script._
|
_Auto-generated by \`gitfield-radicle\` push script._
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
# Commit the metadata
|
|
||||||
git add "$MARKDOWN_FILE"
|
git add "$MARKDOWN_FILE"
|
||||||
git commit -m "Radicle metadata link commit at $TIMESTAMP" || warn "No changes to commit"
|
git commit -m "Radicle metadata link commit at $TIMESTAMP" || warn "No changes to commit"
|
||||||
|
|
||||||
# Final Output
|
# ✅ Output Summary
|
||||||
echo -e "\n✅ Radicle metadata written."
|
echo -e "\n✅ Radicle metadata written."
|
||||||
echo -e "→ Project ID: $PROJECT_ID"
|
echo -e "→ Project ID: ${PROJECT_ID:-Unavailable}"
|
||||||
echo -e "→ Peer ID: $PEER_ID"
|
echo -e "→ Peer ID: ${PEER_ID:-Unavailable}"
|
||||||
[[ -n "$RAD_GATEWAY_URL" ]] && echo -e "🔗 View in Radicle Gateway: $RAD_GATEWAY_URL"
|
[[ -n "$RAD_GATEWAY_URL" ]] && echo -e "🔗 View in Radicle Gateway: $RAD_GATEWAY_URL"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue