103 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
			
		
		
	
	
			103 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
| #!/usr/bin/env python3
 | |
| import sys
 | |
| import resource
 | |
| import logging
 | |
| 
 | |
| 
 | |
| import ogGlobals
 | |
| import SystemLib
 | |
| import DiskLib
 | |
| import NetLib
 | |
| 
 | |
| 
 | |
| from GitLib import OpengnsysGitLibrary, NTFSImplementation, OgProgressPrinterWeb
 | |
| 
 | |
| 
 | |
| class OgLogger(logging.StreamHandler):
 | |
|     def emit(self, record):
 | |
|         log_types = ["command"]
 | |
|         log_level = "info"
 | |
| 
 | |
|         match(record.levelno):
 | |
|             case logging.DEBUG:
 | |
|                 log_level = None
 | |
|             case logging.WARNING:
 | |
|                 log_level = "warning"
 | |
|             case logging.INFO:
 | |
|                 log_level = "info"
 | |
|             case logging.ERROR:
 | |
|                 log_level = "error"
 | |
|             case logging.CRITICAL:
 | |
|                 SystemLib.ogRaiseError()
 | |
| 
 | |
|         SystemLib.ogEcho(log_types, log_level, record.getMessage())
 | |
| 
 | |
| 
 | |
| 
 | |
| def create_image(disk_num, partition_num, repo, image_name):
 | |
| 
 | |
|     ntfs_impl = NTFSImplementation.NTFS3G
 | |
|     og_git = OpengnsysGitLibrary(ntfs_implementation = ntfs_impl)
 | |
|     og_git.progress_callback = OgProgressPrinterWeb()
 | |
| 
 | |
|     device = DiskLib.ogDiskToDev(disk_num, partition_num)
 | |
|     if og_git.initRepo(device, image_name):
 | |
|         return 0
 | |
|     else:
 | |
|         return 1
 | |
| 
 | |
| 
 | |
| def main():
 | |
| 
 | |
|     soft, hard = resource.getrlimit(resource.RLIMIT_NOFILE)
 | |
|     try:
 | |
|         # Usamos el mínimo entre 65536 y el límite hard disponible
 | |
|         new_limit = min(65536, hard)
 | |
|         resource.setrlimit(resource.RLIMIT_NOFILE, (new_limit, hard))
 | |
|         print(f"RLIMIT_NOFILE establecido a: {resource.getrlimit(resource.RLIMIT_NOFILE)}")
 | |
|     except ValueError as e:
 | |
|         print(f"No se pudo aumentar el límite de archivos abiertos: {e}")
 | |
| 
 | |
| 
 | |
| 
 | |
|     if len(sys.argv) < 5:
 | |
|         sys.exit(SystemLib.ogRaiseError([], ogGlobals.OG_ERR_FORMAT, "Incorrect number of arguments. Usage: CrearImagenGit disk_num partition_num image_name repo"))
 | |
| 
 | |
|     # repo - repositorio, ip address. Opcional porque oglive lo recibe como parametro de kernel
 | |
| 
 | |
| 
 | |
|     disk_num, partition_num, image_name, repo = sys.argv[1:5]
 | |
| 
 | |
| 
 | |
|     opengnsys_log_dir = "/opt/opengnsys/log"
 | |
|     ip_address = NetLib.ogGetIpAddress()
 | |
|     logFilePath = f"{opengnsys_log_dir}/{ip_address}.log"
 | |
| 
 | |
|     ogLog = OgLogger()
 | |
|     ogLog.setLevel(logging.DEBUG)
 | |
| 
 | |
|     fileLog = logging.FileHandler(logFilePath)
 | |
|     fileLog.setLevel(logging.DEBUG)
 | |
| 
 | |
|     formatter = logging.Formatter('%(asctime)s - %(name)24s - [%(levelname)5s] - %(message)s')
 | |
| 
 | |
|     fileLog.setFormatter(formatter)
 | |
| 
 | |
|     logger = logging.getLogger(__package__)
 | |
|     logger.setLevel(logging.DEBUG)
 | |
|     logger.addHandler(fileLog)
 | |
|     logger.addHandler(ogLog)
 | |
| 
 | |
| 
 | |
|     logger.info("Starting CrearImagenGit")
 | |
| 
 | |
| 
 | |
|     retval = create_image(disk_num, partition_num, repo, image_name)
 | |
| 
 | |
| 
 | |
| 
 | |
|     sys.exit(retval)
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     main()
 |