mirror of
https://github.com/milk-net/milk-net.github.io.git
synced 2025-04-18 17:23:40 -05:00
Delete sync_forks.py
This commit is contained in:
parent
e5b5750f84
commit
25dac981fc
1 changed files with 0 additions and 67 deletions
|
@ -1,67 +0,0 @@
|
|||
import os
|
||||
import time
|
||||
import subprocess
|
||||
import requests
|
||||
|
||||
# Configuration
|
||||
FORKS = [
|
||||
{"fork": "milknetmirrors/gmusa", "upstream": "milk-net/milk-net.github.io"},
|
||||
{"fork": "milknetmirrors/picklerick", "upstream": "milk-net/milk-net.github.io"},
|
||||
{"fork": "milknetmirrors/precalculus", "upstream": "milk-net/milk-net.github.io"},
|
||||
{"fork": "milknetmirrors/milknetmirrors.github.io", "upstream": "milk-net/milk-net.github.io"},
|
||||
]
|
||||
CHECK_INTERVAL = 20 * 60 # 20 minutes in seconds
|
||||
BASE_DIR = os.getenv("BASE_DIR", "/tmp/clones")
|
||||
GITHUB_TOKEN = os.getenv("TOKEN")
|
||||
|
||||
def get_latest_commit(repo):
|
||||
"""Fetch the latest commit hash from the default branch of a repository."""
|
||||
url = f"https://api.github.com/repos/{repo}/commits/main"
|
||||
headers = {"Authorization": f"token {GITHUB_TOKEN}"}
|
||||
response = requests.get(url, headers=headers)
|
||||
if response.status_code == 200:
|
||||
return response.json()["sha"]
|
||||
else:
|
||||
print(f"Error fetching commits for {repo}: {response.text}")
|
||||
return None
|
||||
|
||||
def clone_repo(fork_repo, local_repo):
|
||||
"""Clone the forked repository if it does not exist."""
|
||||
if not os.path.exists(local_repo):
|
||||
print(f"Cloning {fork_repo} into {local_repo}...")
|
||||
auth_url = f"https://{GITHUB_TOKEN}@github.com/{fork_repo}.git"
|
||||
subprocess.run(["git", "clone", auth_url, local_repo], check=True)
|
||||
subprocess.run(["git", "remote", "add", "upstream", f"https://github.com/{FORKS[0]['upstream']}.git"], cwd=local_repo, check=True)
|
||||
|
||||
def pull_latest_changes(local_repo):
|
||||
"""Pull the latest changes from the upstream repository."""
|
||||
try:
|
||||
subprocess.run(["git", "config", "user.email", "actions@github.com"], cwd=local_repo, check=True)
|
||||
subprocess.run(["git", "config", "user.name", "github-actions"], cwd=local_repo, check=True)
|
||||
subprocess.run(["git", "fetch", "upstream"], cwd=local_repo, check=True)
|
||||
subprocess.run(["git", "merge", "upstream/main"], cwd=local_repo, check=True)
|
||||
subprocess.run(["git", "push"], cwd=local_repo, check=True)
|
||||
print(f"Updated repository: {local_repo}")
|
||||
except subprocess.CalledProcessError as e:
|
||||
print(f"Error updating {local_repo}: {e}")
|
||||
|
||||
if __name__ == "__main__":
|
||||
while True:
|
||||
for repo in FORKS:
|
||||
fork_repo = repo["fork"]
|
||||
upstream_repo = repo["upstream"]
|
||||
local_repo_path = os.path.join(BASE_DIR, fork_repo.split("/")[1])
|
||||
|
||||
print(f"Checking updates for {fork_repo}...")
|
||||
clone_repo(fork_repo, local_repo_path)
|
||||
upstream_commit = get_latest_commit(upstream_repo)
|
||||
fork_commit = get_latest_commit(fork_repo)
|
||||
|
||||
if upstream_commit and fork_commit and upstream_commit != fork_commit:
|
||||
print(f"New changes detected in {upstream_repo}, updating {fork_repo}...")
|
||||
pull_latest_changes(local_repo_path)
|
||||
else:
|
||||
print(f"No new changes for {fork_repo}.")
|
||||
|
||||
print(f"Waiting {CHECK_INTERVAL // 60} minutes before next check...")
|
||||
time.sleep(CHECK_INTERVAL)
|
Loading…
Add table
Reference in a new issue