HashStream.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Tue, 20 Aug 2013 00:07:19 +0100
branchjv
changeset 18084 ab5b38bd8f81
parent 18028 e39da2aa21bc
parent 15622 79d968fa9f05
child 18120 e3a375d5f6a8
permissions -rw-r--r--
Merged 5558dc303721 and 210c3f685d38 (branch default - CVS HEAD)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
 COPYRIGHT (c) 1999 by eXept Software AG
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
              All Rights Reserved
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
 This software is furnished under a license and may be used
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 hereby transferred.
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
"
7014
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
    12
"{ Package: 'stx:libbasic' }"
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
    13
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
Stream subclass:#HashStream
7014
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
    15
	instanceVariableNames:''
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
    16
	classVariableNames:''
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
    17
	poolDictionaries:''
12418
720aa584e5cf category changes
Claus Gittinger <cg@exept.de>
parents: 12273
diff changeset
    18
	category:'System-Crypt-Hashing'
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
!HashStream class methodsFor:'documentation'!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
copyright
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
 COPYRIGHT (c) 1999 by eXept Software AG
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
              All Rights Reserved
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
 This software is furnished under a license and may be used
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
 only in accordance with the terms of that license and with the
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
 be provided or otherwise made available to, or used by, any
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 other person.  No title to or ownership of the software is
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
 hereby transferred.
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
documentation
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
"
13910
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    40
    Abstract class. 
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    41
    Subclasses generate hash values used as checksums
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    or for generating cryptographic signatures.
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
13910
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    44
    Notice: due to historic reasons and compatibility with Squeak,
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    45
    there are two modes of operation:
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    46
        1) hashFunction mode, in which the hash of a single block of bytes is computed
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    47
        2) hashStream mode, in which instances behave like a writeStream, computing and
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    48
           updating the hash, as data is sent to it.
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    49
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    50
    hashFunction mode is called using: #hashValueOf:aStringOrByteArray
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    51
    Warning: Not all subclasses support the stream mode 
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    52
             (especially those which were ported from squeak do not).
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    53
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
    [author:]
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
        Stefan Vogel
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
    [see also:]
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
        SHA1Stream MD5Stream
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
"
13910
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    60
!
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    61
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    62
examples
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    63
"
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    64
  hashFunction mode:
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    65
                                                                [exBegin]
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    66
    MD5Stream hashValueOf:'hello world'
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    67
    MD4Stream hashValueOf:'hello world'
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    68
                                                                [exEnd]
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    69
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    70
  hashStream mode:
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    71
                                                                [exBegin]
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    72
    |md5|
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    73
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    74
    md5 := MD5Stream new.
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    75
    md5 nextPutAll:'hello world'.
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    76
    md5 hashValue  
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    77
                                                                [exEnd]
6fa973ab48c0 added: #examples
Claus Gittinger <cg@exept.de>
parents: 13904
diff changeset
    78
"
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
! !
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
!HashStream class methodsFor:'instance creation'!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
7015
862174119468 category change
penk
parents: 7014
diff changeset
    83
new
862174119468 category change
penk
parents: 7014
diff changeset
    84
    "have to re-allow new - it was disabled in Stream"
862174119468 category change
penk
parents: 7014
diff changeset
    85
    ^ self basicNew initialize
862174119468 category change
penk
parents: 7014
diff changeset
    86
862174119468 category change
penk
parents: 7014
diff changeset
    87
862174119468 category change
penk
parents: 7014
diff changeset
    88
!
862174119468 category change
penk
parents: 7014
diff changeset
    89
862174119468 category change
penk
parents: 7014
diff changeset
    90
random
862174119468 category change
penk
parents: 7014
diff changeset
    91
    "create a random number generator using myself"
862174119468 category change
penk
parents: 7014
diff changeset
    92
862174119468 category change
penk
parents: 7014
diff changeset
    93
    ^ HashRandom with:self
862174119468 category change
penk
parents: 7014
diff changeset
    94
862174119468 category change
penk
parents: 7014
diff changeset
    95
    "
