Expand description
This package contains an implementation of the ISO 6166 International securities identification number (ISIN) specification.
ISO 6166 defines the structure of an International Securities Identification Number (ISIN). An ISIN uniquely identifies a fungible security.
Securities with which ISINs can be used are:
- Equities (shares, units, depository receipts)
- Debt instruments (bonds and debt instruments other than international, international bonds and debt instruments, stripped coupons and principal, treasury bills, others)
- Entitlements (rights, warrants)
- Derivatives (options, futures)
- Others (commodities, currencies, indices, interest rates)
ISINs consist of two alphabetic characters, which are the ISO 3166-1 alpha-2 code for the issuing country, nine alpha-numeric characters (the National Securities Identifying Number, or NSIN, which identifies the security, padded as necessary with leading zeros), and one numerical check digit. They are thus always 12 characters in length. When the NSIN changes due to corporate actions or other reasons, the ISIN will also change. Issuance of ISINs is decentralized to individual national numbering agencies (NNAs). Since existing national numbering schemes administered by the various NNAs form the basis for ISINs, the methodology for assignment is not consistent across agencies globally.
An ISIN cannot specify a particular trading location. Another identifier, typically a MIC (Market Identifier Code) or the three-letter exchange code, will have to be specified in addition to the ISIN for this. The currency of the trade will also be required to uniquely identify the instrument using this method.
§Example
The following demonstrates the most common method for constructing an ISIN,
using the standard FromStr
trait.
use codes_iso_3166::part_1::CountryCode;
use codes_iso_6166::InternationalSecuritiesId as Isin;
use std::str::FromStr;
let walmart = Isin::from_str("US9311421039").unwrap();
assert_eq!(walmart.country_code(), CountryCode::US);
assert_eq!(walmart.national_number(), "931142103");
assert_eq!(walmart.check_digit(), 9);
Alternatively, an ISIN can be constructed from a combination of ISO 3166 country code and an NSIN string. This will calculate and append the ISIN check digit.
use codes_iso_3166::part_1::CountryCode;
use codes_iso_6166::InternationalSecuritiesId as Isin;
use std::str::FromStr;
let bae_systems = Isin::new(CountryCode::GB, "263494").unwrap();
assert_eq!(&format!("{}", bae_systems), "GB0002634946");
assert_eq!(&format!("{:#}", bae_systems), "GB-000263494-6");
§Features
By default only the serde
feature is enabled.
serde
- Enables serialization of the InternationalSecuritiesId type.url
- Enables the conversion between ISIN and URL (URN) forms.
Modules§
Structs§
- International
Securities Id - The ISO 6166 International Securities Identification Number (ISIN)
Enums§
- International
Securities IdError - Common
Error
type, mainly used forFromStr
failures.
Constants§
- ISO_
6166 - An instance of the
Standard
struct defined in thecodes_agency
package that describes the ISO-6166 specification.