xref: /webtrees/app/Source.php (revision e71ef9d2ff0aa5d82e80016f655eee252a32e958)
1a25f0a04SGreg Roach<?php
2a25f0a04SGreg Roach/**
3a25f0a04SGreg Roach * webtrees: online genealogy
41062a142SGreg Roach * Copyright (C) 2018 webtrees development team
5a25f0a04SGreg Roach * This program is free software: you can redistribute it and/or modify
6a25f0a04SGreg Roach * it under the terms of the GNU General Public License as published by
7a25f0a04SGreg Roach * the Free Software Foundation, either version 3 of the License, or
8a25f0a04SGreg Roach * (at your option) any later version.
9a25f0a04SGreg Roach * This program is distributed in the hope that it will be useful,
10a25f0a04SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of
11a25f0a04SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12a25f0a04SGreg Roach * GNU General Public License for more details.
13a25f0a04SGreg Roach * You should have received a copy of the GNU General Public License
14a25f0a04SGreg Roach * along with this program. If not, see <http://www.gnu.org/licenses/>.
15a25f0a04SGreg Roach */
1676692c8bSGreg Roachnamespace Fisharebest\Webtrees;
17a25f0a04SGreg Roach
18a25f0a04SGreg Roach/**
1976692c8bSGreg Roach * A GEDCOM source (SOUR) object.
20a25f0a04SGreg Roach */
21a25f0a04SGreg Roachclass Source extends GedcomRecord {
22a25f0a04SGreg Roach	const RECORD_TYPE = 'SOUR';
23225e381fSGreg Roach	const ROUTE_NAME  = 'source';
24a25f0a04SGreg Roach
2576692c8bSGreg Roach	/**
26*e71ef9d2SGreg Roach	 * Get an instance of a source object. For single records,
27*e71ef9d2SGreg Roach	 * we just receive the XREF. For bulk records (such as lists
28*e71ef9d2SGreg Roach	 * and search results) we can receive the GEDCOM data as well.
29*e71ef9d2SGreg Roach	 *
30*e71ef9d2SGreg Roach	 * @param string      $xref
31*e71ef9d2SGreg Roach	 * @param Tree        $tree
32*e71ef9d2SGreg Roach	 * @param string|null $gedcom
33*e71ef9d2SGreg Roach	 *
34*e71ef9d2SGreg Roach	 * @throws \Exception
35*e71ef9d2SGreg Roach	 *
36*e71ef9d2SGreg Roach	 * @return Source|null
37*e71ef9d2SGreg Roach	 */
38*e71ef9d2SGreg Roach	public static function getInstance($xref, Tree $tree, $gedcom = null) {
39*e71ef9d2SGreg Roach		$record = parent::getInstance($xref, $tree, $gedcom);
40*e71ef9d2SGreg Roach
41*e71ef9d2SGreg Roach		if ($record instanceof Source) {
42*e71ef9d2SGreg Roach			return $record;
43*e71ef9d2SGreg Roach		} else {
44*e71ef9d2SGreg Roach			return null;
45*e71ef9d2SGreg Roach		}
46*e71ef9d2SGreg Roach	}
47*e71ef9d2SGreg Roach
48*e71ef9d2SGreg Roach	/**
4976692c8bSGreg Roach	 * Each object type may have its own special rules, and re-implement this function.
5076692c8bSGreg Roach	 *
5176692c8bSGreg Roach	 * @param int $access_level
5276692c8bSGreg Roach	 *
5376692c8bSGreg Roach	 * @return bool
5476692c8bSGreg Roach	 */
55a25f0a04SGreg Roach	protected function canShowByType($access_level) {
56a25f0a04SGreg Roach		// Hide sources if they are attached to private repositories ...
57a25f0a04SGreg Roach		preg_match_all('/\n1 REPO @(.+)@/', $this->gedcom, $matches);
58a25f0a04SGreg Roach		foreach ($matches[1] as $match) {
5924ec66ceSGreg Roach			$repo = Repository::getInstance($match, $this->tree);
60a25f0a04SGreg Roach			if ($repo && !$repo->canShow($access_level)) {
61a25f0a04SGreg Roach				return false;
62a25f0a04SGreg Roach			}
63a25f0a04SGreg Roach		}
64a25f0a04SGreg Roach
65a25f0a04SGreg Roach		// ... otherwise apply default behaviour
66a25f0a04SGreg Roach		return parent::canShowByType($access_level);
67a25f0a04SGreg Roach	}
68a25f0a04SGreg Roach
6976692c8bSGreg Roach	/**
7076692c8bSGreg Roach	 * Generate a private version of this record
7176692c8bSGreg Roach	 *
7276692c8bSGreg Roach	 * @param int $access_level
7376692c8bSGreg Roach	 *
7476692c8bSGreg Roach	 * @return string
7576692c8bSGreg Roach	 */
76a25f0a04SGreg Roach	protected function createPrivateGedcomRecord($access_level) {
77a25f0a04SGreg Roach		return '0 @' . $this->xref . "@ SOUR\n1 TITL " . I18N::translate('Private');
78a25f0a04SGreg Roach	}
79a25f0a04SGreg Roach
8076692c8bSGreg Roach	/**
8176692c8bSGreg Roach	 * Fetch data from the database
8276692c8bSGreg Roach	 *
8376692c8bSGreg Roach	 * @param string $xref
8476692c8bSGreg Roach	 * @param int    $tree_id
8576692c8bSGreg Roach	 *
8676692c8bSGreg Roach	 * @return null|string
8776692c8bSGreg Roach	 */
8864d9078aSGreg Roach	protected static function fetchGedcomRecord($xref, $tree_id) {
8964d9078aSGreg Roach		return Database::prepare(
9064d9078aSGreg Roach			"SELECT s_gedcom FROM `##sources` WHERE s_id = :xref AND s_file = :tree_id"
9113abd6f3SGreg Roach		)->execute([
9264d9078aSGreg Roach			'xref'    => $xref,
9364d9078aSGreg Roach			'tree_id' => $tree_id,
9413abd6f3SGreg Roach		])->fetchOne();
95a25f0a04SGreg Roach	}
96a25f0a04SGreg Roach
9776692c8bSGreg Roach	/**
9876692c8bSGreg Roach	 * Extract names from the GEDCOM record.
9976692c8bSGreg Roach	 */
100a25f0a04SGreg Roach	public function extractNames() {
10136a0c51dSGreg Roach		parent::extractNamesFromFacts(1, 'TITL', $this->getFacts('TITL'));
102a25f0a04SGreg Roach	}
103a25f0a04SGreg Roach}
104