Test Failed
Push — develop ( 097751...4093b1 )
by Reüel
03:15
created

Security::get_md5_fingerprint()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 2
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 1
dl 0
loc 2
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace Pronamic\WordPress\Pay\Gateways\IDealAdvancedV3;
4
5
/**
6
 * Title: Security
7
 * Description:
8
 * Copyright: 2005-2019 Pronamic
9
 * Company: Pronamic
10
 *
11
 * @author  Remco Tolsma
12
 * @version 2.0.0
13
 * @since   1.0.0
14
 */
15
class Security {
16
	/**
17
	 * Indicator for the begin of an certificate
18
	 *
19
	 * @var string
20
	 */
21
	const CERTIFICATE_BEGIN = '-----BEGIN CERTIFICATE-----';
22
23
	/**
24
	 * Indicator for the end of an certificate
25
	 *
26
	 * @var string
27
	 */
28
	const CERTIFICATE_END = '-----END CERTIFICATE-----';
29
30
	/**
31
	 * Get the sha1 fingerprint from the specified certificate
32
	 *
33
	 * @param string $certificate
34
	 *
35
	 * @return string Fingerprint or null on failure
36
	 */
37
	public static function get_sha_fingerprint( $certificate ) {
38
		return self::get_fingerprint( $certificate, 'sha1' );
39
	}
40
41
	/**
42
	 * Get the md5 fingerprint from the specified certificate
43
	 *
44
	 * @param string $certificate
45
	 *
46
	 * @return string Fingerprint or null on failure
47
	 */
48
	public static function get_md5_fingerprint( $certificate ) {
49
		return self::get_fingerprint( $certificate, 'md5' );
50
	}
51
52
	/**
53
	 * Get the fingerprint from the specified certificate
54
	 *
55
	 * @param string $certificate
56
	 *
57
	 * @return string Fingerprint or null on failure
58
	 */
59
	public static function get_fingerprint( $certificate, $hash = null ) {
60
		$fingerprint = null;
0 ignored issues
show
Unused Code introduced by
The assignment to $fingerprint is dead and can be removed.
Loading history...
61
62
		// The openssl_x509_read() function will throw an warning if the supplied
63
		// parameter cannot be coerced into an X509 certificate
64
		// @codingStandardsIgnoreStart
65
		$resource = @openssl_x509_read( $certificate );
66
		// @codingStandardsIgnoreEnd
67
68
		if ( false === $resource ) {
69
			return false;
0 ignored issues
show
Bug Best Practice introduced by
The expression return false returns the type false which is incompatible with the documented return type string.
Loading history...
70
		}
71
72
		$output = null;
73
74
		$result = openssl_x509_export( $resource, $output );
75
76
		if ( false === $result ) {
77
			return false;
0 ignored issues
show
Bug Best Practice introduced by
The expression return false returns the type false which is incompatible with the documented return type string.
Loading history...
78
		}
79
80
		$output = str_replace( self::CERTIFICATE_BEGIN, '', $output );
81
		$output = str_replace( self::CERTIFICATE_END, '', $output );
82
83
		// Base64 decode
84
		$fingerprint = base64_decode( $output );
85
86
		// Hash
87
		if ( null !== $hash ) {
88
			$fingerprint = hash( $hash, $fingerprint );
89
		}
90
91
		/*
92
		 * Uppercase
93
		 *
94
		 * Cannot find private certificate file with fingerprint: b4845cb5cbcee3e1e0afef2662552a2365960e72
95
		 * (Note: Some acquirers only accept fingerprints in uppercase. Make the value of "KeyName" in your XML data uppercase.).
96
		 * https://www.ideal-checkout.nl/simulator/
97
		 *
98
		 * @since 1.1.11
99
		 */
100
		$fingerprint = strtoupper( $fingerprint );
101
102
		return $fingerprint;
103
	}
104
}
105