Improve validation of ORCID IDs
This commit is contained in:
		| @@ -531,6 +531,24 @@ enum MDNodaRepository implements MDValueEnumInterface, JsonSerializable { | |||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Validates OrCID IDs. | ||||||
|  |      * | ||||||
|  |      * @param string $id ID to validate. | ||||||
|  |      * | ||||||
|  |      * @return string|false | ||||||
|  |      */ | ||||||
|  |     private static function validateOrcidId(string $id):string|false { | ||||||
|  | 
 | ||||||
|  |         $id = strtr(trim($id, '/'), [ | ||||||
|  |             "http://orcid.org/" => "", | ||||||
|  |             "https://orcid.org/" => "", | ||||||
|  |         ]); | ||||||
|  | 
 | ||||||
|  |         return preg_match('/^[0-9]{4}-[0-9]{4}-[0-9]{4}-[0-9]{4}$/', $id) ? $id : false; | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * Validates a PIM ID, returning a string or false. |      * Validates a PIM ID, returning a string or false. | ||||||
|      * |      * | ||||||
| @@ -679,7 +697,7 @@ enum MDNodaRepository implements MDValueEnumInterface, JsonSerializable { | |||||||
|             self::nomisma   => str_replace('http://nomisma.org/id/', '', $id), |             self::nomisma   => str_replace('http://nomisma.org/id/', '', $id), | ||||||
|             self::npg       => self::validateNpgId($id), |             self::npg       => self::validateNpgId($id), | ||||||
|             self::oberbegriffsdatei => self::validateNumericId($id, ['https://term.museum-digital.de/oberbegriffsdatei/tag/']), |             self::oberbegriffsdatei => self::validateNumericId($id, ['https://term.museum-digital.de/oberbegriffsdatei/tag/']), | ||||||
|             self::orcid     => preg_match('/^[0-9]{4}-[0-9]{4}-[0-9]{4}-[0-9]{4}$/', $id) ? $id : false, |             self::orcid     => self::validateOrcidId($id), | ||||||
|             self::osm       => self::validateNumericId($id, ['https://www.openstreetmap.org/relation/']), |             self::osm       => self::validateNumericId($id, ['https://www.openstreetmap.org/relation/']), | ||||||
|             self::pim       => self::validatePimId($id), |             self::pim       => self::validatePimId($id), | ||||||
|             self::pleiades  => self::validateNumericId($id, ['https://pleiades.stoa.org/places/']), |             self::pleiades  => self::validateNumericId($id, ['https://pleiades.stoa.org/places/']), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user