From 41294f38e5b348a8a40066455b8641dce6e2b009 Mon Sep 17 00:00:00 2001
From: RSpeekenbrink <98remco@gmail.com>
Date: Thu, 2 May 2019 10:40:15 +0200
Subject: [PATCH 1/4] Make the GoogleAuthenticator Class PSR-4 Compatible
---
 PHPGangsta/GoogleAuthenticator.php | 20 ++++++++++++--------
 README.md                          |  2 +-
 composer.json                      |  4 +++-
 3 files changed, 16 insertions(+), 10 deletions(-)
diff --git a/PHPGangsta/GoogleAuthenticator.php b/PHPGangsta/GoogleAuthenticator.php
index bf7d116..f333b82 100644
--- a/PHPGangsta/GoogleAuthenticator.php
+++ b/PHPGangsta/GoogleAuthenticator.php
@@ -1,5 +1,7 @@
 _base32Decode($secret);
 
         // Pack time into binary string
-        $time = chr(0).chr(0).chr(0).chr(0).pack('N*', $timeSlice);
+        $time = chr(0) . chr(0) . chr(0) . chr(0) . pack('N*', $timeSlice);
         // Hash it with users secret key
         $hm = hash_hmac('SHA1', $time, $secretkey, true);
         // Use last nipple of result as index/offset
@@ -100,13 +102,13 @@ public function getCode($secret, $timeSlice = null)
      */
     public function getQRCodeGoogleUrl($name, $secret, $title = null, $params = array())
     {
-        $width = !empty($params['width']) && (int) $params['width'] > 0 ? (int) $params['width'] : 200;
-        $height = !empty($params['height']) && (int) $params['height'] > 0 ? (int) $params['height'] : 200;
+        $width = !empty($params['width']) && (int)$params['width'] > 0 ? (int)$params['width'] : 200;
+        $height = !empty($params['height']) && (int)$params['height'] > 0 ? (int)$params['height'] : 200;
         $level = !empty($params['level']) && array_search($params['level'], array('L', 'M', 'Q', 'H')) !== false ? $params['level'] : 'M';
 
-        $urlencoded = urlencode('otpauth://totp/'.$name.'?secret='.$secret.'');
+        $urlencoded = urlencode('otpauth://totp/' . $name . '?secret=' . $secret . '');
         if (isset($title)) {
-            $urlencoded .= urlencode('&issuer='.urlencode($title));
+            $urlencoded .= urlencode('&issuer=' . urlencode($title));
         }
 
         return "https://api.qrserver.com/v1/create-qr-code/?data=$urlencoded&size=${width}x${height}&ecc=$level";
@@ -178,8 +180,10 @@ protected function _base32Decode($secret)
             return false;
         }
         for ($i = 0; $i < 4; ++$i) {
-            if ($paddingCharCount == $allowedValues[$i] &&
-                substr($secret, -($allowedValues[$i])) != str_repeat($base32chars[32], $allowedValues[$i])) {
+            if (
+                $paddingCharCount == $allowedValues[$i] &&
+                substr($secret, -($allowedValues[$i])) != str_repeat($base32chars[32], $allowedValues[$i])
+            ) {
                 return false;
             }
         }
diff --git a/README.md b/README.md
index 0f86d21..2021d86 100644
--- a/README.md
+++ b/README.md
@@ -24,7 +24,7 @@ See following example:
 createSecret();
 echo "Secret is: ".$secret."\n\n";
 
diff --git a/composer.json b/composer.json
index 9de7cc1..5ee1fa0 100644
--- a/composer.json
+++ b/composer.json
@@ -21,7 +21,9 @@
         "php": ">=5.3"
     },
 	"autoload": {
-		"classmap": ["PHPGangsta/GoogleAuthenticator.php"]
+        "psr-4": {
+            "PHPGangsta\\": "PHPGangsta/"
+        }
 	}
 }
 
From 587470fd04aabb9b71d2cd903c88bcdbaa98cdbb Mon Sep 17 00:00:00 2001
From: RSpeekenbrink <98remco@gmail.com>
Date: Fri, 3 May 2019 09:31:10 +0200
Subject: [PATCH 2/4] Change test to be phpunit 8 compatible
---
 composer.json                     |  9 ++++-----
 phpunit.xml                       | 23 +++++++++++++++++++++++
 tests/GoogleAuthenticatorTest.php | 27 +++++++++++++++++----------
 tests/bootstrap.php               |  3 ---
 tests/phpunit.xml                 | 15 ---------------
 5 files changed, 44 insertions(+), 33 deletions(-)
 create mode 100644 phpunit.xml
 delete mode 100644 tests/bootstrap.php
 delete mode 100644 tests/phpunit.xml
diff --git a/composer.json b/composer.json
index 5ee1fa0..acdd727 100644
--- a/composer.json
+++ b/composer.json
@@ -24,9 +24,8 @@
         "psr-4": {
             "PHPGangsta\\": "PHPGangsta/"
         }
