Source code for c7n.resources.eks

# Copyright 2018 Capital One Services, LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from __future__ import absolute_import, division, print_function, unicode_literals

from c7n.actions import Action
from c7n.filters.vpc import SecurityGroupFilter, SubnetFilter, VpcFilter
from c7n.manager import resources
from c7n.query import QueryResourceManager
from c7n.utils import local_session, type_schema

from .aws import shape_validate


[docs]@resources.register('eks') class EKS(QueryResourceManager):
[docs] class resource_type(object): service = 'eks' enum_spec = ('list_clusters', 'clusters', None) arn = 'arn' detail_spec = ('describe_cluster', 'name', None, 'cluster') id = name = 'name' date = 'createdAt' dimension = None filter_name = None
[docs]@EKS.filter_registry.register('subnet') class EKSSubnetFilter(SubnetFilter): RelatedIdsExpression = "resourcesVpcConfig.subnetIds[]"
[docs]@EKS.filter_registry.register('security-group') class EKSSGFilter(SecurityGroupFilter): RelatedIdsExpression = "resourcesVpcConfig.securityGroupIds[]"
[docs]@EKS.filter_registry.register('vpc') class EKSVpcFilter(VpcFilter): RelatedIdsExpression = 'resourcesVpcConfig.vpcId'
[docs]@EKS.action_registry.register('update-config') class UpdateConfig(Action): schema = { 'type': 'object', 'additionalProperties': False, 'oneOf': [ {'required': ['type', 'logging']}, {'required': ['type', 'resourcesVpcConfig']}, {'required': ['type', 'logging', 'resourcesVpcConfig']}], 'properties': { 'type': {'enum': ['update-config']}, 'logging': {'type': 'object'}, 'resourcesVpcConfig': {'type': 'object'} } } permissions = ('eks:UpdateClusterConfig',) shape = 'UpdateClusterConfigRequest'
[docs] def validate(self): cfg = dict(self.data) cfg['name'] = 'validate' cfg.pop('type') return shape_validate( cfg, self.shape, self.manager.resource_type.service)
[docs] def process(self, resources): client = local_session(self.manager.session_factory).client('eks') state_filtered = 0 params = dict(self.data) params.pop('type') for r in resources: if r['status'] != 'ACTIVE': state_filtered += 1 continue client.update_cluster_config(name=r['name'], **params) if state_filtered: self.log.warning( "Filtered %d of %d clusters due to state", state_filtered, len(resources))
[docs]@EKS.action_registry.register('delete') class Delete(Action): schema = type_schema('delete') permissions = ('eks:DeleteCluster',)
[docs] def process(self, resources): client = local_session(self.manager.session_factory).client('eks') for r in resources: try: client.delete_cluster(name=r['name']) except client.exceptions.ResourceNotFoundException: continue