Skip to content

Commit

Permalink
feat: add azure log handler
Browse files Browse the repository at this point in the history
  • Loading branch information
damikael committed Sep 4, 2024
1 parent 32cebe3 commit 9dce6cb
Show file tree
Hide file tree
Showing 5 changed files with 163 additions and 9 deletions.
11 changes: 10 additions & 1 deletion config_sample/config.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,18 @@
"install_dir": "/home/spid-cie-oidc-php",
"www_dir": "/var/www/html",
"service_name": "",
"log_path": "./log/spid-cie-oidc-php.log",
"homepage": "/test.php",
"default_domain": "default",

"log_handler": "stream",
"log_stream_path": "./log/spid-cie-oidc-php.log",
"log_azure_tenantId": "",
"log_azure_appId": "",
"log_azure_appSecret": "",
"log_azure_dceURI": "",
"log_azure_dcrImmutableId": "",
"log_azure_table": "",

"sa": {
"client_id": "http://relying-party-php.org:8003/",
"client_name": "Soggetto Aggregatore",
Expand Down
6 changes: 0 additions & 6 deletions config_sample/federation-authority.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,6 @@
"https://registry.spid.gov.it": {
"organization_name": "Federazione SPID"
},
"https://preprod.oidc.registry.servizicie.interno.gov.it": {
"organization_name": "Federazione preprod CIE"
},
"https://oidc.registry.servizicie.interno.gov.it": {
"organization_name": "Federazione CIE"
},
"http://127.0.0.1:8000": {
"organization_name": "Federazione test local"
},
Expand Down
Empty file modified data/.dummy
100644 → 100755
Empty file.
132 changes: 132 additions & 0 deletions lib/Core/AzureHandler.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,132 @@
<?php declare(strict_types=1);

/**
* spid-cie-oidc-php
* https://github.com/italia/spid-cie-oidc-php
*
* 2022 Michele D'Amico (damikael)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.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.
*
* @author Michele D'Amico <[email protected]>
* @license http://www.apache.org/licenses/LICENSE-2.0 Apache License 2.0
*/

//namespace Monolog\Handler;
namespace SPID_CIE_OIDC_PHP\Core;

use Monolog\Level;
use Monolog\Utils;
use Monolog\LogRecord;
use Monolog\Handler\AbstractProcessingHandler;
use Monolog\Handler\Curl;

/**
* @author Michele D'Amico <[email protected]>
* Linfa Service - https://www.linfaservice.it
* Damikael - https://www.damikael.dev
*/
class AzureHandler extends AbstractProcessingHandler
{
private string $eventName;
private string $secretKey;

/**
* @param string $tenantId
* @param string $appId
* @param string $appSecret
* @param string $dceURI
* @param string $dcrImmutableId;
* @param string $table
*
* @throws MissingExtensionException If the curl extension is missing
*/
public function __construct(string $tenantId, string $appId, string $appSecret, string $dceURI, string $dcrImmutableId, string $table, int|string|Level $level = Level::Debug, bool $bubble = true)
{
if (!\extension_loaded('curl')) {
throw new MissingExtensionException('The curl extension is needed to use the AzureHandler');
}

$this->tenantId = $tenantId;
$this->appId = $appId;
$this->appSecret = $appSecret;
$this->dceURI = $dceURI;
$this->dcrImmutableId = $dcrImmutableId;
$this->table = $table;

parent::__construct($level, $bubble);
}

/**
* @inheritDoc
*/
public function write(LogRecord $record): void
{

// retrieve access_token
$url = "https://login.microsoftonline.com/" . $this->tenantId . "/oauth2/v2.0/token";
$postString = "
grant_type=client_credentials
&scope=https://monitor.azure.com//.default
&client_id=" . $this->appId . "
&client_secret=" . $this->appSecret . "
";

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $postString);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
"Content-Type: application/x-www-form-urlencoded",
]);

$response = Curl\Util::execute($ch);
$access_token = json_decode($response)->access_token;

// send log
$url = $this->dceURI . "/dataCollectionRules/" . $this->dcrImmutableId . "/streams/Custom-" . $this->table . "?api-version=2023-01-01";
$sourceUrl = $_SERVER['HTTP_HOST'];
$clientIp = $_SERVER['REMOTE_ADDR'];

$postString = "[
{
\"TimeGenerated\": \"" . (new \DateTime())->format('c') . "\",
\"Direction\": \"REQUEST\",
\"Method\": \"GET\",
\"Url\": \"" . $sourceUrl ."\",
\"IP\": \"" . $clientIp ."\",
\"Level\": \"INFO\",
\"response_type\": \"code\",
\"message\": \"" . $record->message . "\"
}
]";

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $postString);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
"Authorization: Bearer " . $access_token,
"Content-Type: application/json",
]);

//error_log("Log Request: " . var_export($postString, true));

$response = Curl\Util::execute($ch);
$httpcode = curl_getinfo($ch, CURLINFO_HTTP_CODE);

//error_log("Log Response: [" . $httpcode . "] " . var_export($response, true));
}
}
23 changes: 21 additions & 2 deletions lib/Core/Logger.php
Original file line number Diff line number Diff line change
Expand Up @@ -53,8 +53,27 @@ public function __construct(array $config = null)
}
$this->config = $config;

//$handler = new SyslogHandler('spid-cie-oidc-php');
$handler = new StreamHandler($this->config['log_path']);
switch($this->config['log_handler']) {
case 'azure':
$tenantId = $this->config['log_azure_tenantId'];
$appId = $this->config['log_azure_appId'];
$appSecret = $this->config['log_azure_appSecret'];
$dceURI = $this->config['log_azure_dceURI'];
$dcrImmutableId = $this->config['log_azure_dcrImmutableId'];
$table = $this->config['log_azure_table'];
$handler = new AzureHandler($tenantId, $appId, $appSecret, $dceURI, $dcrImmutableId, $table);
break;

case 'syslog':
$handler = new SyslogHandler('spid-cie-oidc-php');
break;

case 'stream':
default:
$handler = new StreamHandler($this->config['log_stream_path']);
break;
}

$formatter = new SyslogFormatter();
$handler->setFormatter($formatter);

Expand Down

0 comments on commit 9dce6cb

Please sign in to comment.