TS-2555 add global plugin support for ts_lua plugin

Project: http://git-wip-us.apache.org/repos/asf/trafficserver/repo
Commit: http://git-wip-us.apache.org/repos/asf/trafficserver/commit/904e1f7c
Tree: http://git-wip-us.apache.org/repos/asf/trafficserver/tree/904e1f7c
Diff: http://git-wip-us.apache.org/repos/asf/trafficserver/diff/904e1f7c

Branch: refs/heads/5.0.x
Commit: 904e1f7c2995dbb4a8afea7cd99e32f0fd844f46
Parents: 9f509d4
Author: Kit Chan <[email protected]>
Authored: Tue Apr 15 22:30:01 2014 -0700
Committer: Kit Chan <[email protected]>
Committed: Tue Apr 15 22:30:01 2014 -0700

----------------------------------------------------------------------
 plugins/experimental/ts_lua/ts_lua.c        | 155 ++++++++++++++++++++++-
 plugins/experimental/ts_lua/ts_lua_common.h |   8 ++
 plugins/experimental/ts_lua/ts_lua_util.c   |   9 ++
 3 files changed, 170 insertions(+), 2 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/trafficserver/blob/904e1f7c/plugins/experimental/ts_lua/ts_lua.c
----------------------------------------------------------------------
diff --git a/plugins/experimental/ts_lua/ts_lua.c 
b/plugins/experimental/ts_lua/ts_lua.c
index ca78665..32cb58c 100644
--- a/plugins/experimental/ts_lua/ts_lua.c
+++ b/plugins/experimental/ts_lua/ts_lua.c
@@ -26,9 +26,10 @@
 #define TS_LUA_MAX_STATE_COUNT                  2048
 
 static volatile int32_t ts_lua_http_next_id = 0;
+static volatile int32_t ts_lua_g_http_next_id = 0;
 
 ts_lua_main_ctx         *ts_lua_main_ctx_array;
-
+ts_lua_main_ctx         *ts_lua_g_main_ctx_array;
 
 TSReturnCode
 TSRemapInit(TSRemapInterface *api_info, char * errbuf ATS_UNUSED , int 
errbuf_size ATS_UNUSED )
@@ -119,7 +120,7 @@ TSRemapDoRemap(void* ih, TSHttpTxn rh, TSRemapRequestInfo 
*rri)
     http_ctx->client_request_bufp = rri->requestBufp;
     http_ctx->client_request_hdrp = rri->requestHdrp;
     http_ctx->client_request_url = rri->requestUrl;
-
+    http_ctx->remap = 1;
     l = http_ctx->lua;
 
     lua_getglobal(l, TS_LUA_FUNCTION_REMAP);
@@ -146,3 +147,153 @@ TSRemapDoRemap(void* ih, TSHttpTxn rh, TSRemapRequestInfo 
*rri)
     return ret;
 }
 
