summaryrefslogtreecommitdiffstats
path: root/tcllib/modules/valtype/imei.tcl
blob: 2747e745db4c76e070df9bff1b305e6f0a63c847 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# # ## ### ##### ######## ############# ######################
## IMEI (International Mobile Equipment Identity)
## References
##	http://en.wikipedia.org/wiki/IMEI
##	http://www.3gpp.org/ftp/Specs/html-info/23003.htm
## Short notes
##	14-digit number + check digit.
##	Embeds information on origin, model, and serial number of the device.
##	Passes Luhn test as is.

# # ## ### ##### ######## ############# ######################

# The code below implements the interface of a snit validation type,
# making it directly usable with snit's -type option in option
# specifications.

# # ## ### ##### ######## ############# ######################
## Requisites

package require Tcl 8.5
package require snit
package require valtype::luhn
package require valtype::common

# # ## ### ##### ######## ############# ######################
## Implementation

namespace eval ::valtype::imei {
    namespace import ::valtype::common::*
}

snit::type ::valtype::imei {
    #-------------------------------------------------------------------
    # Type Methods

    typemethod validate {value} {
	if {[string length $value] != 15} {
	    badlength IMEI 15 "IMEI number"
	}
	return [valtype::luhn validate $value IMEI]
    }

    typemethod checkdigit {value} {
	if {[string length $value] != 14} {
	    badlength IMEI 14 "IMEI number (without checkdigit)"
	}
	return [valtype::luhn checkdigit $value IMEI]
    }

    #-------------------------------------------------------------------
    # Constructor

    # None needed; no options

    #-------------------------------------------------------------------
    # Public Methods

    method validate {value} {
        $type validate $value
    }
}

# # ## ### ##### ######## ############# ######################
## Ready

package provide valtype::imei 1