[
https://issues.apache.org/jira/browse/JSPWIKI-1188?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
ASF GitHub Bot updated JSPWIKI-1188:
------------------------------------
Labels: pull-request-available (was: )
> Support system property replacement for jsp wiki configuration properties
> -------------------------------------------------------------------------
>
> Key: JSPWIKI-1188
> URL: https://issues.apache.org/jira/browse/JSPWIKI-1188
> Project: JSPWiki
> Issue Type: Improvement
> Components: Core & storage
> Reporter: Alex O'Ree
> Priority: Major
> Labels: pull-request-available
>
> As a sysadmin/integrator/user of jspwiki, i would really like to automate as
> much as integration work as possible for my use case. This includes
> * generating markdown and attachments to "seed" or initialize the content
> for jsp wiki
> * task automating the deployment of jspwiki's war into tomcat
> * configuring jsp wiki via the properties file
> i also need to be able to run on multiple systems, platforms and containers.
> So that said, jspwiki's properties file has a few settings that require paths
> for storing content, such as
> * jspwiki.fileSystemProvider.pageDir
> * jspwiki.workDir
> * jspwiki.basicAttachmentProvider.storageDir
> When running in tomcat from the command line, the bin path is typically the
> current working directory, meaning relative paths are based on that path.
> However when ran as a windows or systemd service, sometimes the current
> working directory is not bin, it's up folder up. Anyhow, relative paths are a
> poor solution in this case.
> In my experience, since i know i'm running on tomcat, i almost always use the
> system property `catalina.base` for locating paths relative to tomcat for
> extra storage locations for stuff.
> Long story short, most systems support property substitution (maven uses
> velocity for example) and i'd like jspwiki to do the same.
> Example file (as stored)
> * jspwiki.fileSystemProvider.pageDir=${catalina.base}/wiki
> * jspwiki.workDir=${catalina.base}/work/wiki
> * jspwiki.basicAttachmentProvider.storageDir=${catalina.base}/wiki
> which would be resolved to something like
> * jspwiki.fileSystemProvider.pageDir=c:/tomcat/wiki
> * jspwiki.workDir=c:/tomcat/work/wiki
> * jspwiki.basicAttachmentProvider.storageDir=c:/tomcat/wiki
> where catalina.base = c:/tomcat. This would effectively enable relative paths
> with some safe guards.
>
> Now as far as implementation, i can think of a few options
> * a DIY, 0 dependency approach to location a ${ and a } in a property value
> to do the substitution
> * maybe use velocity to resolve it, assuming you want to add velocity to the
> dependency list for this project
> * maybe apache commons config might be a better option as they already merge
> system environment variables and system properties. but i'm not clear if it
> does property substitution out of the box
> i'm will to support either way
--
This message was sent by Atlassian Jira
(v8.20.10#820010)