|
@@ -43,41 +43,88 @@
|
|
|
*/
|
|
|
int parse_allow_header(struct hdr_field* _hf)
|
|
|
{
|
|
|
- unsigned int* methods;
|
|
|
-
|
|
|
+ struct allow_body* ab = 0;
|
|
|
+
|
|
|
if (!_hf) {
|
|
|
LOG(L_ERR, "parse_allow_header: Invalid parameter value\n");
|
|
|
return -1;
|
|
|
}
|
|
|
|
|
|
- /* maybe the header is already parsed! */
|
|
|
+ /* maybe the header is already parsed! */
|
|
|
if (_hf->parsed) {
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
- /* bad luck! :-( - we have to parse it */
|
|
|
- methods = pkg_malloc(sizeof(unsigned int));
|
|
|
- if (methods == 0) {
|
|
|
- LOG(L_ERR, "ERROR:parse_allow_header: Out of pkg_memory\n");
|
|
|
- return -1;
|
|
|
- }
|
|
|
+ ab = (struct allow_body*)pkg_malloc(sizeof(struct allow_body));
|
|
|
+ if (ab == 0) {
|
|
|
+ LOG(L_ERR, "ERROR:parse_allow_header: out of pkg_memory\n");
|
|
|
+ return -1;
|
|
|
+ }
|
|
|
+ memset(ab,'\0', sizeof(struct allow_body));
|
|
|
+
|
|
|
+ if (parse_methods(&(_hf->body), &(ab->allow)) !=0 ) {
|
|
|
+ LOG(L_ERR, "ERROR:parse_allow_header: bad allow body header\n");
|
|
|
+ goto error;
|
|
|
+ }
|
|
|
+
|
|
|
+ ab->allow_all = 0;
|
|
|
+ _hf->parsed = (void*)ab;
|
|
|
+ return 0;
|
|
|
+
|
|
|
+error:
|
|
|
+ if (ab) pkg_free(ab);
|
|
|
+ return -1;
|
|
|
+}
|
|
|
+
|
|
|
+/*!
|
|
|
+ * \brief This method is used to parse all Allow HF body.
|
|
|
+ * \param msg sip msg
|
|
|
+ * \return 0 on success,-1 on failure.
|
|
|
+ */
|
|
|
+int parse_allow(struct sip_msg *msg)
|
|
|
+{
|
|
|
+ unsigned int allow;
|
|
|
+ struct hdr_field *hdr;
|
|
|
+
|
|
|
+ /* maybe the header is already parsed! */
|
|
|
+ if (msg->allow && msg->allow->parsed) {
|
|
|
+ return 0;
|
|
|
+ }
|
|
|
|
|
|
- if (!parse_methods(&(_hf->body), methods)) {
|
|
|
- LOG(L_ERR, "ERROR:parse_allow_header: Bad allow header\n");
|
|
|
- pkg_free(methods);
|
|
|
+ /* parse to the end in order to get all ALLOW headers */
|
|
|
+ if (parse_headers(msg,HDR_EOH_F,0)==-1 || !msg->allow) {
|
|
|
return -1;
|
|
|
- }
|
|
|
+ }
|
|
|
+ allow = 0;
|
|
|
|
|
|
- _hf->parsed = methods;
|
|
|
- return 0;
|
|
|
+ for(hdr = msg->allow ; hdr ; hdr = next_sibling_hdr(hdr)) {
|
|
|
+ if (hdr->parsed == 0) {
|
|
|
+ if(parse_allow_header(hdr) < 0) {
|
|
|
+ return -1;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ allow |= ((struct allow_body*)hdr->parsed)->allow;
|
|
|
+ }
|
|
|
+
|
|
|
+ ((struct allow_body*)msg->allow->parsed)->allow_all = allow;
|
|
|
+ return 0;
|
|
|
}
|
|
|
|
|
|
|
|
|
/*
|
|
|
* Release memory
|
|
|
*/
|
|
|
-void free_allow(unsigned int** _methods)
|
|
|
+void free_allow_body(struct allow_body **ab)
|
|
|
+{
|
|
|
+ if (ab && *ab) {
|
|
|
+ pkg_free(*ab);
|
|
|
+ *ab = 0;
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+void free_allow_header(struct hdr_field* hf)
|
|
|
{
|
|
|
- if (_methods && *_methods) pkg_free(*_methods);
|
|
|
- *_methods = 0;
|
|
|
+ free_allow_body((struct allow_body**)(void*)(&(hf->parsed)));
|
|
|
}
|