1
0
mirror of https://github.com/danog/psalm.git synced 2024-12-15 02:47:02 +01:00
psalm/src/Psalm/Plugin/Shepherd.php

195 lines
8.0 KiB
PHP
Raw Normal View History

<?php
namespace Psalm\Plugin;
use Psalm\Codebase;
use Psalm\SourceControl\SourceControlInfo;
2019-03-31 20:02:30 +02:00
class Shepherd implements \Psalm\Plugin\Hook\AfterAnalysisInterface
{
/**
* Called after analysis is complete
* @param array<int, array{severity: string, line_from: int, line_to: int, type: string, message: string,
* file_name: string, file_path: string, snippet: string, from: int, to: int,
* snippet_from: int, snippet_to: int, column_from: int, column_to: int, selected_text: string}> $issues
*
* @return void
*/
public static function afterAnalysis(
Codebase $codebase,
array $issues,
array $build_info,
SourceControlInfo $source_control_info = null
) {
if (!function_exists('curl_init')) {
2019-03-31 20:23:05 +02:00
echo 'No curl found, cannot send data to ' . $codebase->config->shepherd_host . PHP_EOL;
return;
}
2019-03-28 17:06:21 +01:00
if ($source_control_info instanceof \Psalm\SourceControl\Git\GitInfo && $build_info) {
$data = [
'build' => $build_info,
'git' => $source_control_info->toArray(),
'issues' => array_filter(
$issues,
function (array $i) : bool {
return $i['severity'] === 'error';
}
),
'coverage_map' => $codebase->analyzer->getTypeCoverageMap($codebase),
'coverage' => $codebase->analyzer->getTotalTypeCoverage($codebase)
];
$payload = json_encode($data);
2019-03-31 20:02:30 +02:00
$base_address = $codebase->config->shepherd_host;
if (parse_url($base_address, PHP_URL_SCHEME) === null) {
$base_address = 'https://' . $base_address;
}
// Prepare new cURL resource
$ch = curl_init($base_address . '/telemetry');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLINFO_HEADER_OUT, true);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $payload);
// Set HTTP Header for POST request
curl_setopt(
$ch,
CURLOPT_HTTPHEADER,
[
'Content-Type: application/json',
'Content-Length: ' . strlen($payload)
]
);
// Submit the POST request
2019-03-28 17:06:21 +01:00
$return = curl_exec($ch);
if ($return !== '') {
2019-03-31 20:02:30 +02:00
echo 'Error with Psalm Shepherd:' . PHP_EOL;
2019-04-01 01:20:05 +02:00
if ($return === false) {
/** @var array */
$curl_info = curl_getinfo($ch);
if (($curl_info['ssl_verify_result'] ?? 0) !== 0) {
echo 'Curl SSL error: ';
switch ($curl_info['ssl_verify_result']) {
case 2:
echo 'unable to get issuer certificate';
break;
case 3:
echo 'unable to get certificate CRL';
break;
case 4:
echo 'unable to decrypt certificates signature';
break;
case 5:
echo 'unable to decrypt CRLs signature';
break;
case 6:
echo 'unable to decode issuer public key';
break;
case 7:
echo 'certificate signature failure';
break;
case 8:
echo 'CRL signature failure';
break;
case 9:
echo 'certificate is not yet valid';
break;
case 10:
echo 'certificate has expired';
break;
case 11:
echo 'CRL is not yet valid';
break;
case 12:
echo 'CRL has expired';
break;
case 13:
echo 'format error in certificates notBefore field';
break;
case 14:
echo 'format error in certificates notAfter field';
break;
case 15:
echo 'format error in CRLs lastUpdate field';
break;
case 16:
echo 'format error in CRLs nextUpdate field';
break;
case 17:
echo 'out of memory';
break;
case 18:
echo 'self signed certificate';
break;
case 19:
echo 'self signed certificate in certificate chain';
break;
case 20:
echo 'unable to get local issuer certificate';
break;
case 21:
echo 'unable to verify the first certificate';
break;
case 22:
echo 'certificate chain too long';
break;
case 23:
echo 'certificate revoked';
break;
case 24:
echo 'invalid CA certificate';
break;
case 25:
echo 'path length constraint exceeded';
break;
case 26:
echo 'unsupported certificate purpose';
break;
case 27:
echo 'certificate not trusted';
break;
case 28:
echo 'certificate rejected';
break;
case 29:
echo 'subject issuer mismatch';
break;
case 30:
echo 'authority and subject key identifier mismatch';
break;
case 31:
echo 'authority and issuer serial number mismatch';
break;
case 32:
echo 'key usage does not include certificate signing';
break;
case 50:
echo 'application verification failure';
break;
}
echo PHP_EOL;
} else {
echo var_export(curl_getinfo($ch), true) . PHP_EOL;
}
2019-04-01 01:20:05 +02:00
} else {
echo $return . PHP_EOL;
2019-04-01 02:47:33 +02:00
echo 'Git args: ' . var_export($source_control_info->toArray(), true) . PHP_EOL;
echo 'CI args: ' . var_export($build_info, true) . PHP_EOL;
2019-04-01 01:20:05 +02:00
}
2019-03-28 17:06:21 +01:00
}
// Close cURL session handle
curl_close($ch);
}
}
}