fix: add warning for long secret names #359

Merged
decentral1se merged 14 commits from rix/abra:add-secret-length-linting into main 2024-04-06 21:41:37 +00:00
Contributor

A start of a fix for coop-cloud/organising#463
Putting some code out to start a discussion. I've added a linting rule for recipes to establish a general principal but I want to put some validation into cli/app/new.go as that's the point we have both the recipe and the domain and can say for sure whether or not the secret names lengths cause a problem but that will have to wait for a bit. Let me know if I've missed the mark somewhere

A start of a fix for coop-cloud/organising#463 Putting some code out to start a discussion. I've added a linting rule for recipes to establish a general principal but I want to put some validation into cli/app/new.go as that's the point we have both the recipe and the domain and can say for sure whether or not the secret names lengths cause a problem but that will have to wait for a bit. Let me know if I've missed the mark somewhere
rix added 1 commit 2023-09-27 18:03:03 +00:00
Add warning for long secret names.
All checks were successful
continuous-integration/drone/pr Build is passing
ac5f59cf37
rix force-pushed add-secret-length-linting from ac5f59cf37 to a150f227bc 2023-09-27 18:14:53 +00:00 Compare
decentral1se reviewed 2023-09-28 06:59:35 +00:00
decentral1se left a comment
Owner

Looking good!

Yeh, doing some app new ... scary alerta alerta warning might be ideal and help avoid frustration further down the line.

If you're interested in writing a test, I'd say adding something to https://git.coopcloud.tech/coop-cloud/abra/src/branch/main/tests/integration/recipe_lint.bats might be nice. Simply adding a compose.secret-too-long.yml to https://git.coopcloud.tech/coop-cloud/abra-integration-test-recipe would allow you to reproduce the warning (i.e. by sed'ing COMPOSE_FILE="compose.yml:compose.secret-too-long.yml" into the .env).

Looking good! Yeh, doing some `app new ...` scary alerta alerta warning might be ideal and help avoid frustration further down the line. If you're interested in writing a test, I'd say adding something to https://git.coopcloud.tech/coop-cloud/abra/src/branch/main/tests/integration/recipe_lint.bats might be nice. Simply adding a `compose.secret-too-long.yml` to https://git.coopcloud.tech/coop-cloud/abra-integration-test-recipe would allow you to reproduce the warning (i.e. by `sed`'ing `COMPOSE_FILE="compose.yml:compose.secret-too-long.yml"` into the `.env`).
@ -118,0 +119,4 @@
Ref: "R014",
Level: "warn",
Description: "Long secret names",
HowToResolve: "Reduce the lenght of secret names to 12 characters.",
Owner

%s/lenght/length/

`%s/lenght/length/`
Author
Contributor

Good spot! fixed now : )

Good spot! fixed now : )
rix marked this conversation as resolved
rix force-pushed add-secret-length-linting from a150f227bc to 82bcaaa86f 2023-09-30 10:20:41 +00:00 Compare
rix added 2 commits 2023-10-01 10:52:14 +00:00
rix added 1 commit 2023-10-01 10:53:51 +00:00
Fix typo.
All checks were successful
continuous-integration/drone/pr Build is passing
30387cbb1b
Author
Contributor

Just thought I'd update on this. As is turning into a theme with this one, it was harder than I thought! I wrote my code to catch a failing test case and then realised it doesn't actually work because it's already failed before it gets to where I put my method 🤦‍♂️

I'll re-work it to actually work at some point and I promise to come back and writes tests for it at some point : )

Just thought I'd update on this. As is turning into a theme with this one, it was harder than I thought! I wrote my code to catch a failing test case and then realised it doesn't actually work because it's already failed before it gets to where I put my method 🤦‍♂️ I'll re-work it to actually work at some point and I promise to come back and writes tests for it at some point : )
rix added 1 commit 2023-10-03 20:23:59 +00:00
Fix where the secret check happens and fiddle with messages.
All checks were successful
continuous-integration/drone/pr Build is passing
666e9a041c
rix force-pushed add-secret-length-linting from 666e9a041c to d78abfec2f 2023-10-03 20:26:56 +00:00 Compare
Author
Contributor

Some more progress, the error now shows up before the whole thing falls over which is an improvement! I've created the data for an integration test but not the intergation test itself as of yet.

One question I did have is that at the moment the error will only show up if you specify the -S flag on the new command to generate secrets. In some ways this seems reasonable as, 'no secrets, no problem' is at least ostensibly true but I'm imaging you'll need to generate those secrets on deploy anyway.

Do we want the same check on the deploy as well? It would seem to be sensible as secret generation on 'abra new' isn't enabled by default.

Let me know your thoughts and apologies that this PR seems to be like Zeno's arrow : )

