The SCANOSS java package provides a simple, easy to consume library for interacting with SCANOSS APIs.
The latest version of the package can be found on Maven Central.
Include in a maven project using:
<dependency>
<groupId>com.scanoss</groupId>
<artifactId>scanoss</artifactId>
<version>0.7.0</version>
</dependency>
And in gradle using:
implementation group: 'com.scanoss', name: 'scanoss', version: '0.1.3'
Examples of consuming this SDK can be found in the cli package folder.
Specifically, the ScanCommandLine.java shows how to instantiate
the Scanner
class to initiate a scan.
Here is a simple way to initiate a scan using all the SCANOSS defaults:
import com.scanoss.Scanner;
public class Test {
public static void main(String[] args) {
Scanner scanner = Scanner.builder().build();
String file = "test.java";
String result = scanner.scanFile(file);
}
}
The package also ships with a sample CLI. It can be run using the example script scanoss-cli.sh:
scanos-cli.sh -h
In order to connect to a SCANOSS server with a custom (self-signed) certificate, the keychain will need to be imported onto the CA Certs into the instance of java before proceeding:
keytool -cacerts -importcert -file custom-key-chain.pem
Before starting with development of this project, please read our CONTRIBUTING and CODE OF CONDUCT.
Java 11 or higher.
The dependencies can be found in the pom.xml.
A full set of unit tests are included with the package.
To run tests, using the following command:
make test
The version of the package is defined in the pom.xml file. Please update this version before packaging/releasing an update.
The following commands are provided for incrementing version:
make inc_path
make inc_minor
make inc_major
To package the library, please run:
make package
Check for dependency updates:
mvn versions:display-dependency-updates
Then deploy to prod:
make deploy
This will deploy the package to Maven Central.
Alternatively pushing a tagged version to GitHub will trigger the Release Action to automate the deployment.
To request features or alert about bugs, please do so here.
Details of major changes to the library can be found in CHANGELOG.md.