Skip to content

A library to detect well-known licenses based on their title or content.

License

Notifications You must be signed in to change notification settings

aternosorg/php-licensee

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PHP-Licensee

This library can be used to detect well-known licenses based on their title or content. PHP-Licensee is based on the Licensee Ruby Gem, but not quite a full port.

Information about licenses is generated from data from choosealicense.com and the SPDX License List. Note that only licenses that are listed on choosealicense.com can be detected by this library.

Installation

composer require aternos/licensee

Usage

$licensee = new \Aternos\Licensee\Licensee();

Detect license by ID string

$license = $licensee->findLicenseById('mit');
echo "Found " . $license->getTitle() . "\n";

Detect license by title

$license = $licensee->findLicenseByTitle('MIT License');
echo "Found " . $license->getTitle() . "\n";

Setting the optional argument allowMatchWithoutVersion to true will allow the detection of licenses without considering the version number, in case no exact match can be found.

Detect license by content

$content = new \Aternos\Licensee\License\Text\LicenseText(file_get_contents('LICENSE'), 'LICENSE');
$match = $licensee->findLicenseByContent($content);
echo "Found " . $match->getLicense()->getTitle() . "\n";
echo "Confidence: " . $match->getConfidence() . "\n";

This will try to find a license that is an exact match (after some normalization steps), or use a version of the Dice-Sørensen coefficient.

Optionally, a confidenceThreshold value between 0 and 100 can be supplied to findLicenseByContent. If not set, the default value of 98.0 will be used.

Get license information

Most of the information available on choosealicense.com can be accessed through the license object:

$license = $licensee->findLicenseById('mit');

echo "Title: " . $license->getTitle() . "\n";
echo "ID: " . $license->getSpdxId()->value . "\n";
echo "Description: " . $license->getDescription() . "\n";
echo "How: " . $license->getHow() . "\n";

echo "Using:\n";
foreach ($license->getUsing() as $using) {
    echo "  - " . $using . "\n";
}

echo "Permissions:\n";
foreach ($license->getPermissions() as $permission) {
    echo "  - " . $permission->getLabel() . ": " . $permission->getDescription() . "\n";
}

echo "Conditions:\n";
foreach ($license->getConditions() as $condition) {
    echo "  - " . $condition->getLabel() . ": " . $condition->getDescription() . "\n";
}

echo "Limitations:\n";
foreach ($license->getLimitations() as $limitation) {
    echo "  - " . $limitation->getLabel() . ": " . $limitation->getDescription() . "\n";
}

Key differences to Ruby Licensee

No projects

This library does not automatically scan project directories for license files or package metadata. Finding the correct license file is up to the user.

No pseudo licenses

Ruby Licensee can return the pseudo licenses other and no-license if no license could be detected. This library will simply return null in this case.

About

A library to detect well-known licenses based on their title or content.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages