mirror of
https://github.com/frappe/bench.git
synced 2025-01-10 00:37:51 +00:00
refactor(minor): AppMeta class
* Fix tuple addition * Rename App to AppMeta - it's more apt given how Bench classes are being structured now
This commit is contained in:
parent
c5a38b3647
commit
b59379c5a9
52
bench/app.py
52
bench/app.py
@ -13,47 +13,16 @@ from setuptools.config import read_configuration
|
|||||||
|
|
||||||
# imports - module imports
|
# imports - module imports
|
||||||
import bench
|
import bench
|
||||||
|
from bench.bench import Bench
|
||||||
from bench.exceptions import InvalidRemoteException, InvalidBranchException, CommandFailedError
|
from bench.exceptions import InvalidRemoteException, InvalidBranchException, CommandFailedError
|
||||||
from bench.utils import build_assets, check_git_for_shallow_clone, exec_cmd, get_cmd_output, is_bench_directory, restart_supervisor_processes, restart_systemd_processes, run_frappe_cmd
|
from bench.utils import exec_cmd, get_cmd_output, is_bench_directory, run_frappe_cmd
|
||||||
|
from bench.utils import build_assets, check_git_for_shallow_clone, fetch_details_from_tag, restart_supervisor_processes, restart_systemd_processes
|
||||||
|
|
||||||
|
|
||||||
logger = logging.getLogger(bench.PROJECT_NAME)
|
logger = logging.getLogger(bench.PROJECT_NAME)
|
||||||
|
|
||||||
|
|
||||||
def find_org(org_repo):
|
class AppMeta:
|
||||||
import requests
|
|
||||||
|
|
||||||
org_repo = org_repo[0]
|
|
||||||
|
|
||||||
for org in ["frappe", "erpnext"]:
|
|
||||||
res = requests.head(f'https://api.github.com/repos/{org}/{org_repo}')
|
|
||||||
if res.ok:
|
|
||||||
return org, org_repo
|
|
||||||
|
|
||||||
raise InvalidRemoteException
|
|
||||||
|
|
||||||
|
|
||||||
def fetch_details_from_tag(_tag):
|
|
||||||
if not _tag:
|
|
||||||
raise Exception("Tag is not provided")
|
|
||||||
|
|
||||||
app_tag = _tag.split("@")
|
|
||||||
org_repo = app_tag[0].split("/")
|
|
||||||
|
|
||||||
try:
|
|
||||||
repo, tag = app_tag
|
|
||||||
except ValueError:
|
|
||||||
repo, tag = app_tag + [None]
|
|
||||||
|
|
||||||
try:
|
|
||||||
org, repo = org_repo
|
|
||||||
except ValueError:
|
|
||||||
org, repo = find_org(org_repo)
|
|
||||||
|
|
||||||
return org, repo, tag
|
|
||||||
|
|
||||||
|
|
||||||
class App:
|
|
||||||
def __init__(self, name: str, branch : str = None):
|
def __init__(self, name: str, branch : str = None):
|
||||||
"""
|
"""
|
||||||
name (str): This could look something like
|
name (str): This could look something like
|
||||||
@ -95,7 +64,7 @@ class App:
|
|||||||
self.org, self.repo, self.tag = fetch_details_from_tag(self.name)
|
self.org, self.repo, self.tag = fetch_details_from_tag(self.name)
|
||||||
|
|
||||||
def _setup_details_from_mounted_disk(self):
|
def _setup_details_from_mounted_disk(self):
|
||||||
self.org, self.repo, self.tag = os.path.split(self.name)[-2:] + [self.branch]
|
self.org, self.repo, self.tag = os.path.split(self.name)[-2:] + (self.branch,)
|
||||||
|
|
||||||
def _setup_details_from_git_url(self):
|
def _setup_details_from_git_url(self):
|
||||||
return self.__setup_details_from_git()
|
return self.__setup_details_from_git()
|
||||||
@ -126,12 +95,11 @@ class App:
|
|||||||
return f"git@{self.remote_server}:{self.org}/{self.repo}.git"
|
return f"git@{self.remote_server}:{self.org}/{self.repo}.git"
|
||||||
|
|
||||||
|
|
||||||
def get_apps(bench_path='.'):
|
class App(AppMeta):
|
||||||
try:
|
def __init__(self, name: str, branch : str = None, bench=None):
|
||||||
with open(os.path.join(bench_path, 'sites', 'apps.txt')) as f:
|
super().__init__(name, branch)
|
||||||
return f.read().strip().split('\n')
|
self.bench = bench
|
||||||
except IOError:
|
|
||||||
return []
|
|
||||||
|
|
||||||
def add_to_appstxt(app, bench_path='.'):
|
def add_to_appstxt(app, bench_path='.'):
|
||||||
apps = get_apps(bench_path=bench_path)
|
apps = get_apps(bench_path=bench_path)
|
||||||
|
@ -1141,3 +1141,36 @@ def clear_command_cache(bench_path='.'):
|
|||||||
os.remove(bench_cache_file)
|
os.remove(bench_cache_file)
|
||||||
else:
|
else:
|
||||||
print("Bench command cache doesn't exist in this folder!")
|
print("Bench command cache doesn't exist in this folder!")
|
||||||
|
|
||||||
|
|
||||||
|
def find_org(org_repo):
|
||||||
|
import requests
|
||||||
|
|
||||||
|
org_repo = org_repo[0]
|
||||||
|
|
||||||
|
for org in ["frappe", "erpnext"]:
|
||||||
|
res = requests.head(f'https://api.github.com/repos/{org}/{org_repo}')
|
||||||
|
if res.ok:
|
||||||
|
return org, org_repo
|
||||||
|
|
||||||
|
raise InvalidRemoteException
|
||||||
|
|
||||||
|
|
||||||
|
def fetch_details_from_tag(_tag):
|
||||||
|
if not _tag:
|
||||||
|
raise Exception("Tag is not provided")
|
||||||
|
|
||||||
|
app_tag = _tag.split("@")
|
||||||
|
org_repo = app_tag[0].split("/")
|
||||||
|
|
||||||
|
try:
|
||||||
|
repo, tag = app_tag
|
||||||
|
except ValueError:
|
||||||
|
repo, tag = app_tag + [None]
|
||||||
|
|
||||||
|
try:
|
||||||
|
org, repo = org_repo
|
||||||
|
except ValueError:
|
||||||
|
org, repo = find_org(org_repo)
|
||||||
|
|
||||||
|
return org, repo, tag
|
Loading…
Reference in New Issue
Block a user