-
Notifications
You must be signed in to change notification settings - Fork 127
126 lines (113 loc) · 5.07 KB
/
CI_license_compliance.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
name: Core / License Compliance
on:
pull_request:
# paths:
# - "integrations/**/pyproject.toml"
# Since we test PRs, there is no need to run the workflow at each
# merge on `main`. Let's use a cron job instead.
schedule:
- cron: "0 0 * * *" # every day at midnight
env:
# CORE_DATADOG_API_KEY: ${{ secrets.CORE_DATADOG_API_KEY }}
PYTHON_VERSION: "3.10"
EXCLUDE_PACKAGES: "(?i)^(deepeval|cohere|fastembed|ragas|haystack-pydoc-tools|tqdm|psycopg).*"
# Exclusions in the vanilla must be explicitly motivated
#
# - deepeval is Apache 2.0 but the license is not available on PyPI
# - cohere is MIT but the license is not available on PyPI
# - fastembed is Apache 2.0 but the license on PyPI is unclear ("Other/Proprietary License (Apache License)")
# - ragas is Apache 2.0 but the license is not available on PyPI
# - haystack-pydoc-tools is Apache 2.0 but the license is not available on PyPI
# - tqdm is MLP but there are no better alternatives
# - psycopg is LGPL-3.0
jobs:
license_check_direct:
name: Direct dependencies only
env:
REQUIREMENTS_FILE: requirements_direct.txt
runs-on: ubuntu-latest
steps:
- name: Checkout the code
uses: actions/checkout@v4
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version: "${{ env.PYTHON_VERSION }}"
- name: Get changed pyproject files (for pull requests only)
if: ${{ github.event_name == 'pull_request' }}
id: changed-files
uses: tj-actions/changed-files@v45
with:
files: |
integrations/**/pyproject.toml
- name: Get direct dependencies from pyproject.toml files
run: |
pip install toml
> ${{ env.REQUIREMENTS_FILE }} # Empty the requirements file if it exists
# if [ "${{ github.event_name }}" = "schedule" ]; then
if true; then
echo "Scheduled run: processing all pyproject.toml files..."
find integrations -type f -name 'pyproject.toml' | while read file; do
python .github/utils/pyproject_to_requirements.py $file >> ${{ env.REQUIREMENTS_FILE }}
echo "" >> ${{ env.REQUIREMENTS_FILE }} # Add a newline for separation
done
else
echo "Pull request: processing changed pyproject.toml files..."
for file in ${{ steps.changed-files.outputs.all_changed_files }}; do
python .github/utils/pyproject_to_requirements.py $file >> ${{ env.REQUIREMENTS_FILE }}
echo "" >> ${{ env.REQUIREMENTS_FILE }} # Add a newline for separation
done
fi
- name: Check Licenses
id: license_check_report
uses: pilosus/action-pip-license-checker@v2
with:
github-token: ${{ secrets.GH_ACCESS_TOKEN }}
requirements: ${{ env.REQUIREMENTS_FILE }}
fail: "Copyleft,Other,Error"
# Exclusions in the vanilla distribution must be explicitly motivated
#
# - tqdm is MLP but there are no better alternatives
exclude: "${{ env.EXCLUDE_PACKAGES }}"
# # We keep the license inventory on FOSSA
# - name: Send license report to Fossa
# uses: fossas/[email protected]
# continue-on-error: true # not critical
# with:
# api-key: ${{ secrets.FOSSA_LICENSE_SCAN_TOKEN }}
- name: Print report
if: ${{ always() }}
run: echo "${{ steps.license_check_report.outputs.report }}"
# - name: Calculate alert data
# id: calculator
# shell: bash
# if: (success() || failure())
# run: |
# if [ "${{ job.status }}" = "success" ]; then
# echo "alert_type=success" >> "$GITHUB_OUTPUT";
# else
# echo "alert_type=error" >> "$GITHUB_OUTPUT";
# fi
# - name: Send event to Datadog
# # This step would fail when running in PRs opened from forks since
# # secrets are not accessible.
# # To prevent showing bogus failures in those PRs we skip the step.
# # The workflow will fail in any case if the actual check fails in the previous steps.
# if: (success() || failure()) && env.CORE_DATADOG_API_KEY != ''
# uses: masci/datadog@v1
# with:
# api-key: ${{ env.CORE_DATADOG_API_KEY }}
# api-url: https://api.datadoghq.eu
# events: |
# - title: "${{ github.job }} in ${{ github.workflow }} workflow"
# text: "License compliance check: direct dependencies only."
# alert_type: "${{ steps.calculator.outputs.alert_type }}"
# source_type_name: "Github"
# host: ${{ github.repository_owner }}
# tags:
# - "project:${{ github.repository }}"
# - "job:${{ github.job }}"
# - "run_id:${{ github.run_id }}"
# - "workflow:${{ github.workflow }}"
# - "branch:${{ github.ref_name }}"
# - "url:https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}"