refs #2363 Reduce number of required dependencies
							parent
							
								
									83b0fd7c03
								
							
						
					
					
						commit
						037ac63c97
					
				
							
								
								
									
										143
									
								
								api/repo_api.py
								
								
								
								
							
							
						
						
									
										143
									
								
								api/repo_api.py
								
								
								
								
							|  | @ -56,11 +56,10 @@ config_file = '/opt/opengnsys/ogrepository/etc/ogAdmRepo.cfg' | |||
| 
 | ||||
| REPOSITORIES_BASE_PATH = "/opt/opengnsys/ogrepository/oggit/git/" | ||||
| OGGIT_USER = "oggit" | ||||
| OGGIT_FORGEJO_PORT = 3100 | ||||
| 
 | ||||
| import sys | ||||
| import git | ||||
| import pkgutil | ||||
| import importlib | ||||
| import paramiko | ||||
| 
 | ||||
| 
 | ||||
|  | @ -2220,6 +2219,48 @@ def rename_image(): | |||
| # ----------------------------------------------------------- | ||||
| 
 | ||||
| 
 | ||||
| def git_forgejo_post_command(url, json_data): | ||||
|     token = "" | ||||
|     with open("/opt/opengnsys/etc/ogGitApiToken.cfg", "r", encoding='utf-8') as token_file: | ||||
|         token = token_file.read().strip() | ||||
| 
 | ||||
|     if url[0] == "/": | ||||
|         url = url[1:] | ||||
| 
 | ||||
|     url = f"http://localhost:{OGGIT_FORGEJO_PORT}/{url}" | ||||
| 
 | ||||
