Server IP : 103.119.228.120 / Your IP : 18.227.209.101 Web Server : Apache System : Linux v8.techscape8.com 3.10.0-1160.119.1.el7.tuxcare.els2.x86_64 #1 SMP Mon Jul 15 12:09:18 UTC 2024 x86_64 User : nobody ( 99) PHP Version : 5.6.40 Disable Function : shell_exec,symlink,system,exec,proc_get_status,proc_nice,proc_terminate,define_syslog_variables,syslog,openlog,closelog,escapeshellcmd,passthru,ocinum cols,ini_alter,leak,listen,chgrp,apache_note,apache_setenv,debugger_on,debugger_off,ftp_exec,dl,dll,myshellexec,proc_open,socket_bind,proc_close,escapeshellarg,parse_ini_filepopen,fpassthru,exec,passthru,escapeshellarg,escapeshellcmd,proc_close,proc_open,ini_alter,popen,show_source,proc_nice,proc_terminate,proc_get_status,proc_close,pfsockopen,leak,apache_child_terminate,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,dl,symlink,shell_exec,system,dl,passthru,escapeshellarg,escapeshellcmd,myshellexec,c99_buff_prepare,c99_sess_put,fpassthru,getdisfunc,fx29exec,fx29exec2,is_windows,disp_freespace,fx29sh_getupdate,fx29_buff_prepare,fx29_sess_put,fx29shexit,fx29fsearch,fx29ftpbrutecheck,fx29sh_tools,fx29sh_about,milw0rm,imagez,sh_name,myshellexec,checkproxyhost,dosyayicek,c99_buff_prepare,c99_sess_put,c99getsource,c99sh_getupdate,c99fsearch,c99shexit,view_perms,posix_getpwuid,posix_getgrgid,posix_kill,parse_perms,parsesort,view_perms_color,set_encoder_input,ls_setcheckboxall,ls_reverse_all,rsg_read,rsg_glob,selfURL,dispsecinfo,unix2DosTime,addFile,system,get_users,view_size,DirFiles,DirFilesWide,DirPrintHTMLHeaders,GetFilesTotal,GetTitles,GetTimeTotal,GetMatchesCount,GetFileMatchesCount,GetResultFiles,fs_copy_dir,fs_copy_obj,fs_move_dir,fs_move_obj,fs_rmdir,SearchText,getmicrotime MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /lib/python2.7/site-packages/javapackages/ |
Upload File : |
#!/usr/bin/python # Copyright (c) 2013, Red Hat, Inc # All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # # 1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the # distribution. # 3. Neither the name of Red Hat nor the names of its # contributors may be used to endorse or promote products derived # from this software without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # # Authors: Stanislav Ochotnicky <sochotnicky@redhat.com> import gzip import os.path from lxml.etree import fromstring from javapackages.artifact import Artifact class DepmapLoadingException(Exception): pass class DepmapInvalidException(Exception): pass class Depmap(object): """ Class for working with depmap files (dependency maps). These are files used by XMvn to provide mapping between Maven artifacts and file on the filesystem. Example usage: >>> d = Depmap('maven-idea-plugin.xml') >>> print d.get_java_requires() 1.5 >>> print d.get_provided_artifacts()[0] org.apache.maven.plugins:maven-idea-plugin:None:None:2.2 """ def __init__(self, path): self.__path = path self.__load_depmap(path) if self.__doc is None: raise DepmapLoadingException("Failed to load fragment {path} You have a problem".format(path=path)) if not self.get_provided_mappings(): raise DepmapLoadingException("Depmap {path} does not contain any provided artifacts ".format(path=path)) def __load_depmap(self, fragment_path): with open(fragment_path) as f: try: gzf = gzip.GzipFile(os.path.basename(fragment_path), 'rb', fileobj=f) data = gzf.read() except IOError: # not a compressed fragment, just rewind and read the data f.seek(0) data = f.read() self.__doc = fromstring(data) def is_compat(self): """Return true if depmap is for compatibility package This means package should have versioned provides""" provided_maps = self.get_provided_mappings() for m, l in provided_maps: if l.version: return True return self.__doc.find(".//skipProvides") is not None def get_provided_artifacts(self): """Returns list of Artifact provided by given depmap.""" artifacts = [] for dep in self.__doc.findall('.//dependency'): artifact = dep.findall('./maven') if len(artifact) != 1: raise DepmapInvalidException("Multiple maven nodes in dependency") artifact = Artifact.from_xml_element(artifact[0]) if not artifact.version: raise DepmapInvalidException("Depmap {path} does not have version in maven provides".format(path=self.__path)) artifacts.append(artifact) return artifacts def get_provided_mappings(self): """Return list of (Artifact, Artifact) tuples. First part of returned tuple is Maven artifact identification Second part of returned tuple is local artifact identification """ mappings = [] for dep in self.__doc.findall('.//dependency'): m_artifact = dep.findall('./maven') if len(m_artifact) != 1: raise DepmapInvalidException("Multiple maven nodes in dependency") m_artifact = Artifact.from_xml_element(m_artifact[0]) if not m_artifact.version: raise DepmapInvalidException("Depmap {path} does not have version in maven provides".format(path=self.__path)) l_artifact = dep.findall('./jpp') if len(l_artifact) != 1: raise DepmapInvalidException("Multiple jpp nodes in dependency") l_artifact = Artifact.from_xml_element(l_artifact[0]) mappings.append((m_artifact, l_artifact)) return mappings def get_required_artifacts(self): """Returns list of Artifact required by given depmap.""" artifacts = [] for dep in self.__doc.findall('.//autoRequires'): artifact = Artifact.from_xml_element(dep) artifacts.append(artifact) return artifacts def get_skipped_artifacts(self): """Returns list of Artifact that were build but not installed""" artifacts = [] for dep in self.__doc.findall('.//skippedArtifact'): artifact = Artifact.from_xml_element(dep) artifacts.append(artifact) return artifacts def get_java_requires(self): """Returns JVM version required by depmap or None""" jreq = self.__doc.find('.//requiresJava') if jreq is not None: jreq = jreq.text return jreq def get_java_devel_requires(self): """Returns JVM development version required by depmap or None""" jreq = self.__doc.find('.//requiresJavaDevel') if jreq is not None: jreq = jreq.text return jreq