<div dir="ltr">Hi Paul,<div><br></div><div>We are using basically the same process as Seth and Steve mentioned.<br><div><br></div><div>We are building map files per environment and per node using Chef. Basically we parameterized the .map file and fill in parameters for every node when we deploy.</div><div>And because we have multiple map files for different topics we are actually building multiple map files per node per environment. (buildig map file from templates - header_template + layers + styles + end_template)</div><div>But instead of using Chef it could be done using scripts and replacing specific keywords with environment parameters.</div><div>This way web server won't have to do extra steps per request to change values</div><div><br></div><div>Example parts of our "template" header file:</div><div><br></div><div>NAME           "sim_<%= @mapname %>_<%=node.chef_environment%>"<br>  STATUS         ON<br>  EXTENT         <%= node['mapserver']['extent'] %><br>  FONTSET        "<%= node['mapserver']['deploy_to'] %>/fonts/current/fonts.list"<br>  IMAGETYPE      "png"<br>  CONFIG "MS_ERRORFILE" "<%=node['mapserver']['log_dir']%>/<%= @mapname %>.log"<br></div><div>.....</div><div>  WEB<br>      METADATA<br>        "wfs_title"                     "SiM <%= @mapname %> <%=node.chef_environment%>"<br>        "wfs_enable_request"            "*"<br>        "wfs_encoding"                  "UTF-8"<br>        "wms_title"                     "SiM <%= @mapname %> <%=node.chef_environment%>"<br>        "wms_encoding"                  "UTF-8"<br>        "wms_onlineresource"            "https://<%=node['mapserver']['proxy_url']%>/mapserv?map=/gis/<%= @mapname %>.map&"<br>        "wfs_onlineresource"            "https://<%=node['mapserver']['proxy_url']%>/mapserv?map=/gis/<%= @mapname %>.map&"</div><div>....</div><div><br></div><div>Kaido</div><div><br></div><div> </div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">Kontakt Seth G (<<a href="mailto:sethg@geographika.co.uk">sethg@geographika.co.uk</a>>) kirjutas kuupäeval K, 13. aprill 2022 kell 11:21:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><u></u><div><div>Hi Paul,<br></div><div><br></div><div>The runtime substitution and setting a querystring on the server is a good approach - have you found any drawbacks to this? Most web servers can set/add querystrings without any need for further software. <br></div><div><br></div><div>As Steve mentioned the alternative would be to generate Mapfiles for specific environments from a template.<br></div><div>I use mappyfile for this, with a Python script that can be run as part of continuous deployment:<br></div><div><br></div><div>import mappyfile<br></div><div>mapfile = mappyfile.open("original.map")<br></div><div># update the web metadata settings<br></div><div>mapfile["web"]["metadata"]["ows_onlineresource"] = "<a href="https://example.com/cgi-bin/mapserv?map=%7B%7D.map%22.format(%22test%22)" target="_blank">https://example.com/cgi-bin/mapserv?map={}.map".format("test")</a><br></div><div>mappyfile.save(mapfile, "new.map")<br></div><div></div><div><br></div><div>Typical other settings I'd change are connection strings, DEBUG level, and EXTENTs for different Mapfiles.<br></div><div><br></div><div>Seth<br></div><div><br></div><div id="gmail-m_-1301097164103082427sig62266145"><div>--<br></div><div>web:<a href="https://geographika.net" target="_blank">https://geographika.net</a><br></div><div>twitter: @geographika<br></div></div><div><br></div><div><br></div><div>On Wed, Apr 13, 2022, at 3:52 AM, Steve Lime wrote:<br></div><blockquote type="cite" id="gmail-m_-1301097164103082427qt"><div dir="ltr"><div>One other thing. One challenge with environment variables is knowing what's consistently available within a runtime environment - CGI is different from FastCGI and there are differences across web servers. That's one of the reasons pre-processing is kind of attractive IMHO. I suppose the v.8 config file could play a role but I'm unsure what that would be beyond a place to set values consistently.<br></div><div><br></div><div><div dir="ltr">On Tue, Apr 12, 2022 at 8:04 PM Steve Lime <<a href="mailto:sdlime@gmail.com" target="_blank">sdlime@gmail.com</a>> wrote:<br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div>Hi Paul: The idea of referencing environment variables has come up before. Another example would be to leverage settings injected into cloud deployments as environment variables (I think there's an old ticket that was recently re-opened on the topic). I'm not sure what the best way to handle this would be. One possibility would be using a mechanism similar to runtime subs where you'd reference the variables within the mapfile using ${variable} or whatever. Another idea would be to use a pre-processor of some sort to "compile" a mapfile from the environment. The latter would result in better performance since you'd generate the resulting file once and could also do things like inlining included snippets. This functionality would be helpful for the cloud deployments, simplifying deployments in multiple (dev, test, prod) environments and for keeping secrets out of repos altogether.<br></div><div><br></div><div>We're putzing around with the pre-processing idea a bit but haven't gotten anything fully baked. Others?<br></div><div><br></div><div>-Steve<br></div></div><div><br></div><div><div dir="ltr">On Tue, Apr 12, 2022 at 4:56 AM Paul via MapServer-users <<a href="mailto:mapserver-users@lists.osgeo.org" target="_blank">mapserver-users@lists.osgeo.org</a>> wrote:<br></div><blockquote style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><div style="font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px"><div dir="ltr">hi list, this has probably been discussed before, but maybe there are updates (on v8?)<br></div><div dir="ltr"><br></div><div dir="ltr">we would like to extract the <span><code>ows_onlineresource from the environment, instead of having an administrator to configure it on the mapfile</code></span><br></div><div dir="ltr"><br></div><div dir="ltr">currently we implement a hack where the webserver layer sends an additional query parameter `ows_url` to mapserver which contains the current url<br></div><div dir="ltr"><br></div><div dir="ltr">in the mapfile this is implemented as <br></div><div dir="ltr"><br></div><div dir="ltr">```<br></div><div dir="ltr"><div><pre lang="plaintext"><span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC1" lang="plaintext">WEB</span>
<span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC2" lang="plaintext">    VALIDATION</span>
<span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC3" lang="plaintext">      "ows_url" "(\b(https?|ftp|file)://)?[-A-Za-z0-9+&@#/%?=~_|!:,.;]+[-A-Za-z0-9+&@#/%=~_|]"</span>
<span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC4" lang="plaintext">    END</span>
<span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC5" lang="plaintext">    </span>
<span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC6" lang="plaintext">    METADATA</span>
<span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC7" lang="plaintext">      "ows_onlineresource"               "%ows_url%"</span>
<span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC8" lang="plaintext">    END</span>
<span id="gmail-m_-1301097164103082427qt-gmail-m_8906421840414282941gmail-m_-1578593230117342386ydpa2a2adfLC9" lang="plaintext">END</span><br></pre></div></div><div dir="ltr">```<br></div><div dir="ltr"><br></div><div dir="ltr">I wonder if others run into similar challenges, or if there are much more simple best practices for this case.<br></div><div dir="ltr"><br></div><div dir="ltr">I can imagine allowing a environment parameter 'proxy-url' like geoserver would make sense, but it should allow some kind of template, eg:<br></div><div dir="ltr"><br></div><div dir="ltr">```<br></div><div dir="ltr">PROXY-URL <a href="https://example.com/cgi-bin/mapserv?map=%7Bmap%7D.map" target="_blank">https://example.com/cgi-bin/mapserv?map={map}.map</a><br></div><div dir="ltr">```<br></div><div dir="ltr"><br></div><div dir="ltr">which in our case would be <br></div><div dir="ltr"><br></div><div dir="ltr"><div><div dir="ltr" style="color:rgb(0,0,0);font-family:"Helvetica Neue",Helvetica,Arial,sans-serif">```<br></div><div dir="ltr" style="color:rgb(0,0,0);font-family:"Helvetica Neue",Helvetica,Arial,sans-serif">PROXY-URL <a href="https://example.com/cgi-bin/%7Bmap%7D" target="_blank">https://example.com/cgi-bin/{map}</a><br></div><div dir="ltr" style="color:rgb(0,0,0);font-family:"Helvetica Neue",Helvetica,Arial,sans-serif">```<br></div></div><div><br></div></div><div dir="ltr">Thank you, Paul.<br></div></div></div><div>_______________________________________________<br></div><div> MapServer-users mailing list<br></div><div> <a href="mailto:MapServer-users@lists.osgeo.org" target="_blank">MapServer-users@lists.osgeo.org</a><br></div><div> <a href="https://lists.osgeo.org/mailman/listinfo/mapserver-users" rel="noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/mapserver-users</a><br></div></blockquote></div></blockquote></div></div><div>_______________________________________________<br></div><div>MapServer-users mailing list<br></div><div><a href="mailto:MapServer-users@lists.osgeo.org" target="_blank">MapServer-users@lists.osgeo.org</a><br></div><div><a href="https://lists.osgeo.org/mailman/listinfo/mapserver-users" target="_blank">https://lists.osgeo.org/mailman/listinfo/mapserver-users</a><br></div><div><br></div></blockquote><div><br></div></div>_______________________________________________<br>
MapServer-users mailing list<br>
<a href="mailto:MapServer-users@lists.osgeo.org" target="_blank">MapServer-users@lists.osgeo.org</a><br>
<a href="https://lists.osgeo.org/mailman/listinfo/mapserver-users" rel="noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/mapserver-users</a><br>
</blockquote></div>