Some more progress, the error now shows up before the whole thing falls over which is an improvement! I've created the data for an integration test but not the intergation test itself as of yet. One question I did have is that at the moment the error will only show up if you specify the -S flag on the new command to generate secrets. In some ways this seems reasonable as, 'no secrets, no problem' is at least ostensibly true but I'm imaging you'll need to generate those secrets on deploy anyway. Do we want the same check on the deploy as well? It would seem to be sensible as secret generation on 'abra new' isn't enabled by default. Let me know your thoughts and apologies that this PR seems to be like Zeno's arrow : )
Owner

No worries @rix! Doing great work here. If you don't --secrets on abra app new then when you deploy, it will fail with missing secrets. Not very gracefully actually, but I'll open a ticket for that. Then you'd probably run abra app secret generate <domain> -a. Maybe a call to ensureSecretLengths is also worth it there before generation?

No worries @rix! Doing great work here. If you don't `--secrets` on `abra app new` then when you deploy, it will fail with missing secrets. Not very gracefully actually, but I'll open a ticket for that. Then you'd probably run `abra app secret generate <domain> -a`. Maybe a call to `ensureSecretLengths` is also worth it there before generation?
decentral1se reviewed 2023-10-03 23:33:08 +00:00
decentral1se left a comment
Owner

Another pass 🏃‍♀️

Another pass 🏃‍♀️
cli/app/new.go Outdated
@ -258,1 +263,4 @@
}
func ensureSecretLengths(secrets map[string]string, domainName string, sanitisedAppName string) error {
if len(sanitisedAppName) > 45 {
Owner

Maybe it's time to abstract this 45 to a const in pkg/config/env.go? We're starting to use it in several places and this will probably lead to confusion at best and bugs at worst as things change over time.

Maybe it's time to abstract this `45` to a `const` in `pkg/config/env.go`? We're starting to use it in several places and this will probably lead to confusion at best and bugs at worst as things change over time.
Author
Contributor

Done : )

Done : )
decentral1se marked this conversation as resolved
cli/app/new.go Outdated
@ -259,0 +272,4 @@
maxSecretLength := 0
for secretName := range secrets {
Owner

nitpick: drop extra newline?

nitpick: drop extra newline?
Author
Contributor

Think I've got this one now but let me know if I misinterpreted which line you were talking about : )

Think I've got this one now but let me know if I misinterpreted which line you were talking about : )
decentral1se marked this conversation as resolved
cli/app/new.go Outdated
@ -259,0 +277,4 @@
maxSecretLength = len(secretName)
}
if len(secretName)+domainAndFormatLength > 64 {
Owner

Maybe 64 can also go in pkg/config/env.go while we're at it?

Maybe `64` can also go in `pkg/config/env.go` while we're at it?
Author
Contributor

Done

Done
decentral1se marked this conversation as resolved
cli/app/new.go Outdated
@ -259,0 +278,4 @@
}
if len(secretName)+domainAndFormatLength > 64 {
failingSecrets = append(failingSecrets, secretName)
Owner

I think it would be simpler to just error out here. Also a simpler/clearer error message to write?

return fmt.Errorf("%s is too long (> 64 chars when combined with %s)", secretName, sanitisedAppName)
I think it would be simpler to just error out here. Also a simpler/clearer error message to write? ```go return fmt.Errorf("%s is too long (> 64 chars when combined with %s)", secretName, sanitisedAppName) ```
Author
Contributor

I've made it drop out after the first error now but I guess the side effect is that if there's more than one long secret it will be a bit of a whack-a-mole to find them all but I guess it's a pretty rare occurence so the trade off for cleaner code is probably worth it : )

I've made it drop out after the first error now but I guess the side effect is that if there's more than one long secret it will be a bit of a whack-a-mole to find them all but I guess it's a pretty rare occurence so the trade off for cleaner code is probably worth it : )
decentral1se marked this conversation as resolved
cli/app/new.go Outdated
@ -259,0 +287,4 @@
return fmt.Errorf("the following secrets are too long to work with the domain name %s\n change their length or use a shorter domain name:\n %s", domainName, failedSecretsString)
}
logrus.Debugf(
Owner

Unsure if this debug logging is necessary? It would also simplify the logic above and we could drop maxSecretLength and the accompanying if statement?

Unsure if this debug logging is necessary? It would also simplify the logic above and we could drop `maxSecretLength` and the accompanying `if` statement?
Author
Contributor

Removed, it helped me with debugging and I thought that maybe it might help explain the logic but you're right that's it's probably not helpful for the day to day experience.

Removed, it helped me with debugging and I thought that maybe it might help explain the logic but you're right that's it's probably not helpful for the day to day experience.
decentral1se marked this conversation as resolved
rix added 3 commits 2023-10-04 18:07:14 +00:00
rix added 1 commit 2023-10-04 18:10:23 +00:00
Added 'secret' before error to make it clear it's a secret.
Some checks failed
continuous-integration/drone/pr Build is failing
2abb7264b8
Author
Contributor

No worries @rix! Doing great work here. If you don't --secrets on abra app new then when you deploy, it will fail with missing secrets. Not very gracefully actually, but I'll open a ticket for that. Then you'd probably run abra app secret generate <domain> -a. Maybe a call to ensureSecretLengths is also worth it there before generation?

Thanks @decentral1se : ) I think the change for abra app secret generate and the integration test (I haven't checked the status of the test repo PR yet) are the last remaining things after this : )

> No worries @rix! Doing great work here. If you don't `--secrets` on `abra app new` then when you deploy, it will fail with missing secrets. Not very gracefully actually, but I'll open a ticket for that. Then you'd probably run `abra app secret generate <domain> -a`. Maybe a call to `ensureSecretLengths` is also worth it there before generation? Thanks @decentral1se : ) I think the change for abra app secret generate <domain> and the integration test (I haven't checked the status of the test repo PR yet) are the last remaining things after this : )
rix added 2 commits 2023-10-05 17:25:10 +00:00
Member

