summaryrefslogtreecommitdiffhomepage
path: root/src/nxt_php_sapi.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/nxt_php_sapi.c117
1 files changed, 71 insertions, 46 deletions
diff --git a/src/nxt_php_sapi.c b/src/nxt_php_sapi.c
index 425305a5..473b5447 100644
--- a/src/nxt_php_sapi.c
+++ b/src/nxt_php_sapi.c
@@ -122,7 +122,6 @@ typedef struct {
nxt_app_request_t r;
nxt_str_t script;
nxt_app_wmsg_t *wmsg;
- nxt_mp_t *mem_pool;
size_t body_preread_size;
} nxt_php_run_ctx_t;
@@ -137,15 +136,6 @@ static nxt_str_t nxt_php_root;
static nxt_str_t nxt_php_script;
static nxt_str_t nxt_php_index = nxt_string("index.php");
-static void
-nxt_php_strdup(nxt_str_t *dst, nxt_str_t *src)
-{
- dst->start = malloc(src->length + 1);
- nxt_memcpy(dst->start, src->start, src->length);
- dst->start[src->length] = '\0';
-
- dst->length = src->length;
-}
static void
nxt_php_str_trim_trail(nxt_str_t *str, u_char t)
@@ -183,15 +173,24 @@ NXT_EXPORT nxt_application_module_t nxt_app_module = {
};
+nxt_inline u_char *
+nxt_realpath(const void *c)
+{
+ return (u_char *) realpath(c, NULL);
+}
+
+
static nxt_int_t
nxt_php_init(nxt_task_t *task, nxt_common_app_conf_t *conf)
{
+ u_char *p;
+ nxt_str_t rpath;
nxt_str_t *root, *path, *script, *index;
nxt_php_app_conf_t *c;
c = &conf->u.php;
- if (c->root.length == 0) {
+ if (c->root == NULL) {
nxt_log_emerg(task->log, "php root is empty");
return NXT_ERROR;
}
@@ -201,30 +200,57 @@ nxt_php_init(nxt_task_t *task, nxt_common_app_conf_t *conf)
script = &nxt_php_script;
index = &nxt_php_index;
- nxt_php_strdup(root, &c->root);
+ root->start = nxt_realpath(c->root);
+ if (nxt_slow_path(root->start == NULL)) {
+ nxt_log_emerg(task->log, "root realpath(%s) failed %E",
+ c->root, nxt_errno);
+ return NXT_ERROR;
+ }
+
+ root->length = nxt_strlen(root->start);
nxt_php_str_trim_trail(root, '/');
if (c->script.length > 0) {
nxt_php_str_trim_lead(&c->script, '/');
- path->length = root->length + c->script.length + 1;
- path->start = malloc(path->length + 1);
+ path->length = root->length + 1 + c->script.length;
+ path->start = nxt_malloc(path->length);
+ if (nxt_slow_path(path->start == NULL)) {
+ return NXT_ERROR;
+ }
- nxt_memcpy(path->start, root->start, root->length);
- path->start[root->length] = '/';
+ p = nxt_cpymem(path->start, root->start, root->length);
+ *p++ = '/';
- nxt_memcpy(path->start + root->length + 1,
- c->script.start, c->script.length);
+ nxt_memcpy(p, c->script.start, c->script.length);
- path->start[path->length] = '\0';
+ rpath.start = nxt_realpath(path->start);
+ if (nxt_slow_path(rpath.start == NULL)) {
+ nxt_log_emerg(task->log, "script realpath(%V) failed %E",
+ path, nxt_errno);
+ return NXT_ERROR;
+ }
+ rpath.length = nxt_strlen(rpath.start);
+
+ if (!nxt_str_start(&rpath, root->start, root->length)) {
+ nxt_log_emerg(task->log, "script is not under php root");
+ return NXT_ERROR;
+ }
+
+ nxt_free(path->start);
+
+ *path = rpath;
script->length = c->script.length + 1;
- script->start = malloc(script->length + 1);
+ script->start = nxt_malloc(script->length);
+ if (nxt_slow_path(script->start == NULL)) {
+ return NXT_ERROR;
+ }
+
script->start[0] = '/';
nxt_memcpy(script->start + 1, c->script.start, c->script.length);
- script->start[script->length] = '\0';
nxt_log_error(NXT_LOG_INFO, task->log,
"(ABS_MODE) php script \"%V\" root: \"%V\"",
@@ -236,7 +262,13 @@ nxt_php_init(nxt_task_t *task, nxt_common_app_conf_t *conf)
}
if (c->index.length > 0) {
- nxt_php_strdup(index, &c->index);
+ index->length = c->index.length;
+ index->start = nxt_malloc(index->length);
+ if (nxt_slow_path(index->start == NULL)) {
+ return NXT_ERROR;
+ }
+
+ nxt_memcpy(index->start, c->index.start, c->index.length);
}
sapi_startup(&nxt_php_sapi_module);
@@ -299,24 +331,18 @@ nxt_php_read_request(nxt_task_t *task, nxt_app_rmsg_t *rmsg,
ctx->script.length = nxt_php_root.length + h->path.length +
script_name.length;
- ctx->script.start = nxt_mp_nget(ctx->mem_pool,
- ctx->script.length + 1);
-
- p = ctx->script.start;
-
- nxt_memcpy(p, nxt_php_root.start, nxt_php_root.length);
- p += nxt_php_root.length;
+ p = ctx->script.start = nxt_malloc(ctx->script.length);
+ if (nxt_slow_path(p == NULL)) {
+ return NXT_ERROR;
+ }
- nxt_memcpy(p, h->path.start, h->path.length);
- p += h->path.length;
+ p = nxt_cpymem(p, nxt_php_root.start, nxt_php_root.length);
+ p = nxt_cpymem(p, h->path.start, h->path.length);
if (script_name.length > 0) {
nxt_memcpy(p, script_name.start, script_name.length);
- p += script_name.length;
}
- p[0] = '\0';
-
} else {
ctx->script = nxt_php_path;
}
@@ -357,18 +383,12 @@ nxt_php_run(nxt_task_t *task,
nxt_php_run_ctx_t run_ctx;
nxt_app_request_header_t *h;
- if (nxt_php_root.length == 0) {
- return NXT_ERROR;
- }
-
nxt_memzero(&run_ctx, sizeof(run_ctx));
run_ctx.task = task;
run_ctx.rmsg = rmsg;
run_ctx.wmsg = wmsg;
- run_ctx.mem_pool = nxt_mp_create(1024, 128, 256, 32);
-
h = &run_ctx.r.header;
rc = nxt_php_read_request(task, rmsg, &run_ctx);
@@ -410,6 +430,7 @@ nxt_php_run(nxt_task_t *task,
if (nxt_slow_path(php_request_startup() == FAILURE)) {
nxt_debug(task, "php_request_startup() failed");
+ rc = NXT_ERROR;
goto fail;
}
@@ -418,15 +439,15 @@ nxt_php_run(nxt_task_t *task,
nxt_app_msg_flush(task, wmsg, 1);
- nxt_mp_destroy(run_ctx.mem_pool);
-
- return NXT_OK;
+ rc = NXT_OK;
fail:
- nxt_mp_destroy(run_ctx.mem_pool);
+ if (run_ctx.script.start != nxt_php_path.start) {
+ nxt_free(run_ctx.script.start);
+ }
- return NXT_ERROR;
+ return rc;
}
@@ -750,5 +771,9 @@ nxt_php_log_message(char *message
#endif
)
{
- return;
+ nxt_php_run_ctx_t *ctx;
+
+ ctx = SG(server_context);
+
+ nxt_log(ctx->task, NXT_LOG_NOTICE, "php message: %s", message);
}