$this->request = $req;
$this->response = $res;
$this->baseUrl = $baseUrl;
+ ob_start($res);
}
function esc($txt) {
private function serveCanonical($cnn) {
$this->response->setHeader("Location", $this->baseUrl->mod(["path" => $cnn]));
$this->response->setResponseCode(301);
+ $this->response->send();
}
/**
*/
private function serveStylesheet() {
$this->response->setHeader("Content-Type", "text/css");
- $this->esponse->setBody(new \http\Message\Body(fopen(ROOT."/public/index.css", "r")));
+ $this->response->setBody(new \http\Message\Body(fopen(ROOT."/public/index.css", "r")));
+ $this->response->send();
}
/**
private function serveJavascript() {
$this->response->setHeader("Content-Type", "application/javascript");
$this->response->setBody(new \http\Message\Body(fopen(ROOT."/public/index.js", "r")));
+ $this->response->send();
}
/**
* Serve a preset
* @param \stdClass $pld
+ * @return true to continue serving the payload
* @throws Exception
*/
private function servePreset($pld) {
case "LICENSE":
case "VERSION":
$pld->text = file_get_contents(ROOT."/$pld->ref");
- break;
+ return true;
case "index.css":
- $this->serveStylesheet($ctl);
+ $this->serveStylesheet();
break;
case "index.js":
- $this->serveJavascript($ctl);
+ $this->serveJavascript();
break;
default:
throw new Exception(404, "$pld->ref not found");
}
+ return false;
}
private function serve() {
extract((array) func_get_arg(0));
include ROOT."/views/layout.phtml";
+ $this->response->send();
}
public function handle() {
/* direct match */
$pld->entry = $repo->getEntry($pld->ref);
}
- } else {
- return $this->servePreset($pld);
+ } elseif (!$this->servePreset($pld)) {
+ return;
}
}