Package com.illumon.iris.db.util.scripts
Class ScriptRepository
java.lang.Object
com.illumon.iris.db.util.scripts.ScriptRepository
- All Implemented Interfaces:
- ScriptPathLoader
A ScriptPathLoader that loads scripts from a git repository.
If this class is created with updateEnabled = false it loads scripts as if no git repository was present.
- 
Method SummaryModifier and TypeMethodDescriptionvoidclose()Free resources associated with this loader.Gets the display paths available from this loader when it was in the specifiedstate.Get the users allowed to access this repo, defined by the iris.scripts.repo.[name].users property.getName()Get the name of this repository defined by the iris.scripts.repos property.getScriptBodyByDisplayPath(String displayPath) Get the body of a script file via the display path.getScriptBodyByDisplayPath(String displayPath, ScriptPathLoaderState state) Get the specified script at the specified state.getScriptBodyByRelativePath(String relativePath) Get the body of a script file via the relative path.getScriptBodyByRelativePath(String relativePath, ScriptPathLoaderState state) Get the specified script at the specified state.getState()Get astateobject that represents the current branch HEAD commit.voidlock()Acquire a read lock.Create a stat object from the serialized JSON String provided byScriptPathLoaderState.encodeJSON()static List<ScriptRepository>readRepoConfigs(com.fishlib.configuration.Configuration config, String propertyPrefix, com.fishlib.io.logger.Logger log, boolean globalUpdateEnabled, boolean globalGcEnabled, String defaultBranch, boolean resetGitLockFiles) static List<ScriptRepository>readRepoConfigsForUser(com.fishlib.configuration.Configuration config, String propertyPrefix, com.fishlib.io.logger.Logger log, String userName) static List<ScriptRepository>readRepoConfigsForUser(com.fishlib.configuration.Configuration config, String propertyPrefix, com.fishlib.io.logger.Logger log, String userName, IrisGroupProvider groupProvider) voidrefresh()Refresh the loader internally.voidunlock()Release a previously acquired read lock.
- 
Method Details- 
getNameGet the name of this repository defined by the iris.scripts.repos property.- Returns:
- The name of this repo.
 
- 
getGroupNamesGet the users allowed to access this repo, defined by the iris.scripts.repo.[name].users property.- Returns:
- The names of all users allowed to access the repo.
 
- 
getStateGet astateobject that represents the current branch HEAD commit.- Specified by:
- getStatein interface- ScriptPathLoader
- Returns:
- The current branch HEAD or null if updates were disabled.
 
- 
makeStateDescription copied from interface:ScriptPathLoaderCreate a stat object from the serialized JSON String provided byScriptPathLoaderState.encodeJSON()- Specified by:
- makeStatein interface- ScriptPathLoader
- Parameters:
- stateJSON- the JSON state
- Returns:
- the deserialized object from the JSON state
 
- 
lockpublic void lock()Description copied from interface:ScriptPathLoaderAcquire a read lock. Use before invoking any of the get* methods, and hold for as long as consistency is required for this loader.- Specified by:
- lockin interface- ScriptPathLoader
 
- 
unlockpublic void unlock()Description copied from interface:ScriptPathLoaderRelease a previously acquired read lock.- Specified by:
- unlockin interface- ScriptPathLoader
 
- 
getAvailableScriptDisplayPaths- Specified by:
- getAvailableScriptDisplayPathsin interface- ScriptPathLoader
- Returns:
- The display paths currently available from this loader.
 
- 
getScriptBodyByDisplayPathGet the body of a script file via the display path.- Specified by:
- getScriptBodyByDisplayPathin interface- ScriptPathLoader
- Parameters:
- displayPath- The display path to load a script for.
- Returns:
- A String representing the body of the script.
- Throws:
- IOException- If the file is not accessible.
 
- 
getScriptBodyByRelativePathGet the body of a script file via the relative path.- Specified by:
- getScriptBodyByRelativePathin interface- ScriptPathLoader
- Parameters:
- relativePath- The relative path to load a script for.
- Returns:
- A String representing the body of the script
- Throws:
- IOException- If the file is not accessible
 
- 
getAvailableScriptDisplayPathsDescription copied from interface:ScriptPathLoaderGets the display paths available from this loader when it was in the specifiedstate.- Specified by:
- getAvailableScriptDisplayPathsin interface- ScriptPathLoader
- Parameters:
- state- The state of the loader to use when retrieving the list.
- Returns:
- A list of all display paths available when the loader was in the specified state.
- Throws:
- IOException- If a problem occurred loading the script.
 
- 
getScriptBodyByRelativePathpublic String getScriptBodyByRelativePath(String relativePath, ScriptPathLoaderState state) throws IOException Description copied from interface:ScriptPathLoaderGet the specified script at the specified state.- Specified by:
- getScriptBodyByRelativePathin interface- ScriptPathLoader
- Parameters:
- relativePath- The relative path to the script.
- state- The state of the loader.
- Returns:
- The script at relativePath at the specified state.
- Throws:
- IOException- If a problem occurred loading the script.
 
- 
getScriptBodyByDisplayPathpublic String getScriptBodyByDisplayPath(String displayPath, ScriptPathLoaderState state) throws IOException Description copied from interface:ScriptPathLoaderGet the specified script at the specified state.- Specified by:
- getScriptBodyByDisplayPathin interface- ScriptPathLoader
- Parameters:
- displayPath- The display path to the script.
- state- The state of the loader.
- Returns:
- The script at displayPath at the specified state.
- Throws:
- IOException- If a problem occurred loading the script.
 
- 
refreshpublic void refresh()Description copied from interface:ScriptPathLoaderRefresh the loader internally. Will respect existing read locks.- Specified by:
- refreshin interface- ScriptPathLoader
 
- 
closepublic void close()Description copied from interface:ScriptPathLoaderFree resources associated with this loader.- Specified by:
- closein interface- ScriptPathLoader
 
- 
readRepoConfigspublic static List<ScriptRepository> readRepoConfigs(@NotNull com.fishlib.configuration.Configuration config, @NotNull String propertyPrefix, @NotNull com.fishlib.io.logger.Logger log, boolean globalUpdateEnabled, boolean globalGcEnabled, @Nullable String defaultBranch, boolean resetGitLockFiles) 
- 
readRepoConfigsForUserpublic static List<ScriptRepository> readRepoConfigsForUser(@NotNull com.fishlib.configuration.Configuration config, @NotNull String propertyPrefix, @NotNull com.fishlib.io.logger.Logger log, @NotNull String userName, @NotNull IrisGroupProvider groupProvider) 
- 
readRepoConfigsForUserpublic static List<ScriptRepository> readRepoConfigsForUser(@NotNull com.fishlib.configuration.Configuration config, @NotNull String propertyPrefix, @NotNull com.fishlib.io.logger.Logger log, @NotNull String userName) 
 
-