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