local addMixin = (import 'kube-prometheus/lib/mixin.libsonnet');

local etcdMixin = addMixin({
  name: 'etcd',
  mixin: (import 'github.com/etcd-io/etcd/contrib/mixin/mixin.libsonnet') +
         {
           _config+: {
             etcd_instance_labels: 'instance, pod',
           },
         } +
         // Remove both etcdHighNumberOfFailedGRPCRequests from etcd-mixin for now
         {
           prometheusAlerts+: {
             groups: std.map(
               function(group)
                 if group.name == 'etcd' then
                   group {
                     rules: std.filter(
                       function(rule)
                         rule.alert != 'etcdHighNumberOfFailedGRPCRequests',
                       group.rules
                     ),
                   }
                 else
                   group,
               super.groups
             ),
           },
         },
});

local kp = (import 'kube-prometheus/main.libsonnet') + {
  values+:: {
    common+: {
      namespace: 'monitoring',
    },
  },
  kubernetesControlPlane+: {
    prometheusRule+: {
      spec+: {
        groups: [
          (
            if group.name == 'kubernetes-resources' then
              group {
                rules: std.filter(
                  function(rule)
                    rule.alert != 'KubeCPUOvercommit' && rule.alert != 'KubeMemoryOvercommit',
                  group.rules
                ) + [{
                  alert: 'ClusterAutoscalerNodeGroupsEnabled',
                  expr: 'cluster_autoscaler_node_groups_count{job="addons-aws-cluster-autoscaler",node_group_type="autoscaled"} > 0',
                  'for': '5m',
                  labels: {
                    severity: 'none',
                  },
                  annotations: {
                    description: 'Inhibitor rule if the Cluster Autoscaler found at least one node group',
                    summary: 'Cluster Autoscaler found at least one node group.',
                  },
                }],
              }
            else
              group
          )
          for group in super.groups
        ],
      },
    },
  },
};

// We just want the Prometheus Rules
{ 'prometheus-operator-prometheusRule': kp.prometheusOperator.prometheusRule } +
{ 'kube-prometheus-prometheusRule': kp.kubePrometheus.prometheusRule } +
{ 'alertmanager-prometheusRule': kp.alertmanager.prometheusRule } +
{ 'kube-state-metrics-prometheusRule': kp.kubeStateMetrics.prometheusRule } +
{ 'kubernetes-prometheusRule': kp.kubernetesControlPlane.prometheusRule } +
{ 'node-exporter-prometheusRule': kp.nodeExporter.prometheusRule } +
{ 'prometheus-prometheusRule': kp.prometheus.prometheusRule } +
{ 'etcd-mixin-prometheusRule': etcdMixin.prometheusRules }