Passed
Push — develop ( b400fa...24d566 )
by nguereza
04:25
created

PasswordGenerateCommand::execute()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 15
Code Lines 10

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 10
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 15
rs 9.9332
1
<?php
2
3
/**
4
 * Platine Framework
5
 *
6
 * Platine Framework is a lightweight, high-performance, simple and elegant
7
 * PHP Web framework
8
 *
9
 * This content is released under the MIT License (MIT)
10
 *
11
 * Copyright (c) 2020 Platine Framework
12
 *
13
 * Permission is hereby granted, free of charge, to any person obtaining a copy
14
 * of this software and associated documentation files (the "Software"), to deal
15
 * in the Software without restriction, including without limitation the rights
16
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
17
 * copies of the Software, and to permit persons to whom the Software is
18
 * furnished to do so, subject to the following conditions:
19
 *
20
 * The above copyright notice and this permission notice shall be included in all
21
 * copies or substantial portions of the Software.
22
 *
23
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
24
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
26
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
28
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
29
 * SOFTWARE.
30
 */
31
32
/**
33
 *  @file PasswordGenerateCommand.php
34
 *
35
 *  The Password Generator Command class
36
 *
37
 *  @package    Platine\Framework\Console
38
 *  @author Platine Developers team
39
 *  @copyright  Copyright (c) 2020
40
 *  @license    http://opensource.org/licenses/MIT  MIT License
41
 *  @link   http://www.iacademy.cf
42
 *  @version 1.0.0
43
 *  @filesource
44
 */
45
46
declare(strict_types=1);
47
48
namespace Platine\Framework\Console;
49
50
use Platine\Console\Command\Command;
51
use Platine\Console\Input\Reader;
52
use Platine\Console\Output\Writer;
53
use Platine\Security\Hash\HashInterface;
54
55
/**
56
 * @class PasswordGenerateCommand
57
 * @package Platine\Framework\Console
58
 */
59
class PasswordGenerateCommand extends Command
60
{
61
    /**
62
     * The Hash instance
63
     * @var HashInterface
64
     */
65
    protected HashInterface $hash;
66
67
    /**
68
     * The plain password to use
69
     * @var string
70
     */
71
    protected string $password = '';
72
73
    /**
74
     * Create new instance
75
     * @param HashInterface $hash
76
     */
77
    public function __construct(
78
        HashInterface $hash
79
    ) {
80
        parent::__construct('password:generate', 'Command to generate password');
81
        $this->hash = $hash;
82
        $this->addArgument('password', 'The password to hash', null, false);
83
    }
84
85
    /**
86
     * {@inheritdoc}
87
     */
88
    public function execute()
89
    {
90
        $io = $this->io();
91
        $writer = $io->writer();
92
        $password = $this->password;
93
        $passwordHash = $this->hash->hash($password);
94
95
        $writer->boldGreen(sprintf(
96
            'Plain password: [%s]',
97
            $password
98
        ), true);
99
100
        $writer->boldGreen(sprintf('Hashed password: %s', $passwordHash), true)->eol();
101
102
        $writer->green('Command finished successfully')->eol();
103
    }
104
105
    /**
106
     * {@inheritdoc}
107
     */
108
    public function interact(Reader $reader, Writer $writer): void
109
    {
110
        $writer->boldYellow('GENERATION OF PASSWORD', true)->eol();
111
        $password = $this->getArgumentValue('password');
112
        if (empty($password)) {
113
            $io = $this->io();
114
            $password = $io->prompt('Enter the plain password to generate', '');
115
        }
116
117
        $this->password = $password;
118
    }
119
}
120