Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: AuthToken/AuthJWT Config Loading by Initializing in Constructor #1252

Open
wants to merge 3 commits into
base: develop
Choose a base branch
from

Conversation

datamweb
Copy link
Collaborator

@datamweb datamweb commented Feb 16, 2025

Description
AuthToken and AuthJWT Config Loading by Initializing in Constructor

Checklist:

  • Securely signed commits
  • Component(s) with PHPDoc blocks, only if necessary or adds value
  • Unit testing, with >80% coverage
  • User guide updated
  • Conforms to style guide

@datamweb datamweb added the refactor Pull requests that refactor code label Feb 16, 2025
@datamweb datamweb changed the title refactor: Optimize AuthToken Config Loading by Initializing in Constructor refactor: Optimize AuthToken/AuthJWT Config Loading by Initializing in Constructor Feb 16, 2025
Copy link
Member

@paulbalandan paulbalandan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you have a benchmark for this change?

@datamweb
Copy link
Collaborator Author

Do you have a benchmark for this change?

The presence of Optimize probably led to this question. It seems I made a mistake in choosing it, as my main goal in this configuration was to prevent the repeated use of config('AuthToken') and config('AuthJWT'), nothing more.

But now I’m curious—does this change actually impact performance or not? Your benchmark results could be really helpful! @paulbalandan If possible, please share them so we can analyze them together.

@paulbalandan
Copy link
Member

Yes, the word Optimize in your PR title made me curious about the impact to performance since we will now be loading the configs everytime a class is instantiated. I just remembered one time when I did a similar change to the Seeder class instantiating Faker's Generator everytime in the constructor caused a massive slowdown.

@michalsn
Copy link
Member

Are we actually calling an attempt method multiple times per request?

@datamweb datamweb changed the title refactor: Optimize AuthToken/AuthJWT Config Loading by Initializing in Constructor refactor: AuthToken/AuthJWT Config Loading by Initializing in Constructor Feb 27, 2025
@datamweb
Copy link
Collaborator Author

Are we actually calling an attempt method multiple times per request?

I didn't quite understand your question, and I'm not sure how it relates to this PR. Could you please clarify?

@michalsn
Copy link
Member

Sorry, your reason for this change was described as:

my main goal in this configuration was to prevent the repeated use of config('AuthToken') and config('AuthJWT')

So my question is. is this really the case? Are we actually calling these configs multiple times, or only once per request?

@datamweb
Copy link
Collaborator Author

is this really the case? Are we actually calling these configs multiple times, or only once per request?

In fact, the configuration is only called once per request. Therefore, it seems this change wouldn’t have a significant impact on performance. 100%

Which one do you find more suitable and why?"

First method:

<?php

declare(strict_types=1);

class MyClass
{

    public function __construct() {
        $this->config = config('Xconfig');
    }

    public function Y()
    {
        $this->config;
    }

    public function X()
    {

        $this->config;

    }
}

Second method:

<?php

declare(strict_types=1);

class MyClass
{

    public function __construct() {}

    public function Y()
    {
        $config = config('Xconfig);
    }

    public function X()
    {

        $config = config('Xconfig);

    }
}

@michalsn
Copy link
Member

Ok, sorry - that was my mistake. I thought we call this config only in one method. But now I see we call it several times.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
refactor Pull requests that refactor code
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants