This site is the archived OWASP Foundation Wiki and is no longer accepting Account Requests.
To view the new OWASP Foundation website, please visit https://owasp.org
Difference between revisions of "OWASP AppSec Pipeline"
(→Pipeline Design Patterns) |
m (Tag: Visual edit) |
||
(40 intermediate revisions by 3 users not shown) | |||
Line 5: | Line 5: | ||
<!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | <!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | ||
{| style="padding: 0;margin:0;margin-top:10px;text-align:left;" |- | {| style="padding: 0;margin:0;margin-top:10px;text-align:left;" |- | ||
− | | valign="top" | + | | valign="top" style="border-right: 1px dotted gray;padding-right:25px;" | |
==The OWASP AppSec Rugged DevOps Pipeline Project== | ==The OWASP AppSec Rugged DevOps Pipeline Project== | ||
− | The OWASP AppSec Rugged DevOps Pipeline Project is the place to find the information you need to increase the speed and automation of your AppSec program. Using the documentation and references of this project will allow you to setup your own AppSec Pipeline. | + | The OWASP AppSec Rugged DevOps Pipeline Project is the place to find the information you need to increase the speed and automation of your AppSec program. Using the sample implementation, documentation and references of this project will allow you to setup your own AppSec Pipeline. |
==Description== | ==Description== | ||
The AppSec pipeline project is a place to gather together information, techniques and tools to create your own AppSec Pipeline. AppSec Pipelines takes the | The AppSec pipeline project is a place to gather together information, techniques and tools to create your own AppSec Pipeline. AppSec Pipelines takes the | ||
− | + | principles of DevOps and Lean and applies that to an application security program. The project will gather references, code, and specific guidance for tools/software which would compose an AppSec Pipeline. | |
==Licensing== | ==Licensing== | ||
Line 21: | Line 21: | ||
<!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | <!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | ||
− | | valign="top" | + | | valign="top" style="padding-left:25px;width:200px;border-right: 1px dotted gray;padding-right:25px;" | |
− | == What is OWASP | + | == What is the OWASP AppSec Pipeline Project? == |
− | The AppSec | + | The AppSec Pipeline project is a place to gather together information, techniques and tools to create your own AppSec Pipeline. |
== Project Leaders == | == Project Leaders == | ||
[mailto:[email protected] Matt Tesauro]<br /> | [mailto:[email protected] Matt Tesauro]<br /> | ||
− | [mailto:[email protected] Aaron Weaver]<br/> | + | [mailto:[email protected] Aaron Weaver]<br /> |
− | + | ||
+ | == Contributors == | ||
+ | |||
+ | <br /> | ||
== Related Projects == | == Related Projects == | ||
Line 37: | Line 40: | ||
[[OWASP_Web_Testing_Environment_Project]] | [[OWASP_Web_Testing_Environment_Project]] | ||
− | <!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | + | <!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE -->| valign="top" style="padding-left:25px;width:200px;" | |
− | | valign="top" | ||
− | |||
− | |||
− | |||
− | |||
== News and Events == | == News and Events == | ||
− | + | [https://raw.githubusercontent.com/appsecpipeline/AppSecPipeline-Specification/master/reference/diagrams/pipeline-static.png AppSecPipeline Specification Diagram] | |
− | |||
== In Print == | == In Print == | ||
Line 54: | Line 51: | ||
==Classifications== | ==Classifications== | ||
− | |||
{| width="200" cellpadding="2" | {| width="200" cellpadding="2" | ||
|- | |- | ||
− | | align="center" valign="top" width="50% | + | | rowspan="2" align="center" valign="top" width="50%" | [[File:New projects.png|100px|link=https://www.owasp.org/index.php/OWASP_Project_Stages#tab=Incubator_Projects]] |
− | | align="center" valign="top" width="50%"| [[File:Owasp-breakers-small.png|link=]] | + | | align="center" valign="top" width="50%" | [[File:Owasp-breakers-small.png|link=]] |
|- | |- | ||
− | | align="center" valign="top" width="50%"| [[File:Owasp-defenders-small.png|link=]] | + | | align="center" valign="top" width="50%" | [[File:Owasp-defenders-small.png|link=]] |
|- | |- | ||
− | | colspan="2" align="center" | + | | colspan="2" align="center" | [[File:Cc-button-y-sa-small.png|link=http://creativecommons.org/licenses/by-sa/3.0/]] |
|- | |- | ||
− | | colspan="2" align="center" | + | | colspan="2" align="center" | [[File:Project_Type_Files_DOC.jpg|link=]]<br /> <br />[[File:Project_Type_Files_CODE.jpg|link=]]<br /> <br />[[File:Project_Type_Files_TOOL.jpg|link=]] |
|} | |} | ||
|} | |} | ||
− | |||
=Pipeline Tools= | =Pipeline Tools= | ||
Line 91: | Line 86: | ||
We are currently working on gathering a list of the current tools and evaluating each tool based on the criteria listed. The goal is to create a one page wiki document of the application. | We are currently working on gathering a list of the current tools and evaluating each tool based on the criteria listed. The goal is to create a one page wiki document of the application. | ||
+ | |||
+ | ==Sample Tooling by Phase== | ||
+ | |||
+ | [[File:DevOps_AppSec_Tool_Integration.png]] | ||
==Get Involved== | ==Get Involved== | ||
Line 99: | Line 98: | ||
==What is an AppSec Pipeline?== | ==What is an AppSec Pipeline?== | ||
− | An AppSec Pipelines takes the | + | An AppSec Pipelines takes the principles of DevOps and Lean and applies that to an application security program. An AppSec pipeline is designed for iterative improvement and has the ability to grow in functionality organically over time. When starting out an AppSec Pipeline choose the area that is your greatest pain point and work on a reusable path for all the AppSec activities that follow. |
− | Pipelines have | + | Pipelines have four distinct areas which will be covered in depth. The first is the "Intake process" or "first impression." This is where customers request AppSec services such as dynamic, static or manual assessments from the AppSec team. The intake process consists of an application repository that a requestor will either choose from a listing of applications or provide the details of the application. The second part is "triage" where the determination is made for applying the requested services. An application request may have an automated scan in which case a request would be made to conduct a ZAP scan. The third part is "test" which is the heart of the pipeline. It is here where all the AppSec tools are automated, results are fed into a central repository and reviewed for false positives. Finally the end of the pipeline is "deliver" where the results are distributed to the customer. This will vary by organization, however most pipelines will integrate with a defect tracker and will produce summary metrics and reporting for senior management. |
The goal of an AppSec Pipeline is to provides a consistent process from the application security team and the constituency which typically is developers, QA, product managers and senior stakeholders. Throughout the process flow each activity has well-defined states. The pipeline relies heavily on automation for repeatable tasks so that the critical resource, AppSec personnel, is optimized. | The goal of an AppSec Pipeline is to provides a consistent process from the application security team and the constituency which typically is developers, QA, product managers and senior stakeholders. Throughout the process flow each activity has well-defined states. The pipeline relies heavily on automation for repeatable tasks so that the critical resource, AppSec personnel, is optimized. | ||
Line 107: | Line 106: | ||
[[File:AppSec_Pipeline_Rugged_DevOps.png|800px|thumb|left|Rugged DevOps AppSec Pipeline Template]] | [[File:AppSec_Pipeline_Rugged_DevOps.png|800px|thumb|left|Rugged DevOps AppSec Pipeline Template]] | ||
− | <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> | + | <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> |
+ | <br> | ||
+ | ===Pipeline - Intake (“First Impression”)=== | ||
+ | The intake portion of the pipeline is one of the most important aspects of the pipeline. It is here where services are requested from the team. Each service request should be clearly stated and defined. For example consider grouping service requests into bundles. An application security assessment usually consists of a dynamic scan, static scan and manual review. Bundle these into one request and title it 'Application Security Assessment'. | ||
+ | |||
+ | The pipeline request should feed into an application repository that keeps track of the metadata on the application, key contacts, prior engagements and current vulnerabilities. | ||
+ | |||
+ | '''Application Metadata'''<br> | ||
+ | Knowing the background details about an application is an important part of carrying out a successful application assessment. By gathering this data key decisions can be automated. For example if you know that the application being assessed is a critical application, has PII and has 1 million records then you can automatically recommend and or require certain activities. These activities could include a threat model, an automated assessment with manual review.<br> | ||
+ | |||
+ | Key fields recommended for intake are the following:<br> | ||
− | + | *'''Application General Information''': Name, Brief Description, Business Line<br> | |
− | + | *'''Application Metadata''': Business Criticality, Platform, LIfecycle, Origin, User Records, Revenue, External Audience, Internet Accessible<br> | |
− | ''' | + | *'''Technologies''': Coding Language, Data Store, DDoS Protection, Firewall, Framework, Hosting Provider, Operation System, Third-Party Component, Web Server<br> |
− | * | + | *'''Regulations''': Examples: PCI, SOC, FERPA DPA, SOX etc.<br> |
− | * | + | *'''Data Elements''': PII (First name, Last name, Email, Address, Postal Code, Social)<br> |
− | * | ||
− | |||
'''Key Concepts''' | '''Key Concepts''' | ||
− | *Ask for data about | + | * Bundle application service requests instead of offering al la carte. |
− | *Have data reviewed when | + | *Ask for data about applications only once |
− | * | + | *Have data reviewed periodically. (A great time is when new services are requested on the application.) |
+ | |||
+ | '''Recommended Tools''' | ||
+ | A complete listing of tools and review will be in the Pipeline Tools section. | ||
+ | * : An application security utility to assist in the organization and prioritization of software security activities and defect tracking application. | ||
+ | **Dashboard showing entire application portfolio and last engagement dates | ||
+ | **Applications requiring engagements | ||
+ | **Importers for many scanners | ||
+ | **Integration with Jira | ||
+ | **API for integration with security tools | ||
− | ===Pipeline - | + | ===Pipeline - Triage === |
* Inbound request triage | * Inbound request triage | ||
**Ala Carte App Sec | **Ala Carte App Sec | ||
Line 135: | Line 151: | ||
*People focus on customization rather than setup | *People focus on customization rather than setup | ||
− | ===Pipeline - | + | ===Pipeline - Test=== |
+ | |||
+ | ===Pipeline - Deliver=== | ||
Source of truth for all AppSec activities | Source of truth for all AppSec activities | ||
*Dedupe / Consolidate findings | *Dedupe / Consolidate findings | ||
Line 143: | Line 161: | ||
* Report and metrics automation REST + tfclient | * Report and metrics automation REST + tfclient | ||
*Source of many touch points with external teams | *Source of many touch points with external teams | ||
+ | |||
+ | ===How do I integrate an AppSec Pipeline into my existing pipeline(s)?=== | ||
+ | |||
+ | [[File:DevOps_AppSec_Pipline_Integration.png|800px|thumb|left|Example Integration of DevOps and AppSec Pipeline]] | ||
+ | <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> | ||
==AppSec Pipeline Example #1== | ==AppSec Pipeline Example #1== | ||
− | |||
[[File:AppSec-Pipeline-Example.png|800px|thumb|left|Example Rugged DevOps AppSec Pipeline]] | [[File:AppSec-Pipeline-Example.png|800px|thumb|left|Example Rugged DevOps AppSec Pipeline]] | ||
Line 153: | Line 175: | ||
'''AppSec Pipeline Presentations''' | '''AppSec Pipeline Presentations''' | ||
− | *[https://www.youtube.com/watch?v=1CDSOSl4DQU Building An AppSec Pipeline] Aaron Weaver - AppSec EU 2015 | + | *[https://www.youtube.com/watch?v=1CDSOSl4DQU Building An AppSec Pipeline] Aaron Weaver - AppSec EU 2015 |
*[https://www.youtube.com/watch?v=tDnyFitE0y4 Taking DevOps Practices Into Your AppSec Life] Matt Tesauro - AppSec EU 2015 | *[https://www.youtube.com/watch?v=tDnyFitE0y4 Taking DevOps Practices Into Your AppSec Life] Matt Tesauro - AppSec EU 2015 | ||
Line 166: | Line 188: | ||
* [http://gotocon.com/dl/goto-london-2015/slides/JamesWickett_HowToEffectChangeInTheEpistemologicalWastelandOfApplicationSecurity.pdf How to effect change in the Epistemological Wasteland of Application Security] James Wickett - GOTO 2015 | * [http://gotocon.com/dl/goto-london-2015/slides/JamesWickett_HowToEffectChangeInTheEpistemologicalWastelandOfApplicationSecurity.pdf How to effect change in the Epistemological Wasteland of Application Security] James Wickett - GOTO 2015 | ||
− | = | + | =Milestones= |
− | === | + | ===Dockers Released === |
+ | *Released [https://hub.docker.com/u/appsecpipeline/ AppSec Docker] | ||
+ | |||
+ | ===Docker AppSec Pipeline Specification Released=== | ||
+ | *Beta Release: View the [https://github.com/appsecpipeline/AppSecPipeline-Specification Github repo] and specification | ||
=FAQs= | =FAQs= | ||
Line 185: | Line 211: | ||
Besides the project leaders, contributions have been made by: | Besides the project leaders, contributions have been made by: | ||
− | * | + | * |
− | + | ||
− | + | = Getting Involved = | |
+ | |||
+ | Involvement in the DevOps AppSec Pipeline is actively encouraged! | ||
+ | |||
+ | You do not have to be a security expert in order to contribute. | ||
+ | |||
+ | Some of the ways you can help: | ||
+ | |||
+ | ==Case Studies== | ||
+ | |||
+ | Share your AppSec Pipeline! We would like to gather case studies on how organizations are addressing AppSec at scale. Please email the project leaders to have your case study added. | ||
− | = | + | ==Tools== |
+ | Is there a tool that is missing from our AppSec tooling review? Has your organization integrated or created a tool that integrates into the AppSec pipeline? Click on the 'Pipeline Tool's to contribute your review/tool. | ||
− | + | ==Feedback== | |
− | |||
− | |||
− | |||
+ | Please use our mailing list for feedback: | ||
+ | * What do like? | ||
+ | * What don't you like? | ||
<!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | <!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | ||
__NOTOC__ <headertabs /> | __NOTOC__ <headertabs /> | ||
− | [[Category:OWASP Project]] | + | [[Category:OWASP Project]] |
+ | [[Category:OWASP_Builders]] | ||
+ | [[Category:OWASP_Defenders]] | ||
+ | [[Category:OWASP_Document]] | ||
+ | [[Category:Projects|AppSec Pipeline]] | ||
+ | [[Category:Incubator Projects|AppSec Pipeline]] | ||
+ | [[Category:OWASP AppSec Pipeline|AppSec Pipeline]] |
Latest revision as of 16:39, 25 March 2018
- Main
- Pipeline Tools
- Pipeline Design Patterns
- Presentations
- Milestones
- FAQs
- Acknowledgements
- Getting Involved
The OWASP AppSec Rugged DevOps Pipeline ProjectThe OWASP AppSec Rugged DevOps Pipeline Project is the place to find the information you need to increase the speed and automation of your AppSec program. Using the sample implementation, documentation and references of this project will allow you to setup your own AppSec Pipeline. DescriptionThe AppSec pipeline project is a place to gather together information, techniques and tools to create your own AppSec Pipeline. AppSec Pipelines takes the principles of DevOps and Lean and applies that to an application security program. The project will gather references, code, and specific guidance for tools/software which would compose an AppSec Pipeline. LicensingThe OWASP AppSec Pipeline Project documentation is licensed under the Creative Commons Attribution-ShareAlike 3.0 license, so you can copy, distribute and transmit the work, and you can adapt it, and use it commercially, but all provided that you attribute the work and if you alter, transform, or build upon this work, you may distribute the resulting work only under the same or similar license to this one. |
What is the OWASP AppSec Pipeline Project?The AppSec Pipeline project is a place to gather together information, techniques and tools to create your own AppSec Pipeline. Project LeadersContributors
Related Projects |
News and EventsAppSecPipeline Specification Diagram In PrintBuilding an AppSec Pipeline Classifications
|
What are DevOp Security Pipeline Tools?
DevOp security pipeline tools are written with the mindset of API first. The goal is that a security tool will expose all the core functionality of the product as an API. Tools need to have an API so that the 'All the things' can be automated. Each tool will be evaluated with the criteria outlined below including example pipeline use cases.
Evaluation Criteria
Application Description: Overview of the security tool, description and product web page.
API: The type of API (REST, SOAP), API coverage (% of total features available via the API) and API Docs.
Pipeline Position: Where in the AppSec pipeline the tool would be best suited to reside
Cloud Scalable: Is the tool cloud aware and can the tool scale based on demand?
Runs as a Service: Can the tool run as a service or in headless mode?
Pipeline Example: Link to an example use case of the tool in the pipeline
Client Libraries: What client libraries are written to assist in integration. For example a python or Go library.
CI/CD Plugins: Does the tool have CI/CD plugins for integration into a DevOps pipeline. For example a Jenkins plugin.
Data Sent to the Cloud: What kind of data, if any, is sent off premise to the cloud? Is there an option to keep all data in-house?
Results
We are currently working on gathering a list of the current tools and evaluating each tool based on the criteria listed. The goal is to create a one page wiki document of the application.
Sample Tooling by Phase
Get Involved
Interested in participating or having your product included in the review? Contact Aaron Weaver
What is an AppSec Pipeline?
An AppSec Pipelines takes the principles of DevOps and Lean and applies that to an application security program. An AppSec pipeline is designed for iterative improvement and has the ability to grow in functionality organically over time. When starting out an AppSec Pipeline choose the area that is your greatest pain point and work on a reusable path for all the AppSec activities that follow.
Pipelines have four distinct areas which will be covered in depth. The first is the "Intake process" or "first impression." This is where customers request AppSec services such as dynamic, static or manual assessments from the AppSec team. The intake process consists of an application repository that a requestor will either choose from a listing of applications or provide the details of the application. The second part is "triage" where the determination is made for applying the requested services. An application request may have an automated scan in which case a request would be made to conduct a ZAP scan. The third part is "test" which is the heart of the pipeline. It is here where all the AppSec tools are automated, results are fed into a central repository and reviewed for false positives. Finally the end of the pipeline is "deliver" where the results are distributed to the customer. This will vary by organization, however most pipelines will integrate with a defect tracker and will produce summary metrics and reporting for senior management.
The goal of an AppSec Pipeline is to provides a consistent process from the application security team and the constituency which typically is developers, QA, product managers and senior stakeholders. Throughout the process flow each activity has well-defined states. The pipeline relies heavily on automation for repeatable tasks so that the critical resource, AppSec personnel, is optimized.
Pipeline - Intake (“First Impression”)
The intake portion of the pipeline is one of the most important aspects of the pipeline. It is here where services are requested from the team. Each service request should be clearly stated and defined. For example consider grouping service requests into bundles. An application security assessment usually consists of a dynamic scan, static scan and manual review. Bundle these into one request and title it 'Application Security Assessment'.
The pipeline request should feed into an application repository that keeps track of the metadata on the application, key contacts, prior engagements and current vulnerabilities.
Application Metadata
Knowing the background details about an application is an important part of carrying out a successful application assessment. By gathering this data key decisions can be automated. For example if you know that the application being assessed is a critical application, has PII and has 1 million records then you can automatically recommend and or require certain activities. These activities could include a threat model, an automated assessment with manual review.
Key fields recommended for intake are the following:
- Application General Information: Name, Brief Description, Business Line
- Application Metadata: Business Criticality, Platform, LIfecycle, Origin, User Records, Revenue, External Audience, Internet Accessible
- Technologies: Coding Language, Data Store, DDoS Protection, Firewall, Framework, Hosting Provider, Operation System, Third-Party Component, Web Server
- Regulations: Examples: PCI, SOC, FERPA DPA, SOX etc.
- Data Elements: PII (First name, Last name, Email, Address, Postal Code, Social)
Key Concepts
- Bundle application service requests instead of offering al la carte.
- Ask for data about applications only once
- Have data reviewed periodically. (A great time is when new services are requested on the application.)
Recommended Tools A complete listing of tools and review will be in the Pipeline Tools section.
- : An application security utility to assist in the organization and prioritization of software security activities and defect tracking application.
- Dashboard showing entire application portfolio and last engagement dates
- Applications requiring engagements
- Importers for many scanners
- Integration with Jira
- API for integration with security tools
Pipeline - Triage
- Inbound request triage
- Ala Carte App Sec
- Dynamic Testing
- Static Testing
- Re-Testing mitigated findings
- Mix and match based on risk
Key Concepts
- Activities can be run in parallel
- Automation on setup, configuration, data export
- People focus on customization rather than setup
Pipeline - Test
Pipeline - Deliver
Source of truth for all AppSec activities
- Dedupe / Consolidate findings
- Normalize scanner data
- Generate Metrics
- Push issues to bug trackers
- Report and metrics automation REST + tfclient
- Source of many touch points with external teams
How do I integrate an AppSec Pipeline into my existing pipeline(s)?
AppSec Pipeline Example #1
AppSec Pipeline Presentations
- Building An AppSec Pipeline Aaron Weaver - AppSec EU 2015
- Taking DevOps Practices Into Your AppSec Life Matt Tesauro - AppSec EU 2015
Rugged DevOp Interviews
- DevOps, Security and Development w/ Matt Tesauro, Jez Humble and Shannon Lietz AppSec USA 2015
- Pipeline Project Interview Matt Konda - AppSec USA 2015
Rugged DevOps
- The Road to Being Rugged Shannon Lietz - GOTO 2015
- When Devops Meets Security Michael Brunton-Spall - GOTO 2015
- Rugged Building Materials and Creating Agility with Security David Etue - GOTO 2015
- How to effect change in the Epistemological Wasteland of Application Security James Wickett - GOTO 2015
Dockers Released
- Released AppSec Docker
Docker AppSec Pipeline Specification Released
- Beta Release: View the Github repo and specification
Contributors
Besides the project leaders, contributions have been made by:
Involvement in the DevOps AppSec Pipeline is actively encouraged!
You do not have to be a security expert in order to contribute.
Some of the ways you can help:
Case Studies
Share your AppSec Pipeline! We would like to gather case studies on how organizations are addressing AppSec at scale. Please email the project leaders to have your case study added.
Tools
Is there a tool that is missing from our AppSec tooling review? Has your organization integrated or created a tool that integrates into the AppSec pipeline? Click on the 'Pipeline Tool's to contribute your review/tool.
Feedback
Please use our mailing list for feedback:
- What do like?
- What don't you like?