Compare commits

...
Sign in to create a new pull request.

12 commits
v1 ... master

Author SHA1 Message Date
2dcf098153 chore: compat spip 4.*.* 2024-07-15 16:57:59 +02:00
cy_altern
2441f22fc3 build: compatibilité SPIP 4.2 2023-08-20 10:38:03 +02:00
2caf2f808e inutile 2022-11-24 17:01:28 +01:00
f191e4ce8e debug 2022-11-24 17:00:13 +01:00
02e8f50bed compat spip 41 2022-11-07 15:19:52 +01:00
cy_altern
4521675196 merge 2022-04-27 17:06:44 +02:00
0186c57aa6 up de z 2022-02-22 15:37:25 +01:00
a0349698f0 correction deprecated sur l'appel arg fonction 2022-02-22 15:37:14 +01:00
9fac6e1c66 up de z 2022-01-18 11:59:29 +01:00
25544d1588 on permet de sortie à l'affichage que la chaine blocklog 2022-01-18 11:59:11 +01:00
b6710055e7 On ajoute une nouvelle methode pour calculer la chaine, pour cela, une
serialize une array 3 dimensions : sql_fetch_all
on ajoute une constante define("_BLOCKLOG_CHAINE_SIMPLE", true); pour
garder l'ancien fonctionnement et on peut utliser aussi la branche V1
2021-11-23 22:11:55 +01:00
0ae0147a1c compat spip 4 2021-11-23 18:08:36 +01:00
6 changed files with 67 additions and 271 deletions

View file

