<html>
<head>
<style><!--
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
font-size: 12pt;
font-family:Calibri
}
--></style></head>
<body class='hmmessage'><div dir='ltr'>Hi Tim, All,<br> <br>I was in the discussion yesterday (kudva), and would like to start gradually<br>contributing to the code base.<br> <br>So, this discussion below is based on my limited exploration of Congress<br>code, running it. I am trying some small pieces to implement to familiarize.<br>Please view it as such. As I start adding code, I am sure, my thoughts will<br>be more evolved.<br> <br>I agree with the three types you outline. I also agree that these will grow.<br>We are already thinking of expanding congress for various other types of<br>policies. But those would be a manageable start.<br> <br>Regarding the comment below. I was wondering if all conditions, and actions<br>could be both:<br>1. python functions (for conditions they eval<br>2. policy primitives. <br> <br>The advantage of 1, is that it is just executed and a True or False returned<br>by Python for conditions. For actions, python functions are executed to respond to conditions.<br>This controls the growth of policies and adding more primitives, and makes it flexible (say<br>to use alarms, monitors, os clients, nova actions etc).<br> <br>The advantage of 2, is the ability to use unification (as in unify.py) and do<br>some logic reduction. This gives us the full strength of extensive and mature <br>logic reasoning and reduction methods.<br> <br>One possibility is that it checks which one the two it is and does the appropriate<br>evaluation for condition and action.<br> <br><BR><div><span style="font-size: 12pt;">>There are drawbacks to this proposal as well. </span></div><div><span style="font-size: 12pt;">>- We will have 3 separate policies that are conceptually very similar. As the policies grow larger, it will become >increasingly difficult to keep the policies synchronized. This problem can be mitigated to some extent by having >all 3 share a library of policy statements that they all apply in different ways (and such a library mechanism is >already implemented). </span></div><div><span style="font-size: 12pt;">>- As cloud services change their behavior, policies may need to be re-written. For example, right now Nova does >not consult Congress before creating a VM; thus, to enforce policy surrounding VMs, the best we could do is >write a Condition-Action policy that adjusts VM configuration when it learns about new VMs being created. If we >later make Nova consult with Congress before creating a VM, we need to write an Access-control policy that puts >the proper controls in place.</span></div><span style="font-size: 12pt;"></span> <br><span style="font-size: 12pt;">Thanks,</span><br><span style="font-size: 12pt;"></span> <br><span style="font-size: 12pt;">Prabhakar Kudva<br><BR><div><br></span><br> </div><div><hr id="stopSpelling">Date: Wed, 12 Mar 2014 10:05:23 -0700<br>From: thinrichs@vmware.com<br>To: openstack-dev@lists.openstack.org<br>Subject: [openstack-dev] [Congress] Policy types<br><br><div style="color: rgb(0, 0, 0); font-family: times new roman, new york, times, serif; font-size: 12pt;"><div>Hi all,</div><div><br></div><div>We started a discussion on IRC yesterday that I'd like to continue. The main question is what kind of policy does a Congress user actually write? I can see three options. The first two focus on actions (API calls that make changes to the state of the cloud) and the last focuses on just the cloud state. (By "state of the cloud" I mean all the information Congress can see about all the cloud services it is managing, e.g. all the information we can get through API calls to Nova, Neutron, Cinder, Heat, ...).</div><div><br></div><div>1) Access Control (e.g. Linux, XACML, AD): which *actions* can be performed by other cloud services (for each state of the cloud)</div><div>2) Condition Action: which *actions* Congress should execute (for each state of the cloud)</div><div>3) Classification (currently supported in Congress): which *states* violate real-world policy. [For those of you who have read docs/white-papers/etc. I'm using "Classification" in this note to mean the combination of the current "Classification" and "Action Description" policies.]</div><div><br></div><div>The important observation is that each of these policies could contain different information from each of the others.</div><div><br></div><div><div>- Access Control vs Condition Action. The Access Control policy tells *other cloud services* which actions they are *allowed* to execute. The Condition Action policy tells *Congress* which actions it *must* execute. These policies differ because they constrain different sets of cloud services.</div><div><br></div></div><div>- Access Control vs. Classification. The Access Control policy might permit some users to violate the Classification policy in some situations (e.g. to fix violation A, we might need to cause violation B before eliminating both). These policies differ because a violation in one policy might be be a violation in the other.</div><div><br></div><div>- Classification vs. Condition Action. The Classification policy might imply which actions *could* eliminate a given violation, but the Condition Action policy would dictate which of those actions *should* be executed (e.g. the Classification policy might tell us that disconnecting a network and deleting a VM would both eliminate a particular violation, but the Condition Action policy would tell us which to choose). And the Condition Action policy need not eliminate all the violations present in the Classification policy. Again these policies differ because a violation in one policy might not be a violation in the other. </div><div></div><div><br></div><div><span style="font-size: 12pt;">I'm proposing that for the first release of Congress we support all 3 of these policies. When a user inserts/deletes a policy statement, she chooses which policy it belongs to. All would be written in basically the same syntax but would be used in 3 different scenarios:</span></div><div><span style="font-size: 12pt;"><br></span></div><div><span style="font-size: 12pt;">- Prevention: If a component wants to consult Congress before taking action to see if that action is allowed, Congress checks the Access Control policy.</span></div><div><span style="font-size: 12pt;"><br></span></div><div><span style="font-size: 12pt;">- Reaction: When Congress learns of a change in the cloud's state, it checks the Condition Action policy to see which actions should be executed (if any).</span></div><div><span style="font-size: 12pt;"><br></span></div><div><span style="font-size: 12pt;">- Monitoring: If a user wants to simply check if the cloud's state is in compliance and monitor compliance over time, she writes and queries the Classification policy.</span></div><div><span style="font-size: 12pt;"><br></span></div><div><span style="font-size: 12pt;">There are several benefits to this proposal.</span></div><div><span style="font-size: 12pt;">- It allows users to choose any of the policy types, if they only want one of them. From our discussions with potential users, most seem to want one of these 3 policy types (and are uninterested in the others).</span></div><div><span style="font-size: 12pt;">- It makes the introduction to Congress relatively simple. We describe 3 different uses of policy (Prevention, Reaction, Monitoring) and then explain which policy to use in which case.</span></div><div><span style="font-size: 12pt;"></span></div><div><span style="font-size: 12pt;">- This allows us to focus on implementing a single policy-engine technology (a Datalog policy language and evaluation algorithms), which gives us the opportunity to make it solid.</span></div><div><span style="font-size: 12pt;"><br></span></div><div><span style="font-size: 12pt;">There are drawbacks to this proposal as well. </span></div><div><span style="font-size: 12pt;">- We will have 3 separate policies that are conceptually very similar. As the policies grow larger, it will become increasingly difficult to keep the policies synchronized. This problem can be mitigated to some extent by having all 3 share a library of policy statements that they all apply in different ways (and such a library mechanism is already implemented). </span></div><div><span style="font-size: 12pt;">- As cloud services change their behavior, policies may need to be re-written. For example, right now Nova does not consult Congress before creating a VM; thus, to enforce policy surrounding VMs, the best we could do is write a Condition-Action policy that adjusts VM configuration when it learns about new VMs being created. If we later make Nova consult with Congress before creating a VM, we need to write an Access-control policy that puts the proper controls in place.</span></div><div><span style="font-size: 12pt;"><br></span></div><div><span style="font-size: 12pt;">These drawbacks were the original motivation for supporting only the Classification policy and attempting to derive the Access Control and Condition Action policies from it. But given that we can't always derive the proper Access Control and Condition Action policies from the Classification policy, we will eventually need support for all 3. In addition, the technical complexity of supporting all 3 is much lower than supporting just the Classification policy and deriving the others. </span></div><div><span style="font-size: 12pt;"><br></span></div><div><span style="font-size: 12pt;">I'll stop there for now.</span></div><div><span style="font-size: 12pt;"><br></span></div><div><span style="font-size: 12pt;">Comments, thoughts, questions?</span></div><div><span style="font-size: 12pt;">Tim</span></div><div><span style="font-size: 12pt;"></span></div><div><span style="font-size: 12pt;"> </span><span style="font-size: 12pt;"> </span></div></div><br>_______________________________________________
OpenStack-dev mailing list
OpenStack-dev@lists.openstack.org
http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</div> </div></body>
</html>