862174119468 category change
penk
parents: 7014
diff changeset
    96
     SHA1Stream random next
862174119468 category change
penk
parents: 7014
diff changeset
    97
    "
862174119468 category change
penk
parents: 7014
diff changeset
    98
862174119468 category change
penk
parents: 7014
diff changeset
    99
    "Modified: / 12.11.1999 / 17:21:17 / stefan"
862174119468 category change
penk
parents: 7014
diff changeset
   100
! !
862174119468 category change
penk
parents: 7014
diff changeset
   101
12145
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   102
!HashStream class methodsFor:'compatibility - squeak'!
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   103
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   104
hashMessage:aStringOrByteArrayOrStream
12146
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   105
    "SQUEAK compatibility 
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   106
        - but this is a bad choice - squeak uses #digestMessage: at the instance side"
12145
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   107
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   108
    ^ self hashValueOf:aStringOrByteArrayOrStream
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   109
! !
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   110
12174
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   111
!HashStream class methodsFor:'queries'!
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   112
15622
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   113
blockSize
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   114
    "return the block size when the hash is used by encryption/decryption.
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   115
     (see OfbCipherMode and CtrCipherMode)"
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   116
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   117
    ^ self hashSize
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   118
!
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   119
12174
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   120
canStream
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   121
    "simple hash functions (squeak-ported) cannot stream.
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   122
     Use hashFunction: there"
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   123
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   124
    ^ true
13889
f335cf6d5783 added: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13366
diff changeset
   125
!
f335cf6d5783 added: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13366
diff changeset
   126
15622
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   127
hashBlockSize
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   128
    "return the block size used internally by the compression function"
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   129
    
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   130
    self subclassResponsibility
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   131
!
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   132
13889
f335cf6d5783 added: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13366
diff changeset
   133
hashSize
13928
c344ee05a04c changed: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13924
diff changeset
   134
    "return the size of the hashvalue returned by instances of this class (in bytes)"
c344ee05a04c changed: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13924
diff changeset
   135
13889
f335cf6d5783 added: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13366
diff changeset
   136
    self subclassResponsibility
f335cf6d5783 added: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13366
diff changeset
   137
f335cf6d5783 added: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13366
diff changeset
   138
    "Created: / 04-01-2012 / 19:22:32 / cg"
12174
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   139
! !
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   140
12146
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   141
!HashStream class methodsFor:'self tests'!
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   142
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   143
test
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   144
    "test against testVector"
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   145
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   146
    self testVector do:[:pair |
13924
450a2fe36142 changed: #test
Claus Gittinger <cg@exept.de>
parents: 13918
diff changeset
   147
        |data expectedHash expectedHashBytes computedHash hashStream|
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   148
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   149
        data := pair first.
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   150
        expectedHash := pair second.
12753
3e6acf834564 changed: #test
Claus Gittinger <cg@exept.de>
parents: 12418
diff changeset
   151
        expectedHash isString ifTrue:[
3e6acf834564 changed: #test
Claus Gittinger <cg@exept.de>
parents: 12418
diff changeset
   152
            expectedHashBytes := ByteArray fromHexString:expectedHash
3e6acf834564 changed: #test
Claus Gittinger <cg@exept.de>
parents: 12418
diff changeset
   153
        ] ifFalse:[
3e6acf834564 changed: #test
Claus Gittinger <cg@exept.de>
parents: 12418
diff changeset
   154
            expectedHashBytes := expectedHash
3e6acf834564 changed: #test
Claus Gittinger <cg@exept.de>
parents: 12418
diff changeset
   155
        ].
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   156
13366
0e1bdf4f4156 changed: #test
Stefan Vogel <sv@exept.de>
parents: 12753
diff changeset
   157
        "/ non-stream interface must be implemented by all
13924
450a2fe36142 changed: #test
Claus Gittinger <cg@exept.de>
parents: 13918
diff changeset
   158
        computedHash := self hashValueOf:data.
450a2fe36142 changed: #test
Claus Gittinger <cg@exept.de>
parents: 13918
diff changeset
   159
        self assert:computedHash = expectedHashBytes message:'Test failed'.
12174
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   160
        self canStream ifTrue:[
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   161
            hashStream := self new.
e40625636dd5 added: #canStream
Claus Gittinger <cg@exept.de>
parents: 12146
diff changeset
   162
            hashStream nextPut:data.
13924
450a2fe36142 changed: #test
Claus Gittinger <cg@exept.de>
parents: 13918
diff changeset
   163
            computedHash := hashStream hashValue.
450a2fe36142 changed: #test
Claus Gittinger <cg@exept.de>
parents: 13918
diff changeset
   164
            self assert:computedHash = expectedHashBytes message:'Test failed'
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   165
        ].
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   166
    ].
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   167
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   168
    "
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   169
        MD5Stream test.
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   170
        SHA1Stream test.
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   171
        RipeMD160Stream test.
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   172
    "
