Уязвимость уже будет теоретически будет устранена, НО! дополнительно можно (на будущее) отключить вообще протоколы ChaCha20-Poly1305 и Encrypt-then-MAC в ssh, которые собственно и эксплуатируются для этой уязвимости:
Продолжаю попытки нормально пометить на графике дневное и ночное время. Описание предыдущих попыток можно почитать здесь. На этот раз, попробуем при помощи аннотаций. Основная идея: при помощи аннтотаций, на графике возможно помечать и подписывать определенные промежутки данных на графике. Аннотации можно добавлять из вне при помощи специального API.
Создадим ключ API:
Далее, необходимо узнать id дашборда (гаходится как orgId в url) и id панели дашборда, чтобы таргетировать аннотацию.
Далее наваяем небольшой скрипт на PHP, который положим в крон и будем выполнять ночью:
#!/usr/bin/php
<?php
$geo=21; // Код можно узнать здесь: https://xn--90acbu5aj5f.xn--p1ai/?page_id=6661
$api_key_grafana="Bearer eyJrIwedwediLCJpZCI6MX0=";
$api_grafana_url="https://qwedqweai/api/annotations";
$dash_id=1;
$panel_id=30;
$offset=3*60*60; // смещение времени
$ch = curl_init("https://yandex.ru/time/sync.json?geo=21");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$res=curl_exec($ch);
curl_close($ch);
$js=json_decode($res);
if ($js==null){die("Не удалось получить данные для обработки");};
$DayFrom=$js->clocks->$geo->sunrise;
$DayTo=$js->clocks->$geo->sunset;
$dt=Date("Y-m-d");
echo "День $dt с $DayFrom по $DayTo\n";
$dtStart=(strtotime($dt." ".$DayFrom.":00")-$offset)."000";
$dtEnd=(strtotime($dt." ".$DayTo.":00")-$offset)."000";
$ch = curl_init($api_grafana_url);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
"Authorization: $api_key_grafana",
"Content-Type: application/json"
));
curl_setopt($ch, CURLOPT_POST, 1);
$postd=[];
$postd["text"]="Дневное время";
$postd["dashboardId"]=$dash_id;
$postd["panelId"]=$panel_id;
$postd["time"]=$dtStart+0;
$postd["timeEnd"]=$dtEnd+0;
$postd["tags"]=["daytime"];
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($postd));
$res=curl_exec($ch);
var_dump($res);
?>
Задача: получить время захода и восхода солнца в текущую дату..
Решение:
Яндекс предоставляет эту информацию в формате json по ссылке вида https://yandex.ru/time/sync.json?geo=21, где 21 — код города в сервисах Яндекса. Список на всякий случай здесь. Один нюанс — нет возможности получить данные на определённую дату.. Да и зависеть от Яндекса, так себе идея. Сегодня сервис работает, через год нет.
Второй вариант: по ссылке вида https://api.sunrise-sunset.org/json?lat=36.7201600&lng=-4.4203400&date=2024-01-22, мы можем получить восход/заход в любую указанную дату. А так как дней всего у нас 365 в году, то вполне возможно просто выкачать эти данные и разместить их у себя например в формате <день_года>.json
Задача: необходимо строить график в зависимости от выбранного значения в выпадающем списке.
Решение: в Grafana для этого есть штатный функционал.
Заходим в меню «Dashboard Settings» (шестренка) -> Variables (переменные). Создаём новую переменную:
name — имя переменной, для использования в дальнейших запросах
label — заголовок перед выпадающим меню
Query — запрос из которого идёт выборка в поле выбора. Причем поле обозначенное как __text будет использоваться как наименование поля выбора, а __value как его значение.
После сохранения, идём в редактирования панели дашборда и меняем запрос на вида:
select (dt),count(*) as "${division:text}" from (
select
date_trunc('month', agreements_dt)::date as dt
from
ls
where agreements_dt>'2018-01-01' and
owner in ('$division') and
agreements_dt is not null
) as agr
group by dt
order by dt desc
, где:
${division:text} — текст выбранного (Например «Кудыкинский муниципыальный район»
$division — значение выбранного (Например «13432»)