|
import sys |
|
import os |
|
import git |
|
|
|
def gitclone(custom_nodes_path, url): |
|
repo_name = os.path.splitext(os.path.basename(url))[0] |
|
repo_path = os.path.join(custom_nodes_path, repo_name) |
|
|
|
|
|
repo = git.Repo.clone_from(url, repo_path, recursive=True) |
|
repo.git.clear_cache() |
|
repo.close() |
|
|
|
def gitcheck(path, do_fetch=False): |
|
|
|
repo = git.Repo(path) |
|
|
|
current_branch = repo.active_branch |
|
branch_name = current_branch.name |
|
|
|
remote_name = 'origin' |
|
remote = repo.remote(name=remote_name) |
|
|
|
if do_fetch: |
|
remote.fetch() |
|
|
|
|
|
commit_hash = repo.head.commit.hexsha |
|
remote_commit_hash = repo.refs[f'{remote_name}/{branch_name}'].object.hexsha |
|
|
|
|
|
if commit_hash != remote_commit_hash: |
|
|
|
commit_date = repo.head.commit.committed_datetime |
|
remote_commit_date = repo.refs[f'{remote_name}/{branch_name}'].object.committed_datetime |
|
|
|
|
|
if commit_date < remote_commit_date: |
|
print("CUSTOM NODE CHECK: True") |
|
else: |
|
print("CUSTOM NODE CHECK: False") |
|
|
|
def gitpull(path): |
|
|
|
if not os.path.exists(os.path.join(path, '.git')): |
|
raise ValueError('Not a git repository') |
|
|
|
|
|
repo = git.Repo(path) |
|
origin = repo.remote(name='origin') |
|
origin.pull() |
|
repo.git.submodule('update', '--init', '--recursive') |
|
|
|
repo.close() |
|
|
|
try: |
|
if sys.argv[1] == "--clone": |
|
gitclone(sys.argv[2], sys.argv[3]) |
|
elif sys.argv[1] == "--check": |
|
gitcheck(sys.argv[2], False) |
|
elif sys.argv[1] == "--fetch": |
|
gitcheck(sys.argv[2], True) |
|
elif sys.argv[1] == "--pull": |
|
gitpull(sys.argv[2]) |
|
exit(0) |
|
except: |
|
exit(-1) |
|
|
|
|
|
|