Skip to content

Commit

Permalink
Prototype implementation of the push to DejaCode #6
Browse files Browse the repository at this point in the history
Signed-off-by: tdruez <[email protected]>
  • Loading branch information
tdruez committed Apr 25, 2024
1 parent 6cebf8d commit 231347a
Show file tree
Hide file tree
Showing 3 changed files with 4,611 additions and 0 deletions.
17 changes: 17 additions & 0 deletions .github/workflows/push-to-dejacode.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
on: [push]

jobs:
scan-codebase:
runs-on: ubuntu-22.04
name: Scan codebase with ScanCode.io
steps:
- uses: nexB/scancode-action@alpha
with:
pipelines: "scan_codebase"
output-formats: "json"
project-name: "packageurl-python"
input-urls:
https://github.com/package-url/packageurl-python/releases/download/v0.15.0/packageurl-python-0.15.0.tar.gz
env:
DEJACODE_URL: ${{ secrets.DEJACODE_URL }}
DEJACODE_API_KEY: ${{ secrets.DEJACODE_API_KEY }}
73 changes: 73 additions & 0 deletions scripts/push_to_dejacode.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
# SPDX-License-Identifier: Apache-2.0
#
# http://nexb.com and https://github.com/nexB/scancode.io
# The ScanCode.io software is licensed under the Apache License version 2.0.
# Data generated with ScanCode.io is provided as-is without warranties.
# ScanCode is a trademark of nexB Inc.
#
# You may not use this software except in compliance with the License.
# You may obtain a copy of the License at: http://apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing, software distributed
# under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
# CONDITIONS OF ANY KIND, either express or implied. See the License for the
# specific language governing permissions and limitations under the License.
#
# Data Generated with ScanCode.io is provided on an "AS IS" BASIS, WITHOUT WARRANTIES
# OR CONDITIONS OF ANY KIND, either express or implied. No content created from
# ScanCode.io should be considered or used as legal advice. Consult an Attorney
# for any legal advice.
#
# ScanCode.io is a free software code scanning tool from nexB Inc. and others.
# Visit https://github.com/nexB/scancode.io for support and download.

import requests
import os

DEJACODE_URL = os.environ["DEJACODE_URL"]
DEJACODE_API_KEY = os.environ["DEJACODE_API_KEY"]

DEJACODE_API_URL = f"{DEJACODE_URL.rstrip('/')}/api/"
PRODUCTS_API_URL = f"{DEJACODE_API_URL}v2/products/"
DEFAULT_TIMEOUT = 10

session = requests.Session()
if DEJACODE_API_KEY:
session.headers.update({"Authorization": f"Token {DEJACODE_API_KEY}"})


def request_post(url, **kwargs):
"""Return the response from an HTTP POST request on the provided `url` ."""
if "timeout" not in kwargs:
kwargs["timeout"] = DEFAULT_TIMEOUT

# Do not `raise_for_status` as the response may contain valuable data
# even on non 200 status code.
try:
response = session.post(url, **kwargs)
return response.json()
except (requests.RequestException, ValueError, TypeError) as exception:
print(f"[Exception] {exception}")


def create_product(product_data):
response = request_post(PRODUCTS_API_URL, data=product_data)
print(response)
return response["uuid"]


def push_scan_to_product(files):
url = f"{PRODUCTS_API_URL}{product_uuid}/import_from_scan/"
response = request_post(url, files=files)
print(response)


if __name__ == "__main__":
product_data = {
"name": "Demo Push Product",
"version": "1.0",
}
product_uuid = create_product(product_data)

scan_location = "./scancodeio_packageurl-python-0.15.0.tar.gz.json"
files = {"upload_file": open(scan_location, "rb")}
push_scan_to_product(files)
Loading

0 comments on commit 231347a

Please sign in to comment.