License Policy
License Policies allow you to define which package licenses are allowed within your organization. You can specify one or more licenses to exclude and an action to perform when a specified license is detected.
This is useful when you need to flag or optionally automatically quarantine a package based on the associated license.
Supported Package formats
Cloudsmith will automatically match licenses for the following package formats:
View License Policies
To manage the license policies in your workspace, go to your workspace's Settings page and select Manage Policies >> License Policies from the left-hand menu.
Deactivating a policy is not supported at this time, resulting in any policy created being active until deleted.
data:image/s3,"s3://crabby-images/317bd/317bd6df20b767065e91aa4c879ba761f2d405c6" alt="view_policy_new_1.png 1240"
Create License Policy
To add a new license to the deny list, click “Create License Policy”.
data:image/s3,"s3://crabby-images/df1ea/df1eab6811a8e8975a2a6c7cfd0944d8a0bb0981" alt="view_policy_new.png 1239"
Create License Policy Button
You are then presented with the “Create a License Policy” form:
data:image/s3,"s3://crabby-images/285d9/285d9a73e660f8ad6b6fd5980e5f0095a6c43a93" alt="create_license_form_new.png 1295"
Here you can define the following:
Name | A display name for the License Policy. |
Description | A description of the License Policy. |
Allow unknown or absent licenses | Set to “Yes” to ignore packages with missing or unknown licenses. Set to “No” to flag and quarantine packages with a missing or unknown license. Note: SPDX License List is used as the license source. If a package has a license that is not listed in the SPDX License List, this will be treated as an unknown license. |
Quarantine on violation | If set to "Yes", any package that violates this license policy is flagged and automatically quarantined. If set to "No", packages that violate this license policy are flagged, but not automatically quarantined. |
Select licenses to deny | Select the licenses to be denied as part of this policy. The licenses listed in this table are sourced from the SPDX License List. |
Once saved, the policy is enabled across your workspace and the policy compliance check will be performed automatically during the package synchronisation process. This process occurs when a package is uploaded, moved, copied, or cached (such as in upstream caching).
You can also manually trigger a synchronisation of a package using the resync functionality. See Package Resynchronization for instructions on how to do this.
Policy Violations
License policy violations can be viewed on the workspace and repository compliance dashboards. By selecting License Policy Violations from the overview, the table will filter to show all license policy violations across the workspace or repository.
data:image/s3,"s3://crabby-images/9f975/9f97598f43c2e26552be97705077ac90ec99767a" alt="violated policy warning.png 1129"
You can also search for policy violations using policy_violated:true
.
data:image/s3,"s3://crabby-images/cb38e/cb38e695377b4486222465d0a00be7f7d7fe7b32" alt="violated search.png 864"
You can view this violation list at any time using our package search (link) feature and setting the filter to
policy_violated:true
for all policy violations, orlicense_policy_violated:true
to only return license policy violations.
Policy Violation Identifiers
Within a repository, packages with policy violations are identified with the Policy Violation and Vulnerabilities icons.
data:image/s3,"s3://crabby-images/a5690/a569052214cf7907afddd8a5658465e7281db49a" alt="violation indicators.png 1126"
Policy Violation Indicators
![]() | Policy Violation | This package is in violation of policy. Click on the package to view more details. |
![]() | Quarantined | This package has been quarantined, downloads will be blocked until the package is released from quarantine. Reason given: the package was quarantined as a result of a policy violation |
Clicking on the package name displays the Package overview, which provides details on the policy violations for the package.
data:image/s3,"s3://crabby-images/a3abf/a3abfbf6f054c213efd08970c37c34d224600f1c" alt="package page warning.png"
By selecting License Policy Violation from the summary, you can view a list of all license policies the package violates and view and modify the policies from there.
data:image/s3,"s3://crabby-images/490b7/490b78657fe6dd0dc42d6f046abe2b17f7c81391" alt=""
Package Logs
Logs of policy violations and quarantining actions are also displayed within the Package Logs page.
Hover over the “policy violation” text to display additional details on the policy and license violation.
Restore a package that violates a policy
It's important to note that packages cannot be restored from quarantine if they are still in violation of an existing policy which has Quarantine on violation set to "Yes".
To remove a package from quarantine, you have four options:
- Change the package license to an allowed license via the license compliance section of the package's repository.
- Apply a manual license override of "ignored" or "purchased" via the license compliance section of the package's repository.
- Edit the license policy to remove the license from the deny list.
- Edit the license policy to set Quarantine on violation to "No".
If you change the package license, the package will be resynchronized and automatically undergo the policy check again. If the new license is not on the deny list, the package will no longer be marked as a policy violation and can be manually removed from quarantine.
If you update the policy to remove the license from the deny list or set Quarantine on violation set to "No", the package can be manually removed from quarantine.
See Package Quarantine for instructions on restoring a package from quarantine.
Updated 16 days ago