18add1155SRico Sonntag<?php 28add1155SRico Sonntag/** 38add1155SRico Sonntag * webtrees: online genealogy 4*242a7862SGreg Roach * Copyright (C) 2019 webtrees development team 58add1155SRico Sonntag * This program is free software: you can redistribute it and/or modify 68add1155SRico Sonntag * it under the terms of the GNU General Public License as published by 78add1155SRico Sonntag * the Free Software Foundation, either version 3 of the License, or 88add1155SRico Sonntag * (at your option) any later version. 98add1155SRico Sonntag * This program is distributed in the hope that it will be useful, 108add1155SRico Sonntag * but WITHOUT ANY WARRANTY; without even the implied warranty of 118add1155SRico Sonntag * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 128add1155SRico Sonntag * GNU General Public License for more details. 138add1155SRico Sonntag * You should have received a copy of the GNU General Public License 148add1155SRico Sonntag * along with this program. If not, see <http://www.gnu.org/licenses/>. 158add1155SRico Sonntag */ 168add1155SRico Sonntagdeclare(strict_types=1); 178add1155SRico Sonntag 188add1155SRico Sonntagnamespace Fisharebest\Webtrees\Statistics\Repository; 198add1155SRico Sonntag 208add1155SRico Sonntaguse Fisharebest\Webtrees\Date; 218add1155SRico Sonntaguse Fisharebest\Webtrees\GedcomRecord; 228add1155SRico Sonntaguse Fisharebest\Webtrees\Statistics\Repository\Interfaces\GedcomRepositoryInterface; 238add1155SRico Sonntaguse Fisharebest\Webtrees\Tree; 248add1155SRico Sonntaguse Illuminate\Database\Capsule\Manager as DB; 258add1155SRico Sonntaguse Illuminate\Database\Query\Builder; 268add1155SRico Sonntag 278add1155SRico Sonntag/** 288add1155SRico Sonntag * A repository providing methods for GEDCOM related statistics. 298add1155SRico Sonntag */ 308add1155SRico Sonntagclass GedcomRepository implements GedcomRepositoryInterface 318add1155SRico Sonntag{ 328add1155SRico Sonntag /** 338add1155SRico Sonntag * @var Tree 348add1155SRico Sonntag */ 358add1155SRico Sonntag private $tree; 368add1155SRico Sonntag 378add1155SRico Sonntag /** 388add1155SRico Sonntag * Constructor. 398add1155SRico Sonntag * 408add1155SRico Sonntag * @param Tree $tree 418add1155SRico Sonntag */ 428add1155SRico Sonntag public function __construct(Tree $tree) 438add1155SRico Sonntag { 448add1155SRico Sonntag $this->tree = $tree; 458add1155SRico Sonntag } 468add1155SRico Sonntag 478add1155SRico Sonntag /** 488add1155SRico Sonntag * Get information from the GEDCOM's HEAD record. 498add1155SRico Sonntag * 508add1155SRico Sonntag * @return string[] 518add1155SRico Sonntag */ 528add1155SRico Sonntag private function gedcomHead(): array 538add1155SRico Sonntag { 548add1155SRico Sonntag $title = ''; 558add1155SRico Sonntag $version = ''; 568add1155SRico Sonntag $source = ''; 578add1155SRico Sonntag 588add1155SRico Sonntag $head = GedcomRecord::getInstance('HEAD', $this->tree); 598add1155SRico Sonntag 608add1155SRico Sonntag if ($head !== null) { 618add1155SRico Sonntag $sour = $head->getFirstFact('SOUR'); 628add1155SRico Sonntag 638add1155SRico Sonntag if ($sour !== null) { 648add1155SRico Sonntag $source = $sour->value(); 658add1155SRico Sonntag $title = $sour->attribute('NAME'); 668add1155SRico Sonntag $version = $sour->attribute('VERS'); 678add1155SRico Sonntag } 688add1155SRico Sonntag } 698add1155SRico Sonntag 708add1155SRico Sonntag return [ 718add1155SRico Sonntag $title, 728add1155SRico Sonntag $version, 738add1155SRico Sonntag $source, 748add1155SRico Sonntag ]; 758add1155SRico Sonntag } 768add1155SRico Sonntag 778add1155SRico Sonntag /** 788add1155SRico Sonntag * @inheritDoc 798add1155SRico Sonntag */ 808add1155SRico Sonntag public function gedcomFilename(): string 818add1155SRico Sonntag { 828add1155SRico Sonntag return $this->tree->name(); 838add1155SRico Sonntag } 848add1155SRico Sonntag 858add1155SRico Sonntag /** 868add1155SRico Sonntag * @inheritDoc 878add1155SRico Sonntag */ 888add1155SRico Sonntag public function gedcomId(): int 898add1155SRico Sonntag { 908add1155SRico Sonntag return $this->tree->id(); 918add1155SRico Sonntag } 928add1155SRico Sonntag 938add1155SRico Sonntag /** 948add1155SRico Sonntag * @inheritDoc 958add1155SRico Sonntag */ 968add1155SRico Sonntag public function gedcomTitle(): string 978add1155SRico Sonntag { 988add1155SRico Sonntag return e($this->tree->title()); 998add1155SRico Sonntag } 1008add1155SRico Sonntag 1018add1155SRico Sonntag /** 1028add1155SRico Sonntag * @inheritDoc 1038add1155SRico Sonntag */ 1048add1155SRico Sonntag public function gedcomCreatedSoftware(): string 1058add1155SRico Sonntag { 1068add1155SRico Sonntag return $this->gedcomHead()[0]; 1078add1155SRico Sonntag } 1088add1155SRico Sonntag 1098add1155SRico Sonntag /** 1108add1155SRico Sonntag * @inheritDoc 1118add1155SRico Sonntag */ 1128add1155SRico Sonntag public function gedcomCreatedVersion(): string 1138add1155SRico Sonntag { 1148add1155SRico Sonntag $head = $this->gedcomHead(); 1158add1155SRico Sonntag 1168add1155SRico Sonntag if ($head === null) { 1178add1155SRico Sonntag return ''; 1188add1155SRico Sonntag } 1198add1155SRico Sonntag 1208add1155SRico Sonntag // Fix broken version string in Family Tree Maker 1218add1155SRico Sonntag if (strpos($head[1], 'Family Tree Maker ') !== false) { 1228add1155SRico Sonntag $p = strpos($head[1], '(') + 1; 1238add1155SRico Sonntag $p2 = strpos($head[1], ')'); 1248add1155SRico Sonntag $head[1] = substr($head[1], $p, $p2 - $p); 1258add1155SRico Sonntag } 1268add1155SRico Sonntag 1278add1155SRico Sonntag // Fix EasyTree version 1288add1155SRico Sonntag if ($head[2] === 'EasyTree') { 1298add1155SRico Sonntag $head[1] = substr($head[1], 1); 1308add1155SRico Sonntag } 1318add1155SRico Sonntag 1328add1155SRico Sonntag return $head[1]; 1338add1155SRico Sonntag } 1348add1155SRico Sonntag 1358add1155SRico Sonntag /** 1368add1155SRico Sonntag * @inheritDoc 1378add1155SRico Sonntag */ 1388add1155SRico Sonntag public function gedcomDate(): string 1398add1155SRico Sonntag { 1408add1155SRico Sonntag $head = GedcomRecord::getInstance('HEAD', $this->tree); 1418add1155SRico Sonntag 1428add1155SRico Sonntag if ($head !== null) { 1438add1155SRico Sonntag $fact = $head->getFirstFact('DATE'); 1448add1155SRico Sonntag 1458add1155SRico Sonntag if ($fact) { 1468add1155SRico Sonntag return (new Date($fact->value()))->display(); 1478add1155SRico Sonntag } 1488add1155SRico Sonntag } 1498add1155SRico Sonntag 1508add1155SRico Sonntag return ''; 1518add1155SRico Sonntag } 1528add1155SRico Sonntag 1538add1155SRico Sonntag /** 1548add1155SRico Sonntag * @inheritDoc 1558add1155SRico Sonntag */ 1568add1155SRico Sonntag public function gedcomUpdated(): string 1578add1155SRico Sonntag { 1588add1155SRico Sonntag $row = DB::table('dates') 1598add1155SRico Sonntag ->select(['d_year', 'd_month', 'd_day']) 1608add1155SRico Sonntag ->where('d_julianday1', '=', function (Builder $query) { 1618add1155SRico Sonntag $query->selectRaw('MAX(d_julianday1)') 1628add1155SRico Sonntag ->from('dates') 1638add1155SRico Sonntag ->where('d_file', '=', $this->tree->id()) 1648add1155SRico Sonntag ->where('d_fact', '=', 'CHAN'); 1658add1155SRico Sonntag }) 1668add1155SRico Sonntag ->first(); 1678add1155SRico Sonntag 1688add1155SRico Sonntag if ($row) { 1698add1155SRico Sonntag $date = new Date("{$row->d_day} {$row->d_month} {$row->d_year}"); 1708add1155SRico Sonntag return $date->display(); 1718add1155SRico Sonntag } 1728add1155SRico Sonntag 1738add1155SRico Sonntag return $this->gedcomDate(); 1748add1155SRico Sonntag } 1758add1155SRico Sonntag 1768add1155SRico Sonntag /** 1778add1155SRico Sonntag * @inheritDoc 1788add1155SRico Sonntag */ 1798add1155SRico Sonntag public function gedcomRootId(): string 1808add1155SRico Sonntag { 1818add1155SRico Sonntag return $this->tree->getPreference('PEDIGREE_ROOT_ID'); 1828add1155SRico Sonntag } 1838add1155SRico Sonntag} 184