On 13.07.2009 19:51 Uhr, Juha Heinanen wrote:
> Daniel-Constantin Mierla writes:
>
> > here is what mi_rpc modules does:
> > - it receives a rpc handler form the rpc interface in core
> > - reads first parameter and then lookups MI command, if not found then
> > returns error, if found:
> > - reads all parameters as string and build internal MI tree
>
> ok, after andrei fixed some bug, i got stats working via mi_rpc and
> xmlrpc module interface.
>
> all stats except "tm:", which is now implemented using tm.stats command.
>
> res = c.tm.stats()
>
> provides this kind of result:
>
> {'2xx': 0, 'created': 0, '5xx': 0, 'delayed_free': 0, 'current': 0, 'total_local': 0, 'waiting': 0, '6xx': 0, '4xx': 0, '3xx': 0, 'total': 0, 'replied_locally': 0, 'freed': 0}
>
> whereas mi based stat results look like this:
>
> ['200 OK\n', '+ :: core:rcv_requests = 3', '+ :: core:rcv_replies = 0', '+ :: core:fwd_requests = 0', '+ :: core:fwd_replies = 0', '+ :: core:drop_requests = 0', '+ :: core:drop_replies = 0', '+ :: core:err_requests = 0', '+ :: core:err_replies = 0', '+ :: core:bad_URIs_rcvd = 0', '+ :: core:unsupported_methods = 3', '+ :: core:bad_msg_hdr = 0']
>
> would it be possible to get the result in same (preferable the former)
> format in both cases?
>
you can try implementing a new command in the mi_rpc modulem say 'mix'
(mi for xmlrpc) that will format the output as you want.
However would be good to get a single command, but I do not know if is
possible considering that MI reply trees have:
- name for nodes
- values for nodes - string or other nodes
- attributes for nodes - string
IIRC, Andrei proposed to put the value of the attributes in the value of
the node. Now, the formating looks a bit strange, as I did it to
regocnize the above elements, so:
+ means that the printed line corresponds to a node
- means that the printed line corresponds to an attribute of the last
printed node
Within a node line:
- what is before '::' is the name of node
- what is after '::' is the value of node
- tab indentation is used to show the depth of nodes and attributes
All these are taken from mi_fifo.
So, in case of statistics, the nodes have no name and the value has the
format "stat = value". I can say it is pretty weird, but it is the
current style with mi_fifo. As I am not a xmlrpc user, with mi_datagram
I did text parsing.
Cheers,
Daniel
Hi!
there are various TLS parameters in core:
tls_ca_list
tls_certificate
tls_handshake_timeout
tlslog
tls_method
tls_port_no
tls_private_key
tls_require_certificate
tls_send_timeout
tls_verify
Are they still needed? IIRC TLS is now configured by a separate config
file, thus it would make sense to remove them.
regards
klaus
i wrote in python a simple text that sends domain_reload command over s
xmlrpc interface to sr:
---------------------------------------------------------------
import xmlrpclib
XMLRPC_PROTOCOL = 'http'
XMLRPC_SERVER = '127.0.0.1'
XMLRPC_PORT = 6060
server_path = XMLRPC_PROTOCOL + '://' + XMLRPC_SERVER + \
':' + str(XMLRPC_PORT)
c = xmlrpclib.ServerProxy(server_path)
erg = c.domain_reload()
----------------------------------------------------------------
when i execute the program, ngrep immediately prints what one would
expect:
T 2009/07/04 17:20:02.455028 127.0.0.1:33418 -> 127.0.0.1:6060 [AP]
POST /RPC2 HTTP/1.0..Host: 127.0.0.1:6060..User-Agent: xmlrpclib.py/1.0.1 (
by www.pythonware.com)..Content-Type: text/xml..Content-Length: 107....
##
T 2009/07/04 17:20:02.455358 127.0.0.1:33418 -> 127.0.0.1:6060 [AP]
<?xml version='1.0'?>.<methodCall>.<methodName>domain_reload</methodName>.<
params>.</params>.</methodCall>.
##
T 2009/07/04 17:20:02.455718 127.0.0.1:6060 -> 127.0.0.1:33418 [AP]
HTTP/1.0 200 OK..Via: SIP/2.0/TCP 127.0.0.1:33418..Server: SIP Route
r (2.99.0-dev01-serk (i386/linux))..Content-Length: 274....<?xml version="1
.0"?>.<methodResponse>.<fault>.<value>.<struct>.<member>.<name>faultCode</n
ame>.<value><int>500</int></value>.</member>.<member>.<name>faultString</na
me>.<value><string>Method Not Found</string></value>.</member>.</struct>.</
value>.</fault>.</methodResponse>
however, python client program does not terminate until after more
than 2 minutes. then it finally prints:
Traceback (most recent call last):
File "sr-xmlrpc.py", line 15, in <module>
erg = c.domain_reload()
File "/usr/lib/python2.5/xmlrpclib.py", line 1147, in __call__
return self.__send(self.__name, args)
File "/usr/lib/python2.5/xmlrpclib.py", line 1437, in __request
verbose=self.__verbose
File "/usr/lib/python2.5/xmlrpclib.py", line 1201, in request
return self._parse_response(h.getfile(), sock)
File "/usr/lib/python2.5/xmlrpclib.py", line 1340, in _parse_response
return u.close()
File "/usr/lib/python2.5/xmlrpclib.py", line 787, in close
raise Fault(**self._stack[0])
xmlrpclib.Fault: <Fault 500: 'Method Not Found'>
i also tested with a php xmlrcp client with same result.
any idea why it takes so long and why parsing of response fails? is
something missing from the response?
-- juha
andrei 2009/07/14 09:40:17 CEST
SER CVS Repository
Modified files:
parser msg_parser.c
Log:
core: parse_headers flags fix
Restore original flags after parse_headers was called with "next"
(without restoring them, if parse_headers doesn't find again all
the requested headers it will leave their flags cleared although
they might be present in the message).
Revision Changes Path
1.62 +8 -3 sip_router/parser/msg_parser.c
http://cvs.berlios.de/cgi-bin/viewcvs.cgi/ser/sip_router/parser/msg_parser.…
andrei 2009/07/14 09:36:51 CEST
SER CVS Repository
Modified files:
modules/presence_b2b euac_funcs.c
Log:
presence_b2b: fix from & to header access
Access the parsed part of a From or To header only if non-zero
and/or parse_from_header() returned success.
Revision Changes Path
1.16 +4 -2 sip_router/modules/presence_b2b/euac_funcs.c
http://cvs.berlios.de/cgi-bin/viewcvs.cgi/ser/sip_router/modules/presence_b…
andrei 2009/07/14 09:36:20 CEST
SER CVS Repository
Modified files:
modules/rr loose.c
Log:
rr: fix from header access
get_from() can be used _only_ if parse_from_header() returned
success or if msg->from!=0.
Revision Changes Path
1.53 +3 -3 sip_router/modules/rr/loose.c
http://cvs.berlios.de/cgi-bin/viewcvs.cgi/ser/sip_router/modules/rr/loose.c…