On Tue, 15 Nov 2016 13:43:28 -0500
Stephen Smalley <s...@tycho.nsa.gov> wrote:

> On 11/15/2016 01:34 PM, Casey Schaufler wrote:
> > On 11/15/2016 10:14 AM, Stephen Smalley wrote:  
> >> On 11/15/2016 12:28 PM, Casey Schaufler wrote:  
> >>> I am looking for an SELinux configuration that uses CIPSO.
> >>> Ideally, it would be based on a readily available distro,
> >>> but I'm willing to perform semi-heroic acts if I have too.
> >>> I'm not in a position to develop it myself, nor would that
> >>> really suit my nefarious purposes. Thank you.  
> >> Can you clarify what you mean?  There is a sample NetLabel configuration
> >> in the selinux-testsuite (in tests/inet_socket/netlabel-load) that
> >> configures full SELinux labeling over loopback connections, used by the
> >> inet_socket tests.  And the corresponding SELinux policy rules for those
> >> tests can be found in policy/test_inet_socket.te within the testsuite.  
> > 
> > That will probably get me started. I'll have a look at the test
> > documentation. I am also looking for a configuration that I can
> > use for exploring a "real" CIPSO environment, where two or more
> > machines are talking to each other using CIPSO. I think that I
> > understand how that is supposed to work, but there's nothing like
> > seeing the packets fly. Is there a case for that in the test suite?
> > Thank you.  
> 
> Not in the selinux-testsuite, since it doesn't presently require/expect
> you to set up two different systems.  Probably the lspp testsuite or
> Paul Moore's blog or maybe the SELinux Notebook for samples of that kind
> of configuration.  Note that in that cross-machine case, CIPSO only
> passes an encoding of the MLS label, not the user:role:type information.
> 
> 

In addition to the user:role:type information, there are other limits to what 
you can pass over the wire via netlabel due to the way the CIPSO information is 
encoded 
in the packet. 

You can only encode a single sensitivity because the CIPSO spec only stores it 
in a 
single integer. s0:c0.c1023 passes fine, but s0-s2:c0.c1023 will get reduced to 
s0:c0.c1023. 

Unlike the sensitivity it is possible to pass some
fairly complex sets of categories. When you create a DOI, 
you can specify how the categories will be encoded using a tag of 1, 2, or 5. 
( these are bitmap, enumerated and range types respectively ) What categories 
can be passed via netlabel is dependent on the limits of these types.

The bottom line is that it's entirely possible to have a valid context that 
netlabel will not be able to fully preserve. Netlabel is still very useful, 
but you have to remain mindful of its limitations.

The above is based on my reading of the CIPSO spec and my experience with 
netlabel.
It's entirely possible my understanding is incomplete and/or out of date. 
Somone like Paul Moore
can speak with much greater authority. 

HW



_______________________________________________
Selinux mailing list
Selinux@tycho.nsa.gov
To unsubscribe, send email to selinux-le...@tycho.nsa.gov.
To get help, send an email containing "help" to selinux-requ...@tycho.nsa.gov.

Reply via email to