forked from cory/tildefriends
Move last remnant of static file handling from core to C.
This commit is contained in:
parent
9f71ec6194
commit
24cec21465
32
core/core.js
32
core/core.js
@ -8,10 +8,6 @@ let gStatsTimer = false;
|
|||||||
const k_content_security_policy =
|
const k_content_security_policy =
|
||||||
'sandbox allow-downloads allow-top-navigation-by-user-activation';
|
'sandbox allow-downloads allow-top-navigation-by-user-activation';
|
||||||
|
|
||||||
let k_static_files = [
|
|
||||||
{uri: '/', path: 'index.html', type: 'text/html; charset=UTF-8'},
|
|
||||||
];
|
|
||||||
|
|
||||||
const k_global_settings = {
|
const k_global_settings = {
|
||||||
index: {
|
index: {
|
||||||
type: 'string',
|
type: 'string',
|
||||||
@ -918,34 +914,6 @@ async function useAppHandler(
|
|||||||
* @returns
|
* @returns
|
||||||
*/
|
*/
|
||||||
async function blobHandler(request, response, blobId, uri) {
|
async function blobHandler(request, response, blobId, uri) {
|
||||||
// TODO(tasiaiso): break this down ?
|
|
||||||
for (let i in k_static_files) {
|
|
||||||
if (uri === k_static_files[i].uri && k_static_files[i].path) {
|
|
||||||
let stat = await File.stat('core/' + k_static_files[i].path);
|
|
||||||
let id = `${stat.mtime}_${stat.size}`;
|
|
||||||
|
|
||||||
if (request.headers['if-none-match'] === '"' + id + '"') {
|
|
||||||
response.writeHead(304, {'Content-Length': '0'});
|
|
||||||
response.end();
|
|
||||||
} else {
|
|
||||||
let data = await File.readFile('core/' + k_static_files[i].path);
|
|
||||||
response.writeHead(
|
|
||||||
200,
|
|
||||||
Object.assign(
|
|
||||||
{
|
|
||||||
'Content-Type': k_static_files[i].type,
|
|
||||||
'Content-Length': data.byteLength,
|
|
||||||
etag: '"' + id + '"',
|
|
||||||
},
|
|
||||||
k_static_files[i].headers || {}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
response.end(data);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!uri) {
|
if (!uri) {
|
||||||
response.writeHead(303, {
|
response.writeHead(303, {
|
||||||
Location:
|
Location:
|
||||||
|
@ -905,14 +905,23 @@ static void _httpd_endpoint_static(tf_http_request_t* request)
|
|||||||
const char* file_path = NULL;
|
const char* file_path = NULL;
|
||||||
for (int i = 0; i < tf_countof(k_map) && !after; i++)
|
for (int i = 0; i < tf_countof(k_map) && !after; i++)
|
||||||
{
|
{
|
||||||
after = _after(request->path, k_map[i][0]);
|
const char* next_after = _after(request->path, k_map[i][0]);
|
||||||
file_path = k_map[i][1];
|
if (next_after)
|
||||||
is_core = is_core || (after && i == 0);
|
{
|
||||||
|
after = next_after;
|
||||||
|
file_path = k_map[i][1];
|
||||||
|
is_core = after && i == 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strcmp(request->path, "/speedscope/") == 0)
|
if ((!after || !*after) && request->path[strlen(request->path) - 1] == '/')
|
||||||
{
|
{
|
||||||
after = "index.html";
|
after = "index.html";
|
||||||
|
if (!file_path)
|
||||||
|
{
|
||||||
|
file_path = "core/";
|
||||||
|
is_core = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!after || strstr(after, ".."))
|
if (!after || strstr(after, ".."))
|
||||||
@ -1668,6 +1677,7 @@ void tf_httpd_register(JSContext* context)
|
|||||||
tf_http_add_handler(http, "/speedscope/*", _httpd_endpoint_static, NULL, task);
|
tf_http_add_handler(http, "/speedscope/*", _httpd_endpoint_static, NULL, task);
|
||||||
tf_http_add_handler(http, "/static/*", _httpd_endpoint_static, NULL, task);
|
tf_http_add_handler(http, "/static/*", _httpd_endpoint_static, NULL, task);
|
||||||
tf_http_add_handler(http, "/.well-known/*", _httpd_endpoint_static, NULL, task);
|
tf_http_add_handler(http, "/.well-known/*", _httpd_endpoint_static, NULL, task);
|
||||||
|
tf_http_add_handler(http, "/~*/*/", _httpd_endpoint_static, NULL, task);
|
||||||
|
|
||||||
tf_http_add_handler(http, "/robots.txt", _httpd_endpoint_robots_txt, NULL, NULL);
|
tf_http_add_handler(http, "/robots.txt", _httpd_endpoint_robots_txt, NULL, NULL);
|
||||||
tf_http_add_handler(http, "/debug", _httpd_endpoint_debug, NULL, task);
|
tf_http_add_handler(http, "/debug", _httpd_endpoint_debug, NULL, task);
|
||||||
|
Loading…
Reference in New Issue
Block a user