added radcile metadata output

This commit is contained in:
Mark Randall Havens 2025-05-31 02:27:15 -05:00
parent 5eac5c8753
commit eff028680f
2 changed files with 173 additions and 57 deletions

View file

@ -1 +1 @@
ffc48f86dccdf8c2d20845cea3bfad14ac2cd9ea
5eac5c8753f44b79bd62f02073ad437ea5d0176a

View file

@ -2,6 +2,9 @@
set -euo pipefail
IFS=$'\n\t'
# ╭───────────────────────────────╮
# │ Config & Paths │
# ╰───────────────────────────────╯
PROJECT_NAME=$(basename "$(pwd)")
DEFAULT_NAME="Mark Randall Havens"
DEFAULT_EMAIL="mark.r.havens@gmail.com"
@ -15,59 +18,144 @@ RAD_PATH_LINE='export PATH="$HOME/.radicle/bin:$PATH"'
PROFILE_FILE="$HOME/.bashrc"
PUSH_STATE_FILE=".radicle-push-state"
MARKDOWN_FILE=".radicle-link.md"
PUBLIC_GATEWAY="https://app.radicle.xyz/nodes/ash.radicle.garden"
# ╭───────────────────────────────╮
# │ Logging Utils │
# ╰───────────────────────────────╯
info() { echo -e "\e[1;34m[INFO]\e[0m $*"; }
warn() { echo -e "\e[1;33m[WARN]\e[0m $*"; }
error() { echo -e "\e[1;31m[ERROR]\e[0m $*" >&2; exit 1; }
# Ensure tools
sudo apt update -qq
sudo apt install -y git curl jq unzip || error "Missing deps"
# ╭───────────────────────────────╮
# │ Git + Tools Precheck │
# ╰───────────────────────────────╯
info "Checking Git..."
command -v git >/dev/null || {
info "Installing Git..."
sudo apt update && sudo apt install -y git || error "Failed to install Git"
}
info "Git version: $(git --version)"
NAME=$(git config --global user.name || true)
EMAIL=$(git config --global user.email || true)
[[ -z "$NAME" || -z "$EMAIL" ]] && {
info "Setting Git identity..."
git config --global user.name "$DEFAULT_NAME"
git config --global user.email "$DEFAULT_EMAIL"
}
info "Git identity: $(git config --global user.name) <$(git config --global user.email)>"
# ╭───────────────────────────────╮
# │ Radicle CLI Setup │
# ╰───────────────────────────────╯
if [ ! -x "$RAD_BIN" ]; then
info "Installing Radicle CLI..."
sudo apt install -y curl jq unzip || error "Missing dependencies"
curl -sSf https://radicle.xyz/install | sh || error "Radicle install failed"
fi
export PATH="$HOME/.radicle/bin:$PATH"
grep -qxF "$RAD_PATH_LINE" "$PROFILE_FILE" || echo "$RAD_PATH_LINE" >> "$PROFILE_FILE"
if ! grep -Fxq "$RAD_PATH_LINE" "$PROFILE_FILE"; then
echo "$RAD_PATH_LINE" >> "$PROFILE_FILE"
info "→ Added PATH to $PROFILE_FILE"
warn "→ Run 'source $PROFILE_FILE' to make Radicle CLI persistent"
fi
command -v rad >/dev/null || error "Radicle CLI unavailable"
command -v rad >/dev/null || error "Radicle CLI still unavailable. Try restarting terminal."
# Git config
git config --global user.name "$DEFAULT_NAME"
git config --global user.email "$DEFAULT_EMAIL"
info "Radicle CLI ready: $(rad --version)"
[ -d .git ] || git init
git add . || true
git commit -m "Initial commit" || true
# Identity setup
# ╭────────────────────────────────────────────────────╮
# │ Restore or Create Radicle Identity & Backup │
# ╰────────────────────────────────────────────────────╯
mkdir -p "$(dirname "$RAD_BACKUP")"
[ -f "$RAD_KEYS" ] || {
[ -f "$RAD_BACKUP" ] && cp "$RAD_BACKUP" "$RAD_KEYS" || {
rad auth || error "Failed to create identity"
cp "$RAD_KEYS" "$RAD_BACKUP"
if [ ! -f "$RAD_KEYS" ]; then
if [ -f "$RAD_BACKUP" ]; then
info "Restoring Radicle identity from backup..."
cp "$RAD_BACKUP" "$RAD_KEYS" || error "Failed to restore identity"
else
info "Creating new Radicle identity..."
rad auth || error "Identity creation failed"
cp "$RAD_KEYS" "$RAD_BACKUP" || warn "Backup of identity failed"
fi
else
info "Radicle identity already exists."
fi
# ╭───────────────────────────────╮
# │ Start Rad Node │
# ╰───────────────────────────────╯
pgrep -f "rad node start" >/dev/null || {
info "Starting Radicle node..."
nohup rad node start > /\#include <bits/stdc++.h>
using namespace std;
int main() {
int t; cin >> t;
while(t--) {
int n; cin >> n;
vector<int> a(n);
for(int i = 0; i < n; i++) cin >> a[i];
int ans = 0;
for(int i = 0; i < n; i++) {
for(int j = i + 1; j < n; j++) {
if(__gcd(a[i], a[j]) <= 2) ans++;
}
}
cout << ans << endl;
}
return 0;
}dev/null 2>&1 &
sleep 3
}
# Start node
pgrep -f "rad node start" >/dev/null || nohup rad node start >/dev/null 2>&1 &
# ╭───────────────────────────────╮
# │ Git Repo Initialization │
# ╰───────────────────────────────╯
if [ ! -d .git ]; then
git init
git add . || warn "Nothing to add"
git commit -m "Initial commit" || warn "Nothing to commit"
else
info "Git repo already initialized."
fi
# Register project
rad projects | grep -q "$PROJECT_NAME" || \
rad init --name "$PROJECT_NAME" --description "Radicle sovereign repo for $PROJECT_NAME"
# ╭───────────────────────────────╮
# │ Radicle Project Registration│
# ╰───────────────────────────────╯
if ! rad projects | grep -q "$PROJECT_NAME"; then
info "Registering Radicle project '$PROJECT_NAME'..."
rad init --name "$PROJECT_NAME" --description "Radicle sovereign repo for $PROJECT_NAME" || warn "Repo may already exist"
else
info "Project '$PROJECT_NAME' already registered."
fi
# Push commit
BRANCH=$(git symbolic-ref --short HEAD)
COMMIT=$(git rev-parse HEAD)
LAST_PUSHED=$(cat "$PUSH_STATE_FILE" 2>/dev/null || echo "none")
[ "$COMMIT" = "$LAST_PUSHED" ] || {
git push rad "$BRANCH" && echo "$COMMIT" > "$PUSH_STATE_FILE"
}
# ╭───────────────────────────────╮
# │ Push Current Commit Logic │
# ╰───────────────────────────────╯
CURRENT_BRANCH=$(git symbolic-ref --short HEAD)
CURRENT_COMMIT=$(git rev-parse HEAD)
LAST_PUSHED_COMMIT=$(cat "$PUSH_STATE_FILE" 2>/dev/null || echo "none")
# Metadata
TIMESTAMP=$(date '+%Y-%m-%d %H:%M:%S')
REPO_PATH=$(pwd)
LATEST_SHA=$COMMIT
if [[ "$CURRENT_COMMIT" == "$LAST_PUSHED_COMMIT" ]]; then
info "✓ Already pushed commit: $CURRENT_COMMIT"
else
info "Pushing commit '$CURRENT_COMMIT' on branch '$CURRENT_BRANCH'..."
if git push rad "$CURRENT_BRANCH"; then
echo "$CURRENT_COMMIT" > "$PUSH_STATE_FILE"
info "✓ Pushed to Radicle successfully"
else
warn "Push may have failed — check 'rad sync status'"
fi
fi
# ╭─────────────────────────────────────╮
# │ GIT METADATA SNAPSHOT │
# ╰─────────────────────────────────────╯
TIMESTAMP="$(date '+%Y-%m-%d %H:%M:%S')"
DEFAULT_BRANCH="$(git symbolic-ref --short HEAD)"
REPO_PATH="$(pwd)"
LATEST_SHA=$(git rev-parse HEAD)
LAST_COMMIT_MSG=$(git log -1 --pretty=format:"%s")
LAST_COMMIT_DATE=$(git log -1 --pretty=format:"%ad")
LAST_COMMIT_AUTHOR=$(git log -1 --pretty=format:"%an <%ae>")
@ -75,39 +163,44 @@ TOTAL_COMMITS=$(git rev-list --count HEAD)
TRACKED_FILES=$(git ls-files | wc -l)
UNCOMMITTED=$(if ! git diff --quiet || ! git diff --cached --quiet; then echo "Yes"; else echo "No"; fi)
LATEST_TAG=$(git describe --tags --abbrev=0 2>/dev/null || echo "None")
HOSTNAME=$(hostname)
CURRENT_USER=$(whoami)
TIMEZONE=$(date +%Z)
# Radicle-specific metadata
PROJECT_ID=$(rad self | grep 'Project ID' | awk '{print $NF}' || echo "Unknown")
PEER_ID=$(rad self | grep 'Peer ID' | awk '{print $NF}' || echo "Unknown")
REPO_URN="rad://$PROJECT_ID"
PUBLIC_GATEWAY_URL="$PUBLIC_GATEWAY/$REPO_URN/tree/$LATEST_SHA"
# ╭─────────────────────────────────────╮
# │ HARDWARE + OS FINGERPRINT BLOCK │
# ╰─────────────────────────────────────╯
OS_NAME=$(uname -s)
KERNEL_VERSION=$(uname -r)
ARCHITECTURE=$(uname -m)
OS_PRETTY_NAME=$(grep PRETTY_NAME /etc/os-release | cut -d= -f2 | tr -d '"')
DOCKER_CHECK=$(grep -qE '/docker|/lxc' /proc/1/cgroup && echo "Yes" || echo "No")
WSL_CHECK=$(grep -qi microsoft /proc/version && echo "Yes" || echo "No")
OS_PRETTY_NAME=$(grep PRETTY_NAME /etc/os-release 2>/dev/null | cut -d= -f2 | tr -d '"') || OS_PRETTY_NAME="Unknown"
DOCKER_CHECK=$(grep -qE '/docker|/lxc' /proc/1/cgroup 2>/dev/null && echo "Yes" || echo "No")
WSL_CHECK=$(grep -qi microsoft /proc/version 2>/dev/null && echo "Yes" || echo "No")
VM_CHECK=$(systemd-detect-virt 2>/dev/null || echo "Unknown")
UPTIME=$(uptime -p)
UPTIME=$(uptime -p 2>/dev/null || echo "Unknown")
MAC_ADDR=$(ip link | awk '/ether/ {print $2}' | head -n 1)
LOCAL_IP=$(hostname -I | awk '{print $1}')
CPU_MODEL=$(grep -m1 'model name' /proc/cpuinfo | cut -d: -f2 | sed 's/^ //')
RAM_GB=$(awk '/MemTotal/ {printf "%.2f", $2/1024/1024}' /proc/meminfo)
PROJECT_ID=$(rad self | grep 'Project ID' | awk '{print $NF}')
PEER_ID=$(rad self | grep 'Peer ID' | awk '{print $NF}')
RAD_LINK="rad:$PROJECT_ID"
# ╭─────────────────────────────────────╮
# │ WRITE RICH MARKDOWN ARTIFACT │
# ╰─────────────────────────────────────╯
cat > "$MARKDOWN_FILE" <<EOF
# 🕸️ Radicle Repository Link
# 🔗 Radicle Repository Link
- **Repo Name**: \`$PROJECT_NAME\`
- **Radicle Project ID**: \`$PROJECT_ID\`
- **Radicle Peer ID**: \`$PEER_ID\`
- **Radicle URL**: \`$RAD_LINK\`
- **Project Name**: \`$PROJECT_NAME\`
- **Radicle URN**: \`$REPO_URN\`
- **Public Gateway**: [$PUBLIC_GATEWAY_URL]($PUBLIC_GATEWAY_URL)
- **Local Repo Path**: \`$REPO_PATH\`
- **Remote Label**: \`rad\`
- **Default Branch**: \`$BRANCH\`
- **Repo Synced**: \`$TIMESTAMP\`
- **Default Branch**: \`$DEFAULT_BRANCH\`
- **Repo Created**: \`$TIMESTAMP\`
---
@ -118,6 +211,7 @@ cat > "$MARKDOWN_FILE" <<EOF
- **Commit Message**: \`$LAST_COMMIT_MSG\`
- **Commit Author**: \`$LAST_COMMIT_AUTHOR\`
- **Commit Date**: \`$LAST_COMMIT_DATE\`
- **Commit URL**: [$PUBLIC_GATEWAY_URL]($PUBLIC_GATEWAY_URL)
---
@ -156,13 +250,35 @@ cat > "$MARKDOWN_FILE" <<EOF
---
## 🌱 Radicle-Specific Metadata
- **Project ID**: \`$PROJECT_ID\`
- **Peer ID**: \`$PEER_ID\`
- **Public Gateway Base**: \`$PUBLIC_GATEWAY\`
---
_Auto-generated by \`gitfield-radicle\` push script._
EOF
git add "$MARKDOWN_FILE"
git commit -m "Radicle metadata link commit at $TIMESTAMP" || warn "No changes to commit"
git push rad "$BRANCH"
# ╭───────────────────────────────╮
# │ Final Output Block │
# ╰───────────────────────────────╯
info "✓ Project ID: $PROJECT_ID"
info "→ Peer ID: $PEER_ID (Share to connect)"
info "🔗 View in browser: $PUBLIC_GATEWAY_URL"
echo -e "\n🌱 Project ID: $PROJECT_ID"
echo -e "🌐 Peer ID: $PEER_ID"
echo -e "🔗 Link: $RAD_LINK"
# Commit the markdown file
git add "$MARKDOWN_FILE"
git commit -m "Radicle metadata link commit at $TIMESTAMP" || warn "No changes to commit for $MARKDOWN_FILE"
# Push the updated commit
if [[ "$CURRENT_COMMIT" != "$LAST_PUSHED_COMMIT" ]]; then
info "Pushing updated commit with metadata..."
if git push rad "$CURRENT_BRANCH"; then
echo "$CURRENT_COMMIT" > "$PUSH_STATE_FILE"
info "✓ Pushed updated commit to Radicle successfully"
else
warn "Push may have failed — check 'rad sync status'"
fi
fi