13924
450a2fe36142 changed: #test
Claus Gittinger <cg@exept.de>
parents: 13918
diff changeset
   173
450a2fe36142 changed: #test
Claus Gittinger <cg@exept.de>
parents: 13918
diff changeset
   174
    "Modified: / 10-01-2012 / 22:35:17 / cg"
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   175
!
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   176
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   177
testVector
13918
1452ea5f41f0 test stuff
Claus Gittinger <cg@exept.de>
parents: 13910
diff changeset
   178
    "/ obsolete - moved to TestHashAlgorithms unit test.
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   179
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   180
    ^ self subclassResponsibility
13918
1452ea5f41f0 test stuff
Claus Gittinger <cg@exept.de>
parents: 13910
diff changeset
   181
1452ea5f41f0 test stuff
Claus Gittinger <cg@exept.de>
parents: 13910
diff changeset
   182
    "Modified (comment): / 09-01-2012 / 21:49:59 / cg"
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   183
! !
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   184
7015
862174119468 category change
penk
parents: 7014
diff changeset
   185
!HashStream class methodsFor:'utilities'!
862174119468 category change
penk
parents: 7014
diff changeset
   186
15621
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   187
cryptBlock:aStringOrByteArray from:srcIdx into:resultOrNil startingAt:dstIdx encrypt:encryptMode
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   188
    "one-way encryption of aStringOrByteArray.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   189
     Used when a HashStream is used as the block copher with OFB or CTR mode.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   190
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   191
     encryptMode is ignored here."
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   192
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   193
    |hashValue|
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   194
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   195
    srcIdx == 1 ifTrue:[
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   196
        hashValue := self hashValueOf:aStringOrByteArray.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   197
    ] ifFalse:[
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   198
        |bytesToEncrypt|
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   199
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   200
        bytesToEncrypt := aStringOrByteArray copyFrom:srcIdx to:srcIdx+self hashSize-1.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   201
        hashValue := self hashValueOf:bytesToEncrypt.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   202
    ].
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   203
    resultOrNil isNil ifTrue:[
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   204
        ^ hashValue.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   205
    ] ifFalse:[
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   206
        resultOrNil replaceBytesFrom:dstIdx to:dstIdx+hashValue size-1 with:hashValue startingAt:1.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   207
        ^ resultOrNil.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   208
    ].
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   209
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   210
    "
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   211
        |cipher iv cipherText|
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   212
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   213
        cipher := OfbCipher for:SHA512Stream.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   214
        iv := cipher randomInitializationVector.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   215
        cipherText := cipher encrypt:'Hello world, here is the alien from Mars and 1234567890' asByteArray.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   216
        self information:cipherText printString.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   217
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   218
        cipher initializationVector:iv.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   219
        self information:(cipher decrypt:cipherText) asString.
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   220
    "
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   221
!
2a93f0420de1 class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14842
diff changeset
   222
12145
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   223
digestMessage:aStringOrByteArrayOrStream
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   224
    ^ self hashValueOf:aStringOrByteArrayOrStream
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   225
!
Stefan Vogel <sv@exept.de>
parents: 12142
diff changeset
   226
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   227
hashValueOf:aStringOrByteArrayOrStream
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   228
    |hashStream|
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   229
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   230
    hashStream := self new.
