summaryrefslogtreecommitdiffstats
path: root/doc/man_pages/idl2wrs.adoc
blob: 605f441a220bd52496c1726efd85bfa590377080 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
include::../attributes.adoc[]
= idl2wrs(1)
:doctype: manpage
:stylesheet: ws.css
:linkcss:
:copycss: {css_dir}/{stylesheet}

== NAME

idl2wrs - CORBA IDL to Wireshark Plugin Generator

== SYNOPSIS

*idl2wrs* <filename>

== DESCRIPTION

*idl2wrs* is a program that takes a user specified *CORBA IDL*
file and generates *"C"* source code for a *Wireshark* "plugin".

This resulting file can be compiled as a *Wireshark* plugin, and
used to monitor *GIOP/IIOP* traffic that is using this IDL.

*idl2wrs* is actually a shell script wrapper for two *Python* programs.
These programs are:

* *wireshark_be.py*
Contains the main IDL Visitor Class

* *wireshark_gen.py*
Contains the Source Code Generator Class

*idl2wrs* supports heuristic dissection of GIOP/IIOP traffic,
and some experimental code for explicit dissection, based on
Object Key <-> Repository Id mapping.
However, code for heuristic based plugins is
generated by default, and users should consider this the preferred
method unless you have some namespace collisions.

== OPTIONS

Currently there are no options. *idl2wrs* can be invoked as follows.

1.  To write the C code to stdout.

    idl2wrs  <your_file.idl>

    eg: idl2wrs echo.idl

2. To write to a file, just redirect the output.

    idl2wrs echo.idl > packet-test.c

== ENVIRONMENT

*idl2wrs* will look for *wireshark_be.py* and *wireshark_gen.py* in
*$PYTHONPATH/site-packages/* and if not found, will try the current
directory *./*

The *-p* option passed to omniidl (inside *idl2wrs*) indicates where
*wireshark_be.py* and *wireshark_gen.py* will be searched.  This may
need tweaking if you place these files somewhere else.

If it complains about being unable to find some modules (eg tempfile.py),
you may want to check if PYTHONPATH is set correctly.

eg:  PYTHONPATH=/usr/lib/python3/

== SEE ALSO

xref:wireshark.html[wireshark](1), xref:tshark.html[tshark](1)

== NOTES

*idl2wrs* (including *wireshark_be.py* and *wireshark_gen.py*) are part of
the *Wireshark* distribution.  The latest version of *Wireshark* can
be found at https://www.wireshark.org.

*idl2wrs* uses *omniidl*, an IDL parser, and can be found at
http://omniorb.sourceforge.net/

== TODO

Some of the more important things to do are:

* Improve Explicit dissection code.

* Improve command line options.

* Improve decode algorithm when we have operation name collision.

== AUTHORS

.Original Author
[%hardbreaks]
Frank Singleton <frank.singleton[AT]ericsson.com>

.Contributors
[%hardbreaks]