[ 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)