13929
ef3fa2d52e05 changed: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13928
diff changeset
   231
    aStringOrByteArrayOrStream isStream ifTrue:[
ef3fa2d52e05 changed: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13928
diff changeset
   232
        aStringOrByteArrayOrStream copyToEndInto:hashStream.
ef3fa2d52e05 changed: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13928
diff changeset
   233
    ] ifFalse:[
ef3fa2d52e05 changed: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13928
diff changeset
   234
        hashStream nextPutAll:aStringOrByteArrayOrStream.
ef3fa2d52e05 changed: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13928
diff changeset
   235
    ].
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   236
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   237
    ^ hashStream hashValue
7014
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   238
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   239
    "
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   240
     MD5Stream hashValueOf:'BlaBlaBla'
12146
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   241
     MD5Stream hashValueOf:('makefile' asFilename readStream)
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   242
     MD5Stream hashValueOf:('BlaBlaBla' readStream)
7014
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   243
    "
13929
ef3fa2d52e05 changed: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13928
diff changeset
   244
ef3fa2d52e05 changed: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13928
diff changeset
   245
    "Modified: / 12-01-2012 / 12:14:44 / cg"
7014
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   246
!
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   247
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
hashValueOfFile:aFilename
12146
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   249
    |hash|
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   250
12146
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   251
    aFilename asFilename readingFileDo:[:readStream|
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   252
        readStream binary.
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   253
        hash := self hashValueOf:readStream.
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   254
    ].
12146
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   255
    ^ hash
7014
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   256
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   257
    "
12146
cc757f348884 comment/format in:
Stefan Vogel <sv@exept.de>
parents: 12145
diff changeset
   258
     MD5Stream hashValueOfFile:'makefile'
7014
c443479ee603 hashValueOf - generalized
penk
parents: 6864
diff changeset
   259
    "
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
! !
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
!HashStream methodsFor:'accessing'!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
contents
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   265
    "return the entire contents of the stream
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   266
     - this is our hashValue."
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
    ^ self hashValue
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
    "Created: / 17.3.1999 / 15:10:03 / stefan"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
! !
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   273
!HashStream methodsFor:'not implemented'!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   274
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   275
next
13904
1aacd72f4414 comment/format in: #next
Claus Gittinger <cg@exept.de>
parents: 13903
diff changeset
   276
    "I can only write"
1aacd72f4414 comment/format in: #next
Claus Gittinger <cg@exept.de>
parents: 13903
diff changeset
   277
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
    ^ self shouldNotImplement
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
13904
1aacd72f4414 comment/format in: #next
Claus Gittinger <cg@exept.de>
parents: 13903
diff changeset
   280
    "Created: / 17-03-1999 / 15:11:03 / stefan"
1aacd72f4414 comment/format in: #next
Claus Gittinger <cg@exept.de>
parents: 13903
diff changeset
   281
    "Modified (comment): / 09-01-2012 / 16:55:28 / cg"
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   282
! !
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   283
12142
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   284
!HashStream methodsFor:'operations'!
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   285
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   286
digestMessage:bytes
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   287
    "answer the digest of bytes"
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   288
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   289
    self reset.
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   290
    self nextPutAll:bytes.
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   291
14842
8f7ca0be2aed class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14453
diff changeset
   292
    ^ self hashValue.
12142
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   293
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   294
    "
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   295
        SHA1Stream new 
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   296
                digestMessage:'123456789abcdefg';
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   297
                digestMessage:'123456789abcdefg'
12273
96403b4aeb20 comment/format in: #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 12174
diff changeset
   298
96403b4aeb20 comment/format in: #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 12174
diff changeset
   299
        (SHA1Stream new hmac key:'123456') 
96403b4aeb20 comment/format in: #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 12174
diff changeset
   300
                digestMessage:'123456789abcdefg';
96403b4aeb20 comment/format in: #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 12174
diff changeset
   301
                digestMessage:'123456789abcdefg'
