Commit Graph

15 Commits

Author SHA1 Message Date
Chris PeBenito
6c147f8c7b PortconProtocol: add support for specifiying by protocol string
Leverage Python lib socket.getprotobyname()
2016-04-01 10:42:00 -04:00
Chris PeBenito
60ac053ce3 PortconQuery: move protocol type checking into PortconProtocol.
Also import useful policyrep classes in its __init__.py
2016-03-21 10:55:13 -04:00
Chris PeBenito
216836ca76 Portcon: fix hashing function. 2016-01-21 09:35:37 -05:00
Chris PeBenito
0c1b0a101d Netifcon/Nodecon/Portcon: add hashing functions 2016-01-13 09:43:51 -05:00
Chris PeBenito
ee1c0b3328 Genfscon/Portcon: add classes to handle file type/protocol numbers
These new classes subclass int to override the string representation with
the appropriate text from the policy.  This allows programmatic uses of the
values, but allows useful display of the values at any time, not just in
the Genfscon/Portcon statement strings.
2016-01-11 13:20:24 -05:00
Chris PeBenito
4bea20b522 Misc docstring cleanups. 2015-05-16 22:01:03 -04:00
Chris PeBenito
82b021a5a4 Portcon: implement port ranges using a namedtuple
Has the benefit of unifying the object attributes for port range and MLS
range objects, making the PolicyQuery._match_range() function work
naturally for both object types.
2015-04-27 14:15:31 -04:00
Chris PeBenito
9d51dcc7e3 Misc cleanups suggested by pylint
* unnecessary parentheses on return
* variable shadowing
* unused variables
* classmethod variable naming
2015-04-02 14:50:21 -04:00
Chris PeBenito
3a0af0341f Create factory functions for all policyrep classes.
* break apart classes that are overloaded (e.g. TypeAttr)
* move object class member function out of Rule subclasses, into Rule.
* Fix SWIG wrapper to make class member function for rules to be consistent
2014-12-18 15:10:31 -05:00
Chris PeBenito
8ba3cf16f5 Change all unit tests for "unset" query to use full comparison.
Fully compare the lists rather than only counting objects.

Also fix comparison problem in Nodecon and Genfscon. In libqpol, the all
genfscons/nodecons iterators allocate new objects, so the pointer
comparison in PolicySymbol fails.
2014-11-25 13:24:36 -05:00
Chris PeBenito
4791d0044f netcontext whitespace fix. 2014-11-10 07:50:46 -05:00
Chris PeBenito
fc597fed99 Add nodecon query.
It could use IPv6 tests, but those have the same code paths as IPv4.
2014-11-05 13:09:35 -05:00
Chris PeBenito
177c185a77 Correct SWIG wrapper to return IP address text representations for nodecons
Otherwise the Python would have to use unsafe cdata.i SWIG functions to
access the memory areas to do the same thing.

Also eliminate the QPOL_IPV4/QPOL_IPV6 from the protocol funtion, to
abstract away the binary policy representation details.
2014-10-30 15:44:37 -04:00
Chris PeBenito
43e9019193 Use relative imports for submodules.
Needed for Python 3.x.
2014-10-25 08:07:11 -04:00
Chris PeBenito
109ba68a92 Rename libapol package to setools. 2014-10-24 21:23:13 -04:00