Skip to content

Conversation

@TylerLeonhardt
Copy link
Member

@TylerLeonhardt TylerLeonhardt commented May 27, 2020

This adds the following cmdlets:

This does take a dependency on a module I created for this use-case: PSSodium
https://www.powershellgallery.com/packages/PSSodium/0.2.0

which just exposes a

ConvertTo-SodiumEncryptedString -Text <securestring> -PublicKey <string>

I'll get that in its own repo soon-ish. Done: https://github.com/TylerLeonhardt/PSSodium

Open questions

  • Some operations depend on others... so the output looks silly and this text appears multiple times...
Telemetry is currently enabled.  It can be disabled by calling "Set-GitHubConfiguration -DisableTelemetry". Refer to USAGE.md#telemetry for more information. Stop seeing this message in the future by calling "Set-GitHubConfiguration -SuppressTelemetryReminder".                                                                                             
Telemetry is currently enabled.  It can be disabled by calling "Set-GitHubConfiguration -DisableTelemetry". Refer to USAGE.md#telemetry for more information. Stop seeing this message in the future by calling "Set-GitHubConfiguration -SuppressTelemetryReminder".                                                                                             
Telemetry is currently enabled.  It can be disabled by calling "Set-GitHubConfiguration -DisableTelemetry". Refer to USAGE.md#telemetry for more information. Stop seeing this message in the future by calling "Set-GitHubConfiguration -SuppressTelemetryReminder".

any way I can avoid that?

  • How can I test this? Ideally in GitHub Actions in a full E2E way but I'll need your help enabling that

@TylerLeonhardt
Copy link
Member Author

cc @HowardWolosky

@TylerLeonhardt
Copy link
Member Author

I considered adding support for the Org-level secrets but put that on hold for now:
https://developer.github.com/v3/actions/secrets/#list-organization-secrets

@HowardWolosky HowardWolosky added api-actions-secrets Work to complete the API's defined here: https://developer.github.com/v3/actions/secrets enhancement An issue or pull request introducing new functionality to the project. labels Jun 2, 2020
@HowardWolosky HowardWolosky added api completeness This is basic API functionality that hasn't been implemented yet. under consideration and removed enhancement An issue or pull request introducing new functionality to the project. labels Jun 18, 2020
@TylerLeonhardt
Copy link
Member Author

TylerLeonhardt commented Jul 20, 2020

So, something I was thinking about... since PowerShellForGitHub exposes Invoke-GHRestMethod and Invoke-GHRestMethodMultipleResult I was thinking about refactoring this PR to only include:

Then I'll make my own module called CreateGitHubSecrets or something that depends on PSSodium and PowerShellForGitHub that will implement:

@HowardWolosky
Copy link
Contributor

I think that would totally unblock this in the short term, and provides an easy path towards moving New/Set back into here at some point in the future (since they would have already been built on-top of Invoke-GHRestMethod) should it become more clear that taking on external dependencies makes sense.

@TylerLeonhardt TylerLeonhardt force-pushed the added-github-secrets-support branch from 77d5805 to fdf6477 Compare July 21, 2020 05:12
@TylerLeonhardt
Copy link
Member Author

Alright I removed those but to write tests I need you to add a couple test secrets to either one of the test repos or to this repo. Let me know when you do that - I can't get the value so set that to whatever. The name can be whatever you want but share those here for me.

@HowardWolosky
Copy link
Contributor

Would an organization secret work? A secret stored in this repository won't help, because the accounts that are used while running CI don't have access to this repo. And there currently is no repo that is guaranteed to exist in any of the test accounts...but the organization is guaranteed to be available, so I could add a secret to the test organizations.

If you do this though, you should add a comment to the tests (and to the CONTRIBUTING.md documentation in the tests section) to indicate that there is the expectation for those secrets to exist in the test organization in order for those tests to succeed...

@TylerLeonhardt
Copy link
Member Author

No I don't think org secrets will work. That's a separate API and should be tested in and of itself.

@JustinGrote
Copy link

@HowardWolosky if this gets completed and merged I would happily contribute a Powershell SecretManagement Provider that would leverage this API to easily fetch repository secrets.
https://github.com/powershell/secretmanagement

@TylerLeonhardt
Copy link
Member Author

@JustinGrote the problem is that there's no way to retrieve the value of secrets. You can set them and list meta data about them, but you can't get them.

@sean-r-williams
Copy link

FWIW, my org just ran into this this week. We have a use case where we may be provisioning repo-level secrets in bulk from an external source - being able to call New-GitHubSecret or similar across multiple repos would be a huge help.

(Org level secrets aren't applicable, since we have different secrets per team - the current PoR involves replicating the same team-scoped secret across many repos, which doesn't feel great.)

Not sure if this is still on the roadmap for the module (seems like there hasn't been commits in a couple of years), but it'd be great to get a temperature-check on iteration in this area.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

api completeness This is basic API functionality that hasn't been implemented yet. api-actions-secrets Work to complete the API's defined here: https://developer.github.com/v3/actions/secrets under consideration

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants