On Tue, Sep 29, 2009 at 16:54, Paul Moore <paul.moore@xxxxxx> wrote: > On Tuesday 29 September 2009 09:54:56 am Kyle Moffett wrote: >> The problem is that there is no way to do catch-all rules *based* on >> the MLS label. For example, if I have a TopSecret wire and I want to >> allow (for example) Unclass and TS//SI/TK traffic over it without >> risking mixing of data or exposure, there is no way for me to set it >> up without a lot of manual and duplicated configuration. What I want >> to happen is: > > Just a few questions so I'm clear on your problem. > >> (1) If any of 8 different SELinux domains of TS-level processes (IE: >> s4) try to communicate out the network interface, the policy is "none" > > So any of the eight domains can send network traffic w/o IPsec as long as > their MLS label is "s4" ... > >> (2) If those *same* SELinux domains with any of TS//SI/TK (s4:c1), >> TS//BYEMAN (s4:c2) try to communicate, the policy should be >> "esp/transport//require", using *different* certificates depending on >> the domain. > > ... and these same eight domains need to send network traffic using IPsec/ESP > when their MLS label is "s4:c1" or "s4:c2" (do you really mean different > certificates for each connection, which implies a new phase-1 IKE negotiation > or did you simply mean new ESP SAs?) > >> (3) Again, if those *same* SELinux domains with U (IE: s1) try to >> communicate, the policy would be "ah/transport//require", (and yet >> more certificates). > > ... and if these same eight domains need to send network traffic using > IPsec/AH when their MLS label is "s1" (once again, do you really mean SA > instead of cert)? Yes, this is correct. Imagine, if you will, for government purposes (or even for a corporation complying with the various personal information requirements), you have a patched HTTPD running on one box. The parent process runs with a range like "s1 - s4:c1,c2" (or "s0 - s0:c1,c2" for the business case). When you receive a connection, the HTTPD server does "getpeercon" and then either forks and sets its range or sends the FD over a UNIX-domain socket to the right child process. The end result, is with *one* HTTP server started with "s1 - s4:c1,c2", communicating over a wire treated as "s4", you can serve multiple clients. For government or corporate purposes, it prevents somebody from a lower level from receiving data they are not allowed to access (either personal info or classified data), and prevents somebody from a higher level from contaminating files on the server that are of the lower level. The best part is, you can even have computers connected to the network which are not trusted to maintain data separation, as long as they are allowed to process data at the "level" of the unprotected data going over the wire (IE: s4). If you can use separate certificates to do the authentication, you can have partially-trusted systems (which only have keys issued for some levels and not others). >> If it's possible to do this with the existing tools, that's great, but >> I played around with it for a good long while and was not able to work >> out a way to do so. > > The different IPsec configurations per label is a little interesting, and not > something that I've heard of people using (until just now). I'd have to go > spelunking in the code but I'm pretty sure you can't pick SPD rules based on > security labels (you can authorize access to a rule using labels, but I don't > believe the label acts as a selector). I imagine you could get something > working with manual SA creation but that is too ugly to spend much time > thinking about it. > > At this point I have to ask some workaround type questions - can you isolate > the traffic using traditional IPsec traffic selectors instead of labels, e.g. > protocol/port? Is there any harm in applying both AH and ESP to all traffic > that needs IPsec protection? Do you need to convey the type information > across the wire or is the MLS label sufficient? Depending on your answers we > may be able to arrive at a solution with the existing code. Basically, my end goal is to be able to have a network of Linux boxes (with the network itself being "s4", for example) and *guarantee* that: (A) Any unlabelled data coming in off the network is treated by SELinux is s4 (B) No processes are allowed to communicate out the network unprotected unless they are exactly s4 (C) Processes which are *not* s4 may communicate over the network only when protected by IPsec, and only if the IPsec connection is specifically negotiated using certificates/keys based on the level of the data being protected. These kinds of guarantees are available if you take something like a hardware IPsec device, plug the plaintext and ciphertext ports into the SELinux box, and then label traffic through those two interfaces specifically. The problem is, that only works with the two MLS labels configured on the ports of that device. Beyond that, those devices are damn expensive and a lot of boards already have usable crypto-accelerators on them. Cheers, Kyle Moffett -- This message was distributed to subscribers of the selinux mailing list. If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with the words "unsubscribe selinux" without quotes as the message.