@ -3,14 +3,9 @@
## Utilisation
> Génération du blocklog
```php
$requete = sql_allfetsel($s, $f, $w,'','','','','', false);
$blocklog = charger_fonction('blocklog', 'inc');
// $chaine : string ou array
$blocklog("monObjet", $id_objet, $num_dossier, $chaine);
```
## Page html de generation d'un bloclog
```
?page=sha256sum
$blocklog($objet, $id_objet, $numero_facture, $requete);
```
## options :
@ -21,4 +16,16 @@ define("_BLOCKLOG_ALGO", 'sha256');
//activer les log : blocklog.log
define("_DEBUG_BLOCKLOG", true);
// garder le calcul de la chaine simple, requete avec sql_fetch et non sql_fetch_all
// utiliser sur lcdp
// l'autre solution est de rester en version 1 du plugin
define("_BLOCKLOG_CHAINE_SIMPLE", true);
```
## Page html de generation d'un bloclog
```
?page=sha256sum
```

View file

@ -15,33 +15,28 @@ if (!defined('_ECRIRE_INC_VERSION')) {
function trouver_blocklog($id_objet, $objet, $all = false){
static $r;
if ($r == null) {
$from = array(
'spip_blocklogs',
);
$where = array(
if (is_null($r)) {
$where = [
'id_objet='.intval($id_objet),
'objet='.sql_quote($objet),
);
$r = sql_fetsel('id_blocklog, blockchaine, chaine, requete', $from, $where);
];
$r = sql_fetsel('id_blocklog, blockchaine, chaine, requete', 'spip_blocklogs', $where);
}
if ($all) {
return $r;
}
return $r['blockchaine'];
return $r['blockchaine'] ?? '';
}
function blockchaine_sur_pdf(){
if (!defined('_BLOCKLOG_CACHER_PDF') or _BLOCKLOG_CACHER_PDF !== true){
if (!defined('_BLOCKLOG_CACHER_PDF') or (defined('_BLOCKLOG_CACHER_PDF') and _BLOCKLOG_CACHER_PDF !== true)){
return true;
}
return false;
}
function afficher_blocklog($texte, $id_dossier, $objet, $type = 'chaine'){
function afficher_blocklog($texte = '', $id_objet = 0, $objet = '', $type = 'chaine'){
$objet = trim($objet);
$blockchaine = '<span class="affichage_blockchaine">';
@ -51,12 +46,16 @@ function afficher_blocklog($texte, $id_dossier, $objet, $type = 'chaine'){
$img .= "&nbsp;";
}
if (!defined('_BLOCKLOG_CACHER_PDF') or _BLOCKLOG_CACHER_PDF !== true){
if (intval($id_dossier) and $objet) {
if (intval($id_objet) and $objet) {
$recup_bl = trouver_blocklog($id_objet, $objet, true);
$blockchaine .= $img;
$blockchaine .= trouver_blocklog($id_dossier, $objet, true)[$type];
$blockchaine .= $recup_bl[$type] ?? '';
$blockchaine .= '</span>';
}
}
if (empty($texte)) {
return $blockchaine;
}
$texte = str_replace('@@blockchaine@@', $blockchaine, $texte);
$texte = str_replace('@@blocklog@@', $blockchaine, $texte);
@ -72,23 +71,23 @@ function blocklog_verifier_blockchaine($num, $objet){
);
$r = sql_fetsel('id_blocklog, blockchaine, chaine, requete', 'spip_blocklogs', $where);
if (is_array($r)) {
$where = array(
'objet='.sql_quote($objet),
'id_blocklog<'.intval($r['id_blocklog'])
);
$blockchaine_prec = sql_getfetsel('blockchaine', 'spip_blocklogs', $where, 'id_blocklog DESC', 1);
$blockchaine_prec = sql_getfetsel('blockchaine', 'spip_blocklogs', $where, 'id_blocklog DESC', 1) ?? '';
$blockchaine = $blockchaine_prec . $r['chaine'];
$blockchaine = hash(_BLOCKLOG_ALGO, $blockchaine);
return $blockchaine === $r['blockchaine'];
}
}
return false;
}
function blocklog_verifier_chaine($num, $objet){
if (intval($num) and $objet) {
$where = array(
'num='.intval($num),
@ -96,21 +95,28 @@ function blocklog_verifier_chaine($num, $objet){
);
$r = sql_fetsel('id_blocklog, blockchaine, chaine, requete', 'spip_blocklogs', $where);
if (isset($r['chaine']) and isset($r['requete'])) {
$chaine_bdd = $r['chaine'];
$chaine_dynamique = blocklog_creer_chaine($r['requete']);
return $chaine_bdd === $chaine_dynamique;
}
}
return false;
}
function blocklog_creer_chaine($requete = ""){
if ( strlen($requete) < 5 ) {
return '';
}
$r = sql_query($requete);
$chaine = sql_fetch($r);
$get_infos = charger_fonction('get_infos', 'plugins');
$version = $get_infos('blocklog');
$r = sql_query($requete);
if (intval($version) < 2 or defined('_BLOCKLOG_CHAINE_SIMPLE')) {
$chaine = sql_fetch($r);
if (is_array($chaine)) {
$c = [];
foreach ($chaine as $i => $v) {
@ -118,6 +124,12 @@ function blocklog_creer_chaine($requete = ""){
}
$chaine = implode('|', $c);
}
} else {
$chaine = sql_fetch_all($r);
if (is_array($chaine)) {
$chaine = serialize($chaine);
}
}
$chaine = hash(_BLOCKLOG_ALGO, $chaine);
@ -125,10 +137,10 @@ function blocklog_creer_chaine($requete = ""){
}
function blocklog_creer_blockchaine($chaine, $objet){
$where = array(
$where = [
'objet='.sql_quote($objet)
);
$blockchaine = sql_getfetsel('blockchaine', 'spip_blocklogs', $where,'', 'id_blocklog DESC', '1');
];
$blockchaine = sql_getfetsel('blockchaine', 'spip_blocklogs', $where,'', 'id_blocklog DESC', '1') ?? '';
$blockchaine .= $chaine;
$blockchaine = hash(_BLOCKLOG_ALGO, $blockchaine);

File diff suppressed because one or more lines are too long

View file

@ -9,7 +9,7 @@ if (!defined('_ECRIRE_INC_VERSION')){
*
* @param string $objet
* @param int $id_objet
* @param string | array $chaine : ensemble des valeurs utilisées pour creer la chaine
* @param string : requete sql pour recuperer les valeurs a intergrer dans la blockchaine
* @return array [id_blocklog, chaine, blockchaine]
*/
function inc_blocklog_dist($objet, $id_objet = 0, $num = 0, $requete = '') {

View file

@ -1,9 +1,9 @@
<paquet
prefix="blocklog"
categorie="outil"
version="1.1.5"
version="2.0.2"
etat="dev"
compatibilite="[3.2.0;3.3.*]"
compatibilite="[3.2.0;4.*.*]"
logo="prive/themes/spip/images/blocklog-64.png"
documentation=""
schema="1.0.7"

View file

@ -115,7 +115,6 @@
let c3 = document.querySelector('#c3').value;
let chaine = c1 + c2 +c3;
chaine = sha256(chaine);
console.log(chaine);
document.querySelector('#sha').value = chaine;
});