npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@fnzc/nz-ird-validator

v1.1.0

Published

Validates New Zealand tax numbers (IRD)

Downloads

21,149

Readme

nz-ird-validator

npm

A validator for New Zealand tax numbers (IRD)

Installation

npm install --save @fnzc/nz-ird-validator

or

yarn add @fnzc/nz-ird-validator

Usage

Function requires one string parameter:

  • IRD number (normal or dashed format) Returns a boolean.
var irdValidator = require('@fnzc/nz-ird-validator');
irdValidator.isValidIRDNumber('000-000-000');

Allows you to specify whether dashes / no dashes are required - defaults to agnostic ('either').

validator.configureValidator({requireFormat: 'dashes'})('123-123-123')

Algorithm

The algorithm is based on the 'Non-Resident Withholding Tax And Resident Withholding Tax Specification Document' issues by the Inland Revenue on the 31st of March 2016.

IR number validation - modulus 11 digit check

The IRD number format used by Inland Revenue is an eight or nine digit number consisting of the following parts -

  • A seven or eight digit base number
  • A trailing check digit

Check digit validation

The following steps are to be performed:

  • Check the valid range
    • If the IRD number is < 10-000-000 or > 150-000-000 then the number is invalid. This step ensures that the IRD number is in the already issued range, or is in the range expected to be issued in the next 10 years.
  • Form the eight digit base number
    • Remove the trailing check digit.
    • If the resulting number is seven digits long, pad to eight digits by adding a leading zero.
  • Calculate the check digit
    • To each of the base number’s eight digits a weight factor is assigned. From left to right these are: 3, 2, 7, 6, 5, 4, 3, 2.
    • Sum together the products of the weight factors and their associated digits.
    • Divide the sum by 11. If the remainder is 0 then the calculated check digit is 0.
    • If the remainder is not 0 then subtract the remainder from 11, giving the calculated check digit.
    • If the calculated check digit is in the range 0 to 9, go to step 5.
    • If the calculated check digit is 10, continue with step 4.
  • Re-calculate the check digit
    • To each of the base number’s eight digits a secondary weight factor is assigned. From left to right these are: 7, 4, 3, 2, 5, 2, 7, 6.
    • Sum together the products of the weight factors and their associated digits.
    • Divide the sum by 11. If the remainder is 0 then the calculated check digit is 0.
    • If the remainder is not 0 then subtract the remainder from 11, giving the 00 calculated check digit.
    • If the calculated check digit is 10, the IRD number is invalid. 5. Compare the check digit :
    • Compare the calculated check digit to the last digit of the original IRD number.
    • If they match, the IRD number is valid.

Changelog

Contributing

Pull requests are welcome.

License