Code Coverage
 
Lines
Branches
Paths
Functions and Methods
Classes and Traits
Total
88.89% covered (warning)
88.89%
8 / 9
80.00% covered (warning)
80.00%
4 / 5
75.00% covered (warning)
75.00%
3 / 4
66.67% covered (warning)
66.67%
2 / 3
CRAP
0.00% covered (danger)
0.00%
0 / 1
AltchaService
88.89% covered (warning)
88.89%
8 / 9
80.00% covered (warning)
80.00%
4 / 5
75.00% covered (warning)
75.00%
3 / 4
66.67% covered (warning)
66.67%
2 / 3
4.25
0.00% covered (danger)
0.00%
0 / 1
 __construct
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 createChallenge
100.00% covered (success)
100.00%
5 / 5
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 verifySolution
66.67% covered (warning)
66.67%
2 / 3
66.67% covered (warning)
66.67%
2 / 3
50.00% covered (danger)
50.00%
1 / 2
0.00% covered (danger)
0.00%
0 / 1
2.50
1<?php
2
3namespace App\Security\Service;
4
5use AltchaOrg\Altcha\Altcha;
6use AltchaOrg\Altcha\Challenge;
7use AltchaOrg\Altcha\ChallengeOptions;
8use Symfony\Component\DependencyInjection\Attribute\Autowire;
9
10/**
11 * ALTCHA is fully disabled when ALTCHA_ENABLED=false
12 * This happens typically in e2e testing in CI/Staging
13 * In that case, backend verification is bypassed and frontend does not request challenges.
14 *
15 * @author Wilhelm Zwertvaegher
16 */
17class AltchaService implements AltchaServiceInterface
18{
19    public function __construct(
20        private readonly Altcha $altcha,
21        #[Autowire('%altcha.token_expiry_seconds%')]
22        private readonly int $altchaTokenExpirySeconds,
23        #[Autowire('%altcha.enabled%')]
24        private readonly bool $altchaEnabled,
25    ) {
26    }
27
28    public function createChallenge(): Challenge
29    {
30        // Create a new challenge
31        $options = new ChallengeOptions(
32            maxNumber: 50000, // the maximum random number
33            expires: new \DateTimeImmutable()->add(new \DateInterval(sprintf('PT%sS', $this->altchaTokenExpirySeconds))),
34        );
35
36        return $this->altcha->createChallenge($options);
37    }
38
39    public function verifySolution(string $data): bool
40    {
41        if (!$this->altchaEnabled) {
42            return true;
43        }
44
45        return $this->altcha->verifySolution($data);
46    }
47}

Branches

Below are the source code lines that represent each code branch as identified by Xdebug. Please note a branch is not necessarily coterminous with a line, a line may contain multiple branches and therefore show up more than once. Please also be aware that some branches may be implicit rather than explicit, e.g. an if statement always has an else as part of its logical flow even if you didn't write one.

AltchaService->__construct
19    public function __construct(
20        private readonly Altcha $altcha,
21        #[Autowire('%altcha.token_expiry_seconds%')]
22        private readonly int $altchaTokenExpirySeconds,
23        #[Autowire('%altcha.enabled%')]
24        private readonly bool $altchaEnabled,
25    ) {
26    }
AltchaService->createChallenge
31        $options = new ChallengeOptions(
32            maxNumber: 50000, // the maximum random number
33            expires: new \DateTimeImmutable()->add(new \DateInterval(sprintf('PT%sS', $this->altchaTokenExpirySeconds))),
34        );
35
36        return $this->altcha->createChallenge($options);
37    }
AltchaService->verifySolution
39    public function verifySolution(string $data): bool
40    {
41        if (!$this->altchaEnabled) {
42            return true;
45        return $this->altcha->verifySolution($data);
46    }
{main}
3namespace App\Security\Service;
4
5use AltchaOrg\Altcha\Altcha;
6use AltchaOrg\Altcha\Challenge;
7use AltchaOrg\Altcha\ChallengeOptions;
8use Symfony\Component\DependencyInjection\Attribute\Autowire;
9
10/**
11 * ALTCHA is fully disabled when ALTCHA_ENABLED=false
12 * This happens typically in e2e testing in CI/Staging
13 * In that case, backend verification is bypassed and frontend does not request challenges.
14 *
15 * @author Wilhelm Zwertvaegher
16 */
17class AltchaService implements AltchaServiceInterface
18{
19    public function __construct(
20        private readonly Altcha $altcha,
21        #[Autowire('%altcha.token_expiry_seconds%')]
22        private readonly int $altchaTokenExpirySeconds,
23        #[Autowire('%altcha.enabled%')]
24        private readonly bool $altchaEnabled,
25    ) {
26    }
27
28    public function createChallenge(): Challenge
29    {
30        // Create a new challenge
31        $options = new ChallengeOptions(
32            maxNumber: 50000, // the maximum random number
33            expires: new \DateTimeImmutable()->add(new \DateInterval(sprintf('PT%sS', $this->altchaTokenExpirySeconds))),
34        );
35
36        return $this->altcha->createChallenge($options);
37    }
38
39    public function verifySolution(string $data): bool
40    {
41        if (!$this->altchaEnabled) {
42            return true;
43        }
44
45        return $this->altcha->verifySolution($data);
46    }