+static int
+globalHookHandler(TSCont contp, TSEvent event, void *edata) {
+  TSHttpTxn txnp = (TSHttpTxn) edata;
+
+  int ret = 0;
+  int64_t req_id;
+
+  lua_State *l;
+  TSCont txn_contp;
+
+  ts_lua_main_ctx     *main_ctx;
+  ts_lua_http_ctx     *http_ctx;
+
+  ts_lua_instance_conf *conf = (ts_lua_instance_conf *)TSContDataGet(contp);
+
+  req_id = (int64_t) ts_lua_atomic_increment((&ts_lua_g_http_next_id), 1);
+  main_ctx = &ts_lua_g_main_ctx_array[req_id%TS_LUA_MAX_STATE_COUNT];
+
+  TSMutexLock(main_ctx->mutexp);
+
+  http_ctx = ts_lua_create_http_ctx(main_ctx, conf);
+  http_ctx->txnp = txnp;
+  http_ctx->remap = 0;
+
+  TSMBuffer bufp;
+  TSMLoc hdr_loc;
+  TSMLoc url_loc;
+
+  if(TSHttpTxnClientReqGet(txnp, &bufp, &hdr_loc) == TS_SUCCESS) {
+    http_ctx->client_request_bufp = bufp;
+    http_ctx->client_request_hdrp = hdr_loc;
+    if (TSHttpHdrUrlGet(bufp, hdr_loc, &url_loc) == TS_SUCCESS) {
+      http_ctx->client_request_url = url_loc;
+    }
+  }
+
+  if(!http_ctx->client_request_hdrp) {
+    TSMutexUnlock(main_ctx->mutexp);
+    TSHttpTxnReenable(txnp,TS_EVENT_HTTP_CONTINUE);
+    return 0;
+  }
+ 
+  l = http_ctx->lua;
+
+  switch (event) {
+  case TS_EVENT_HTTP_READ_REQUEST_HDR:
+    lua_getglobal(l, TS_LUA_FUNCTION_G_READ_REQUEST);
+    break;
+
+  case TS_EVENT_HTTP_SEND_REQUEST_HDR:
+    lua_getglobal(l, TS_LUA_FUNCTION_G_SEND_REQUEST);
+    break;
+
+  case TS_EVENT_HTTP_READ_RESPONSE_HDR:
+    lua_getglobal(l, TS_LUA_FUNCTION_G_READ_RESPONSE);
+    break;
+
+  case TS_EVENT_HTTP_SEND_RESPONSE_HDR:
+    lua_getglobal(l, TS_LUA_FUNCTION_G_SEND_RESPONSE);
+    break;
+
+  case TS_EVENT_HTTP_CACHE_LOOKUP_COMPLETE:
+    lua_getglobal(l, TS_LUA_FUNCTION_G_CACHE_LOOKUP_COMPLETE);
+    break;
+
+  default:
+    TSMutexUnlock(main_ctx->mutexp);
+    TSHttpTxnReenable(txnp, TS_EVENT_HTTP_CONTINUE);
+    return 0;
+    break;
+  }
+
+  if (lua_type(l, -1) != LUA_TFUNCTION) {
+      TSMutexUnlock(main_ctx->mutexp);
+      TSHttpTxnReenable(txnp, TS_EVENT_HTTP_CONTINUE);
+      return 0;
+  }
+
+  txn_contp = TSContCreate(ts_lua_http_cont_handler, NULL);
+  TSContDataSet(txn_contp, http_ctx);
+  http_ctx->main_contp = txn_contp;
+
+  if (lua_pcall(l, 0, 1, 0) != 0) {
+      fprintf(stderr, "lua_pcall failed: %s\n", lua_tostring(l, -1));
+  }
+
+  ret = lua_tointeger(l, -1);
+  lua_pop(l, 1);
+
+  TSHttpTxnHookAdd(txnp, TS_HTTP_TXN_CLOSE_HOOK, txn_contp);
+
+  TSMutexUnlock(main_ctx->mutexp);
+
+  TSHttpTxnReenable(txnp, TS_EVENT_HTTP_CONTINUE);
+  return ret;
+}
+
+void
+TSPluginInit(int argc, const char *argv[]) {
+    int ret = 0;
+    ts_lua_g_main_ctx_array = TSmalloc(sizeof(ts_lua_main_ctx) * 
TS_LUA_MAX_STATE_COUNT);
+    memset(ts_lua_g_main_ctx_array, 0, sizeof(ts_lua_main_ctx) * 
TS_LUA_MAX_STATE_COUNT);
+    
+    ret = ts_lua_create_vm(ts_lua_g_main_ctx_array, TS_LUA_MAX_STATE_COUNT);
+    
+    if (ret) {
+      ts_lua_destroy_vm(ts_lua_g_main_ctx_array, TS_LUA_MAX_STATE_COUNT);
+      TSfree(ts_lua_g_main_ctx_array);
+      return;
+    }
+    
+    if (argc < 2) {
+      TSError("[%s] lua script file required !!", __FUNCTION__);
+      return;
+    }
+    
+    if (strlen(argv[1]) >= TS_LUA_MAX_SCRIPT_FNAME_LENGTH - 16) {
+      TSError("[%s] lua script file name too long !!", __FUNCTION__);
+      return;
+    }
+    
+    ts_lua_instance_conf *conf = TSmalloc(sizeof(ts_lua_instance_conf));
+    if (!conf) {
+      TSError("[%s] TSmalloc failed !!", __FUNCTION__);
+      return;
+    }
+    
+    sprintf(conf->script, "%s", argv[1]);
+    
+    ret = ts_lua_add_module(conf, ts_lua_g_main_ctx_array, 
TS_LUA_MAX_STATE_COUNT, argc-1, (char**)&argv[1]);
+    
+    if (ret != 0) {
+      TSError("[%s] ts_lua_add_module failed", __FUNCTION__);
+      return;
+    }
+
+    TSCont global_contp = TSContCreate(globalHookHandler, NULL);
+    if (!global_contp) {
+      TSError("[%s] Could not create global continuation", __FUNCTION__);
+      return;
+    }
+    TSContDataSet(global_contp, conf);
+
+    TSHttpHookAdd(TS_HTTP_READ_REQUEST_HDR_HOOK, global_contp);
+    TSHttpHookAdd(TS_HTTP_SEND_REQUEST_HDR_HOOK, global_contp);
+    TSHttpHookAdd(TS_HTTP_READ_RESPONSE_HDR_HOOK, global_contp);
+    TSHttpHookAdd(TS_HTTP_SEND_RESPONSE_HDR_HOOK, global_contp);
+    TSHttpHookAdd(TS_HTTP_CACHE_LOOKUP_COMPLETE_HOOK, global_contp);
+ 
+}

