[Koha-devel] Serving Intranet from a subpath

Thomas Klausner domm at plix.at
Fri Aug 12 12:54:59 CEST 2022


Hi!

(I'm sending this to koha-devel because I guess it's too technical for 
the general list?)

We are running running the "Intranet" inside an actual intranet (i.e. 
inside a VPN). But this Koha instance is also hosting a related Library 
whose staff cannot access the VPN. For various reasons it is not 
possible to mount Koha at it's own domain, so we must make it available 
at a sub-path (something like "https://www.example.com/foo/koha")

For the OPAC, I already implemented a hacky Plack Middleware that does 
some rather ugly rewriting or URLs and HTML (ughh..). While we could do 
the same for Intranet, I first wanted to check if it is maybe already 
possible to mount it under a subpath, i.e. have an Apache use something 
like 

ProxyPass /foo/koha/index.html   ...
ProxyPass /foo/koha/cgi-bin/koha ...

Now, while this actually works, the pages returned do not, as all the 
links they contain point to /cgi-bin/koha (i.e., they loose the mount 
point and generate bad links).

The usual way to solve this is via something like
https://metacpan.org/pod/Plack::Middleware::ReverseProxyPath

But for this work, two things (one small, one not) have to be changed:

* the plack app (i.e. Koha) needs to honor some HTTP Header ENV vars
  (X_FORWARDED_SCRIPT_NAME, X_TRAVERSAL_PATH)
* and all links generated by the app need to also honor those vars.

The usual way for the latter is to *not* generate links by concatenating 
path fragments or hardcoded them in templates (which seems to be what 
Koha is doing), but to use a function/method to generate all links (to 
html pages, static assets and endpoints)

So for example in a template like prog/en/modules/cataloguing/addbooks.tt
we find:
            <a href="/cgi-bin/koha/mainpage.pl">Home</a>

This would need to be changed to 

            <a href=uri_for("/cgi-bin/koha/mainpage.pl")>Home</a>

and uri_for needs to take a look at the ENV and fix the link 
accordingly.

(The ugly workaround I am using in an OPAC is to use a Middleware to 
change the HTML after it's generated by Koha but before it is send to 
the client. shudder...)

So on the one hand this seems to be a small change, but to work it needs 
to touch ALL templates. (and it will be hard to automatically identify 
all link-ish text in the templates (href, src, maybe sometimes the url 
is generated in a template, ...)

Another approach would be to set the mount-point into <base 
href="/foo/koha">
https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base
But we would still need to change all the links to relative links, as 
`base` will ignore absolute links, which is what Koha is using now.
though maybe the regex to replace the code is a bit easier 
(s{/cgi-bin}{cgi-bin}) as it does have to fiddle with quotes etc.


Our customer is willing to do the work to implement this (probably also 
in OPAC), but only if the change will be accepted upstream and be usable 
by the end of this year (i.e. 22.11).

Shall we try to tackle this? Or will this massive change never be 
accepted? If there is interest, I guess the next step is to open a 
bug...


Greetings,
domm



-- 
#!/usr/bin/perl                             https://domm.plix.at
for(ref bless{},just'another'perl'hacker){s-:+-$"-g&&print$_.$/}


More information about the Koha-devel mailing list