-
Notifications
You must be signed in to change notification settings - Fork 38
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
Support for config.json
credHelpers
#142
Comments
This should already be supported here: Lines 188 to 207 in fd8a83c
Line 63 in fd8a83c
|
I don't have a username or password, so I solved this by doing the following override in my registry: def load_configs(self, container: container_type, configs: Optional[list] = None):
if self._basic_auth:
return
config = docker.auth.load_config()
hostname = docker.auth.convert_to_hostname(self.hostname)
auth = config.resolve_authconfig(hostname)
self.set_basic_auth(username=auth['Username'], password=auth['Password']) |
We have a new set of auth backends for this purpose: https://github.com/oras-project/oras-py/blob/main/oras/auth/base.py What you'd do is subclass that base, and update the load_configs to be that (and edit the other functions if needed for google cloud). Would you be open to doing a PR with these changes? Then you could specify your auth backend and it should just work. |
I have the same usecase (access google cloud registry while the local docker client already has all the authentication set up). My guess is, using the new "base" auth code structure, the basic idea would look something like this (have not thought about error handling yet though): import docker.auth
import oras.auth
class DockerClientAuth(oras.auth.BasicAuth):
def _load_auth(self, hostname: str) -> bool:
if super()._load_auth(hostname):
return True
config = docker.auth.load_config()
hostname = docker.auth.convert_to_hostname(hostname)
a = config.resolve_authconfig(hostname)
self.set_basic_auth(username=a['Username'], password=a['Password'])
return True
oras.auth.auth_backends['docker'] = DockerClientAuth
registry = Registry(auth_backend='docker')
filenames = registry.pull('europe-west3-docker.pkg.dev/myproject/myrepo:tag') This of course depends on the https://pypi.org/project/docker/ package being installed. |
In case you missed the message above, we already have the docker client included and "login" is called from it: Line 63 in fd8a83c
I would be open to review a PR to address this need, from either of you. |
A lot of legacy clients and for example the oras cli support credHelpers from
~/.docker/config.json
. Support for those would be very helpful.The text was updated successfully, but these errors were encountered: