Thanks for the update. I look forward to SETools version 4 Richard ----- Original Message ----- From: Christopher J. PeBenito <cpebenito@xxxxxxxxxx> To: Richard Haines <richard_c_haines@xxxxxxxxxxxxxx>; selinux@xxxxxxxxxxxxx; setools-bugs@xxxxxxxxxx Cc: Sent: Tuesday, 8 April 2014, 16:38 Subject: Re: [PATCH 0/4] APOL Enhancements to support additional policy features On 04/08/2014 10:52 AM, Richard Haines wrote: > These four patches will update setools-3.3.8.tar.bz2 available from > http://oss.tresys.com/projects/setools/wiki/download > > I know this is not being fully supported but as I use APOL frequently > I thought I would update it to support the latest policy version 29 (I > could be the only user!!!). Tested on latest Fedora 20 x86_64 Thanks, we'll take a look at these. You're not the only user, as we use it internally at Tresys a lot. Actually, we're in the process of prototyping SETools 4. There are a few things that have been a challenge for maintaining SETools over the years: * Libsepol is only designed for building the policy, not analyzing the policy: It doesn't have an API that's conducive to querying the policy (it didn't even exist when SETools started). SETools' source policy parsers have to be copied from checkpolicy/checkmodule. * It's over 10 years old and has been very evolutionary in its development (hence tk and gtk toolkits, for example) * A (nearly) full C implementation is fast, but we have our own implementations of functions/structures come built-in on OO languages. So we're looking at the possibility of reimplementing SETools in Python. That brings in a huge amount of capability. For example, libapol has it's own vector implementation, which can be replaced with Python lists (or sets) and all their functions. Similarly, we're evaluating the NetworkX graph library as a basis for the information flow and domain transition analyses. Additionally, we'd like to see if some form of the libqpol API (or something similar) could be upstreamed into libsepol (or be a new upstream library). It was discussed before at some point after the SETools dependency in audit2allow got upstreamed, but didn't really end in any implementation. We're not quite ready for shifting to public development (we're not even set on Python yet, though it's very likely), but we'll let the list know when that happens. -- Chris PeBenito Tresys Technology, LLC www.tresys.com | oss.tresys.com