Git Product home page Git Product logo

creditcardvalidator's Introduction

Installation

CocoaPods

pod "CreditCardValidator", '~> 0.5.3'

Swift Package Manager

.package(url: "https://github.com/vitkuzmenko/CreditCardValidator.git", from: "0.5.3")

After specifying "CreditCardValidator" as a dependency of the target in which you want to use it, run swift package update.

Accio

Do the same configurations as for SwiftPM, then run accio update instead of swift package update.

Usage

Validating

let number = "1234 5678 9123 4567"
   
if CreditCardValidator(number).isValid {
  // Card number is valid
} else {
  // Card number is invalid
}

Detect Card Type

let number = "1234 5678 9123 4567"
   
if let type = CreditCardValidator(number).type {
    print(type.name) // Visa, Mastercard, Amex etc.
} else {
    // I Can't detect type of credit card
}

Check type and validation

let number = "1234 5678 9123 4567"
   
if CreditCardValidator(number).isValid(for: .visa) {
    // Card number is valid and type is .visa
} else {
    // I Can't detect type of credit card
}

Supported types

  • Amex
  • Visa
  • MasterCard
  • Maestro
  • DinersClub
  • JCB
  • Discover
  • UnionPay
  • Mir

Contribution

Contributions are very welcomed ๐Ÿ‘๐Ÿ˜ƒ.

creditcardvalidator's People

Contributors

asmaa-elaraby avatar faranmemon avatar fredpi avatar kuchmiyalex avatar teodortalov avatar vitkuzmenko avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar

creditcardvalidator's Issues

Can't use package with Carthage instead of Cocoapods

Dependency "CreditCardValidator" has no shared framework schemes for any of the platforms: iOS

If you believe this to be an error, please file an issue with the maintainers at https://github.com/vitkuzmenko/CreditCardValidator/issues/new

Says Card Numbers with Too Few Digits are Valid

The app example app says that this is a valid Visa card number: 4242424242

All of the sources I can find say a Visa card must have 13, 16, or 19 characters. That number has 10 digits. Are you certain this is correct?

Swift 3.0

Obviously the auto-converter tool is not perfect and lets some loose ends. I have found this working solution for CreditCardValidator.swift
`
import Foundation

open class CreditCardValidator {

open lazy var types: [CreditCardValidationType] = {
    var types = [CreditCardValidationType]()
    for object in CreditCardValidator.types {
        types.append(CreditCardValidationType(dict: object as [String : AnyObject]))
    }
    return types
    }()

public init() { }

/**
Get card type from string

- parameter string: card number string

- returns: CreditCardValidationType structure
*/
open func typeFromString(_ string: String) -> CreditCardValidationType? {
    for type in types {
        let predicate = NSPredicate(format: "SELF MATCHES %@", type.regex)
        let numbersString = self.onlyNumbersFromString(string)
        if predicate.evaluate(with: numbersString) {
            return type
        }
    }
    return nil
}

/**
Validate card number

- parameter string: card number string

- returns: true or false
*/
open func validateString(_ string: String) -> Bool {
    let numbers = self.onlyNumbersFromString(string)
    if numbers.characters.count < 9 {
        return false
    }

    var reversedString = ""
    let range = Range<String.Index>(uncheckedBounds: (lower: numbers.startIndex, upper: numbers.endIndex))

    numbers.enumerateSubstrings(in: range, options: [NSString.EnumerationOptions.reverse, NSString.EnumerationOptions.byComposedCharacterSequences]) { (substring, substringRange, enclosingRange, stop) -> () in
        reversedString += substring!
    }

    var oddSum = 0, evenSum = 0
    let reversedArray = reversedString.characters
    var i = 0

    for s in reversedArray {

        let digit = Int(String(s))!

        if (i+1) % 2 == 0 {
            evenSum += digit
        } else {
            oddSum += digit / 5 + (2 * digit) % 10
        }
    }
    return (oddSum + evenSum) % 10 == 0
}

/**
Validate card number string for type

- parameter string: card number string
- parameter type:   CreditCardValidationType structure

- returns: true or false
*/
open func validateString(_ string: String, forType type: CreditCardValidationType) -> Bool {
    return typeFromString(string) == type
}

open func onlyNumbersFromString(_ string: String) -> String {
    let set = CharacterSet.decimalDigits.inverted
    let numbers = string.components(separatedBy: set)
    return numbers.joined(separator: "")
}

// MARK: - Loading data

fileprivate static let types = [
    [
        "name": "Amex",
        "regex": "^3[47][0-9]{5,}$"
    ], [
        "name": "Visa",
        "regex": "^4[0-9]{6,}$"
    ], [
        "name": "MasterCard",
        "regex": "^5[1-5][0-9]{5,}$"
    ], [
        "name": "Maestro",
        "regex": "^(?:5[0678]\\d\\d|6304|6390|67\\d\\d)\\d{8,15}$"
    ], [
        "name": "Diners Club",
        "regex": "^3(?:0[0-5]|[68][0-9])[0-9]{4,}$"
    ], [
        "name": "JCB",
        "regex": "^(?:2131|1800|35[0-9]{3})[0-9]{3,}$"
    ], [
        "name": "Discover",
        "regex": "^6(?:011|5[0-9]{2})[0-9]{3,}$"
    ], [
        "name": "UnionPay",
        "regex": "^62[0-5]\\d{13,16}$"
    ]
]

}
`

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.