* vendor: add vendored code
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* controller: use shared informers and a work queue
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* errors: use cpuguy83/strongerrors
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* aci: fix test that uses resource manager
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* readme: clarify skaffold run before e2e
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* cmd: use root context everywhere
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: refactor pod lifecycle management
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* e2e: fix race in test when observing deletions
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* e2e: test pod forced deletion
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* cmd: fix root context potential leak
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: rename metaKey
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: remove calls to HandleError
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* Revert "errors: use cpuguy83/strongerrors"
This reverts commit f031fc6d.
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* manager: remove redundant lister constraint
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: rename the pod event recorder
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: amend misleading comment
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* mock: add tracing
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: add tracing
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* test: observe timeouts
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* trace: remove unnecessary comments
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: limit concurrency in deleteDanglingPods
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: never store context, always pass in calls
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: remove HandleCrash and just panic
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: don't sync succeeded pods
Signed-off-by: Paulo Pires <pjpires@gmail.com>
* sync: ensure pod deletion from kubernetes
Signed-off-by: Paulo Pires <pjpires@gmail.com>
52 lines
1.6 KiB
Go
52 lines
1.6 KiB
Go
package manager
|
|
|
|
import (
|
|
"sync"
|
|
|
|
"k8s.io/api/core/v1"
|
|
"k8s.io/apimachinery/pkg/labels"
|
|
corev1listers "k8s.io/client-go/listers/core/v1"
|
|
|
|
"github.com/virtual-kubelet/virtual-kubelet/log"
|
|
)
|
|
|
|
// ResourceManager acts as a passthrough to a cache (lister) for pods assigned to the current node.
|
|
// It is also a passthrough to a cache (lister) for Kubernetes secrets and config maps.
|
|
type ResourceManager struct {
|
|
sync.RWMutex
|
|
|
|
podLister corev1listers.PodLister
|
|
secretLister corev1listers.SecretLister
|
|
configMapLister corev1listers.ConfigMapLister
|
|
}
|
|
|
|
// NewResourceManager returns a ResourceManager with the internal maps initialized.
|
|
func NewResourceManager(podLister corev1listers.PodLister, secretLister corev1listers.SecretLister, configMapLister corev1listers.ConfigMapLister) (*ResourceManager, error) {
|
|
rm := ResourceManager{
|
|
podLister: podLister,
|
|
secretLister: secretLister,
|
|
configMapLister: configMapLister,
|
|
}
|
|
return &rm, nil
|
|
}
|
|
|
|
// GetPods returns a list of all known pods assigned to this virtual node.
|
|
func (rm *ResourceManager) GetPods() []*v1.Pod {
|
|
l, err := rm.podLister.List(labels.Everything())
|
|
if err == nil {
|
|
return l
|
|
}
|
|
log.L.Errorf("failed to fetch pods from lister: %v", err)
|
|
return make([]*v1.Pod, 0)
|
|
}
|
|
|
|
// GetConfigMap retrieves the specified config map from the cache.
|
|
func (rm *ResourceManager) GetConfigMap(name, namespace string) (*v1.ConfigMap, error) {
|
|
return rm.configMapLister.ConfigMaps(namespace).Get(name)
|
|
}
|
|
|
|
// GetSecret retrieves the specified secret from Kubernetes.
|
|
func (rm *ResourceManager) GetSecret(name, namespace string) (*v1.Secret, error) {
|
|
return rm.secretLister.Secrets(namespace).Get(name)
|
|
}
|