nicebooks / isbn
ISBN tools
Installs: 320 636
Dependents: 3
Suggesters: 1
Security: 0
Stars: 27
Watchers: 2
Forks: 3
Open Issues: 0
pkg:composer/nicebooks/isbn
Requires
- php: ^8.2
Requires (Dev)
- ext-dom: *
- brick/varexporter: ~0.5.0
- carthage-software/mago: 1.0.3
- php-coveralls/php-coveralls: ^2.5.2
- phpunit/phpunit: ^11.5
- dev-master
- 0.6.1
- 0.6.0
- 0.5.2
- 0.5.1
- 0.5.0
- 0.4.68
- 0.4.67
- 0.4.66
- 0.4.65
- 0.4.64
- 0.4.63
- 0.4.62
- 0.4.61
- 0.4.60
- 0.4.59
- 0.4.58
- 0.4.57
- 0.4.56
- 0.4.55
- 0.4.54
- 0.4.53
- 0.4.52
- 0.4.51
- 0.4.50
- 0.4.49
- 0.4.48
- 0.4.47
- 0.4.46
- 0.4.45
- 0.4.44
- 0.4.43
- 0.4.42
- 0.4.41
- 0.4.40
- 0.4.39
- 0.4.38
- 0.4.37
- 0.4.36
- 0.4.35
- 0.4.34
- 0.4.33
- 0.4.32
- 0.4.31
- 0.4.30
- 0.4.29
- 0.4.28
- 0.4.27
- 0.4.26
- 0.4.25
- 0.4.24
- 0.4.23
- 0.4.22
- 0.4.21
- 0.4.20
- 0.4.19
- 0.4.18
- 0.4.17
- 0.4.16
- 0.4.15
- 0.4.14
- 0.4.13
- 0.4.12
- 0.4.11
- 0.4.10
- 0.4.9
- 0.4.8
- 0.4.7
- 0.4.6
- 0.4.5
- 0.4.4
- 0.4.3
- 0.4.2
- 0.4.1
- 0.4.0
- 0.3.48
- 0.3.47
- 0.3.46
- 0.3.45
- 0.3.44
- 0.3.43
- 0.3.42
- 0.3.41
- 0.3.40
- 0.3.39
- 0.3.38
- 0.3.37
- 0.3.36
- 0.3.35
- 0.3.34
- 0.3.33
- 0.3.32
- 0.3.31
- 0.3.30
- 0.3.29
- 0.3.28
- 0.3.27
- 0.3.26
- 0.3.25
- 0.3.24
- 0.3.23
- 0.3.22
- 0.3.21
- 0.3.20
- 0.3.19
- 0.3.18
- 0.3.17
- 0.3.16
- 0.3.15
- 0.3.14
- 0.3.13
- 0.3.12
- 0.3.11
- 0.3.10
- 0.3.9
- 0.3.8
- 0.3.7
- 0.3.6
- 0.3.5
- 0.3.4
- 0.3.3
- 0.3.2
- 0.3.1
- 0.3.0
- 0.2.93
- 0.2.92
- 0.2.91
- 0.2.90
- 0.2.89
- 0.2.88
- 0.2.87
- 0.2.86
- 0.2.85
- 0.2.84
- 0.2.83
- 0.2.82
- 0.2.81
- 0.2.80
- 0.2.79
- 0.2.78
- 0.2.77
- 0.2.76
- 0.2.75
- 0.2.74
- 0.2.73
- 0.2.72
- 0.2.71
- 0.2.70
- 0.2.69
- 0.2.68
- 0.2.67
- 0.2.66
- 0.2.65
- 0.2.64
- 0.2.63
- 0.2.62
- 0.2.61
- 0.2.60
- 0.2.59
- 0.2.58
- 0.2.57
- 0.2.56
- 0.2.55
- 0.2.54
- 0.2.53
- 0.2.52
- 0.2.51
- 0.2.50
- 0.2.49
- 0.2.48
- 0.2.47
- 0.2.46
- 0.2.45
- 0.2.44
- 0.2.43
- 0.2.42
- 0.2.41
- 0.2.40
- 0.2.39
- 0.2.38
- 0.2.37
- 0.2.36
- 0.2.35
- 0.2.34
- 0.2.33
- 0.2.32
- 0.2.31
- 0.2.30
- 0.2.29
- 0.2.28
- 0.2.27
- 0.2.26
- 0.2.25
- 0.2.24
- 0.2.23
- 0.2.22
- 0.2.21
- 0.2.20
- 0.2.19
- 0.2.18
- 0.2.17
- 0.2.16
- 0.2.15
- 0.2.14
- 0.2.13
- 0.2.12
- 0.2.11
- 0.2.10
- 0.2.9
- 0.2.8
- 0.2.7
- 0.2.6
- 0.2.5
- 0.2.4
- 0.2.3
- 0.2.2
- 0.2.1
- 0.2.0
- 0.1.0
- dev-dependabot/composer/carthage-software/mago-1.1.0
- dev-dependabot/github_actions/actions/checkout-6
- dev-dependabot/composer/brick/varexporter-approx-0.5.0or-approx-0.7.0
This package is auto-updated.
Last update: 2026-01-21 00:57:46 UTC
README
This library provides functionality for validating, formatting, and converting ISBN numbers. It powers the nicebooks.com website and is available for use under the permissive MIT open-source license.
ISBN validation and formatting follow the rules defined by the ISBN range file published by the International ISBN Agency.
Installation
This library is installable via Composer:
composer require nicebooks/isbn
Requirements
The current version of this library requires PHP 8.2 or higher.
You may use earlier versions of nicebooks/isbn with earlier versions of PHP, but you will only receive ISBN range updates if you use the latest version.
Project status & release process
While this library is still under development, it is well tested and should be stable enough to use in production environments. It is currently in use in production on nicebooks.com.
The current releases are numbered 0.x.y. When a non-breaking change is introduced (updating ISBN ranges,
adding new methods, optimizing existing code, etc.), y is incremented.
When a breaking change is introduced, a new 0.x version cycle is always started.
It is therefore safe to lock your project to a given release cycle, such as 0.6.*.
If you need to upgrade to a newer release cycle, check the release history
for a list of changes introduced by each further 0.x.0 version.
Overview
The Isbn class
The Isbn class is an abstract, immutable class representing an ISBN-10 or ISBN-13 with a valid format and a valid check digit.
It has 2 subclasses: Isbn10 and Isbn13, allowing for narrower typing if your application expects only ISBN-10 or only ISBN-13 at some point.
An Isbn instance is obtained with the of() factory method:
use Nicebooks\Isbn\Isbn; $isbn = Isbn::of('123456789X'); // will return an instance of Isbn10 $isbn = Isbn::of('9781234567897'); // will return an instance of Isbn13
You can also use the Isbn10::of() and Isbn13::of() factory methods, which will attempt to convert the given ISBN to the corresponding subclass:
Isbn10::of('123456789X'); // equivalent to Isbn::of('123456789X')->to10(); Isbn13::of('9781234567897'); // equivalent to Isbn::of('9781234567897')->to13();
If the given string does not have a valid format or check digit, an InvalidIsbnException is thrown.
Note
Before validation, the provided string is stripped of all non-alphanumeric ASCII characters.
Checking the type of an ISBN
You can check the type of an ISBN with the is10() and is13() methods:
Isbn::of('123456789X')->is10(); // true Isbn::of('123456789X')->is13(); // false Isbn::of('9781234567897')->is10(); // false Isbn::of('9781234567897')->is13(); // true
You can also use instanceof checks:
Isbn::of('123456789X') instanceof Isbn10; // true Isbn::of('9781234567897') instanceof Isbn13; // true
Converting between ISBN-10 and ISBN-13
An ISBN-10 can be converted to an ISBN-13 with the to13() method:
Isbn::of('123456789X')->to13(); // Isbn13 instance with value 9781234567897
An ISBN-13 can be converted to an ISBN-10 with the to10() method:
Isbn::of('9781234567897')->to10(); // Isbn10 instance with value 123456789X
Only ISBN-13 numbers starting with 978 can be converted to ISBN-10. You can check if an ISBN can be converted to an ISBN-10 with the isConvertibleTo10() method:
Isbn::of('9781234567897')->isConvertibleTo10(); // true Isbn::of('9791234567896')->isConvertibleTo10(); // false
If you call to10() on an ISBN-13 that does not start with 978, an IsbnNotConvertibleException is thrown.
Comparing ISBN numbers
You can compare two Isbn instances with the isEqualTo() method. An ISBN-10 can be compared to an ISBN-13, and the comparison will be successful if both numbers resolve to the same ISBN-13 number:
Isbn::of('123456789X')->isEqualTo(Isbn::of('9781234567897')); // true
Validating an ISBN
While an Isbn instance is guaranteed to have a valid format and a valid check digit, it may not belong to a valid range according to the range file published by the International ISBN Agency.
The Isbn class provides two methods to further validate an ISBN:
| Method | Description |
|---|---|
hasValidRegistrationGroup() |
Only checks if the ISBN belongs to a known registration group. |
isValid() |
Checks if the ISBN belongs to a known registration group and a known range. This is the highest level of validation that can be performed by looking at the ISBN number alone. |
Note
Which ISBNs are considered valid depends on the library version you are using. This library is kept in sync with the ISBN ranges published by the International ISBN Agency, so keep it up to date for proper validation.
Formatting an ISBN
The library provides two methods to format an ISBN:
| Method | Description | ISBN-10 example | ISBN-13 example |
|---|---|---|---|
toString() |
Returns the unformatted ISBN | 133887893X |
9781338878936 |
toFormattedString() |
Returns the formatted ISBN if the ISBN is valid, otherwise returns the unformatted number | 1-338-87893-X |
978-1-338-87893-6 |
Splitting an ISBN into parts
An ISBN-13 is divided into 5 parts:
978-1-338-87893-6
——— — ——— ————— —
A B C D E
While an ISBN-10 is divided into 4 parts:
1-338-87893-X
— ——— ————— —
B C D E
The Isbn class provides getters for each part:
| Part | Example | Description | Getter |
|---|---|---|---|
A |
978 |
Prefix | getRegistrationGroup()->prefix |
B |
1 |
Registration group identifier | getRegistrationGroup()->identifier |
C |
338 |
Publisher identifier (registrant) | getPublisherIdentifier() |
D |
87893 |
Title identifier (publication) | getTitleIdentifier() |
E |
6 |
Check digit | getCheckDigit() |
Important
- Parts
AandBrequirehasValidRegistrationGroup()(orisValid(), which implies it) - Parts
CandDrequireisValid()
You can also get the ISBN parts as an array:
Isbn::of('9781338878936')->getParts(); // ['978', '1', '338', '87893', '6']
Important
getParts() requires isValid()
If the part you're trying to access is not available because the ISBN does not belong to a valid registration group or range, an IsbnException is thrown.
Getting the registration group name
getRegistrationGroup() also exposes the group's name:
Isbn::of('9781338878936')->getRegistrationGroup()->name; // 'English language'
Exceptions
Exceptions live in the Nicebooks\Isbn\Exception namespace.
IsbnExceptionis the base class for all exceptions thrown by this library.InvalidIsbnExceptionis thrown when an invalid ISBN is detectedIsbnNotConvertibleExceptionis thrown when trying to convert an ISBN-13 that does not start with978to an ISBN-10.