관리-도구
편집 파일: extensions.py
# -*- coding: utf-8 -*- # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2019 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENSE.TXT from __future__ import print_function from __future__ import division from __future__ import absolute_import import glob import os import re from future.moves import configparser as ConfigParser from future.moves.configparser import SafeConfigParser from clselect.utils import check_output from clselect.utils import file_writelines, file_readlines EXTENSION_PATTERN = re.compile('^(?P<name>.+) \((?P<version>.+)\)$', re.MULTILINE) CACHE = '/var/lve/rubygems' CACHE_BINARY = '/usr/share/l.v.e-manager/utils/cache_rubygems.py' class ExtensionInfo(object): url = 'http://rubygems.org/gems' def __init__(self, gem=None): if gem: self.gem = gem else: self.gem = sorted(glob.glob('/opt/alt/ruby??/bin/gem'))[-1] def _list_gems(self): output = check_output(self.gem, 'list', '--remote') return EXTENSION_PATTERN.findall(output) def _list_gem_version(self, gem): output = check_output(self.gem, 'list', '^' + gem + '$', '--remote', '--all') versions = [version.split(',') for extension, version in EXTENSION_PATTERN.findall(output)] return sorted(list(set(version.strip().split(" ")[0] for version in versions[0]))) def list_extensions(self): extensions = [extension for extension, _ in self._list_gems()] return ExtensionInfo.extensions_docs(extensions) def list_extensions_cached(self): if not os.path.isfile(CACHE): extensions = self.write_cache() else: extensions = [i.strip() for i in file_readlines(CACHE)] return ExtensionInfo.extensions_docs(extensions) def write_cache(self): extensions = [extension for extension, _ in self._list_gems()] try: file_writelines(CACHE, ['%s\n' % extension for extension in extensions], 'w') os.chmod(CACHE, 0o644) except IOError: pass return extensions def list_extensions_version(self, extensions): return dict((extension, {'versions': self._list_gem_version(extension)}) for extension in extensions) @staticmethod def delete_cache(): try: os.unlink(CACHE) except OSError: pass @staticmethod def extension_doc(extension): return str.join('/', (ExtensionInfo.url, extension)) @staticmethod def extensions_docs(extensions): docs = (ExtensionInfo.extension_doc(extension) for extension in extensions) return dict((extension, {'doc': doc}) for extension, doc in zip(extensions, docs)) @staticmethod def get_locked_extensions(interpreter): alt_ver = interpreter.replace('.','') file_path = os.path.join('/opt/alt', alt_ver ,'etc', 'locked_extensions.ini') if not os.path.exists(file_path): file_path = os.path.join(os.path.dirname(__file__), '..', 'locked_extensions.ini') parser = SafeConfigParser(interpolation=None, strict=False) parser.read(file_path) try: items = parser.items(interpreter) except ConfigParser.NoSectionError: items = () return dict((extension, [v.strip() for v in versions.split(',') if v]) for extension, versions in items) @staticmethod def is_extensions_locked(locked_extensions, extension, version): return (extension in locked_extensions and ( list(set([v.strip() for v in version.split(',') if len(version) > 0]) & set(locked_extensions.get(extension))) or len(locked_extensions.get(extension)) == 0 ))