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

Suggestion on how to prevent potential client-side abuse #3

Open
caendesilva opened this issue Oct 14, 2024 · 10 comments
Open

Suggestion on how to prevent potential client-side abuse #3

caendesilva opened this issue Oct 14, 2024 · 10 comments

Comments

@caendesilva
Copy link

By default, Pan only allows 50 or fewer analytics to be stored. This prevents any potential abuse of the system, as the analytics "name" are controlled on the client-side. Open to suggestions on how to improve this.

Maybe a "strict" mode could be added, where Pan scans all Blade files for data-pan attributes in the HTML, and adds them to a cached array of whitelisted analytic names. This would not work for dynamic attributes but could still be pretty cool I think. That way only names declared on the server-side are accepted.

@nunomaduro
Copy link
Contributor

Honestly; probably a configuration file, or a Pan::analytics(['foo', 'bar']); in your service provider could be good enough.

@caendesilva
Copy link
Author

Would work too!

@adiologydev
Copy link

adiologydev commented Oct 14, 2024

What if there was a command you could use to go through the project find the tags and store them in a file?

Maybe this could be a utility command that populates Pan::analytics by default without requiring manual labour.
Similarly, it could let you create/remove tags via commands as well.

@coclav
Copy link

coclav commented Oct 15, 2024

I am not sure I understand why this limitation of 50 rows.

I think the DatabaseAnalyticsRepository @ increment method could be written in a single SQL query providing there is a unique key on name

insert into
    pan (name, impressions, hovers, clicks)
values
    ('admin-user-mgmt', 0, 0, 0) 
on duplicate key update
   -- add one or more of the following to update the different type
    hovers = (
        select
            p.hovers + 1
        from
            pan p
        where
            name = name
    );

@nunomaduro
Copy link
Contributor

nunomaduro commented Oct 15, 2024

Can someone contribute with a pull request that adds two methods?

Pan::analytics()->max(100);
Pan::analytics()->allowed(['name-one', 'name-two']);
Pan::analytics()->unlimited();

@assertchris
Copy link

On it!

@assertchris
Copy link

Draft here: #9

@pxpm
Copy link
Contributor

pxpm commented Oct 25, 2024

Hey @nunomaduro thanks for this package, really easy to use.

I've been thinking on how to prevent abuse from the FE. It's a tricky one.

Maybe instead of directly writing the data-pan="my-button" we could create a blade directive that uses some key to validate it's a developer pan and not some malicious actor on the front-end ?

Something like:

<button @pan("my-button")>
<button @pan("my-button-2")>

That outputs something like:

<button data-pan-34j3jdslk23="my-button">
<button data-pan-asmfj3kjwe="my-button-2">

The BE can then validate the 34j3jdslk23 and asmfj3kjwe as valid tokens for pans ?

In addition to allowed('pan-name'), we could also add allowed('pan-name')->on('route.name') or something similar ? So that malicious actors can't add pans in non-relevant urls ?

I think the "tokens" solve one part of the issue, tying the pan to a route solves the second part. We are left with click abusers and page refreshers on steroids... maybe with a debounce we solve that later too 🤷

Let me know what you guys think 👍

@caendesilva
Copy link
Author

Hey @nunomaduro thanks for this package, really easy to use.

I've been thinking on how to prevent abuse from the FE. It's a tricky one.

Maybe instead of directly writing the data-pan="my-button" we could create a blade directive that uses some key to validate it's a developer pan and not some malicious actor on the front-end ?

Something like:

<button @pan("my-button")>
<button @pan("my-button-2")>

That outputs something like:

<button data-pan-34j3jdslk23="my-button">
<button data-pan-asmfj3kjwe="my-button-2">

The BE can then validate the 34j3jdslk23 and asmfj3kjwe as valid tokens for pans ?

In addition to allowed('pan-name'), we could also add allowed('pan-name')->on('route.name') or something similar ? So that malicious actors can't add pans in non-relevant urls ?

I think the "tokens" solve one part of the issue, tying the pan to a route solves the second part. We are left with click abusers and page refreshers on steroids... maybe with a debounce we solve that later too 🤷

Let me know what you guys think 👍

I think the @pan directive is a very solid solution to this problem. The question is if the problem is bad enough to warrant the increased complexity of implementing this solution. It's of course up to Nuno, but I would think that it could be reasonable to hold off and see if this issue affects a lot of people, so it can be weighed against the added steps of both a new directive which IDEs may not recognize, and the added setup of having to add a secret key to the setup process.

@pxpm
Copy link
Contributor

pxpm commented Oct 25, 2024

I think the @pan directive is a very solid solution to this problem. The question is if the problem is bad enough to warrant the increased complexity of implementing this solution. It's of course up to Nuno, but I would think that it could be reasonable to hold off and see if this issue affects a lot of people, so it can be weighed against the added steps of both a new directive which IDEs may not recognize, and the added setup of having to add a secret key to the setup process.

Hey @caendesilva thanks for the feedback. 👍

I was just shooting from the top of my head, I am not 100% sure it may be the correct solution for the problem at hand. It could be a way to make things more difficult, but you can just copy the data-pan-s3cr3t around the page .. so it would probably need some extra layer of enforcing the uniqueness of the pan.

I will hold for sure, I trust Nuno judgment way more than mine 🙏

Once again, thanks for your input and for raising the question, I think it's something that warrants some brainstorming to try to solve. No one would like to have skewed analytics to take on business decisions 👍

Cheers

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

No branches or pull requests

6 participants