http://git-wip-us.apache.org/repos/asf/trafficserver/blob/904e1f7c/plugins/experimental/ts_lua/ts_lua_common.h
----------------------------------------------------------------------
diff --git a/plugins/experimental/ts_lua/ts_lua_common.h 
b/plugins/experimental/ts_lua/ts_lua_common.h
index 66ba35e..4c84e3f 100644
--- a/plugins/experimental/ts_lua/ts_lua_common.h
+++ b/plugins/experimental/ts_lua/ts_lua_common.h
@@ -41,6 +41,12 @@
 #define TS_LUA_FUNCTION_READ_RESPONSE           "do_read_response"
 #define TS_LUA_FUNCTION_SEND_RESPONSE           "do_send_response"
 
+#define TS_LUA_FUNCTION_G_SEND_REQUEST "do_global_send_request"
+#define TS_LUA_FUNCTION_G_READ_REQUEST "do_global_read_request"
+#define TS_LUA_FUNCTION_G_SEND_RESPONSE "do_global_send_response"
+#define TS_LUA_FUNCTION_G_READ_RESPONSE "do_global_read_response"
+#define TS_LUA_FUNCTION_G_CACHE_LOOKUP_COMPLETE 
"do_global_cache_lookup_complete"
+
 #define TS_LUA_MAX_SCRIPT_FNAME_LENGTH      1024
 #define TS_LUA_MAX_URL_LENGTH               2048
 
@@ -85,6 +91,8 @@ typedef struct {
     int         intercept_type;
     int         ref;
 
+    int         remap;
+
 } ts_lua_http_ctx;
 
 

http://git-wip-us.apache.org/repos/asf/trafficserver/blob/904e1f7c/plugins/experimental/ts_lua/ts_lua_util.c
----------------------------------------------------------------------
diff --git a/plugins/experimental/ts_lua/ts_lua_util.c 
b/plugins/experimental/ts_lua/ts_lua_util.c
index ea20fa9..81231ee 100644
--- a/plugins/experimental/ts_lua/ts_lua_util.c
+++ b/plugins/experimental/ts_lua/ts_lua_util.c
@@ -280,6 +280,15 @@ ts_lua_destroy_http_ctx(ts_lua_http_ctx* http_ctx)
 
     main_ctx = http_ctx->mctx;
 
+    if(!http_ctx->remap) {
+      if(http_ctx->client_request_bufp) {
+        if(http_ctx->client_request_url) {
+          TSHandleMLocRelease(http_ctx->client_request_bufp, 
http_ctx->client_request_hdrp, http_ctx->client_request_url);
+        } 
+        TSHandleMLocRelease(http_ctx->client_request_bufp, TS_NULL_MLOC, 
http_ctx->client_request_hdrp);
+      }
+    } 
+
     if (http_ctx->server_request_bufp) {
         TSHandleMLocRelease(http_ctx->server_request_bufp, TS_NULL_MLOC, 
http_ctx->server_request_hdrp);
     }

Reply via email to