-
Notifications
You must be signed in to change notification settings - Fork 59
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Joyce Quach <[email protected]>
- Loading branch information
Showing
7 changed files
with
40 additions
and
15,152 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,12 +2,17 @@ name: Convert CCI List XML to JSON | |
|
||
on: | ||
push: | ||
branches: ['master'] | ||
# branches: ['master'] | ||
branches: ['add-convert-cci-list-workflow'] | ||
|
||
# Run this workflow at 00:00 every month | ||
schedule: | ||
- cron: '0 0 1 * *' | ||
|
||
env: | ||
# This URL is super brittle with how links constantly get changed. | ||
CCI_LIST_ZIP_URL: https://dl.dod.cyber.mil/wp-content/uploads/stigs/zip/U_CCI_List.zip | ||
|
||
jobs: | ||
convert-cci-list: | ||
runs-on: ubuntu-22.04 | ||
|
@@ -26,49 +31,32 @@ jobs: | |
run: yarn install --frozen-lockfile | ||
|
||
- name: Prepare environment | ||
run: apt update && apt install -y unzip | ||
run: apt update | ||
|
||
- name: Download CCI List | ||
run: curl -o U_CCI_List.zip https://dl.dod.cyber.mil/wp-content/uploads/stigs/zip/U_CCI_List.zip && unzip U_CCI_List.zip | ||
run: curl -o U_CCI_List.zip $CCI_LIST_ZIP_URL && unzip U_CCI_List.zip | ||
|
||
- name: Get publish date of CCI List | ||
id: publish-date | ||
uses: mavrosxristoforos/[email protected] | ||
with: | ||
xml-file: '/U_CCI_List/U_CCI_List.xml' | ||
xpath: '/cci_list/metadata/publishdate' | ||
|
||
- name: Convert CCI List XML to two JSON files | ||
run: yarn workspace @mitre/hdf-converters cciListXml2json /U_CCI_List/U_CCI_List.xml U_CCI_List.nist.json U_CCI_List.defs.json | ||
|
||
- name: Update CciNistMappingData.ts | ||
- name: Update CCI to NIST and CCI to Definition mappings | ||
run: | | ||
touch tmp.ts | ||
echo "export const CCI_TO_NIST: Record<string, string> = " >> tmp.ts | ||
cat U_CCI_List.nist.json >> tmp.ts | ||
echo ";" >> tmp.ts | ||
echo "export const CCI_TO_DEFINITION: Record<string, string> = " >> tmp.ts | ||
cat U_CCI_List.defs.json >> tmp.ts | ||
echo ";" >> tmp.ts | ||
cat tmp.ts > libs/hdf-converters/src/mappings/CciNistMappingData.ts | ||
rm tmp.ts | ||
mv U_CCI_List.nist.json libs/hdf-converters/src/mappings/ | ||
mv U_CCI_List.defs.json libs/hdf-converters/src/mappings/ | ||
- name: Commit changes to CciNistMappingData.ts | ||
env: | ||
DATETIME: ${{steps.publish-date.outputs}} | ||
run: | | ||
git config --local user.email "[email protected]" | ||
git config --local user.name "MITRE SAF Automation" | ||
git add libs/hdf-converters/src/mappings/CciNistMappingData.ts | ||
git commit -sm "Update CCI List to NIST and definition mappings" | ||
- name: Push changes to repository | ||
uses: ad-m/github-push-action@master | ||
with: | ||
github_token: ${{secrets.GITHUB_TOKEN}} | ||
branch: ${{github.ref}} | ||
prettier: | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- name: Checkout the code | ||
uses: actions/checkout@v4 | ||
with: | ||
ref: ${{github.head_ref}} | ||
fetch-depth: 0 | ||
|
||
- name: Prettify code | ||
uses: creyD/[email protected] | ||
with: | ||
only_changed: True | ||
git commit -sm "Update CCI List to the current NIST and definition mappings as of $DATETIME" | ||
git push |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.