aboutsummaryrefslogtreecommitdiff
path: root/server/src/net
diff options
context:
space:
mode:
authorJuan J. Martinez <jjm@usebox.net>2021-09-01 21:14:35 +0100
committerJuan J. Martinez <jjm@usebox.net>2021-09-01 21:14:35 +0100
commitcfbb8d48a22bd8c905b5e247c52a949d73c363be (patch)
tree9dd863be5d129cb1cc47731462963391b665196f /server/src/net
parent05b5bb6b77877cf8165d85560d5dec145a9369e1 (diff)
downloadspacebeans-cfbb8d48a22bd8c905b5e247c52a949d73c363be.tar.gz
spacebeans-cfbb8d48a22bd8c905b5e247c52a949d73c363be.zip
FIX: index file can be a CGI and should be executed
Diffstat (limited to 'server/src/net')
-rw-r--r--server/src/net/usebox/gemini/server/Response.scala2
-rw-r--r--server/src/net/usebox/gemini/server/Server.scala10
2 files changed, 9 insertions, 3 deletions
diff --git a/server/src/net/usebox/gemini/server/Response.scala b/server/src/net/usebox/gemini/server/Response.scala
index edb6cdc..1c2071f 100644
--- a/server/src/net/usebox/gemini/server/Response.scala
+++ b/server/src/net/usebox/gemini/server/Response.scala
@@ -115,6 +115,8 @@ case class Cgi(
"REMOTE_HOST" -> remoteAddr
).toSeq
+ logger.debug(s"CGI env: $env")
+
val (status: Int, meta: String, body: String) = {
val output = new java.io.ByteArrayOutputStream
Try {
diff --git a/server/src/net/usebox/gemini/server/Server.scala b/server/src/net/usebox/gemini/server/Server.scala
index f402191..a14d829 100644
--- a/server/src/net/usebox/gemini/server/Server.scala
+++ b/server/src/net/usebox/gemini/server/Server.scala
@@ -104,12 +104,16 @@ case class Server(conf: ServiceConf) {
.getDefault()
.getPath(root, path)
.normalize()
- val cgi = vhost.getCgi(resource)
+ val cgi = vhost
+ .getCgi(resource) match {
+ case None => vhost.getCgi(resource.resolve(vhost.indexFile))
+ case cgi => cgi
+ }
logger.debug(s"requesting: '$resource', cgi is '$cgi'")
resource.toFile() match {
- case file
+ case _
if cgi
.map(_.toFile())
.map(f => f.isFile() && f.canExecute())
@@ -120,7 +124,7 @@ case class Server(conf: ServiceConf) {
val queryString =
if (uri.getQuery() == null) "" else uri.getQuery()
val pathInfo =
- if (cgiFile.compareTo(resource) == 0) ""
+ if (cgiFile.compareTo(resource) >= 0) ""
else
"/" + resource
.subpath(