-
Notifications
You must be signed in to change notification settings - Fork 2
/
EPaymentHmacSignedMessage.class.php
executable file
·48 lines (41 loc) · 1.83 KB
/
EPaymentHmacSignedMessage.class.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
<?php
/*
Copyright 2009 MONOGRAM Technologies
This file is part of MONOGRAM EPayment libraries
MONOGRAM EPayment libraries is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
MONOGRAM EPayment libraries is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with MONOGRAM EPayment libraries. If not, see <http://www.gnu.org/licenses/>.
*/
require_once dirname(__FILE__).'/EPaymentMessage.class.php';
abstract class EPaymentHmacSignedMessage extends EPaymentMessage {
protected function getRawSharedSecret($sharedSecret) {
if (strlen($sharedSecret) == 64) {
return pack('A*', $sharedSecret);
} elseif (strlen($sharedSecret) == 128) {
return pack('A*', pack('H*', $sharedSecret));
} else {
throw new Exception(__METHOD__.": Invalid shared secret format.");
}
}
public function computeSign($sharedSecret) {
if (!$this->isValid)
throw new Exception(__METHOD__.": Message was not validated.");
$signature = false;
try {
$signatureBase = $this->GetSignatureBase();
$rawSignatureBase = pack('A*', $signatureBase);
$rawSharedSecret = $this->getRawSharedSecret($sharedSecret);
$signature = strtoupper(hash_hmac('sha256', $rawSignatureBase, $rawSharedSecret, false));
} catch (Exception $e) {
return false;
}
return $signature;
}
}