Parcourir la source

secsipid: added modparams to set url file cache options

Daniel-Constantin Mierla il y a 4 ans
Parent
commit
cac73df6e2
2 fichiers modifiés avec 17 ajouts et 10 suppressions
  1. 6 7
      src/modules/secsipid/libsecsipid.h
  2. 11 3
      src/modules/secsipid/secsipid_mod.c

+ 6 - 7
src/modules/secsipid/libsecsipid.h

@@ -70,20 +70,19 @@ extern "C" {
 
 
 // SecSIPIDSignJSONHP --
-
-extern int SecSIPIDSignJSONHP(char* p0, char* p1, char* p2, char** p3);
+extern int SecSIPIDSignJSONHP(char* headerJSON, char* payloadJSON, char* prvkeyPath, char** outPtr);
 
 // SecSIPIDGetIdentity --
-
-extern int SecSIPIDGetIdentity(char* p0, char* p1, char* p2, char* p3, char* p4, char* p5, char** p6);
+extern int SecSIPIDGetIdentity(char* origTN, char* destTN, char* attestVal, char* origID, char* x5uVal, char* prvkeyPath, char** outPtr);
 
 // SecSIPIDCheck --
-
-extern int SecSIPIDCheck(char* p0, int p1, int p2, char* p3, int p4);
+extern int SecSIPIDCheck(char* identityVal, int identityLen, int expireVal, char* pubkeyPath, int timeoutVal);
 
 // SecSIPIDCheckFull --
+extern int SecSIPIDCheckFull(char* identityVal, int identityLen, int expireVal, char* pubkeyPath, int timeoutVal);
 
-extern int SecSIPIDCheckFull(char* p0, int p1, int p2, char* p3, int p4);
+// SecSIPIDSetFileCacheOptions --
+extern int SecSIPIDSetFileCacheOptions(char* dirPath, int expireVal);
 
 #ifdef __cplusplus
 }

+ 11 - 3
src/modules/secsipid/secsipid_mod.c

@@ -38,6 +38,9 @@ MODULE_VERSION
 static int secsipid_expire = 300;
 static int secsipid_timeout = 5;
 
+static int secsipid_cache_expire = 3600;
+static str secsipid_cache_dir = str_init("");
+
 static int mod_init(void);
 static int child_init(int);
 static void mod_destroy(void);
@@ -57,8 +60,10 @@ static cmd_export_t cmds[]={
 };
 
 static param_export_t params[]={
-	{"expire",     PARAM_INT,   &secsipid_expire},
-	{"timeout",    PARAM_INT,   &secsipid_timeout},
+	{"expire",        PARAM_INT,   &secsipid_expire},
+	{"timeout",       PARAM_INT,   &secsipid_timeout},
+	{"cache_expire",  PARAM_INT,   &secsipid_cache_expire},
+	{"cache_dir",     PARAM_STR,   &secsipid_cache_dir},
 	{0, 0, 0}
 };
 
@@ -127,6 +132,9 @@ static int ki_secsipid_check_identity(sip_msg_t *msg, str *keypath)
 
 	ibody = hf->body;
 
+	if(secsipid_cache_dir.len > 0) {
+		SecSIPIDSetFileCacheOptions(secsipid_cache_dir.s, secsipid_cache_expire);
+	}
 	ret = SecSIPIDCheckFull(ibody.s, ibody.len, secsipid_expire, keypath->s,
 			secsipid_timeout);
 
@@ -281,4 +289,4 @@ int mod_register(char *path, int *dlflags, void *p1, void *p2)
 {
 	sr_kemi_modules_add(sr_kemi_secsipid_exports);
 	return 0;
-}
+}