On Fri, 2011-08-05 at 08:56 -0400, Stephen Smalley wrote: > On Fri, 2011-08-05 at 12:19 +0800, Harry Ciao wrote: > > Hi Eric, > > > > Let me explain more about the background story. > > > > The existing type rule could declare a type, and optionally associate it > > with a list of type attributes. So I invented this "role <regular role> > > attribute <a list of role attributes>" rule in the same manner to do the > > similar things for roles, since I figure this would make refpolicy rules > > similar and easy to remember and use. > > > > Now that the above new role-attr rule takes care of declaring roles, > > this duty has to be removed from role-type rule in order to avoid > > ambiguity, and the role-type rule would be used to only associate types > > with roles, which only requires TWO lines of code as in 3cbc9727, since > > mostly used roles such as system_r have been declared in kernel.te(in > > order to avoid some build failure). > > > > In a word, we could preserve the behavior of role-type rule, but this > > would introduce discrepancy between that of role-attr rule and type-attr > > rule, considering that getting used to the new toolchain only requires > > an easy cherry-pick of only 2 lines of change, would it be that > > desirable for us to do so? > > I don't think we should introduce an incompatible policy language change > without very strong reasons. It is fine to introduce new constructs > like your role...attribute construct, but we shouldn't change the > meaning of role...type statements and thereby render invalid policies > that used to be valid. > In the up and coming CIL compiler, declaration and use are always separate, so user, role, and type rules are only used to declare. There are typealias, typeattribute, and other such rules to define associations. For a role there is a separate roletype rule to associate a type with a role. So if roletype and roleattribute rules were created for the current toolchain, the current role rule would not have to be changed. Newer policies could use the role rule only to declare a role, but it could still be used in the old way for backwards compatibility. -- James Carter <jwcart2@xxxxxxxxxxxxx> National Security Agency -- 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.