ONAP Policy Enhancements
Internship Projects/Mentors
Title | ONAP Policy Enhancements |
Status | Approved by tsc |
Difficulty | Medium |
Description
This internship is a great entry opportunity to contribute meaningful enhancements and improvements to the ONAP Policy code base. The Policy project is a core component of ONAP.
There are four focus areas of the internship: improving the security of the python code base, updating the ONAP oparent.pom, enhancing the Policy xacml policy decision point (xacml-pdp), and hardening the ONAP base images.
Python security improvement will provide the opportunity to understand the Policy code base by fixing problems identified by SonarCloud, upgrading vulnerable open source packages identified by NexusIQ scans, and improving the automated code coverage testing. Code improvement and package upgrades are regular code grooming activities that help to ensure that the ONAP code base remains secure. Code coverage testing is important to the community because it ensures that all code is tested before it is released to the community. This activity will provide an opportunity to learn more about test driven development by creating automated unit tests.
ONAP oparent.pom update is a straightforward activity that will give the resource the opportunity to learn how to find and integrate the latest open source packages into java projects.
The Policy xacml-pdp is a key component. This is a java development task to enhance the xacml policy decision point (pdp) with new capabilities such as more flexible time constraints and code refactoring to facilitate data validation.
ONAP image hardening includes grooming ubuntu, alpine and other docker base images for use in ONAP by tailoring each image for use with java or python. The creation of a variety of base images enables ONAP to support components with different requirements to build efficient and secure images.
Additional Information
https://wiki.onap.org/display/DW/Policy+Framework+Project
Repositories:
Learning Objectives
Understanding of the use of Policy within ONAP and the details of Policy code base.
Learning how to create automated unit tests.
Upgrading open source packages used in a project, working with commercial code scanning tools such as SonarCloud and NexusIQ.
Code contribution using gerrit, the ONAP CI/CD pipeline, Docker builds, Docker base images.
Expected Outcome
Updated oparent.pom file
Enhanced xacml-pdp module
Automated unit tests for xacml-pdp
Contribution of ONAP base images for Alpine
Relation to LF Networking
ONAP
Education Level
Skills
Java and Python
Future plans
Preferred Hours and Length of Internship
Full-time (40 hours a week for 12 weeks during the summer)
Mentor(s) Names and Contact Info
Jim Hahn, jh7358@att.com, AT&T
Pam Dragosh, pamela.dragosh@att.com, AT&T
Amy Zwarico, az9121@att.com, AT&T