Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Only display domains that are directly attributable to a cidr #647

Merged
merged 7 commits into from
Oct 1, 2024

Conversation

DJensen94
Copy link
Contributor

🗣 Description

We only want to display data for domains whose IP is directly attributable to a user provided CIDR. We only want this functionality for non-FCEB organizations.

  1. Add new column to Domains table called "fromCyhyCidr", which will be a boolean for if the domains ip links to a cidr provided to VS
  2. Create a helper function that accepts an organization_id and an ip and returns true if the ip is found inside a cidr block owned by the given org, it will check this against the cidr table in the mini datalake that is updated daily from the VS data in the AE
  3. We will make a crossfeed scan that loops through all domains and runs the ips through the newly created helper function and correctly checks the "fromCyhyCidr" column
  4. Update the api calls that pull domains to filter out domains where "fromCyhyCidr" is false

💭 Motivation and context

This is to avoid reporting issues with IPs that belong to cloud providers and incorrectly attributed domains

🧪 Testing

I have tested locally with both in-cidr and out-cidr ips as well as on fceb and non fceb organizations

✅ Pre-approval checklist

  • This PR has an informative and human-readable title.
  • Changes are limited to a single goal - eschew scope creep!
  • All future TODOs are captured in issues, which are referenced
    in code comments.
  • All relevant type-of-change labels have been added.
  • I have read the CONTRIBUTING document.
  • These code changes follow cisagov code standards.
  • All relevant repo and/or project documentation has been updated
    to reflect the changes in this PR.

✅ Pre-merge checklist

  • Revert dependencies to default branches.
  • Finalize version.

✅ Post-merge checklist

  • Create a release.

update model to have new boolean columns, add helper function to identify if cidr holds the ip and create scan to update domain table
add filter to relevant APIs
Made fixes to filters and logic to mark fceb children as fceb
run precommits and linter fixes
remove console logs
@schmelz21 schmelz21 marked this pull request as ready for review October 1, 2024 15:38
delete flagFloatingIps in order to rename it
Re-add flagFloating Ips with new capitalization
@ameliav ameliav self-requested a review October 1, 2024 17:07
Copy link
Contributor

@ameliav ameliav left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Worked for me after the following:

  • Having the mini datalake already
  • Doing a complete docker rebuild including syncdb
  • Making changes to the crossfeed database to match some of the mini datalake's org acronyms (Dane walked me through the different test cases and what fields to change)
  • Running the flagFloatingIps scan and then checking the frontend for verification after each test case

@schmelz21 schmelz21 merged commit 99efc2d into develop Oct 1, 2024
11 of 18 checks passed
@schmelz21 schmelz21 deleted the dj-cidr_hot_fix-WIP branch October 1, 2024 17:34
@schmelz21 schmelz21 restored the dj-cidr_hot_fix-WIP branch October 1, 2024 17:38
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants