func (sv *secretVolume) SetUpAt(dir string) error { isMnt, err := sv.mounter.IsMountPoint(dir) // Getting an os.IsNotExist err from is a contingency; the directory // may not exist yet, in which case, setup should run. if err != nil && !os.IsNotExist(err) { return err } // If the plugin readiness file is present for this volume and // the setup dir is a mountpoint, this volume is already ready. if volumeutil.IsReady(sv.getMetaDir()) && isMnt { return nil } glog.V(3).Infof("Setting up volume %v for pod %v at %v", sv.volName, sv.pod.UID, dir) // Wrap EmptyDir, let it do the setup. wrapped, err := sv.plugin.host.NewWrapperBuilder(wrappedVolumeSpec, &sv.pod, *sv.opts, sv.mounter) if err != nil { return err } if err := wrapped.SetUpAt(dir); err != nil { return err } kubeClient := sv.plugin.host.GetKubeClient() if kubeClient == nil { return fmt.Errorf("Cannot setup secret volume %v because kube client is not configured", sv) } secret, err := kubeClient.Secrets(sv.pod.Namespace).Get(sv.secretName) if err != nil { glog.Errorf("Couldn't get secret %v/%v", sv.pod.Namespace, sv.secretName) return err } else { totalBytes := totalSecretBytes(secret) glog.V(3).Infof("Received secret %v/%v containing (%v) pieces of data, %v total bytes", sv.pod.Namespace, sv.secretName, len(secret.Data), totalBytes) } for name, data := range secret.Data { hostFilePath := path.Join(dir, name) glog.V(3).Infof("Writing secret data %v/%v/%v (%v bytes) to host file %v", sv.pod.Namespace, sv.secretName, name, len(data), hostFilePath) err := ioutil.WriteFile(hostFilePath, data, 0444) if err != nil { glog.Errorf("Error writing secret data to host path: %v, %v", hostFilePath, err) return err } } volumeutil.SetReady(sv.getMetaDir()) return nil }
// SetUpAt creates new directory. func (ed *emptyDir) SetUpAt(dir string) error { if ed.legacyMode { return fmt.Errorf("legacy mode: can not create new instances") } isMnt, err := ed.mounter.IsMountPoint(dir) // Getting an os.IsNotExist err from is a contingency; the directory // may not exist yet, in which case, setup should run. if err != nil && !os.IsNotExist(err) { return err } // If the plugin readiness file is present for this volume, and the // storage medium is the default, then the volume is ready. If the // medium is memory, and a mountpoint is present, then the volume is // ready. if volumeutil.IsReady(ed.getMetaDir()) { if ed.medium == api.StorageMediumMemory && isMnt { return nil } else if ed.medium == api.StorageMediumDefault { return nil } } // Determine the effective SELinuxOptions to use for this volume. securityContext := "" if selinuxEnabled() { securityContext, err = ed.determineEffectiveSELinuxOptions() if err != nil { return err } } switch ed.medium { case api.StorageMediumDefault: err = ed.setupDir(dir, securityContext) case api.StorageMediumMemory: err = ed.setupTmpfs(dir, securityContext) default: err = fmt.Errorf("unknown storage medium %q", ed.medium) } if err == nil { volumeutil.SetReady(ed.getMetaDir()) } return err }
func (sv *secretVolume) SetUpAt(dir string) error { if volumeutil.IsReady(sv.getMetaDir()) { return nil } glog.V(3).Infof("Setting up volume %v for pod %v at %v", sv.volName, sv.podRef.UID, dir) // Wrap EmptyDir, let it do the setup. wrapped, err := sv.plugin.host.NewWrapperBuilder(wrappedVolumeSpec, &sv.podRef, *sv.opts) if err != nil { return err } if err := wrapped.SetUpAt(dir); err != nil { return err } kubeClient := sv.plugin.host.GetKubeClient() if kubeClient == nil { return fmt.Errorf("Cannot setup secret volume %v because kube client is not configured", sv) } secret, err := kubeClient.Secrets(sv.podRef.Namespace).Get(sv.secretName) if err != nil { glog.Errorf("Couldn't get secret %v/%v", sv.podRef.Namespace, sv.secretName) return err } else { totalBytes := totalSecretBytes(secret) glog.V(3).Infof("Received secret %v/%v containing (%v) pieces of data, %v total bytes", sv.podRef.Namespace, sv.secretName, len(secret.Data), totalBytes) } for name, data := range secret.Data { hostFilePath := path.Join(dir, name) glog.V(3).Infof("Writing secret data %v/%v/%v (%v bytes) to host file %v", sv.podRef.Namespace, sv.secretName, name, len(data), hostFilePath) err := ioutil.WriteFile(hostFilePath, data, 0444) if err != nil { glog.Errorf("Error writing secret data to host path: %v, %v", hostFilePath, err) return err } } volumeutil.SetReady(sv.getMetaDir()) return nil }
// SetUpAt creates new directory and clones a git repo. func (gr *gitRepo) SetUpAt(dir string) error { if volumeutil.IsReady(gr.getMetaDir()) { return nil } if gr.legacyMode { return fmt.Errorf("legacy mode: can not create new instances") } // Wrap EmptyDir, let it do the setup. wrapped, err := gr.plugin.host.NewWrapperBuilder(wrappedVolumeSpec, &gr.pod, gr.opts, gr.mounter) if err != nil { return err } if err := wrapped.SetUpAt(dir); err != nil { return err } if output, err := gr.execCommand("git", []string{"clone", gr.source}, dir); err != nil { return fmt.Errorf("failed to exec 'git clone %s': %s: %v", gr.source, output, err) } files, err := ioutil.ReadDir(dir) if err != nil { return err } if len(files) != 1 { return fmt.Errorf("unexpected directory contents: %v", files) } if len(gr.revision) == 0 { // Done! volumeutil.SetReady(gr.getMetaDir()) return nil } subdir := path.Join(dir, files[0].Name()) if output, err := gr.execCommand("git", []string{"checkout", gr.revision}, subdir); err != nil { return fmt.Errorf("failed to exec 'git checkout %s': %s: %v", gr.revision, output, err) } if output, err := gr.execCommand("git", []string{"reset", "--hard"}, subdir); err != nil { return fmt.Errorf("failed to exec 'git reset --hard': %s: %v", output, err) } volumeutil.SetReady(gr.getMetaDir()) return nil }