96403b4aeb20 comment/format in: #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 12174
diff changeset
   302
96403b4aeb20 comment/format in: #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 12174
diff changeset
   303
        (SHA1Stream new hmac key:'123456') 
96403b4aeb20 comment/format in: #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 12174
diff changeset
   304
                nextPutAll:'123456789abcdefg';
96403b4aeb20 comment/format in: #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 12174
diff changeset
   305
                contents
12142
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   306
    "
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   307
!
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   308
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   309
reset
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   310
    "initialize to a clean state"
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   311
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   312
    ^ self subclassResponsibility
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   313
! !
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   314
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   315
!HashStream methodsFor:'queries'!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   316
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   317
blockSize
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   318
    "the class knows about the basic block size"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   319
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   320
    ^ self class blockSize
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   321
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   322
    "Created: / 18.3.1999 / 10:17:02 / stefan"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   323
!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   324
15622
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   325
hashBlockSize
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   326
    "the class knows about the basic block size"
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   327
    
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   328
    ^ self class hashBlockSize
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   329
!
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   330
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   331
hashSize
13928
c344ee05a04c changed: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13924
diff changeset
   332
    "return the size of the returned hashvalue (in bytes)"
c344ee05a04c changed: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13924
diff changeset
   333
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   334
    "the class knows about the basic hash size"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   335
    ^ self class hashSize
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
13928
c344ee05a04c changed: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13924
diff changeset
   337
    "Created: / 18-03-1999 / 10:17:12 / stefan"
c344ee05a04c changed: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13924
diff changeset
   338
    "Modified: / 15-10-1999 / 11:53:20 / stefan"
c344ee05a04c changed: #hashSize
Claus Gittinger <cg@exept.de>
parents: 13924
diff changeset
   339
    "Modified (comment): / 11-01-2012 / 10:12:09 / cg"
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   340
!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   341
7251
0ef2a2a16faa *** empty log message ***
Stefan Vogel <sv@exept.de>
parents: 7042
diff changeset
   342
hashValue
13969
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   343
    "return the value of the computed hash"
7251
0ef2a2a16faa *** empty log message ***
Stefan Vogel <sv@exept.de>
parents: 7042
diff changeset
   344
0ef2a2a16faa *** empty log message ***
Stefan Vogel <sv@exept.de>
parents: 7042
diff changeset
   345
    ^ self subclassResponsibility
13969
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   346
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   347
    "Modified (comment): / 23-01-2012 / 10:01:20 / cg"
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   348
!
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   349
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   350
hashValueOf:aString
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   351
    "for convenience:
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   352
     return the value of the computed hash of aString"
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   353
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   354
    self reset.
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   355
    self nextPutAll:aString.
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   356
    ^ self hashValue
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   357
b5df2d4c7581 added: #hashValueOf:
Claus Gittinger <cg@exept.de>
parents: 13929
diff changeset
   358
    "Created: / 18-01-2012 / 17:26:25 / cg"
7251
0ef2a2a16faa *** empty log message ***
Stefan Vogel <sv@exept.de>
parents: 7042
diff changeset
   359
!
0ef2a2a16faa *** empty log message ***
Stefan Vogel <sv@exept.de>
parents: 7042
diff changeset
   360
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   361
isReadable
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   362
    "return true, if reading is supported by the recevier.
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   363
     Always return false here"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   364
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   365
    ^ false
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   366
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   367
    "Modified: / 17.3.1999 / 15:06:09 / stefan"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   368
!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   369
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   370
isWritable
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   371
    "return true, if writing is supported by the recevier.
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   372
     Always return true here"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   373
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   374
    ^ true
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   375
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   376
    "Created: / 17.3.1999 / 15:05:49 / stefan"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   377
! !
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   378
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   379
!HashStream methodsFor:'testing'!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   380
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   381
atEnd
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   382
    "return true if the end of the stream has been reached;
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   383
    this is never reached"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   384
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   385
    ^ false
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   386
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   387
    "Created: / 17.3.1999 / 15:08:55 / stefan"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   388
