Warning
This document is for an in-development version of Galaxy. You can alternatively view this page in the latest release if it exists or view the top of the latest release's documentation.
galaxy.util.path package¶
Path manipulation functions.
- 
galaxy.util.path.safe_contains(prefix, path, whitelist=None, real=None)[source]¶
- Ensure a path is contained within another path. - Given any two filesystem paths, ensure that - pathis contained in- prefix. If- pathexists (either as an absolute path or relative to- prefix), it is canonicalized with- os.path.realpath()to ensure it is not a symbolic link that points outside of- prefix. If it is a symbolic link and- whitelistis set, the symbolic link may also point inside a- whitelistpath.- The - pathis checked against- whitelistusing either its absolute pathname (if passed in as absolute) or relative to- prefixand canonicalized (if applicable). It is not- os.path.join()``ed with each ``whitelistdirectory.- Parameters: - Return type: - Returns: - Trueif- pathis contained within- prefixor- whitelist,- Falseotherwise.
- 
galaxy.util.path.safe_makedirs(path)[source]¶
- Safely make a directory, do not fail if it already exists or is created during execution. - Parameters: - path (string) – a directory to create 
- 
galaxy.util.path.safe_relpath(path)[source]¶
- Determine whether a relative path references a path outside its root. - This is a path computation: the filesystem is not accessed to confirm the existence or nature of - path.- Parameters: - path (string) – a path to check - Return type: - bool - Returns: - Trueif path is relative and does not reference a path in a parent directory,- Falseotherwise.
- 
galaxy.util.path.safe_walk(path, whitelist=None)[source]¶
- Walk a path and return only the contents that are not symlinks outside the path. - Symbolic links are followed if a whitelist is provided. The path itself cannot be a symbolic link unless the pointed to location is in the whitelist. - Parameters: - path (string) – a directory to check for unsafe contents
- whitelist (list of strings) – list of additional paths under which contents may be located
 - Return type: - iterator - Returns: - Iterator of “safe” - os.walk()tuples found under- path
- 
galaxy.util.path.unsafe_walk(path, whitelist=None, username=None)[source]¶
- Walk a path and ensure that none of its contents are symlinks outside the path. - It is assumed that - pathitself has already been validated e.g. with- safe_relpath()or- safe_contains(). This function is most useful for the case where you want to test whether a directory contains safe paths, but do not want to actually walk the safe contents.- Parameters: - path (string) – a directory to check for unsafe contents
- whitelist (list of strings) – list of additional paths under which contents may be located
 - Return type: - list of strings - Returns: - A list of “bad” files found under - path
- 
galaxy.util.path.joinext(root, ext)[source]¶
- Roughly the reverse of os.path.splitext. - Parameters: - root (string) – part of the filename before the extension
- ext – the extension
 - Return type: - Returns: - rootjoined with- extseparated by a single- os.extsep
- 
galaxy.util.path.has_ext(path, ext, aliases=False, ignore=None)[source]¶
- Determine whether - pathhas extension- ext- Parameters: - Return type: - Returns: - Trueif path is a YAML file,- Falseotherwise.
- 
galaxy.util.path.get_ext(path, ignore=None, canonicalize=True)[source]¶
- Return the extension of - path- Parameters: - Return type: 
Submodules¶
galaxy.util.path.ntpath module¶
Galaxy “safe” path functions forced to work with Windows-style paths regardless of current platform
galaxy.util.path.posixpath module¶
Galaxy “safe” path functions forced to work with POSIX-style paths regardless of current platform