#github-actions (2023-01)
Discussions related to GitHub Actions
2023-01-04
2023-01-10
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="actions Archives | The GitHub Blog avatar"
GitHub Actions: OpenID Connect token now supports more claims for configuring granular cloud access GitHub Actions: OpenID Connect token now supports more claims for configuring granular cloud access
data:image/s3,"s3://crabby-images/61576/61576eccb78f9a40a4cf08eb64e36f9db1f15c3c" alt="attachment image"
GitHub Actions: OpenID Connect token now supports more claims for configuring granular cloud access
2023-01-11
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Overview It’s Friday at 5PM and an urgent request comes in from the Chief Infotainment Officer. You know exactly what you have to update in terraform and create a new feature branch to make the changes. You’re rolling through the lower environments and finally get to production. You run a terraform plan and unexpected resource deletions show up in the output. You panic a little, then realize that your work didn’t trigger the deletion.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cc @matt
Overview It’s Friday at 5PM and an urgent request comes in from the Chief Infotainment Officer. You know exactly what you have to update in terraform and create a new feature branch to make the changes. You’re rolling through the lower environments and finally get to production. You run a terraform plan and unexpected resource deletions show up in the output. You panic a little, then realize that your work didn’t trigger the deletion.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
@jose.amengual
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes, I gave it a read
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I think is a very simplistic “good enough” solution with no feedback loops except for some task status etc
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
in my opinion Drift detection should have an option to have more detail and historical reference of what happened etc
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so in a GitOps scenario you should be able to see what happened and hopefully that is recorded in the repo too
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah, I kinda kept it open ended with the alerting mechanism on this article. Slack, email, etc. For something more in-depth, I would use a dedicated tool, but I think for a lot of people, this and possibly cloudtrail should be a good start. Also having strict rules on how terraform code is promoted through environments should help eliminate drift
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
totally, your article is pretty good , and for most people this is more than enough for sure
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Where I come from if from the Atlantis side ( I’m a Maintainer) and I just implemented a github action workflow similar to what you propose in the article but for a tool that already does GitOps the github action user workflow is not the best to go about it and makes unnecessary steps to be needed for implementation
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Ideally the GitOps tool ( Atlantis, spacelift, TFC) should communicate back through more than one channel
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and in case of finding drift it should report back in or leave a trail of what it did if autoremediation was done, in form of a ticket, PR or whatever
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and hopefully the GitOps tools can have and /api/drift
than can be trigger by a simple workflow(not github specific) or support multiple VCSs too
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah, I guess hoping what’s committed to main
is the desired state and if the drift is too destructive, then maybe triggering an escalation for human review
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
correct
2023-01-12
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is there such thing as user tags in Github actions? like a user can have a tag called prod
that then is used to filter PR against a prod environment etc
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Hmm i don’t think you can access custom user attributes in github
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
If you could, i imagine that would be through gh enterprise with a saml sso setup but even then i don’t think gh actions would have that granularity out of the box
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
You could use a gh action to ping your idp for a custom attribute and then allow or deny based on the value returned
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I was thinking maybe at the PR level
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
on the payload that could be reflected
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
like the group the user belongs to
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
couldnt you do that with teams instead ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes you can
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
what problem are you trying to solve?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
just an idea not a problem
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
take this script for example :
#!/usr/bin/env bash
atmos describe affected --ref refs/heads/main --file affected.json
stacks=""
components=""
for s in `jq -cr '.[]|.stack' affected.json|uniq`; do stacks+="${s},"; done
for c in `jq -cr '.[]|.component' affected.json|uniq`; do components+="${c},"; done
echo ${stacks%?}
echo ${components%?}
atmos atlantis generate repo-config --config-template config-1 --project-template project-1 --workflow-template workflow-1 --stacks ${stacks%?} --components ${components%?}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
do you guess what it does?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
(you need bash4)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that will generate an atlantis.yaml
file that will only contain the affected components/projects
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
this limits the blast radius of the user PR against other project that should not be planned at all
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
oh wow very cool
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
cc: @Andriy Knysh (Cloud Posse) @Erik Osterman (Cloud Posse)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so the user can go in and do atlantis plan -p myproject
or have autoplan enabled and it will only plan the stuff that pretends to the PR, do you see how powerful this is?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it extrapolates the complexity in this case atlantis
to have to have this guardrails and brings is back to the source …..the VCS
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so not imagine this:
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
it might be a good feature request to create the atlantis.yaml
file for only stacks/components affected so you do not need to run the custom shell script e.g. atmos atlantis generate repo-config --affected
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you match the user group and now you only do
for s in `jq -cr '.[]|.stack' affected.json|uniq`; do if [ $s == “.*-prod”]; then stacks+=“${s},” fi; done
( I think the syntax is wrong but you get the idea)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes that will be really cool feature
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I requested the project name to be part of the affected Json output
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Describe the Feature
Add integrations to the output of the atmos describe affected
Expected Behavior
When I run :
atmos describe affected --ref refs/heads/main --verbose=true
the output is:
{
"stack": "pepe-ue2-lab",
"component_type": "terraform",
"component": "vpc",
"affected": "stack.vars"
}
]
if atlantis integration is enabled it will be useful to have the project name added to the output like :+1::skin-tone-4:
{
"stack": "pepe-ue2-lab",
"component_type": "terraform",
"component": "vpc",
"affected": "stack.vars"
"atlantis_project_name": "pepe-ue2-lab-vpc"
}
]
Use Case
since Atlantis supports dynamically generated atlantis.yaml
files it is possible to generate an atlantis.yaml
for only the affected component/s and this way limit the blast radius of a PR significantly.
Alternatives Considered
parsing yaml until is not fun anymore….
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I just added your suggestion
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes, we’ll add the atlantis project name to atmos describe affected
- it will eliminate a lot of shell code
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
atmos atlantis generate repo-config --affected-only
is another feature, @jose.amengual if you think it would be useful, please open another issue or add it to the one you already opened
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I will open a new issue , np
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
https://github.com/cloudposse/atmos/issues/303 @Andriy Knysh (Cloud Posse)
Have a question? Please checkout our Slack Community or visit our Slack Archive.
Describe the Feature
it will very useful to expand the atmos describe affected
to the Atlantis integration to be able to generate an atlantis.yaml
file of only the affected components instead of all the components.
this will be useful to limit the blast radius of possible changes a user can trigger in an attlantis project.
Expected Behavior
atmos atlantis generate repo-config --affected-only --ref refs/heads/main
should only generate the atlantis.yaml file base on the branch specified.
Use Case
limit the blast radius of possible changes a user can trigger in an attlantis project.
Alternatives Considered
#!/usr/bin/env bash
atmos describe affected --ref refs/heads/main --file affected.json
stacks=""
components=""
for s in `jq -cr '.[]|.stack' affected.json|uniq`; do stacks+="${s},"; done
for c in `jq -cr '.[]|.component' affected.json|uniq`; do components+="${c},"; done
echo ${stacks%?}
echo ${components%?}
atmos atlantis generate repo-config --config-template config-1 --project-template project-1 --workflow-template workflow-1 --stacks ${stacks%?} --components ${components%?}
Additional Context
(#294)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks
2023-01-16
data:image/s3,"s3://crabby-images/5899c/5899c66f046ee21cb69a2803ba0c1c9599617625" alt="deniz gökçin avatar"
Hi all!!
We are on GitHub Teams plan and I was wondering how are the folks here handling shared-actions. I have some workflows that are identical in all repos and I have some workfows that have minor differences in different repos. Although I am using dependabot to handle version bumps, it started to be super painful to update 30+ repos whenever I think of an enhancement. Any tips??
Thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
good #office-hours question
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
this was just recently released — https://github.blog/changelog/2022-12-14-github-actions-sharing-actions-and-reusable-workflows-from-private-repositories-is-now-ga/
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
note this is for GitHub Enterprise only
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
or so I thought…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Actually, I can’t find mention that it’s enterprise only.
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
2023-01-17
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="actions Archives | The GitHub Blog avatar"
Push Notifications for Actions on Mobile Push Notifications for Actions on Mobile
2023-01-18
data:image/s3,"s3://crabby-images/f423c/f423c8e850268e533a4e86e173d6f4a9a3b27039" alt="managedkaos avatar"
Is it just me or has this workflow been running for more than 1 year? https://github.com/NTTDATA-EMEA/viewnode/actions/runs/1470423403/jobs/1909240965
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Guessing the repo was archived while the build was running. Once archived, the repo state is readonly and the state couldn’t be updated.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This repository has been archived by the owner before Nov 8, 2022. It is now read-only.
data:image/s3,"s3://crabby-images/81d28/81d28ba8905ad1587b6f924945c3f9b6fa43c721" alt="Darren Cunningham avatar"
Thank you for contacting GitHub Support.
I took a look at the affected run. It seems the repository was archived before the push that triggered that workflow hence it stayed in a pending state.
This will not affect the billing since the repository has been archived by the owner.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ya, makes sense
2023-01-19
2023-01-20
2023-01-27
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
What GH action are people using instead of gitleaks? I can’t justify the license cost for our 200+ repos
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I didn’t know gitleaks costs money
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I’ve used gitleaks locally and haven’t used their action. I never had to pay for it tho
data:image/s3,"s3://crabby-images/80531/80531e0bf93b913a163b28cb71c7d4ab622913b1" alt="akhan4u avatar"
Are you using it as a pre-commit hook?
data:image/s3,"s3://crabby-images/68e2f/68e2faea152619db914e1267b8c8468c55f93633" alt="Jim Park avatar"
GitHub has a paid feature for secret scanning, but it too costs money.
data:image/s3,"s3://crabby-images/68e2f/68e2faea152619db914e1267b8c8468c55f93633" alt="Jim Park avatar"
In my Pivotal days, we wrote our own open-source credential scanner.
It’s effectively unmaintained, the last release was over a year ago. However, if you’re keen, it may serve as an inspiration for your own project.
data:image/s3,"s3://crabby-images/bc8f1/bc8f1f1433637665b2246535f6b2bff3632d4327" alt="Pawel Rein avatar"
did any of you came across a tool that scans GHA artifacts and logs?
2023-01-29
2023-01-31
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="actions Archives | The GitHub Blog avatar"
GitHub Actions: Job summary updates GitHub Actions: Job summary updates