1c2ed51d1SGreg Roach<?php 2c2ed51d1SGreg Roach 3c2ed51d1SGreg Roach/** 4c2ed51d1SGreg Roach * webtrees: online genealogy 5c2ed51d1SGreg Roach * Copyright (C) 2021 webtrees development team 6c2ed51d1SGreg Roach * This program is free software: you can redistribute it and/or modify 7c2ed51d1SGreg Roach * it under the terms of the GNU General Public License as published by 8c2ed51d1SGreg Roach * the Free Software Foundation, either version 3 of the License, or 9c2ed51d1SGreg Roach * (at your option) any later version. 10c2ed51d1SGreg Roach * This program is distributed in the hope that it will be useful, 11c2ed51d1SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 12c2ed51d1SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13c2ed51d1SGreg Roach * GNU General Public License for more details. 14c2ed51d1SGreg Roach * You should have received a copy of the GNU General Public License 15c2ed51d1SGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 16c2ed51d1SGreg Roach */ 17c2ed51d1SGreg Roach 18c2ed51d1SGreg Roachdeclare(strict_types=1); 19c2ed51d1SGreg Roach 20c2ed51d1SGreg Roachnamespace Fisharebest\Webtrees\Elements; 21c2ed51d1SGreg Roach 22c2ed51d1SGreg Roachuse Exception; 23c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Tree; 24c2ed51d1SGreg Roachuse Ramsey\Uuid\Uuid; 25c2ed51d1SGreg Roach 26c2ed51d1SGreg Roachuse function dechex; 27c2ed51d1SGreg Roachuse function hexdec; 28c2ed51d1SGreg Roachuse function strtoupper; 29c2ed51d1SGreg Roachuse function strtr; 30c2ed51d1SGreg Roachuse function substr; 31c2ed51d1SGreg Roach 32c2ed51d1SGreg Roach/** 33c2ed51d1SGreg Roach * _UID fields, as created by PAF and other applications 34c2ed51d1SGreg Roach */ 35c2ed51d1SGreg Roachclass PafUid extends AbstractElement 36c2ed51d1SGreg Roach{ 37*ae0043b7SGreg Roach protected const MAXIMUM_LENGTH = 34; 38c2ed51d1SGreg Roach 39c2ed51d1SGreg Roach /** 40c2ed51d1SGreg Roach * Create a default value for this element. 41c2ed51d1SGreg Roach * 42c2ed51d1SGreg Roach * @param Tree $tree 43c2ed51d1SGreg Roach * 44c2ed51d1SGreg Roach * @return string 45c2ed51d1SGreg Roach */ 46c2ed51d1SGreg Roach public function default(Tree $tree): string 47c2ed51d1SGreg Roach { 48c2ed51d1SGreg Roach try { 49c2ed51d1SGreg Roach $uid = strtr(Uuid::uuid4()->toString(), ['-' => '']); 50c2ed51d1SGreg Roach } catch (Exception $ex) { 51c2ed51d1SGreg Roach // uuid4() can fail if there is insufficient entropy in the system. 52c2ed51d1SGreg Roach return ''; 53c2ed51d1SGreg Roach } 54c2ed51d1SGreg Roach 55c2ed51d1SGreg Roach $checksum_a = 0; // a sum of the bytes 56c2ed51d1SGreg Roach $checksum_b = 0; // a sum of the incremental values of $checksum_a 57c2ed51d1SGreg Roach 58c2ed51d1SGreg Roach // Compute checksums 59c2ed51d1SGreg Roach for ($i = 0; $i < 32; $i += 2) { 60c2ed51d1SGreg Roach $checksum_a += hexdec(substr($uid, $i, 2)); 61c2ed51d1SGreg Roach $checksum_b += $checksum_a & 0xff; 62c2ed51d1SGreg Roach } 63c2ed51d1SGreg Roach 64c2ed51d1SGreg Roach return strtoupper($uid . substr(dechex($checksum_a), -2) . substr(dechex($checksum_b), -2)); 65c2ed51d1SGreg Roach } 66c2ed51d1SGreg Roach} 67