Skip to content

Commit

Permalink
Merge pull request #341 from OPUS4/v4.8.0.1
Browse files Browse the repository at this point in the history
#338 Functions for finding (duplicate) DOIs
  • Loading branch information
j3nsch authored Nov 28, 2023
2 parents 99b482c + 2e157f0 commit 5907a11
Show file tree
Hide file tree
Showing 2 changed files with 133 additions and 0 deletions.
39 changes: 39 additions & 0 deletions library/Opus/Doi/DoiManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@
use Opus\Common\Log;
use Opus\Common\Log\LogService;
use Opus\Common\Model\NotFoundException;
use Opus\Db\DocumentIdentifiers;
use Opus\Db\TableGateway;
use Opus\Document;
use Opus\DocumentFinder;
use Opus\Doi\Generator\DoiGeneratorException;
Expand Down Expand Up @@ -851,4 +853,41 @@ public function storeRegistrationXml($doc, $xml)

file_put_contents($filePath, $xml);
}

/**
* @return string[]
*/
public function getAllDoiValues()
{
$table = TableGateway::getInstance(DocumentIdentifiers::class);

$database = $table->getAdapter();

$select = $table->select()
->from('document_identifiers', 'value')
->distinct(true)
->where('type = ?', 'doi');

return $database->fetchCol($select);
}

/**
* Returns DOIs that are linked to multiple documents.
*
* @return string[]
*/
public function getDuplicateDoiValues()
{
$table = TableGateway::getInstance(DocumentIdentifiers::class);

$database = $table->getAdapter();

$select = $table->select()
->from('document_identifiers', 'value')
->group('value')
->having('count(value) > 1')
->where('type = ?', 'doi');

return $database->fetchCol($select);
}
}
94 changes: 94 additions & 0 deletions tests/Opus/Doi/DoiManagerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -908,4 +908,98 @@ public function testGetLandingPageUrlOfDocForId()
$manager->getLandingPageUrlOfDoc($docId)
);
}

public function testGetAllDoiValues()
{
$doiValues = [
'10.0000/1111',
'10.0000/2222',
'10.0000/3333',
];

foreach ($doiValues as $doi) {
$doc = Document::new();
$identifier = $doc->addIdentifier();
$identifier->setType('doi');
$identifier->setValue($doi);
$doc->store();
}

// other identifier type than DOI
$identifier = $doc->addIdentifier();
$identifier->setType('isbn');
$identifier->setValue('isbn-value');

// duplicate DOI identifier
$identifier = $doc->addIdentifier();
$identifier->setType('doi');
$identifier->setValue('10.0000/3333');

$doc->store();

$manager = new DoiManager();

$values = $manager->getAllDoiValues();

$this->assertCount(3, $values);
$this->assertEquals($doiValues, $values);
}

public function testGetAllDoiValuesNonFound()
{
$manager = new DoiManager();

$values = $manager->getAllDoiValues();

$this->assertIsArray($values);
$this->assertEmpty($values);
}

public function testGetDuplicateDoiValues()
{
$doi1 = '10.1000/1111';
$doi2 = '10.1000/2222';

$doc = Document::new();
$doi = $doc->addIdentifier();
$doi->setType('doi');
$doi->setValue($doi1);
$doc->store();

$doc = Document::new();
$doi = $doc->addIdentifier();
$doi->setType('doi');
$doi->setValue($doi1);
$doc->store();

$doc = Document::new();
$doi = $doc->addIdentifier();
$doi->setType('doi');
$doi->setValue($doi2);
$doc->store();

// other identifier type than DOI
$doc = Document::new();
$identifier = $doc->addIdentifier();
$identifier->setType('isbn');
$identifier->setValue('isbn-value');
$doc->store();

$manager = new DoiManager();

$values = $manager->getDuplicateDoiValues();

$this->assertCount(1, $values);
$this->assertEquals($doi1, $values[0]);
}

public function testGetDuplicateDoiValuesNonFound()
{
$manager = new DoiManager();

$values = $manager->getDuplicateDoiValues();

$this->assertIsArray($values);
$this->assertEmpty($values);
}
}

0 comments on commit 5907a11

Please sign in to comment.