! !
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   389
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   390
!HashStream methodsFor:'writing'!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   391
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   392
nextPut:anObject
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   393
    "add the hash of anObject to the computed hash so far.
13903
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   394
     anObject can be a Character, SmallInteger ByteArray or String"
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   395
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   396
    anObject isByteCollection ifTrue:[
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   397
        self nextPutBytes:(anObject byteSize) from:anObject startingAt:1.
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   398
        ^ self.
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   399
    ].
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   400
13903
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   401
    anObject isCharacter ifTrue:[
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   402
        "/ only ascii allowed !!
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   403
        self nextPutBytes:(ByteArray with:anObject codePoint).
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   404
        ^ self.
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   405
    ].
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   406
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   407
    anObject isInteger ifTrue:[
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   408
        "/ only 0..255 allowed !!
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   409
        anObject < 256 ifTrue:[
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   410
            self nextPutAll:(ByteArray with:anObject).
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   411
            ^ self.
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   412
        ].
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   413
    ].
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   414
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   415
    self error:'unsupported argument'.
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   416
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   417
    "Modified (comment): / 09-01-2012 / 16:54:05 / cg"
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   418
!
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   419
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   420
nextPutAll:aCollection
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   421
    "Hash streams handle Strings and ByteArrays in nextPut:"
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   422
11799
2cbd0a5e7c64 changed #nextPutAll:
Stefan Vogel <sv@exept.de>
parents: 7251
diff changeset
   423
    aCollection isByteCollection ifTrue:[
13900
0dc22ed6d46f changed: #nextPutAll:
Claus Gittinger <cg@exept.de>
parents: 13889
diff changeset
   424
        self nextPutBytes:(aCollection byteSize) from:aCollection startingAt:1.
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   425
    ] ifFalse:[
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   426
        super nextPutAll:aCollection
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   427
    ].
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
13900
0dc22ed6d46f changed: #nextPutAll:
Claus Gittinger <cg@exept.de>
parents: 13889
diff changeset
   429
    "Created: / 14-10-1999 / 11:22:50 / stefan"
0dc22ed6d46f changed: #nextPutAll:
Claus Gittinger <cg@exept.de>
parents: 13889
diff changeset
   430
    "Modified: / 09-01-2012 / 13:02:44 / cg"
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   431
!
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   432
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   433
nextPutBytes:count from:anObject startingAt:start
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   434
    "write count bytes from an object starting at index start.
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   435
     Return the number of bytes written.
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   436
     The object must have non-pointer indexed instvars 
13903
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   437
     (i.e. be a ByteArray, String, Float- or DoubleArray)."
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   438
13903
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   439
    self subclassResponsibility
7042
dbb7898901e3 Fix #hashValueOf:
Stefan Vogel <sv@exept.de>
parents: 7015
diff changeset
   440
13903
f2b227a2fcaa changed:
Claus Gittinger <cg@exept.de>
parents: 13901
diff changeset
   441
    "Modified: / 09-01-2012 / 16:41:31 / cg"
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   442
! !
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   443
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   444
!HashStream class methodsFor:'documentation'!
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   445
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   446
version
15622
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   447
    ^ '$Header: /cvs/stx/stx/libbasic/HashStream.st,v 1.29 2013-08-11 22:25:34 stefan Exp $'
12142
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   448
!
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   449
1814d6072f33 new: #hmac, #digestMessage:
Stefan Vogel <sv@exept.de>
parents: 11799
diff changeset
   450
version_CVS
15622
79d968fa9f05 Rename #blockSize to #hashBlockSize
Stefan Vogel <sv@exept.de>
parents: 15621
diff changeset
   451
    ^ '$Header: /cvs/stx/stx/libbasic/HashStream.st,v 1.29 2013-08-11 22:25:34 stefan Exp $'
6864
0d5bd7218853 MD5 stuff now in base system
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   452
! !
14842
8f7ca0be2aed class: HashStream
Stefan Vogel <sv@exept.de>
parents: 14453
diff changeset
   453