Hi @rix,
there are some merge conflicts, which are propably caused by my pr coop-cloud/abra#394 (sorry about that). Could you try and resolve these? I can help of course or do it for you if you want :)

Hi @rix, there are some merge conflicts, which are propably caused by my pr https://git.coopcloud.tech/coop-cloud/abra/pulls/394 (sorry about that). Could you try and resolve these? I can help of course or do it for you if you want :)
Owner

@rix shall we try to get this merged? Unsure of status atm but down to help

@rix shall we try to get this merged? Unsure of status atm but down to help ✊
Author
Contributor

Sorry or the delay in getting back to you, I did reply to my e-mail notification thinking that the comment would show up but it seemingly hasn't. I've been a bit burned out for a while but I'm trying to get back to looking at this now. I've done a basic merge from main on the branch but it looks like there's been a number of changes (for the better!) in the code that I will need to build into this. It looks like the new secret struct is going to make this easier than it was going to be initially but it will take me a little while to get my head around : ) I think I should be able to take a longer look tomorrow so I'll let you know how that goes : )

Sorry or the delay in getting back to you, I did reply to my e-mail notification thinking that the comment would show up but it seemingly hasn't. I've been a bit burned out for a while but I'm trying to get back to looking at this now. I've done a basic merge from main on the branch but it looks like there's been a number of changes (for the better!) in the code that I will need to build into this. It looks like the new secret struct is going to make this easier than it was going to be initially but it will take me a little while to get my head around : ) I think I should be able to take a longer look tomorrow so I'll let you know how that goes : )
rix added 2 commits 2024-04-06 10:42:22 +00:00
rix added 1 commit 2024-04-06 20:12:33 +00:00
Attempted rework to match new code.
All checks were successful
continuous-integration/drone/pr Build is passing
ba956f340a
Author
Contributor

Hey, I've just pushed up some new stuff that I think works with the flow moving the verification as part of the read secret config since we seem to have all the data we need now. I've also added a test to the secret stuff that hopefully should illustrate what I'm going for. I feel like there's some scenario I'm potentially missing though so would appreciate some feedback. I'd be delighted to pair on this if you want to get into it but due to work it'd either have to a lunch time (somewhere between 12 - 2pm) or an evening.

Either way, let me know what you think about the new code : )

Hey, I've just pushed up some new stuff that I think works with the flow moving the verification as part of the read secret config since we seem to have all the data we need now. I've also added a test to the secret stuff that hopefully should illustrate what I'm going for. I feel like there's some scenario I'm potentially missing though so would appreciate some feedback. I'd be delighted to pair on this if you want to get into it but due to work it'd either have to a lunch time (somewhere between 12 - 2pm) or an evening. Either way, let me know what you think about the new code : )
decentral1se changed title from WIP: Add warning for long secret names. to fix: add warning for long secret names 2024-04-06 21:39:58 +00:00
decentral1se approved these changes 2024-04-06 21:40:40 +00:00
decentral1se left a comment
Owner

tysm @rix for coming back to this, let's merge it! It's looking solid.

Hope you're doing OK 💝

tysm @rix for coming back to this, let's merge it! It's looking solid. Hope you're doing OK 💝
decentral1se merged commit d21c35965d into main 2024-04-06 21:41:37 +00:00
rix deleted branch add-secret-length-linting 2024-04-06 22:15:52 +00:00
Sign in to join this conversation.
No description provided.