Skip to content

Commit

Permalink
POLICY-171 Incident fix
Browse files Browse the repository at this point in the history
  • Loading branch information
arpit-at committed Jan 11, 2025
1 parent 10f04d5 commit 45125fb
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 42 deletions.
1 change: 1 addition & 0 deletions .github/workflows/maven.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ on:
- development
- master
- lineageondemand
- arpitbulklinkingmaster2

jobs:
build:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -64,17 +64,16 @@ public String toString() {
public static class AssetComplianceInfo implements Serializable {
private static final long serialVersionUID = 1L;

//guids for asset
private String assetId;

//guids for complaint rules
private Set<String> complaintRules;
private Set<String> addCompliantGUIDs;

//guids for non complaint rules
private Set<String> nonComplaintRules;
private Set<String> removeCompliantGUIDs;

//guids for complaint policies
private Set<String> complaintPolicies;

private Set<String> addNonCompliantGUIDs;

private Set<String> removeNonCompliantGUIDs;


public String getAssetId() {
Expand All @@ -85,39 +84,48 @@ public void setAssetId(String assetId) {
this.assetId = assetId;
}

public Set<String> getComplaintRules() {
return complaintRules;
public Set<String> getAddCompliantGUIDs() {
return addCompliantGUIDs;
}

public void setComplaintRules(Set<String> complaintRules) {
this.complaintRules = complaintRules;
public void setAddCompliantGUIDs(Set<String> addCompliantGUIDs) {
this.addCompliantGUIDs = addCompliantGUIDs;
}

public Set<String> getNonComplaintRules() {
return nonComplaintRules;
public Set<String> getRemoveCompliantGUIDs() {
return removeCompliantGUIDs;
}

public void setNonComplaintRules(Set<String> nonComplaintRules) {
this.nonComplaintRules = nonComplaintRules;
public void setRemoveCompliantGUIDs(Set<String> removeCompliantGUIDs) {
this.removeCompliantGUIDs = removeCompliantGUIDs;
}

public Set<String> getComplaintPolicies() {
return complaintPolicies;
public Set<String> getAddNonCompliantGUIDs() {
return addNonCompliantGUIDs;
}

public void setComplaintPolicies(Set<String> complaintPolicies) {
this.complaintPolicies = complaintPolicies;
public void setAddNonCompliantGUIDs(Set<String> addNonCompliantGUIDs) {
this.addNonCompliantGUIDs = addNonCompliantGUIDs;
}

public Set<String> getRemoveNonCompliantGUIDs() {
return removeNonCompliantGUIDs;
}

public void setRemoveNonCompliantGUIDs(Set<String> removeNonCompliantGUIDs) {
this.removeNonCompliantGUIDs = removeNonCompliantGUIDs;
}

@Override
public String toString() {
return "AssetComplianceInfo{" +
"assetId='" + assetId + '\'' +
", complaintRules=" + complaintRules +
", nonComplaintRules=" + nonComplaintRules +
", complaintPolicies=" + complaintPolicies +
'}';
final StringBuilder sb = new StringBuilder("AssetComplianceInfo{");
sb.append("assetId='").append(assetId).append('\'');
sb.append(", addCompliantGUIDs=").append(addCompliantGUIDs);
sb.append(", removeCompliantGUIDs=").append(removeCompliantGUIDs);
sb.append(", addNonCompliantGUIDs=").append(addNonCompliantGUIDs);
sb.append(", removeNonCompliantGUIDs=").append(removeNonCompliantGUIDs);
sb.append('}');
return sb.toString();
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4779,21 +4779,28 @@ public AtlasVertex linkBusinessPolicy(final BusinessPolicyRequest.AssetComplianc
Set<String> existingNonCompliant = getVertexPolicies(vertex, NON_COMPLIANT_ASSET_POLICY_GUIDS);

// Retrieve new policies
Set<String> newCompliantRulesGUIDs = data.getComplaintRules();
Set<String> newNonCompliantRulesGUIDs = data.getNonComplaintRules();
Set<String> newCompliantPolicyGUIDs = data.getComplaintPolicies();
Set<String> addCompliantGUIDs = data.getAddCompliantGUIDs();
Set<String> addNonCompliantGUIDs = data.getAddNonCompliantGUIDs();
Set<String> removeCompliantGUIDs = data.getRemoveCompliantGUIDs();
Set<String> removeNonCompliantGUIDs = data.getAddNonCompliantGUIDs();

// Calculate effective compliant and non-compliant policies
Set<String> effectiveCompliantGUIDs = calculateEffectivePolicies(existingCompliant, newCompliantRulesGUIDs, newCompliantPolicyGUIDs);
Set<String> effectiveNonCompliantGUIDs = calculateEffectivePolicies(existingNonCompliant, newNonCompliantRulesGUIDs);

// Update vertex properties
updateVertexPolicies(vertex, ASSET_POLICY_GUIDS, effectiveCompliantGUIDs);
updateVertexPolicies(vertex, NON_COMPLIANT_ASSET_POLICY_GUIDS, effectiveNonCompliantGUIDs);
addToAttribute(vertex, ASSET_POLICY_GUIDS, addCompliantGUIDs);
removeFromAttribute(vertex, ASSET_POLICY_GUIDS, removeCompliantGUIDs);


addToAttribute(vertex, NON_COMPLIANT_ASSET_POLICY_GUIDS, addNonCompliantGUIDs);
removeFromAttribute(vertex, NON_COMPLIANT_ASSET_POLICY_GUIDS, removeNonCompliantGUIDs);

// Count and set policies

Set<String> effectiveCompliantGUIDs = getVertexPolicies(vertex, ASSET_POLICY_GUIDS);
Set<String> effectiveNonCompliantGUIDs = getVertexPolicies(vertex, NON_COMPLIANT_ASSET_POLICY_GUIDS);

int compliantPolicyCount = countPoliciesExcluding(effectiveCompliantGUIDs, "rule");
int nonCompliantPolicyCount = countPoliciesExcluding(effectiveNonCompliantGUIDs, "rule");

int totalPolicyCount = compliantPolicyCount + nonCompliantPolicyCount;

vertex.setProperty(ASSET_POLICIES_COUNT, totalPolicyCount);
Expand All @@ -4807,20 +4814,19 @@ public AtlasVertex linkBusinessPolicy(final BusinessPolicyRequest.AssetComplianc
return vertex;
}

@SafeVarargs
private final Set<String> calculateEffectivePolicies(Set<String> existing, Set<String>... additions) {
Set<String> effective = new HashSet<>(existing);
for (Set<String> addition : additions) {
effective.addAll(addition);
private void addToAttribute(AtlasVertex vertex, String propertyKey, Set<String> policies) {
if(ASSET_POLICY_GUIDS.equals(propertyKey)){
policies.forEach(policyGuid -> vertex.setProperty(ASSET_POLICY_GUIDS, policyGuid));
}else {
policies.forEach(policyGuid -> vertex.setProperty(NON_COMPLIANT_ASSET_POLICY_GUIDS, policyGuid));
}
return effective;
}

private void updateVertexPolicies(AtlasVertex vertex, String propertyKey, Set<String> policies) {
private void removeFromAttribute(AtlasVertex vertex, String propertyKey, Set<String> policies) {
if(ASSET_POLICY_GUIDS.equals(propertyKey)){
policies.forEach(policyGuid -> vertex.setProperty(ASSET_POLICY_GUIDS, policyGuid));
policies.forEach(policyGuid -> vertex.removePropertyValue(ASSET_POLICY_GUIDS, policyGuid));
}else {
policies.forEach(policyGuid -> vertex.setProperty(NON_COMPLIANT_ASSET_POLICY_GUIDS, policyGuid));
policies.forEach(policyGuid -> vertex.removePropertyValue(NON_COMPLIANT_ASSET_POLICY_GUIDS, policyGuid));
}
}

Expand Down

0 comments on commit 45125fb

Please sign in to comment.