-	}
+	},
+    "require-dev": {
+        "phpunit/phpunit": "^8.1"
+    }
 }
-
-
-
-
diff --git a/phpunit.xml b/phpunit.xml
new file mode 100644
index 0000000..c0c77df
--- /dev/null
+++ b/phpunit.xml
@@ -0,0 +1,23 @@
+
+
+
+    
+        
+            ./tests/
+        
+    
+
+    
+        
+            ./PHPGangsta/
+        
+    
+
diff --git a/tests/GoogleAuthenticatorTest.php b/tests/GoogleAuthenticatorTest.php
index 4e13b5c..f512e0b 100644
--- a/tests/GoogleAuthenticatorTest.php
+++ b/tests/GoogleAuthenticatorTest.php
@@ -1,15 +1,22 @@
 googleAuthenticator = new PHPGangsta_GoogleAuthenticator();
+        $this->googleAuthenticator = new GoogleAuthenticator();
     }
 
     public function codeProvider()
@@ -24,9 +31,9 @@ public function codeProvider()
 
     public function testItCanBeInstantiated()
     {
-        $ga = new PHPGangsta_GoogleAuthenticator();
+        $ga = new GoogleAuthenticator();
 
-        $this->assertInstanceOf('PHPGangsta_GoogleAuthenticator', $ga);
+        $this->assertInstanceOf('PHPGangsta\GoogleAuthenticator', $ga);
     }
 
     public function testCreateSecretDefaultsToSixteenCharacters()
@@ -71,7 +78,7 @@ public function testGetQRCodeGoogleUrlReturnsCorrectUrl()
         $this->assertEquals($urlParts['host'], 'api.qrserver.com');
         $this->assertEquals($urlParts['path'], '/v1/create-qr-code/');
 
-        $expectedChl = 'otpauth://totp/'.$name.'?secret='.$secret;
+        $expectedChl = 'otpauth://totp/' . $name . '?secret=' . $secret;
 
         $this->assertEquals($queryStringArray['data'], $expectedChl);
     }
@@ -97,7 +104,7 @@ public function testVerifyCodeWithLeadingZero()
         $result = $this->googleAuthenticator->verifyCode($secret, $code);
         $this->assertEquals(true, $result);
 
-        $code = '0'.$code;
+        $code = '0' . $code;
         $result = $this->googleAuthenticator->verifyCode($secret, $code);
         $this->assertEquals(false, $result);
     }
@@ -106,6 +113,6 @@ public function testSetCodeLength()
     {
         $result = $this->googleAuthenticator->setCodeLength(6);
 
-        $this->assertInstanceOf('PHPGangsta_GoogleAuthenticator', $result);
+        $this->assertInstanceOf('PHPGangsta\GoogleAuthenticator', $result);
     }
 }
diff --git a/tests/bootstrap.php b/tests/bootstrap.php
deleted file mode 100644
index e91cc12..0000000
--- a/tests/bootstrap.php
+++ /dev/null
@@ -1,3 +0,0 @@
-
-
-
-    
-        
-            ./
-        
-    
-
-    
-        
-            src/
-        
-    
-
From 1eabf1b8a74af9526dc093cad908f1d03e4153b6 Mon Sep 17 00:00:00 2001
From: RSpeekenbrink <98remco@gmail.com>
Date: Fri, 3 May 2019 10:03:14 +0200
Subject: [PATCH 3/4] Update Readme.md
---
 README.md | 9 ++++-----
 1 file changed, 4 insertions(+), 5 deletions(-)
diff --git a/README.md b/README.md
index 2021d86..87749f7 100644
--- a/README.md
+++ b/README.md
@@ -24,7 +24,7 @@ See following example:
 createSecret();
 echo "Secret is: ".$secret."\n\n";
 
@@ -64,15 +64,14 @@ Installation:
 - [Composer](https://getcomposer.org/doc/01-basic-usage.md) will take care of autoloading
   the library. Just include the following at the top of your file
 
-  `require_once __DIR__ . '/../vendor/autoload.php';`
+  `require_once __DIR__ . '/vendor/autoload.php';`
 
 Run Tests:
 ----------
 
 - All tests are inside `tests` folder.
-- Execute `composer install` and then run the tests from project root
-  directory
-- Run as `phpunit tests` from the project root directory
+- Execute `composer install`
+- Run as `./vendor/bin/phpunit` from the project root directory
 
 
 ToDo:
From 366eb684d76725c4efdaa6aefaf1f876ec15362d Mon Sep 17 00:00:00 2001
From: RSpeekenbrink <98remco@gmail.com>
Date: Fri, 3 May 2019 10:08:11 +0200
Subject: [PATCH 4/4] Update travis config
---
 .travis.yml | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/.travis.yml b/.travis.yml
index ba19be3..b2bc460 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -8,4 +8,4 @@ install:
   - export PATH="$HOME/.composer/vendor/bin:$PATH"
   - composer install
 
-script: phpunit --coverage-text --configuration tests/phpunit.xml
+script: phpunit --coverage-text --configuration phpunit.xml