|     journal.send(f"Executing forgejo POST to {url} with data {json_data}...", PRIORITY=journal.LOG_DEBUG, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
| 
 | ||||
|     r = requests.post( | ||||
|         url, | ||||
|         json = json_data, | ||||
|         headers = { 'Authorization' : f"token {token}" }, | ||||
|         timeout = 60 | ||||
|     ) | ||||
| 
 | ||||
|     journal.send(f"Request status was {r.status_code}, content {r.content}", PRIORITY=journal.LOG_DEBUG, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
| 
 | ||||
|     return r.status_code, r.content.decode('utf-8') | ||||
| 
 | ||||
| def git_forgejo_create_repo(repo): | ||||
|     return git_forgejo_post_command("/api/v1/user/repos", | ||||
|                     { | ||||
|                         "auto_init" : False, | ||||
|                         "default_branch" : "main", | ||||
|                         "description" : "", | ||||
|                         "name" : repo, | ||||
|                         "private" : False | ||||
|                     }) | ||||
| 
 | ||||
| 
 | ||||
| def git_forgejo_add_sshkey(pubkey, description = ""): | ||||
|     return git_forgejo_post_command("/api/v1/user/keys", | ||||
|                                     { | ||||
|                                         "key" : pubkey, | ||||
|                                         "read_only" : False, | ||||
|                                         "title" : description | ||||
|                                     }) | ||||
| 
 | ||||
| def git_compact_repository_task(repo, job_id): | ||||
|     journal.send("Running function 'git_compact_repository_task'...", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
| 
 | ||||
|  | @ -2289,40 +2330,6 @@ def git_backup_repository_task(repo, params, job_id): | |||
|     journal.send(f"Calling function 'recall_ogcore' (JOB_ID: {job_id}, SUCCESS: True)", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
|     recall_ogcore(data) | ||||
| 
 | ||||
| 
 | ||||
| def git_add_sshkey_task(oglive, description, job_id): | ||||
|     module = _load_installer() | ||||
|     print(f"Got {module}") | ||||
|     OpengnsysGitInstaller = getattr(module, 'OpengnsysGitInstaller') | ||||
|     installer = OpengnsysGitInstaller() | ||||
| 
 | ||||
|     results = installer.add_ssh_key_from_squashfs(oglive_file = oglive) | ||||
|     keys_added = 0 | ||||
|     keys_existed = 0 | ||||
|     keys_failed = 0 | ||||
| 
 | ||||
|     for status, message in results: | ||||
|         if status == 200 or status == 201: | ||||
|             keys_added = keys_added + 1 | ||||
|         elif status == 422: | ||||
|             keys_existed = keys_existed + 1 | ||||
|         else: | ||||
|             keys_failed = keys_failed + 1 | ||||
|             journal.send(f"Unrecognized reply from forgejo: code {status}, content {message}", PRIORITY=journal.LOG_ERR, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
| 
 | ||||
| 
 | ||||
|     data = { | ||||
|         'job_id': job_id, | ||||
|         'keys_added' : keys_added, | ||||
|         'keys_failed' : keys_failed, | ||||
|         'keys_existed' : keys_existed, | ||||
|         'output' : message | ||||
|     } | ||||
| 
 | ||||
|     journal.send(f"Calling function 'recall_ogcore' (JOB_ID: {job_id}, SUCCESS: True)", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
|     recall_ogcore(data) | ||||
| 
 | ||||
| 
 | ||||
| @app.route("/ogrepository/v1/git/repositories", methods=['GET']) | ||||
| def git_list_repositories(): | ||||
|     """ | ||||
|  | @ -2369,42 +2376,6 @@ def git_list_repositories(): | |||
|         "repositories": repos | ||||
|     }), 200 | ||||
| 
 | ||||
| def _load_module(module_name): | ||||
|    # module = importlib.util.find_spec(module_name) | ||||
|     module = importlib.import_module(module_name) | ||||
| 
 | ||||
|     if module is not None: | ||||
|         journal.send(f"Module {module_name} loaded successfully. Got {module}", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="oggit-api_DEBUG") | ||||
|         return module | ||||
| 
 | ||||
|     journal.send(f"Module {module_name} failed to load, not found", PRIORITY=journal.LOG_ERR, SYSLOG_IDENTIFIER="oggit-api_DEBUG") | ||||
|     return False | ||||
| 
 | ||||
| def _load_installer(): | ||||
| 
 | ||||
|     journal.send(f"Loading oggit installer module", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="oggit-api_DEBUG") | ||||
| 
 | ||||
|     script_dir = os.path.dirname(os.path.realpath(__file__)) | ||||
| 
 | ||||
|     system_bin_path = '/opt/opengnsys/ogrepository/oggit/bin/' | ||||
|     system_lib_path = '/opt/opengnsys/ogrepository/oggit/lib/' | ||||
|     devel_lib_path = os.path.join(script_dir, "../../oggit/installer") | ||||
| 
 | ||||
|     if devel_lib_path not in sys.path and os.path.isdir(devel_lib_path): | ||||
|         journal.send(f"Using {devel_lib_path} development library path", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="oggit-api_DEBUG") | ||||
|         sys.path.append(devel_lib_path) | ||||
| 
 | ||||
|     if system_bin_path not in sys.path: | ||||
|         journal.send(f"Using {system_bin_path} system library path", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="oggit-api_DEBUG") | ||||
|         sys.path.append(system_bin_path) | ||||
| 
 | ||||
|     if system_lib_path not in sys.path: | ||||
|         journal.send(f"Using {system_lib_path} system library path", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="oggit-api_DEBUG") | ||||
|         sys.path.append(system_lib_path) | ||||
| 
 | ||||
|     return _load_module("opengnsys_git_installer") | ||||
| 
 | ||||
| 
 | ||||
| @app.route("/ogrepository/v1/git/repositories", methods=['POST']) | ||||
| def git_create_repository(): | ||||
|     """ | ||||
|  | @ -2434,11 +2405,7 @@ def git_create_repository(): | |||
|         journal.send(f"Can't create repository {repo}, already exists at {repo_path}", PRIORITY=journal.LOG_ERR, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
|         return jsonify({"status": "Repository already exists"}), 409 | ||||
| 
 | ||||
|     module = _load_installer() | ||||
|     print(f"Got {module}") | ||||
|     OpengnsysGitInstaller = getattr(module, 'OpengnsysGitInstaller') | ||||
|     installer = OpengnsysGitInstaller() | ||||
|     installer.add_forgejo_repo(repo) | ||||
|     ret = git_forgejo_create_repo(repo) | ||||
| 
 | ||||
|     journal.send(f"Repository {repo} created", PRIORITY=journal.LOG_INFO, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
| 
 | ||||
|  | @ -2879,27 +2846,11 @@ def git_add_sshkey(): | |||
|     if not "description" in data: | ||||
|         data["description"] = "" | ||||
| 
 | ||||
|     if not ("ssh_key" in data or "oglive" in data): | ||||
|         journal.send(f"Can't add SSH keys, either ssh_key or oglive is required", PRIORITY=journal.LOG_ERR, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
|     if not ("ssh_key" in data ): | ||||
|         journal.send(f"Can't add SSH keys, ssh_key is required", PRIORITY=journal.LOG_ERR, SYSLOG_IDENTIFIER="ogrepo-api_DEBUG") | ||||
|         return jsonify({"error" : "Parameters missing, specify ssh_key or oglive"}), 400 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     module = _load_installer() | ||||
|     print(f"Got {module}") | ||||
|     OpengnsysGitInstaller = getattr(module, 'OpengnsysGitInstaller') | ||||
|     installer = OpengnsysGitInstaller() | ||||
| 
 | ||||
|     if "oglive" in data: | ||||
|         job_id = f"GitSshKey_{''.join(random.choice('0123456789abcdef') for char in range(8))}" | ||||
|         threading.Thread(target=git_add_sshkey_task, args=(data["oglive"], data["description"], job_id)).start() | ||||
|         return jsonify({ | ||||
|             "success": True, | ||||
|             "output": "Extracting key from ogLive...", | ||||
|             "job_id": job_id | ||||
|         }), 200 | ||||
|     else: | ||||
|         status, content = installer.add_forgejo_sshkey(data["ssh_key"], data["description"]) | ||||
|     status, content = git_forgejo_add_sshkey(data["ssh_key"], data["description"]) | ||||
|     message = "Result unrecognized" | ||||
|     success = False | ||||
|     httpcode = 500 | ||||
|  |  | |||
|  | @ -1,3 +1,17 @@ | |||
| ogrepository (1.1.4) UNRELEASED; urgency=medium | ||||
| 
 | ||||
|   * refs #2363 Reduce number of required dependencies | ||||
| 
 | ||||
|  -- OpenGnsys <opengnsys@opengnsys.com>  Tue, 30 Jun 2025 15:50:11 +0000 | ||||
| 
 | ||||
| ogrepository (1.1.3) UNRELEASED; urgency=medium | ||||
| 
 | ||||
|   * refs #2317 Fix performance problems, remove stats | ||||
|   * refs #2298 Add commmits endpoint | ||||
| 
 | ||||
|  -- OpenGnsys <opengnsys@opengnsys.com>  Tue, 30 Jun 2025 15:50:11 +0000 | ||||
| 
 | ||||
| 
 | ||||
| ogrepository (1.1.2) UNRELEASED; urgency=medium | ||||
| 
 | ||||
|   * Fix path handling when there are no repositories | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue