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

Update Devo Integration #4419

Closed
wants to merge 4 commits into from
Closed

Update Devo Integration #4419

wants to merge 4 commits into from

Conversation

ansfan
Copy link
Contributor

@ansfan ansfan commented Sep 17, 2019

New version of Devo integration with enhanced features. Includes new features for fetch-incidents, querying alerts, multi-table querying, and writing back to Devo. Using newer version of the Devo SDK which has been updated to use Devo's most recent APIs.

Status

Ready

Related Issues

Description

New version of Devo integration with enhanced features. Includes new features for fetch-incidents, querying alerts, multi-table querying, and writing back to Devo.

Refer to README.md found here: https://github.com/devods/demisto-devo

Screenshots

image
image

Related PRs

List related PRs against other branches:

demisto/dockerfiles#462 <- This is assuming demisto/devo:1.0.0 docker image name to be built.

Required version of Demisto

4.x.x
5.x.x

Does it break backward compatibility?

  • Yes
    • We are upgrading this integration to use the newest Devo HTTP APIs. Also using a different authentication method for enhanced security.

Must have

Dependencies

demisto/dockerfiles#462 <- Dockerfiles to create image needed for Devo's Python SDK.

Additional changes

Re-write of entire existing Devo integration.

Technical writer review

Mention and link to the files that require a technical writer review.

@welcome
Copy link

welcome bot commented Sep 17, 2019

Hi and welcome to the Demisto Content project! Thank you and congrats on your first pull request, we will review it soon! Until then you can check out our documentation for more details. We would be thrilled to see you get involved in our Slack DFIR community for discussions. Hope you have a great time here :)

@guardrails
Copy link

guardrails bot commented Sep 17, 2019

⚠️ We detected security issues in this pull request:

Hard-Coded Secrets (1)

https://github.com/demisto/content/blob/6fc8aa6c12ca5b16638be77c0d20e6501f69aed2/Integrations/integration-Devo.yml#L7

More info on how to fix Hard-Coded Secrets in General.

Happy with the results? Give your feedback.

@content-bot content-bot added the Contribution Thank you! Contributions are always welcome! label Sep 18, 2019
@content-bot content-bot changed the base branch from master to devods_devo_base September 18, 2019 08:54
@content-bot
Copy link
Collaborator

Thank you for your contribution. Your generosity and caring are unrivaled! Rest assured - our content wizard @anara123 will very shortly look over your proposed changes.

@CLAassistant
Copy link

CLAassistant commented Sep 18, 2019

CLA assistant check
All committers have signed the CLA.

@ansfan
Copy link
Contributor Author

ansfan commented Sep 20, 2019

⚠️ We detected security issues in this pull request:

Hard-Coded Secrets (1)
Happy with the results? Give your feedback.

Guardrails - Base64 encoded image not a secret.

Also for the circleci might have to whitelist the default devo.com domains so not to be categorized as secrets.

@anara123
Copy link
Contributor

anara123 commented Sep 23, 2019

@ansfan Hi. Thank you for the contribution.
We changed some the way we store our integration. Please take a look at https://github.com/demisto/content/tree/master/docs/package_directory_structure

  1. Navigate to content folder (the folder you cloned to your local env)

  2. Installation prerequisites:
    python3
    python2
    pip
    pipenv
    pyyaml
    ruamel.yaml
    docker
    autopep8
    flake8
    mypy

  3. You should run in order to convert yml to package format (replace the old integration-Devo.yml with the new Devo folder):

PYTHONPATH="`pwd`:${PYTHONPATH}" python3 package_extractor.py -i /Integrations/integration-Devo.yml -o Integrations/Devo -m -t integration
  1. Then run linting
PYTHONPATH="`pwd`:${PYTHONPATH}" python3 Tests/scripts/pkg_dev_test_tasks.py -d Integrations/Devo
  1. Validate files before you commit your changes
PYTHONPATH="`pwd`:${PYTHONPATH}" python2 Tests/scripts/validate_files.py
  1. Add CHANGELE.md file to the package

You can take a look at the following integration example:
https://github.com/demisto/content/tree/master/Integrations/ProofpointTAP_v2

@ansfan ansfan closed this Sep 23, 2019
@ansfan ansfan reopened this Sep 23, 2019
…features for fetch-incidents, querying alerts, multi-table querying, and writing back to Devo. Using newer version of the Devo SDK which has been updated to use Devo's most recent APIs.
@ansfan
Copy link
Contributor Author

ansfan commented Sep 24, 2019

@anara123 Please rebase/fast forward the demisto:devods_devo_base branch to the master git commit: 857896ea12c0c360defe1f559390def192fbc4de.

I have done this in order to make sure I had the latest testing environment setup. I believe the rebasing is blocking the license/cla check from passing.

Let me know if this looks okay to you and I also have included pytest unit tests but have set myself to mimic the proofpoint integration by skipping the playbook test.

@anara123 anara123 changed the base branch from devods_devo_base to master September 24, 2019 17:03
Comment on lines +55 to +78
### Devo (Preview) Commands ###

`devo-run-query`

Runs a linq query and returns results from the specified timeframe.

*inputs*

| Argument | Required | Type | Description |
|----------------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| query | TRUE | string | A linq query that you wish to run against Devo |
| from | TRUE | float | Start datetime for specified Query. Expects a unix timestamp in seconds with milliseconds allowed after decimal points. |
| to | FALSE | float | End datetime for specified Query. If no value is provided will default to now. Expects a unix timestamp in seconds with milliseconds allowed after decimal points |
| writeToContext | FALSE | string | String of `true` or `false` to pass on the results context. |

*outputs*

| ContextPath | Type | Description |
|-------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Devo.QueryResults | list(objects) | Will return a list of python dictionary objects. Each object in the list will be a row from the query. If no rows are returned result will be null. |
| Devo.QueryLink | object | Will return an JSON object with a single key called DevoTableLink and a URL link back to Devo for the results just queried. |

*current caveats*
- None
Copy link
Contributor

Choose a reason for hiding this comment

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

_description file should only contain instructions on how to configure the integration in order to connect to Devo instance.
For each parameter means like you explained above.
Remove the documentation about the commands. For commands you need to create README.md file in this folder and generate documentation file and fill it with data.
Follow: https://github.com/demisto/content/blob/master/docs/integration_documentation/README.MD

@anara123 anara123 changed the base branch from master to devods_devo_base October 7, 2019 10:08
@content-bot
Copy link
Collaborator

This PR is starting to get a little stale. @ansfan are there any changes you wanted to make since @anara123's last comment?

demisto.results(write_to_table_command())

except Exception as e:
LOG(e)
Copy link
Contributor

Choose a reason for hiding this comment

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

remove LOG(e) and LOG.print_log(True)
return_error(e) will do them both

except Exception as e:
LOG(e)
LOG.print_log(True)
return_error(e)
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
return_error(e)
return_error('Failed to execute command {}. Error: {}'.format(demisto.command(), str(e)))

@@ -0,0 +1,145 @@
commonfields:
id: Devo
Copy link
Contributor

Choose a reason for hiding this comment

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

change to Devo v2

commonfields:
id: Devo
version: -1
name: Devo
Copy link
Contributor

Choose a reason for hiding this comment

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

change to Devo v2

id: Devo
version: -1
name: Devo
display: Devo
Copy link
Contributor

Choose a reason for hiding this comment

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

change to Devo v2

Copy link
Contributor

Choose a reason for hiding this comment

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

This integration breaking backward compatibility with the previous integration. The instance parameters are different. In this case we should create new integration v2 and deprecate the old one.

name: Devo
display: Devo
category: Analytics & SIEM
image: 
Copy link
Contributor

Choose a reason for hiding this comment

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

undo the deletion, if we will delete this integration and replace by another , then we will break backward compatibility

@content-bot
Copy link
Collaborator

This PR is starting to get a little stale. @ansfan are there any changes you wanted to make since @anara123's last comment?

@anara123
Copy link
Contributor

@anara123
Copy link
Contributor

Closing due to inactivity. @ansfan please reopen the PR when you have time to continue the review process

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Contribution Thank you! Contributions are always welcome!
Projects
None yet
4 participants