all:
  children:
    tempest:
      hosts:
        controller: null
    zuul_unreachable:
      hosts: {}
  hosts:
    controller:
      ansible_connection: ssh
      ansible_host: 199.204.45.155
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      configure_swap_size: 8192
      devstack_local_conf:
        post-config:
          $NEUTRON_CONF:
            DEFAULT:
              global_physnet_mtu: '{{ external_bridge_mtu }}'
          /etc/magnum/magnum.conf:
            cluster_template:
              kubernetes_allowed_network_drivers: calico,cilium
              kubernetes_default_network_driver: calico
            nova_client:
              api_version: 2.15
          /etc/manila/manila.conf:
            generic:
              connect_share_server_to_tenant_network: true
              driver_handles_share_servers: true
      devstack_localrc:
        ADMIN_PASSWORD: secretadmin
        DATABASE_PASSWORD: secretdatabase
        DEBUG_LIBVIRT_COREDUMPS: true
        DISABLE_AMP_IMAGE_BUILD: true
        ENABLE_SYSCTL_MEM_TUNING: true
        ENABLE_SYSCTL_NET_TUNING: true
        ENABLE_ZSWAP: true
        ERROR_ON_CLONE: true
        FIXED_RANGE: 10.1.0.0/20
        FLOATING_RANGE: 172.24.5.0/24
        GIT_BASE: https://github.com
        HOST_IP: '{{ hostvars[''controller''][''nodepool''][''private_ipv4''] }}'
        IPV4_ADDRS_SAFE_TO_USE: 10.1.0.0/20
        LIBVIRT_TYPE: '{{ devstack_libvirt_type | default("qemu") }}'
        LOGFILE: /opt/stack/logs/devstacklog.txt
        LOG_COLOR: false
        MAGNUM_GUEST_IMAGE_URL: '{{ image_url }}'
        MANILA_DEFAULT_SHARE_TYPE_EXTRA_SPECS: snapshot_support=True create_share_from_snapshot_support=True
        MANILA_ENABLED_BACKENDS: generic
        MANILA_USE_SERVICE_INSTANCE_PASSWORD: true
        NETWORK_GATEWAY: 10.1.0.1
        NOVA_LIBVIRT_TB_CACHE_SIZE: 128
        NOVA_VNC_ENABLED: true
        OCTAVIA_NODE: api
        OVN_DBS_LOG_LEVEL: dbg
        PUBLIC_BRIDGE_MTU: '{{ external_bridge_mtu }}'
        PUBLIC_NETWORK_GATEWAY: 172.24.5.1
        RABBIT_PASSWORD: secretrabbit
        SERVICE_HOST: '{{ hostvars[''controller''][''nodepool''][''private_ipv4'']
          }}'
        SERVICE_PASSWORD: secretservice
        SWIFT_HASH: 1234123412341234
        SWIFT_REPLICAS: 1
        SWIFT_START_ALL_SERVICES: false
        VERBOSE: true
        VERBOSE_NO_TIMESTAMP: true
      devstack_plugins:
        barbican: https://github.com/openstack/barbican
        magnum: https://review.opendev.org/openstack/magnum
        magnum-cluster-api: https://github.com/vexxhost/magnum-cluster-api
        manila: https://github.com/openstack/manila
        octavia: https://github.com/openstack/octavia
        ovn-octavia-provider: https://github.com/openstack/ovn-octavia-provider
      devstack_services:
        base: false
        c-api: true
        c-bak: true
        c-sch: true
        c-vol: true
        dstat: false
        etcd3: true
        file_tracker: true
        g-api: true
        horizon: false
        key: true
        memory_tracker: true
        mysql: true
        n-api: true
        n-api-meta: true
        n-cond: true
        n-cpu: true
        n-novnc: true
        n-sch: true
        o-api: true
        o-da: true
        o-hk: true
        octavia: true
        openstack-cli-server: true
        ovn-controller: true
        ovn-northd: true
        ovs-vswitchd: true
        ovsdb-server: true
        placement-api: true
        q-ovn-agent: true
        q-svc: true
        rabbit: true
        s-account: false
        s-container: false
        s-object: false
        s-proxy: false
        tempest: false
        tls-proxy: true
      extensions_to_txt:
        auto: true
        conf: true
        localrc: true
        log: true
        stackenv: true
      image_url: https://github.com/vexxhost/capo-image-elements/releases/latest/download/ubuntu-22.04-{{
        kube_tag }}.qcow2
      kube_tag: v1.33.9
      network_driver: cilium
      nodepool:
        az: nova
        cloud: public
        external_id: 013453b9-e053-4d2b-a579-f16e5669d0bf
        host_id: c9670958829e9c96e47d452d2c9c4ce9edaac336d3dbc4a3c4ec531c
        interface_ip: 199.204.45.155
        label: ubuntu-noble-16
        node_properties: {}
        private_ipv4: 199.204.45.155
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.155
        public_ipv6: 2604:e100:1:0:f816:3eff:fe1e:4ab7
        region: ca-ymq-1
        slot: null
      zuul_copy_output:
        /etc/ceph: logs
        /etc/glusterfs/glusterd.vol: logs
        /etc/libvirt: logs
        /etc/lvm: logs
        /etc/resolv.conf: logs
        /etc/sudoers: logs
        /etc/sudoers.d: logs
        /var/log/ceph: logs
        /var/log/glusterfs: logs
        /var/log/libvirt: logs
        /var/log/mysql: logs
        /var/log/openvswitch: logs
        /var/log/postgresql: logs
        /var/log/rabbitmq: logs
        /var/log/unbound.log: logs
        '{{ devstack_conf_dir }}/.localrc.auto': logs
        '{{ devstack_conf_dir }}/.stackenv': logs
        '{{ devstack_conf_dir }}/local.conf': logs
        '{{ devstack_conf_dir }}/localrc': logs
        '{{ devstack_full_log}}': logs
        '{{ devstack_log_dir }}/atop': logs
        '{{ devstack_log_dir }}/devstacklog.txt': logs
        '{{ devstack_log_dir }}/devstacklog.txt.summary': logs
        '{{ devstack_log_dir }}/dstat-csv.log': logs
        '{{ devstack_log_dir }}/qemu.coredump': logs
        '{{ devstack_log_dir }}/tcpdump.pcap': logs
        '{{ devstack_log_dir }}/worlddump-latest.txt': logs
        '{{ stage_dir }}/apache': logs
        '{{ stage_dir }}/apache_config': logs
        '{{ stage_dir }}/audit.log': logs
        '{{ stage_dir }}/core': logs
        '{{ stage_dir }}/deprecations.log': logs
        '{{ stage_dir }}/df.txt': logs
        '{{ stage_dir }}/dpkg-l.txt': logs
        '{{ stage_dir }}/etc': logs
        '{{ stage_dir }}/iptables.txt': logs
        '{{ stage_dir }}/listen53.txt': logs
        '{{ stage_dir }}/mount.txt': logs
        '{{ stage_dir }}/performance.json': logs
        '{{ stage_dir }}/pip2-freeze.txt': logs
        '{{ stage_dir }}/pip3-freeze.txt': logs
        '{{ stage_dir }}/rpm-qa.txt': logs
        '{{ stage_dir }}/services.txt': logs
        '{{ stage_dir }}/verify_tempest_conf.log': logs
      zuul_node:
        az: nova
        cloud: public
        external_id: 013453b9-e053-4d2b-a579-f16e5669d0bf
        host_id: c9670958829e9c96e47d452d2c9c4ce9edaac336d3dbc4a3c4ec531c
        interface_ip: 199.204.45.155
        label: ubuntu-noble-16
        node_properties: {}
        private_ipv4: 199.204.45.155
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.155
        public_ipv6: 2604:e100:1:0:f816:3eff:fe1e:4ab7
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    configure_swap_size: 8192
    devstack_local_conf:
      post-config:
        $NEUTRON_CONF:
          DEFAULT:
            global_physnet_mtu: '{{ external_bridge_mtu }}'
        /etc/magnum/magnum.conf:
          cluster_template:
            kubernetes_allowed_network_drivers: calico,cilium
            kubernetes_default_network_driver: calico
          nova_client:
            api_version: 2.15
        /etc/manila/manila.conf:
          generic:
            connect_share_server_to_tenant_network: true
            driver_handles_share_servers: true
    devstack_localrc:
      ADMIN_PASSWORD: secretadmin
      DATABASE_PASSWORD: secretdatabase
      DEBUG_LIBVIRT_COREDUMPS: true
      DISABLE_AMP_IMAGE_BUILD: true
      ENABLE_SYSCTL_MEM_TUNING: true
      ENABLE_SYSCTL_NET_TUNING: true
      ENABLE_ZSWAP: true
      ERROR_ON_CLONE: true
      FIXED_RANGE: 10.1.0.0/20
      FLOATING_RANGE: 172.24.5.0/24
      GIT_BASE: https://github.com
      HOST_IP: '{{ hostvars[''controller''][''nodepool''][''private_ipv4''] }}'
      IPV4_ADDRS_SAFE_TO_USE: 10.1.0.0/20
      LIBVIRT_TYPE: '{{ devstack_libvirt_type | default("qemu") }}'
      LOGFILE: /opt/stack/logs/devstacklog.txt
      LOG_COLOR: false
      MAGNUM_GUEST_IMAGE_URL: '{{ image_url }}'
      MANILA_DEFAULT_SHARE_TYPE_EXTRA_SPECS: snapshot_support=True create_share_from_snapshot_support=True
      MANILA_ENABLED_BACKENDS: generic
      MANILA_USE_SERVICE_INSTANCE_PASSWORD: true
      NETWORK_GATEWAY: 10.1.0.1
      NOVA_LIBVIRT_TB_CACHE_SIZE: 128
      NOVA_VNC_ENABLED: true
      OCTAVIA_NODE: api
      OVN_DBS_LOG_LEVEL: dbg
      PUBLIC_BRIDGE_MTU: '{{ external_bridge_mtu }}'
      PUBLIC_NETWORK_GATEWAY: 172.24.5.1
      RABBIT_PASSWORD: secretrabbit
      SERVICE_HOST: '{{ hostvars[''controller''][''nodepool''][''private_ipv4''] }}'
      SERVICE_PASSWORD: secretservice
      SWIFT_HASH: 1234123412341234
      SWIFT_REPLICAS: 1
      SWIFT_START_ALL_SERVICES: false
      VERBOSE: true
      VERBOSE_NO_TIMESTAMP: true
    devstack_plugins:
      barbican: https://github.com/openstack/barbican
      magnum: https://review.opendev.org/openstack/magnum
      magnum-cluster-api: https://github.com/vexxhost/magnum-cluster-api
      manila: https://github.com/openstack/manila
      octavia: https://github.com/openstack/octavia
      ovn-octavia-provider: https://github.com/openstack/ovn-octavia-provider
    devstack_services:
      base: false
      c-api: true
      c-bak: true
      c-sch: true
      c-vol: true
      dstat: false
      etcd3: true
      file_tracker: true
      g-api: true
      horizon: false
      key: true
      memory_tracker: true
      mysql: true
      n-api: true
      n-api-meta: true
      n-cond: true
      n-cpu: true
      n-novnc: true
      n-sch: true
      o-api: true
      o-da: true
      o-hk: true
      octavia: true
      openstack-cli-server: true
      ovn-controller: true
      ovn-northd: true
      ovs-vswitchd: true
      ovsdb-server: true
      placement-api: true
      q-ovn-agent: true
      q-svc: true
      rabbit: true
      s-account: false
      s-container: false
      s-object: false
      s-proxy: false
      tempest: false
      tls-proxy: true
    extensions_to_txt:
      auto: true
      conf: true
      localrc: true
      log: true
      stackenv: true
    image_url: https://github.com/vexxhost/capo-image-elements/releases/latest/download/ubuntu-22.04-{{
      kube_tag }}.qcow2
    kube_tag: v1.33.9
    network_driver: cilium
    zuul:
      _inheritance_path:
      - '<Job base explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/zuul-config/zuul.d/jobs.yaml@main#1>'
      - '<Job openstack-multinode-fips explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/zuul-config/zuul.d/jobs.yaml@main#17>'
      - '<Job devstack-base explicit: None implied: {MatchAny:{ImpliedBranchMatcher:master}}
        source: openstack/devstack/.zuul.yaml@master#426>'
      - '<Job devstack-minimal explicit: None implied: {MatchAny:{ImpliedBranchMatcher:master}}
        source: openstack/devstack/.zuul.yaml@master#558>'
      - '<Job devstack explicit: None implied: {MatchAny:{ImpliedBranchMatcher:master}}
        source: openstack/devstack/.zuul.yaml@master#601>'
      - '<Job magnum-cluster-api-devstack explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/magnum-cluster-api/zuul.d/jobs.yaml@main#1>'
      - '<Job magnum-cluster-api-hydrophone explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/magnum-cluster-api/zuul.d/jobs.yaml@main#60>'
      - '<Job magnum-cluster-api-hydrophone-v1.33.9 explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/magnum-cluster-api/zuul.d/jobs.yaml@main#72>'
      - '<Job magnum-cluster-api-hydrophone-v1.33.9-cilium explicit: None implied:
        {MatchAny:{ImpliedBranchMatcher:main}} source: vexxhost/magnum-cluster-api/zuul.d/jobs.yaml@main#84>'
      - '<Job magnum-cluster-api-hydrophone-v1.33.9-cilium explicit: None implied:
        None source: vexxhost/magnum-cluster-api/zuul.d/project.yaml@main#1>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: a8a2f990a80b4c9085ad3ab798003a72
      build_refs:
      - branch: main
        change: '702'
        change_message: "fix(deps): update rust crate kube to v3\n\nThis PR contains
          the following updates:\n\n| Package | Type | Update | Change |\n|---|---|---|---|\n|
          [kube](https://redirect.github.com/kube-rs/kube) | dependencies | major
          | `1.0.0` \u2192 `3.0.0` |\n\n---\n\n### Release Notes\n\n<details>\n<summary>kube-rs/kube
          (kube)</summary>\n\n### [`v3.1.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#310--2026-03-17)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/3.0.1...3.1.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.1.0
          -->\n\n#### What's Changed\n\nMaintenance release with fixes for schemas/validation,
          client exec blocking and proxy handling, as well as some smaller new features
          listed below. Internal changes and documentation improvements listed in
          the [milestone](https://redirect.github.com/kube-rs/kube/milestone/54?closed=1).\n\n#####
          Added\n\n- allow empty body in const context by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1927](https://redirect.github.com/kube-rs/kube/pull/1927)\n-
          Add typed printcolumn argument to derive macro by [@&#8203;cchndl](https://redirect.github.com/cchndl)
          in [#&#8203;1872](https://redirect.github.com/kube-rs/kube/pull/1872)\n-
          kube-core: add optionalOldSelf to CEL `Rule` by [@&#8203;Immortal-Beyond-Oblivion](https://redirect.github.com/Immortal-Beyond-Oblivion)
          in [#&#8203;1947](https://redirect.github.com/kube-rs/kube/pull/1947)\n-
          Re-add support for basic auth in Proxy by [@&#8203;goenning](https://redirect.github.com/goenning)
          in [#&#8203;1959](https://redirect.github.com/kube-rs/kube/pull/1959)\n\n#####
          Fixed\n\n- Fix OptionalEnum transform for complex enums by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1934](https://redirect.github.com/kube-rs/kube/pull/1934)\n\n-
          Bump tower-http dependency to 0.6.4 by [@&#8203;abustany](https://redirect.github.com/abustany)
          in [#&#8203;1939](https://redirect.github.com/kube-rs/kube/pull/1939)\n\n-
          Add minimal-versions CI check by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1940](https://redirect.github.com/kube-rs/kube/pull/1940)\n\n-
          fix: Produce valid CRDs containing flattened untagged enums by [@&#8203;NickLarsenNZ](https://redirect.github.com/NickLarsenNZ)
          in [#&#8203;1942](https://redirect.github.com/kube-rs/kube/pull/1942)\n\n-
          kube-client: Avoid blocking tokio worker during exec auth token refresh
          by [@&#8203;blakelawson](https://redirect.github.com/blakelawson) in [#&#8203;1950](https://redirect.github.com/kube-rs/kube/pull/1950)\n\n-
          [@&#8203;abustany](https://redirect.github.com/abustany) made their first
          contribution in [#&#8203;1939](https://redirect.github.com/kube-rs/kube/pull/1939)\n\n-
          [@&#8203;cchndl](https://redirect.github.com/cchndl) made their first contribution
          in [#&#8203;1872](https://redirect.github.com/kube-rs/kube/pull/1872)\n\n-
          [@&#8203;Immortal-Beyond-Oblivion](https://redirect.github.com/Immortal-Beyond-Oblivion)
          made their first contribution in [#&#8203;1947](https://redirect.github.com/kube-rs/kube/pull/1947)\n\n-
          [@&#8203;gauravgahlot](https://redirect.github.com/gauravgahlot) made their
          first contribution in [#&#8203;1949](https://redirect.github.com/kube-rs/kube/pull/1949)\n\n-
          [@&#8203;blakelawson](https://redirect.github.com/blakelawson) made their
          first contribution in [#&#8203;1950](https://redirect.github.com/kube-rs/kube/pull/1950)\n\n**Full
          Changelog**: <https://github.com/kube-rs/kube/compare/3.0.1...3.1.0>\n\n###
          [`v3.0.1`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#301--2026-01-30)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/3.0.0...3.0.1)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.1
          -->\n\n#### What's Changed\n\nBugfix release for schemas, admission, and
          docs. Minor internal improvements listed in the [milestone](https://redirect.github.com/kube-rs/kube/milestone/53?closed=1).
          Important fixes below.\n\n##### Fixed\n\n- Update API version of [`AdmissionResponse`](https://docs.rs/kube/3.0.1/kube/core/admission/struct.AdmissionResponse.html)
          created via invalid call by [@&#8203;Magicloud](https://redirect.github.com/Magicloud)
          in [#&#8203;1905](https://redirect.github.com/kube-rs/kube/pull/1905)\n-
          Fix [`OptionalEnum`](https://docs.rs/kube/3.0.1/kube/core/schema/struct.OptionalEnum.html)
          transform skipping schemas with description by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1908](https://redirect.github.com/kube-rs/kube/pull/1908)\n-
          Remove conflicting `additionalProperties: false` from schema by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1920](https://redirect.github.com/kube-rs/kube/pull/1920)\n\n###
          [`v3.0.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#300--2026-01-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/2.0.1...3.0.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.0
          -->\n\n#### New Major\n\nAs per the new release schedule to match up with
          the new Kubernetes release.\nLots of additions, fixes and improvements.
          Thanks to everyone who contributed so heavily over the holidays! Happy new
          year.\n\n#### Breaking Changes\n\n##### Kubernetes `v1_35` support via k8s-openapi
          [0.27](https://redirect.github.com/Arnavion/k8s-openapi/releases/tag/v0.27.0)\n\nPlease
          [upgrade k8s-openapi along with kube](https://kube.rs/upgrading/) to avoid
          conflicts.\n\n##### `jiff` replaces `chrono`\n\nMatching k8s-openapi's [change](https://redirect.github.com/Arnavion/k8s-openapi/commit/8c1b6fccb7258eb487ed8c829791d427a4b16216),
          kube has also swapped out `chrono`. The biggest impact of this is for interacting
          with timestamps in `metadata`, but it also updates 2 smaller public interfaces
          in [`LogParams`](https://docs.rs/kube/latest/kube/api/struct.LogParams.html#structfield.since_time),
          [`Client::with_valid_until`](https://docs.rs/kube/latest/kube/struct.Client.html#method.with_valid_until).
          \ See [controller-rs#217](https://redirect.github.com/kube-rs/controller-rs/pull/217/changes)
          for an example change.\n\nChanges: [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)
          + [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n\n####
          `ErrorResponse` has been replaced with [`Status`](https://docs.rs/kube/latest/kube/core/struct.Status.html)\n\n`ErrorResponse`
          served as a partial metav1/Status replacement which ended up hiding error
          information to users. These structs have merged, more information is available
          on errors, and a type alias with a deprecation warning is in place for [`ErrorResponse`](https://docs.rs/kube/latest/kube/core/type.ErrorResponse.html)
          which will be removed in a later version.\n\nThis creates a small breaking
          change for users matching on specific [`Error::Api`](https://docs.rs/kube/latest/kube/enum.Error.html#variant.Api)
          codes;\n\n```diff\n     .map_err(|error| match error {\n-        kube::Error::Api(kube::error::ErrorResponse
          { code: 403, .. }) => {\n-            Error::UnauthorizedToPatch(obj)\n-
          \       }\n+        kube::Error::Api(s) if s.is_forbidden() => Error::UnauthorizedToPatch(obj),\n
          \        other => Error::Other(other),\n     })?;\n```\n\n[#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)
          + [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883) + [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891).\n\n####
          Predicates now has a TTL Cache\n\nThis prevents unbounded memory for controllers,
          particularly affecting ones watching quickly rotating objects with generated
          names (e.g. pods). By default the TTL is `1h`. It can be configured via
          new [`PredicateConfig`](https://docs.rs/kube/latest/kube/runtime/struct.PredicateConfig.html)
          parameter. To use the default;\n\n```diff\n-        .predicate_filter(predicates::resource_version);\n+
          \       .predicate_filter(predicates::resource_version, Default::default());\n```\n\nChange
          in [#&#8203;1836](https://redirect.github.com/kube-rs/kube/pull/1836). This
          helped expose and fix a bug in watches with streaming\\_lists now fixed
          in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882).\n\n####
          Subresource Api\n\nSome subresource write methods were public with inconsistent
          signatures that required less ergonomic use than any other write methods.
          They took a `Vec<u8>` for the post body, now they take a `&K: Serialize`
          or the actual subresource.\nThere affect `Api::create_subresource`, `Api::replace_subresource`,
          [`Api::replace_status`](https://docs.rs/kube/latest/kube/struct.Api.html#method.replace_status),
          `Api::replace_scale`. In essence this generally means you do not have to
          wrap raw objects in `json!` and `serde_json::to_vec` for these calls and
          lean more on rust's typed objects rather than `json!` blobs which has some
          [footguns](https://redirect.github.com/kube-rs/kube/pull/1884#discussion_r2680782556)
          for subresources.\n\n```diff\n-    let o = foos.replace_status(\"qux\",
          &pp, serde_json::to_vec(&object)?).await?;\n+    let o = foos.replace_status(\"qux\",
          &pp, &object).await?;\n```\n\nSee some more shifts in examples in the implementation;
          [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n\n####
          Improvements\n\n##### Support Kubernetes 1.30 [Aggregated Discovery](https://kubernetes.io/docs/concepts/overview/kubernetes-api/#aggregated-discovery)\n\nSpeeds
          up api discovery **significantly** by using the newer api with much less
          round-tripping.\nTo opt-in change `Discovery::run()` to [`Discovery::run_aggregated()`](https://docs.rs/kube/latest/kube/struct.Discovery.html#method.run_aggregated)\n\nChanges;
          [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876) + [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)
          + [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          Rust 2024\n\nWhile this is mostly for internal ergonomics, we would like
          to highlight this also simplifies the [`Condition`](https://docs.rs/kube/latest/kube/runtime/wait/conditions/trait.Condition.html)
          implementors which had to deal with a lot of options;\n\n```diff\n    pub
          fn is_job_completed() -> impl Condition<Job> {\n        |obj: Option<&Job>|
          {\n-            if let Some(job) = &obj {\n-                if let Some(s)
          = &job.status {\n-                    if let Some(conds) = &s.conditions
          {\n-                        if let Some(pcond) = conds.iter().find(|c| c.type_
          == \"Complete\") {\n-                            return pcond.status ==
          \"True\";\n-                        }\n-                    }\n-                }\n+
          \           if let Some(job) = &obj\n+                && let Some(s) = &job.status\n+
          \               && let Some(conds) = &s.conditions\n+                &&
          let Some(pcond) = conds.iter().find(|c| c.type_ == \"Complete\")\n+            {\n+
          \               return pcond.status == \"True\";\n```\n\nChange [#&#8203;1856](https://redirect.github.com/kube-rs/kube/pull/1856)
          + [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n\n#####
          New Client [`RetryPolicy`](https://docs.rs/kube/latest/kube/client/retry/struct.RetryPolicy.html)
          opt-in\n\nAllows custom clients (for now) to enable exponential backoff'd
          retries for retryable errors by exposing a [`tower::retry::Policy`](https://tower-rs.github.io/tower/tower/retry/trait.Policy.html)
          for a [`tower::retry::Layer`](https://tower-rs.github.io/tower/tower/retry/struct.RetryLayer.html).
          See the new [custom\\_client\\_retry](https://redirect.github.com/kube-rs/kube/blob/main/examples/custom_client_retry.rs#L24-L37)
          example for details.\n\nEnabled by a [cloneable body](https://redirect.github.com/kube-rs/kube/pull/1867)
          + the new [RetryPolicy](https://redirect.github.com/kube-rs/kube/pull/1894)
          based on mirrord's solution[\\*](https://redirect.github.com/metalbear-co/mirrord/blob/a9e4c52a720fd5a833e30aee1ac650360031b7a7/mirrord/kube/src/retry.rs#L41-L135).\n\n####
          Fixes\n\n- streaming list bug fix - [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          watcher jitter bug fix - [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n-
          schema fix for IntOrString - [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          schema fix for optional enums - [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          websocket keepalives for long running attaches - [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          More\n\n- `Resize` subresource impl for `Pod` - [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          add `#[kube(attr=\"...\")` to allow custom attrs on derives - [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          example updates for admission w/axum - [#&#8203;1859](https://redirect.github.com/kube-rs/kube/pull/1859)\n\n####
          What's Changed\n\n##### Added\n\n- Add `Resize` subresource for `Pod` by
          [@&#8203;hugoponthieu](https://redirect.github.com/hugoponthieu) in [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          feat: add #\\[kube(attr=\"...\")] attribute helper to set attribute helper
          on the CR root type by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          Rust 2024 let-chains to simplify wait Conditions by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n-
          Adds a `try_clone` method for `kube_client::client::Body` when it's `Kind::Once`
          by [@&#8203;meowjesty](https://redirect.github.com/meowjesty) in [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          Implement client aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)\n-
          Implement aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876)\n-
          Permit older version of API for v2 discovery for k8s < 1.30 (down to 1.27)
          by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n-
          Add RetryPolicy for client-level request retries by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1894](https://redirect.github.com/kube-rs/kube/pull/1894)\n\n#####
          Changed\n\n- Update tokio-tungstenite requirement from 0.27.0 to 0.28.0
          by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot] in
          [#&#8203;1829](https://redirect.github.com/kube-rs/kube/pull/1829)\n- Predicates:
          add configurable cache TTL for `predicate_filter` by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1838](https://redirect.github.com/kube-rs/kube/pull/1838)\n-
          Update darling requirement from 0.21.0 to 0.23.0 by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot]
          in [#&#8203;1861](https://redirect.github.com/kube-rs/kube/pull/1861)\n-
          update to jsonpath-rust 1 by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1863](https://redirect.github.com/kube-rs/kube/pull/1863)\n-
          Replace `chrono` with `jiff` by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)\n-
          Merge ErrorResponse and Status by [@&#8203;imp](https://redirect.github.com/imp)
          in [#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)\n-
          Make subresource methods more ergonomic by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n-
          Drop k8s v1.30, crono->jiff replacement for runtime & examples by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n-
          Add a metadata field to Status by [@&#8203;ryanpbrewster](https://redirect.github.com/ryanpbrewster)
          in [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891)\n-
          Bump `k8s-openapi` for Kubernetes 1.35 by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1898](https://redirect.github.com/kube-rs/kube/pull/1898)\n\n#####
          Fixed\n\n- fix: add use<> to kubelet\\_node\\_logs for rust edition 2024
          by [@&#8203;co42](https://redirect.github.com/co42) in [#&#8203;1849](https://redirect.github.com/kube-rs/kube/pull/1849)\n-
          Transform optional enums to match pre kube 2.0.0 format by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          Distinguish between initial and resumed watch phases for streaming lists
          by [@&#8203;doxxx93](https://redirect.github.com/doxxx93) in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          Re-export deprecated type alias and improve deprecation guidance by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883)\n-
          Add nullable to optional fields with x-kubernetes-int-or-string by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1885](https://redirect.github.com/kube-rs/kube/pull/1885)\n-
          send websocket ping to keep idle connections alive by [@&#8203;inqode-lars](https://redirect.github.com/inqode-lars)
          in [#&#8203;1887](https://redirect.github.com/kube-rs/kube/pull/1887)\n-
          Fix watcher ExponentialBackoff jitter ignored by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n\n###
          [`v2.0.1`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#201--2025-09-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/2.0.0...2.0.1)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 2.0.1
          -->\n\n#### What's Changed\n\nFixes an accidental inclusion of a constraint
          added to `Api::log_stream` introduced in the 2.0.0 Rust 2024 upgrade.\n\n#####
          Fixed\n\n- Remove unused use<'\\_> from log\\_stream() by [@&#8203;pgerber](https://redirect.github.com/pgerber)
          in [#&#8203;1824](https://redirect.github.com/kube-rs/kube/pull/1824)\n\n###
          [`v2.0.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#300--2026-01-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/1.1.0...2.0.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.0
          -->\n\n#### New Major\n\nAs per the new release schedule to match up with
          the new Kubernetes release.\nLots of additions, fixes and improvements.
          Thanks to everyone who contributed so heavily over the holidays! Happy new
          year.\n\n#### Breaking Changes\n\n##### Kubernetes `v1_35` support via k8s-openapi
          [0.27](https://redirect.github.com/Arnavion/k8s-openapi/releases/tag/v0.27.0)\n\nPlease
          [upgrade k8s-openapi along with kube](https://kube.rs/upgrading/) to avoid
          conflicts.\n\n##### `jiff` replaces `chrono`\n\nMatching k8s-openapi's [change](https://redirect.github.com/Arnavion/k8s-openapi/commit/8c1b6fccb7258eb487ed8c829791d427a4b16216),
          kube has also swapped out `chrono`. The biggest impact of this is for interacting
          with timestamps in `metadata`, but it also updates 2 smaller public interfaces
          in [`LogParams`](https://docs.rs/kube/latest/kube/api/struct.LogParams.html#structfield.since_time),
          [`Client::with_valid_until`](https://docs.rs/kube/latest/kube/struct.Client.html#method.with_valid_until).
          \ See [controller-rs#217](https://redirect.github.com/kube-rs/controller-rs/pull/217/changes)
          for an example change.\n\nChanges: [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)
          + [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n\n####
          `ErrorResponse` has been replaced with [`Status`](https://docs.rs/kube/latest/kube/core/struct.Status.html)\n\n`ErrorResponse`
          served as a partial metav1/Status replacement which ended up hiding error
          information to users. These structs have merged, more information is available
          on errors, and a type alias with a deprecation warning is in place for [`ErrorResponse`](https://docs.rs/kube/latest/kube/core/type.ErrorResponse.html)
          which will be removed in a later version.\n\nThis creates a small breaking
          change for users matching on specific [`Error::Api`](https://docs.rs/kube/latest/kube/enum.Error.html#variant.Api)
          codes;\n\n```diff\n     .map_err(|error| match error {\n-        kube::Error::Api(kube::error::ErrorResponse
          { code: 403, .. }) => {\n-            Error::UnauthorizedToPatch(obj)\n-
          \       }\n+        kube::Error::Api(s) if s.is_forbidden() => Error::UnauthorizedToPatch(obj),\n
          \        other => Error::Other(other),\n     })?;\n```\n\n[#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)
          + [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883) + [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891).\n\n####
          Predicates now has a TTL Cache\n\nThis prevents unbounded memory for controllers,
          particularly affecting ones watching quickly rotating objects with generated
          names (e.g. pods). By default the TTL is `1h`. It can be configured via
          new [`PredicateConfig`](https://docs.rs/kube/latest/kube/runtime/struct.PredicateConfig.html)
          parameter. To use the default;\n\n```diff\n-        .predicate_filter(predicates::resource_version);\n+
          \       .predicate_filter(predicates::resource_version, Default::default());\n```\n\nChange
          in [#&#8203;1836](https://redirect.github.com/kube-rs/kube/pull/1836). This
          helped expose and fix a bug in watches with streaming\\_lists now fixed
          in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882).\n\n####
          Subresource Api\n\nSome subresource write methods were public with inconsistent
          signatures that required less ergonomic use than any other write methods.
          They took a `Vec<u8>` for the post body, now they take a `&K: Serialize`
          or the actual subresource.\nThere affect `Api::create_subresource`, `Api::replace_subresource`,
          [`Api::replace_status`](https://docs.rs/kube/latest/kube/struct.Api.html#method.replace_status),
          `Api::replace_scale`. In essence this generally means you do not have to
          wrap raw objects in `json!` and `serde_json::to_vec` for these calls and
          lean more on rust's typed objects rather than `json!` blobs which has some
          [footguns](https://redirect.github.com/kube-rs/kube/pull/1884#discussion_r2680782556)
          for subresources.\n\n```diff\n-    let o = foos.replace_status(\"qux\",
          &pp, serde_json::to_vec(&object)?).await?;\n+    let o = foos.replace_status(\"qux\",
          &pp, &object).await?;\n```\n\nSee some more shifts in examples in the implementation;
          [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n\n####
          Improvements\n\n##### Support Kubernetes 1.30 [Aggregated Discovery](https://kubernetes.io/docs/concepts/overview/kubernetes-api/#aggregated-discovery)\n\nSpeeds
          up api discovery **significantly** by using the newer api with much less
          round-tripping.\nTo opt-in change `Discovery::run()` to [`Discovery::run_aggregated()`](https://docs.rs/kube/latest/kube/struct.Discovery.html#method.run_aggregated)\n\nChanges;
          [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876) + [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)
          + [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          Rust 2024\n\nWhile this is mostly for internal ergonomics, we would like
          to highlight this also simplifies the [`Condition`](https://docs.rs/kube/latest/kube/runtime/wait/conditions/trait.Condition.html)
          implementors which had to deal with a lot of options;\n\n```diff\n    pub
          fn is_job_completed() -> impl Condition<Job> {\n        |obj: Option<&Job>|
          {\n-            if let Some(job) = &obj {\n-                if let Some(s)
          = &job.status {\n-                    if let Some(conds) = &s.conditions
          {\n-                        if let Some(pcond) = conds.iter().find(|c| c.type_
          == \"Complete\") {\n-                            return pcond.status ==
          \"True\";\n-                        }\n-                    }\n-                }\n+
          \           if let Some(job) = &obj\n+                && let Some(s) = &job.status\n+
          \               && let Some(conds) = &s.conditions\n+                &&
          let Some(pcond) = conds.iter().find(|c| c.type_ == \"Complete\")\n+            {\n+
          \               return pcond.status == \"True\";\n```\n\nChange [#&#8203;1856](https://redirect.github.com/kube-rs/kube/pull/1856)
          + [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n\n#####
          New Client [`RetryPolicy`](https://docs.rs/kube/latest/kube/client/retry/struct.RetryPolicy.html)
          opt-in\n\nAllows custom clients (for now) to enable exponential backoff'd
          retries for retryable errors by exposing a [`tower::retry::Policy`](https://tower-rs.github.io/tower/tower/retry/trait.Policy.html)
          for a [`tower::retry::Layer`](https://tower-rs.github.io/tower/tower/retry/struct.RetryLayer.html).
          See the new [custom\\_client\\_retry](https://redirect.github.com/kube-rs/kube/blob/main/examples/custom_client_retry.rs#L24-L37)
          example for details.\n\nEnabled by a [cloneable body](https://redirect.github.com/kube-rs/kube/pull/1867)
          + the new [RetryPolicy](https://redirect.github.com/kube-rs/kube/pull/1894)
          based on mirrord's solution[\\*](https://redirect.github.com/metalbear-co/mirrord/blob/a9e4c52a720fd5a833e30aee1ac650360031b7a7/mirrord/kube/src/retry.rs#L41-L135).\n\n####
          Fixes\n\n- streaming list bug fix - [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          watcher jitter bug fix - [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n-
          schema fix for IntOrString - [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          schema fix for optional enums - [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          websocket keepalives for long running attaches - [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          More\n\n- `Resize` subresource impl for `Pod` - [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          add `#[kube(attr=\"...\")` to allow custom attrs on derives - [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          example updates for admission w/axum - [#&#8203;1859](https://redirect.github.com/kube-rs/kube/pull/1859)\n\n####
          What's Changed\n\n##### Added\n\n- Add `Resize` subresource for `Pod` by
          [@&#8203;hugoponthieu](https://redirect.github.com/hugoponthieu) in [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          feat: add #\\[kube(attr=\"...\")] attribute helper to set attribute helper
          on the CR root type by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          Rust 2024 let-chains to simplify wait Conditions by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n-
          Adds a `try_clone` method for `kube_client::client::Body` when it's `Kind::Once`
          by [@&#8203;meowjesty](https://redirect.github.com/meowjesty) in [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          Implement client aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)\n-
          Implement aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876)\n-
          Permit older version of API for v2 discovery for k8s < 1.30 (down to 1.27)
          by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n-
          Add RetryPolicy for client-level request retries by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1894](https://redirect.github.com/kube-rs/kube/pull/1894)\n\n#####
          Changed\n\n- Update tokio-tungstenite requirement from 0.27.0 to 0.28.0
          by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot] in
          [#&#8203;1829](https://redirect.github.com/kube-rs/kube/pull/1829)\n- Predicates:
          add configurable cache TTL for `predicate_filter` by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1838](https://redirect.github.com/kube-rs/kube/pull/1838)\n-
          Update darling requirement from 0.21.0 to 0.23.0 by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot]
          in [#&#8203;1861](https://redirect.github.com/kube-rs/kube/pull/1861)\n-
          update to jsonpath-rust 1 by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1863](https://redirect.github.com/kube-rs/kube/pull/1863)\n-
          Replace `chrono` with `jiff` by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)\n-
          Merge ErrorResponse and Status by [@&#8203;imp](https://redirect.github.com/imp)
          in [#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)\n-
          Make subresource methods more ergonomic by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n-
          Drop k8s v1.30, crono->jiff replacement for runtime & examples by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n-
          Add a metadata field to Status by [@&#8203;ryanpbrewster](https://redirect.github.com/ryanpbrewster)
          in [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891)\n-
          Bump `k8s-openapi` for Kubernetes 1.35 by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1898](https://redirect.github.com/kube-rs/kube/pull/1898)\n\n#####
          Fixed\n\n- fix: add use<> to kubelet\\_node\\_logs for rust edition 2024
          by [@&#8203;co42](https://redirect.github.com/co42) in [#&#8203;1849](https://redirect.github.com/kube-rs/kube/pull/1849)\n-
          Transform optional enums to match pre kube 2.0.0 format by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          Distinguish between initial and resumed watch phases for streaming lists
          by [@&#8203;doxxx93](https://redirect.github.com/doxxx93) in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          Re-export deprecated type alias and improve deprecation guidance by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883)\n-
          Add nullable to optional fields with x-kubernetes-int-or-string by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1885](https://redirect.github.com/kube-rs/kube/pull/1885)\n-
          send websocket ping to keep idle connections alive by [@&#8203;inqode-lars](https://redirect.github.com/inqode-lars)
          in [#&#8203;1887](https://redirect.github.com/kube-rs/kube/pull/1887)\n-
          Fix watcher ExponentialBackoff jitter ignored by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n\n</details>\n\n---\n\n###
          Configuration\n\n\U0001F4C5 **Schedule**: Branch creation - At any time
          (no schedule defined), Automerge - At any time (no schedule defined).\n\n\U0001F6A6
          **Automerge**: Disabled by config. Please merge this manually once you are
          satisfied.\n\n\u267B **Rebasing**: Whenever PR is behind base branch, or
          you tick the rebase/retry checkbox.\n\n\U0001F515 **Ignore**: Close this
          PR and you won't be reminded about this update again.\n\n---\n\n - [ ] <!--
          rebase-check -->If you want to rebase/retry this PR, check this box\n\n---\n\nThis
          PR was generated by [Mend Renovate](https://mend.io/renovate/). View the
          [repository job log](https://developer.mend.io/github/vexxhost/magnum-cluster-api).\n<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0MC4xMS45IiwidXBkYXRlZEluVmVyIjoiNDMuNjYuNCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==-->\n"
        change_url: https://github.com/vexxhost/magnum-cluster-api/pull/702
        commit_id: ba7a6fc9b0c447bcf908b92d6b7b9731dc91da42
        patchset: 12fec567ed329a015d3964c475e25b8e5275f3eb
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/magnum-cluster-api
          name: vexxhost/magnum-cluster-api
          short_name: magnum-cluster-api
          src_dir: src/github.com/vexxhost/magnum-cluster-api
        src_dir: src/github.com/vexxhost/magnum-cluster-api
        topic: null
      buildset: afd5bbd3c0ac44e49ed89eebd2631804
      buildset_refs:
      - branch: main
        change: '702'
        change_message: "fix(deps): update rust crate kube to v3\n\nThis PR contains
          the following updates:\n\n| Package | Type | Update | Change |\n|---|---|---|---|\n|
          [kube](https://redirect.github.com/kube-rs/kube) | dependencies | major
          | `1.0.0` \u2192 `3.0.0` |\n\n---\n\n### Release Notes\n\n<details>\n<summary>kube-rs/kube
          (kube)</summary>\n\n### [`v3.1.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#310--2026-03-17)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/3.0.1...3.1.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.1.0
          -->\n\n#### What's Changed\n\nMaintenance release with fixes for schemas/validation,
          client exec blocking and proxy handling, as well as some smaller new features
          listed below. Internal changes and documentation improvements listed in
          the [milestone](https://redirect.github.com/kube-rs/kube/milestone/54?closed=1).\n\n#####
          Added\n\n- allow empty body in const context by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1927](https://redirect.github.com/kube-rs/kube/pull/1927)\n-
          Add typed printcolumn argument to derive macro by [@&#8203;cchndl](https://redirect.github.com/cchndl)
          in [#&#8203;1872](https://redirect.github.com/kube-rs/kube/pull/1872)\n-
          kube-core: add optionalOldSelf to CEL `Rule` by [@&#8203;Immortal-Beyond-Oblivion](https://redirect.github.com/Immortal-Beyond-Oblivion)
          in [#&#8203;1947](https://redirect.github.com/kube-rs/kube/pull/1947)\n-
          Re-add support for basic auth in Proxy by [@&#8203;goenning](https://redirect.github.com/goenning)
          in [#&#8203;1959](https://redirect.github.com/kube-rs/kube/pull/1959)\n\n#####
          Fixed\n\n- Fix OptionalEnum transform for complex enums by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1934](https://redirect.github.com/kube-rs/kube/pull/1934)\n\n-
          Bump tower-http dependency to 0.6.4 by [@&#8203;abustany](https://redirect.github.com/abustany)
          in [#&#8203;1939](https://redirect.github.com/kube-rs/kube/pull/1939)\n\n-
          Add minimal-versions CI check by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1940](https://redirect.github.com/kube-rs/kube/pull/1940)\n\n-
          fix: Produce valid CRDs containing flattened untagged enums by [@&#8203;NickLarsenNZ](https://redirect.github.com/NickLarsenNZ)
          in [#&#8203;1942](https://redirect.github.com/kube-rs/kube/pull/1942)\n\n-
          kube-client: Avoid blocking tokio worker during exec auth token refresh
          by [@&#8203;blakelawson](https://redirect.github.com/blakelawson) in [#&#8203;1950](https://redirect.github.com/kube-rs/kube/pull/1950)\n\n-
          [@&#8203;abustany](https://redirect.github.com/abustany) made their first
          contribution in [#&#8203;1939](https://redirect.github.com/kube-rs/kube/pull/1939)\n\n-
          [@&#8203;cchndl](https://redirect.github.com/cchndl) made their first contribution
          in [#&#8203;1872](https://redirect.github.com/kube-rs/kube/pull/1872)\n\n-
          [@&#8203;Immortal-Beyond-Oblivion](https://redirect.github.com/Immortal-Beyond-Oblivion)
          made their first contribution in [#&#8203;1947](https://redirect.github.com/kube-rs/kube/pull/1947)\n\n-
          [@&#8203;gauravgahlot](https://redirect.github.com/gauravgahlot) made their
          first contribution in [#&#8203;1949](https://redirect.github.com/kube-rs/kube/pull/1949)\n\n-
          [@&#8203;blakelawson](https://redirect.github.com/blakelawson) made their
          first contribution in [#&#8203;1950](https://redirect.github.com/kube-rs/kube/pull/1950)\n\n**Full
          Changelog**: <https://github.com/kube-rs/kube/compare/3.0.1...3.1.0>\n\n###
          [`v3.0.1`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#301--2026-01-30)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/3.0.0...3.0.1)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.1
          -->\n\n#### What's Changed\n\nBugfix release for schemas, admission, and
          docs. Minor internal improvements listed in the [milestone](https://redirect.github.com/kube-rs/kube/milestone/53?closed=1).
          Important fixes below.\n\n##### Fixed\n\n- Update API version of [`AdmissionResponse`](https://docs.rs/kube/3.0.1/kube/core/admission/struct.AdmissionResponse.html)
          created via invalid call by [@&#8203;Magicloud](https://redirect.github.com/Magicloud)
          in [#&#8203;1905](https://redirect.github.com/kube-rs/kube/pull/1905)\n-
          Fix [`OptionalEnum`](https://docs.rs/kube/3.0.1/kube/core/schema/struct.OptionalEnum.html)
          transform skipping schemas with description by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1908](https://redirect.github.com/kube-rs/kube/pull/1908)\n-
          Remove conflicting `additionalProperties: false` from schema by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1920](https://redirect.github.com/kube-rs/kube/pull/1920)\n\n###
          [`v3.0.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#300--2026-01-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/2.0.1...3.0.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.0
          -->\n\n#### New Major\n\nAs per the new release schedule to match up with
          the new Kubernetes release.\nLots of additions, fixes and improvements.
          Thanks to everyone who contributed so heavily over the holidays! Happy new
          year.\n\n#### Breaking Changes\n\n##### Kubernetes `v1_35` support via k8s-openapi
          [0.27](https://redirect.github.com/Arnavion/k8s-openapi/releases/tag/v0.27.0)\n\nPlease
          [upgrade k8s-openapi along with kube](https://kube.rs/upgrading/) to avoid
          conflicts.\n\n##### `jiff` replaces `chrono`\n\nMatching k8s-openapi's [change](https://redirect.github.com/Arnavion/k8s-openapi/commit/8c1b6fccb7258eb487ed8c829791d427a4b16216),
          kube has also swapped out `chrono`. The biggest impact of this is for interacting
          with timestamps in `metadata`, but it also updates 2 smaller public interfaces
          in [`LogParams`](https://docs.rs/kube/latest/kube/api/struct.LogParams.html#structfield.since_time),
          [`Client::with_valid_until`](https://docs.rs/kube/latest/kube/struct.Client.html#method.with_valid_until).
          \ See [controller-rs#217](https://redirect.github.com/kube-rs/controller-rs/pull/217/changes)
          for an example change.\n\nChanges: [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)
          + [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n\n####
          `ErrorResponse` has been replaced with [`Status`](https://docs.rs/kube/latest/kube/core/struct.Status.html)\n\n`ErrorResponse`
          served as a partial metav1/Status replacement which ended up hiding error
          information to users. These structs have merged, more information is available
          on errors, and a type alias with a deprecation warning is in place for [`ErrorResponse`](https://docs.rs/kube/latest/kube/core/type.ErrorResponse.html)
          which will be removed in a later version.\n\nThis creates a small breaking
          change for users matching on specific [`Error::Api`](https://docs.rs/kube/latest/kube/enum.Error.html#variant.Api)
          codes;\n\n```diff\n     .map_err(|error| match error {\n-        kube::Error::Api(kube::error::ErrorResponse
          { code: 403, .. }) => {\n-            Error::UnauthorizedToPatch(obj)\n-
          \       }\n+        kube::Error::Api(s) if s.is_forbidden() => Error::UnauthorizedToPatch(obj),\n
          \        other => Error::Other(other),\n     })?;\n```\n\n[#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)
          + [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883) + [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891).\n\n####
          Predicates now has a TTL Cache\n\nThis prevents unbounded memory for controllers,
          particularly affecting ones watching quickly rotating objects with generated
          names (e.g. pods). By default the TTL is `1h`. It can be configured via
          new [`PredicateConfig`](https://docs.rs/kube/latest/kube/runtime/struct.PredicateConfig.html)
          parameter. To use the default;\n\n```diff\n-        .predicate_filter(predicates::resource_version);\n+
          \       .predicate_filter(predicates::resource_version, Default::default());\n```\n\nChange
          in [#&#8203;1836](https://redirect.github.com/kube-rs/kube/pull/1836). This
          helped expose and fix a bug in watches with streaming\\_lists now fixed
          in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882).\n\n####
          Subresource Api\n\nSome subresource write methods were public with inconsistent
          signatures that required less ergonomic use than any other write methods.
          They took a `Vec<u8>` for the post body, now they take a `&K: Serialize`
          or the actual subresource.\nThere affect `Api::create_subresource`, `Api::replace_subresource`,
          [`Api::replace_status`](https://docs.rs/kube/latest/kube/struct.Api.html#method.replace_status),
          `Api::replace_scale`. In essence this generally means you do not have to
          wrap raw objects in `json!` and `serde_json::to_vec` for these calls and
          lean more on rust's typed objects rather than `json!` blobs which has some
          [footguns](https://redirect.github.com/kube-rs/kube/pull/1884#discussion_r2680782556)
          for subresources.\n\n```diff\n-    let o = foos.replace_status(\"qux\",
          &pp, serde_json::to_vec(&object)?).await?;\n+    let o = foos.replace_status(\"qux\",
          &pp, &object).await?;\n```\n\nSee some more shifts in examples in the implementation;
          [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n\n####
          Improvements\n\n##### Support Kubernetes 1.30 [Aggregated Discovery](https://kubernetes.io/docs/concepts/overview/kubernetes-api/#aggregated-discovery)\n\nSpeeds
          up api discovery **significantly** by using the newer api with much less
          round-tripping.\nTo opt-in change `Discovery::run()` to [`Discovery::run_aggregated()`](https://docs.rs/kube/latest/kube/struct.Discovery.html#method.run_aggregated)\n\nChanges;
          [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876) + [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)
          + [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          Rust 2024\n\nWhile this is mostly for internal ergonomics, we would like
          to highlight this also simplifies the [`Condition`](https://docs.rs/kube/latest/kube/runtime/wait/conditions/trait.Condition.html)
          implementors which had to deal with a lot of options;\n\n```diff\n    pub
          fn is_job_completed() -> impl Condition<Job> {\n        |obj: Option<&Job>|
          {\n-            if let Some(job) = &obj {\n-                if let Some(s)
          = &job.status {\n-                    if let Some(conds) = &s.conditions
          {\n-                        if let Some(pcond) = conds.iter().find(|c| c.type_
          == \"Complete\") {\n-                            return pcond.status ==
          \"True\";\n-                        }\n-                    }\n-                }\n+
          \           if let Some(job) = &obj\n+                && let Some(s) = &job.status\n+
          \               && let Some(conds) = &s.conditions\n+                &&
          let Some(pcond) = conds.iter().find(|c| c.type_ == \"Complete\")\n+            {\n+
          \               return pcond.status == \"True\";\n```\n\nChange [#&#8203;1856](https://redirect.github.com/kube-rs/kube/pull/1856)
          + [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n\n#####
          New Client [`RetryPolicy`](https://docs.rs/kube/latest/kube/client/retry/struct.RetryPolicy.html)
          opt-in\n\nAllows custom clients (for now) to enable exponential backoff'd
          retries for retryable errors by exposing a [`tower::retry::Policy`](https://tower-rs.github.io/tower/tower/retry/trait.Policy.html)
          for a [`tower::retry::Layer`](https://tower-rs.github.io/tower/tower/retry/struct.RetryLayer.html).
          See the new [custom\\_client\\_retry](https://redirect.github.com/kube-rs/kube/blob/main/examples/custom_client_retry.rs#L24-L37)
          example for details.\n\nEnabled by a [cloneable body](https://redirect.github.com/kube-rs/kube/pull/1867)
          + the new [RetryPolicy](https://redirect.github.com/kube-rs/kube/pull/1894)
          based on mirrord's solution[\\*](https://redirect.github.com/metalbear-co/mirrord/blob/a9e4c52a720fd5a833e30aee1ac650360031b7a7/mirrord/kube/src/retry.rs#L41-L135).\n\n####
          Fixes\n\n- streaming list bug fix - [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          watcher jitter bug fix - [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n-
          schema fix for IntOrString - [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          schema fix for optional enums - [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          websocket keepalives for long running attaches - [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          More\n\n- `Resize` subresource impl for `Pod` - [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          add `#[kube(attr=\"...\")` to allow custom attrs on derives - [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          example updates for admission w/axum - [#&#8203;1859](https://redirect.github.com/kube-rs/kube/pull/1859)\n\n####
          What's Changed\n\n##### Added\n\n- Add `Resize` subresource for `Pod` by
          [@&#8203;hugoponthieu](https://redirect.github.com/hugoponthieu) in [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          feat: add #\\[kube(attr=\"...\")] attribute helper to set attribute helper
          on the CR root type by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          Rust 2024 let-chains to simplify wait Conditions by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n-
          Adds a `try_clone` method for `kube_client::client::Body` when it's `Kind::Once`
          by [@&#8203;meowjesty](https://redirect.github.com/meowjesty) in [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          Implement client aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)\n-
          Implement aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876)\n-
          Permit older version of API for v2 discovery for k8s < 1.30 (down to 1.27)
          by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n-
          Add RetryPolicy for client-level request retries by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1894](https://redirect.github.com/kube-rs/kube/pull/1894)\n\n#####
          Changed\n\n- Update tokio-tungstenite requirement from 0.27.0 to 0.28.0
          by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot] in
          [#&#8203;1829](https://redirect.github.com/kube-rs/kube/pull/1829)\n- Predicates:
          add configurable cache TTL for `predicate_filter` by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1838](https://redirect.github.com/kube-rs/kube/pull/1838)\n-
          Update darling requirement from 0.21.0 to 0.23.0 by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot]
          in [#&#8203;1861](https://redirect.github.com/kube-rs/kube/pull/1861)\n-
          update to jsonpath-rust 1 by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1863](https://redirect.github.com/kube-rs/kube/pull/1863)\n-
          Replace `chrono` with `jiff` by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)\n-
          Merge ErrorResponse and Status by [@&#8203;imp](https://redirect.github.com/imp)
          in [#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)\n-
          Make subresource methods more ergonomic by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n-
          Drop k8s v1.30, crono->jiff replacement for runtime & examples by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n-
          Add a metadata field to Status by [@&#8203;ryanpbrewster](https://redirect.github.com/ryanpbrewster)
          in [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891)\n-
          Bump `k8s-openapi` for Kubernetes 1.35 by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1898](https://redirect.github.com/kube-rs/kube/pull/1898)\n\n#####
          Fixed\n\n- fix: add use<> to kubelet\\_node\\_logs for rust edition 2024
          by [@&#8203;co42](https://redirect.github.com/co42) in [#&#8203;1849](https://redirect.github.com/kube-rs/kube/pull/1849)\n-
          Transform optional enums to match pre kube 2.0.0 format by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          Distinguish between initial and resumed watch phases for streaming lists
          by [@&#8203;doxxx93](https://redirect.github.com/doxxx93) in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          Re-export deprecated type alias and improve deprecation guidance by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883)\n-
          Add nullable to optional fields with x-kubernetes-int-or-string by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1885](https://redirect.github.com/kube-rs/kube/pull/1885)\n-
          send websocket ping to keep idle connections alive by [@&#8203;inqode-lars](https://redirect.github.com/inqode-lars)
          in [#&#8203;1887](https://redirect.github.com/kube-rs/kube/pull/1887)\n-
          Fix watcher ExponentialBackoff jitter ignored by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n\n###
          [`v2.0.1`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#201--2025-09-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/2.0.0...2.0.1)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 2.0.1
          -->\n\n#### What's Changed\n\nFixes an accidental inclusion of a constraint
          added to `Api::log_stream` introduced in the 2.0.0 Rust 2024 upgrade.\n\n#####
          Fixed\n\n- Remove unused use<'\\_> from log\\_stream() by [@&#8203;pgerber](https://redirect.github.com/pgerber)
          in [#&#8203;1824](https://redirect.github.com/kube-rs/kube/pull/1824)\n\n###
          [`v2.0.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#300--2026-01-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/1.1.0...2.0.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.0
          -->\n\n#### New Major\n\nAs per the new release schedule to match up with
          the new Kubernetes release.\nLots of additions, fixes and improvements.
          Thanks to everyone who contributed so heavily over the holidays! Happy new
          year.\n\n#### Breaking Changes\n\n##### Kubernetes `v1_35` support via k8s-openapi
          [0.27](https://redirect.github.com/Arnavion/k8s-openapi/releases/tag/v0.27.0)\n\nPlease
          [upgrade k8s-openapi along with kube](https://kube.rs/upgrading/) to avoid
          conflicts.\n\n##### `jiff` replaces `chrono`\n\nMatching k8s-openapi's [change](https://redirect.github.com/Arnavion/k8s-openapi/commit/8c1b6fccb7258eb487ed8c829791d427a4b16216),
          kube has also swapped out `chrono`. The biggest impact of this is for interacting
          with timestamps in `metadata`, but it also updates 2 smaller public interfaces
          in [`LogParams`](https://docs.rs/kube/latest/kube/api/struct.LogParams.html#structfield.since_time),
          [`Client::with_valid_until`](https://docs.rs/kube/latest/kube/struct.Client.html#method.with_valid_until).
          \ See [controller-rs#217](https://redirect.github.com/kube-rs/controller-rs/pull/217/changes)
          for an example change.\n\nChanges: [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)
          + [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n\n####
          `ErrorResponse` has been replaced with [`Status`](https://docs.rs/kube/latest/kube/core/struct.Status.html)\n\n`ErrorResponse`
          served as a partial metav1/Status replacement which ended up hiding error
          information to users. These structs have merged, more information is available
          on errors, and a type alias with a deprecation warning is in place for [`ErrorResponse`](https://docs.rs/kube/latest/kube/core/type.ErrorResponse.html)
          which will be removed in a later version.\n\nThis creates a small breaking
          change for users matching on specific [`Error::Api`](https://docs.rs/kube/latest/kube/enum.Error.html#variant.Api)
          codes;\n\n```diff\n     .map_err(|error| match error {\n-        kube::Error::Api(kube::error::ErrorResponse
          { code: 403, .. }) => {\n-            Error::UnauthorizedToPatch(obj)\n-
          \       }\n+        kube::Error::Api(s) if s.is_forbidden() => Error::UnauthorizedToPatch(obj),\n
          \        other => Error::Other(other),\n     })?;\n```\n\n[#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)
          + [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883) + [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891).\n\n####
          Predicates now has a TTL Cache\n\nThis prevents unbounded memory for controllers,
          particularly affecting ones watching quickly rotating objects with generated
          names (e.g. pods). By default the TTL is `1h`. It can be configured via
          new [`PredicateConfig`](https://docs.rs/kube/latest/kube/runtime/struct.PredicateConfig.html)
          parameter. To use the default;\n\n```diff\n-        .predicate_filter(predicates::resource_version);\n+
          \       .predicate_filter(predicates::resource_version, Default::default());\n```\n\nChange
          in [#&#8203;1836](https://redirect.github.com/kube-rs/kube/pull/1836). This
          helped expose and fix a bug in watches with streaming\\_lists now fixed
          in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882).\n\n####
          Subresource Api\n\nSome subresource write methods were public with inconsistent
          signatures that required less ergonomic use than any other write methods.
          They took a `Vec<u8>` for the post body, now they take a `&K: Serialize`
          or the actual subresource.\nThere affect `Api::create_subresource`, `Api::replace_subresource`,
          [`Api::replace_status`](https://docs.rs/kube/latest/kube/struct.Api.html#method.replace_status),
          `Api::replace_scale`. In essence this generally means you do not have to
          wrap raw objects in `json!` and `serde_json::to_vec` for these calls and
          lean more on rust's typed objects rather than `json!` blobs which has some
          [footguns](https://redirect.github.com/kube-rs/kube/pull/1884#discussion_r2680782556)
          for subresources.\n\n```diff\n-    let o = foos.replace_status(\"qux\",
          &pp, serde_json::to_vec(&object)?).await?;\n+    let o = foos.replace_status(\"qux\",
          &pp, &object).await?;\n```\n\nSee some more shifts in examples in the implementation;
          [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n\n####
          Improvements\n\n##### Support Kubernetes 1.30 [Aggregated Discovery](https://kubernetes.io/docs/concepts/overview/kubernetes-api/#aggregated-discovery)\n\nSpeeds
          up api discovery **significantly** by using the newer api with much less
          round-tripping.\nTo opt-in change `Discovery::run()` to [`Discovery::run_aggregated()`](https://docs.rs/kube/latest/kube/struct.Discovery.html#method.run_aggregated)\n\nChanges;
          [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876) + [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)
          + [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          Rust 2024\n\nWhile this is mostly for internal ergonomics, we would like
          to highlight this also simplifies the [`Condition`](https://docs.rs/kube/latest/kube/runtime/wait/conditions/trait.Condition.html)
          implementors which had to deal with a lot of options;\n\n```diff\n    pub
          fn is_job_completed() -> impl Condition<Job> {\n        |obj: Option<&Job>|
          {\n-            if let Some(job) = &obj {\n-                if let Some(s)
          = &job.status {\n-                    if let Some(conds) = &s.conditions
          {\n-                        if let Some(pcond) = conds.iter().find(|c| c.type_
          == \"Complete\") {\n-                            return pcond.status ==
          \"True\";\n-                        }\n-                    }\n-                }\n+
          \           if let Some(job) = &obj\n+                && let Some(s) = &job.status\n+
          \               && let Some(conds) = &s.conditions\n+                &&
          let Some(pcond) = conds.iter().find(|c| c.type_ == \"Complete\")\n+            {\n+
          \               return pcond.status == \"True\";\n```\n\nChange [#&#8203;1856](https://redirect.github.com/kube-rs/kube/pull/1856)
          + [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n\n#####
          New Client [`RetryPolicy`](https://docs.rs/kube/latest/kube/client/retry/struct.RetryPolicy.html)
          opt-in\n\nAllows custom clients (for now) to enable exponential backoff'd
          retries for retryable errors by exposing a [`tower::retry::Policy`](https://tower-rs.github.io/tower/tower/retry/trait.Policy.html)
          for a [`tower::retry::Layer`](https://tower-rs.github.io/tower/tower/retry/struct.RetryLayer.html).
          See the new [custom\\_client\\_retry](https://redirect.github.com/kube-rs/kube/blob/main/examples/custom_client_retry.rs#L24-L37)
          example for details.\n\nEnabled by a [cloneable body](https://redirect.github.com/kube-rs/kube/pull/1867)
          + the new [RetryPolicy](https://redirect.github.com/kube-rs/kube/pull/1894)
          based on mirrord's solution[\\*](https://redirect.github.com/metalbear-co/mirrord/blob/a9e4c52a720fd5a833e30aee1ac650360031b7a7/mirrord/kube/src/retry.rs#L41-L135).\n\n####
          Fixes\n\n- streaming list bug fix - [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          watcher jitter bug fix - [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n-
          schema fix for IntOrString - [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          schema fix for optional enums - [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          websocket keepalives for long running attaches - [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          More\n\n- `Resize` subresource impl for `Pod` - [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          add `#[kube(attr=\"...\")` to allow custom attrs on derives - [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          example updates for admission w/axum - [#&#8203;1859](https://redirect.github.com/kube-rs/kube/pull/1859)\n\n####
          What's Changed\n\n##### Added\n\n- Add `Resize` subresource for `Pod` by
          [@&#8203;hugoponthieu](https://redirect.github.com/hugoponthieu) in [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          feat: add #\\[kube(attr=\"...\")] attribute helper to set attribute helper
          on the CR root type by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          Rust 2024 let-chains to simplify wait Conditions by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n-
          Adds a `try_clone` method for `kube_client::client::Body` when it's `Kind::Once`
          by [@&#8203;meowjesty](https://redirect.github.com/meowjesty) in [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          Implement client aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)\n-
          Implement aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876)\n-
          Permit older version of API for v2 discovery for k8s < 1.30 (down to 1.27)
          by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n-
          Add RetryPolicy for client-level request retries by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1894](https://redirect.github.com/kube-rs/kube/pull/1894)\n\n#####
          Changed\n\n- Update tokio-tungstenite requirement from 0.27.0 to 0.28.0
          by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot] in
          [#&#8203;1829](https://redirect.github.com/kube-rs/kube/pull/1829)\n- Predicates:
          add configurable cache TTL for `predicate_filter` by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1838](https://redirect.github.com/kube-rs/kube/pull/1838)\n-
          Update darling requirement from 0.21.0 to 0.23.0 by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot]
          in [#&#8203;1861](https://redirect.github.com/kube-rs/kube/pull/1861)\n-
          update to jsonpath-rust 1 by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1863](https://redirect.github.com/kube-rs/kube/pull/1863)\n-
          Replace `chrono` with `jiff` by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)\n-
          Merge ErrorResponse and Status by [@&#8203;imp](https://redirect.github.com/imp)
          in [#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)\n-
          Make subresource methods more ergonomic by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n-
          Drop k8s v1.30, crono->jiff replacement for runtime & examples by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n-
          Add a metadata field to Status by [@&#8203;ryanpbrewster](https://redirect.github.com/ryanpbrewster)
          in [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891)\n-
          Bump `k8s-openapi` for Kubernetes 1.35 by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1898](https://redirect.github.com/kube-rs/kube/pull/1898)\n\n#####
          Fixed\n\n- fix: add use<> to kubelet\\_node\\_logs for rust edition 2024
          by [@&#8203;co42](https://redirect.github.com/co42) in [#&#8203;1849](https://redirect.github.com/kube-rs/kube/pull/1849)\n-
          Transform optional enums to match pre kube 2.0.0 format by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          Distinguish between initial and resumed watch phases for streaming lists
          by [@&#8203;doxxx93](https://redirect.github.com/doxxx93) in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          Re-export deprecated type alias and improve deprecation guidance by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883)\n-
          Add nullable to optional fields with x-kubernetes-int-or-string by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1885](https://redirect.github.com/kube-rs/kube/pull/1885)\n-
          send websocket ping to keep idle connections alive by [@&#8203;inqode-lars](https://redirect.github.com/inqode-lars)
          in [#&#8203;1887](https://redirect.github.com/kube-rs/kube/pull/1887)\n-
          Fix watcher ExponentialBackoff jitter ignored by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n\n</details>\n\n---\n\n###
          Configuration\n\n\U0001F4C5 **Schedule**: Branch creation - At any time
          (no schedule defined), Automerge - At any time (no schedule defined).\n\n\U0001F6A6
          **Automerge**: Disabled by config. Please merge this manually once you are
          satisfied.\n\n\u267B **Rebasing**: Whenever PR is behind base branch, or
          you tick the rebase/retry checkbox.\n\n\U0001F515 **Ignore**: Close this
          PR and you won't be reminded about this update again.\n\n---\n\n - [ ] <!--
          rebase-check -->If you want to rebase/retry this PR, check this box\n\n---\n\nThis
          PR was generated by [Mend Renovate](https://mend.io/renovate/). View the
          [repository job log](https://developer.mend.io/github/vexxhost/magnum-cluster-api).\n<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0MC4xMS45IiwidXBkYXRlZEluVmVyIjoiNDMuNjYuNCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==-->\n"
        change_url: https://github.com/vexxhost/magnum-cluster-api/pull/702
        commit_id: ba7a6fc9b0c447bcf908b92d6b7b9731dc91da42
        patchset: 12fec567ed329a015d3964c475e25b8e5275f3eb
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/magnum-cluster-api
          name: vexxhost/magnum-cluster-api
          short_name: magnum-cluster-api
          src_dir: src/github.com/vexxhost/magnum-cluster-api
        src_dir: src/github.com/vexxhost/magnum-cluster-api
        topic: null
      change: '702'
      change_message: "fix(deps): update rust crate kube to v3\n\nThis PR contains
        the following updates:\n\n| Package | Type | Update | Change |\n|---|---|---|---|\n|
        [kube](https://redirect.github.com/kube-rs/kube) | dependencies | major |
        `1.0.0` \u2192 `3.0.0` |\n\n---\n\n### Release Notes\n\n<details>\n<summary>kube-rs/kube
        (kube)</summary>\n\n### [`v3.1.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#310--2026-03-17)\n\n[Compare
        Source](https://redirect.github.com/kube-rs/kube/compare/3.0.1...3.1.0)\n\n\\===================\n\n<!--
        Release notes generated using configuration in .github/release.yml at 3.1.0
        -->\n\n#### What's Changed\n\nMaintenance release with fixes for schemas/validation,
        client exec blocking and proxy handling, as well as some smaller new features
        listed below. Internal changes and documentation improvements listed in the
        [milestone](https://redirect.github.com/kube-rs/kube/milestone/54?closed=1).\n\n#####
        Added\n\n- allow empty body in const context by [@&#8203;tottoto](https://redirect.github.com/tottoto)
        in [#&#8203;1927](https://redirect.github.com/kube-rs/kube/pull/1927)\n- Add
        typed printcolumn argument to derive macro by [@&#8203;cchndl](https://redirect.github.com/cchndl)
        in [#&#8203;1872](https://redirect.github.com/kube-rs/kube/pull/1872)\n- kube-core:
        add optionalOldSelf to CEL `Rule` by [@&#8203;Immortal-Beyond-Oblivion](https://redirect.github.com/Immortal-Beyond-Oblivion)
        in [#&#8203;1947](https://redirect.github.com/kube-rs/kube/pull/1947)\n- Re-add
        support for basic auth in Proxy by [@&#8203;goenning](https://redirect.github.com/goenning)
        in [#&#8203;1959](https://redirect.github.com/kube-rs/kube/pull/1959)\n\n#####
        Fixed\n\n- Fix OptionalEnum transform for complex enums by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1934](https://redirect.github.com/kube-rs/kube/pull/1934)\n\n-
        Bump tower-http dependency to 0.6.4 by [@&#8203;abustany](https://redirect.github.com/abustany)
        in [#&#8203;1939](https://redirect.github.com/kube-rs/kube/pull/1939)\n\n-
        Add minimal-versions CI check by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1940](https://redirect.github.com/kube-rs/kube/pull/1940)\n\n-
        fix: Produce valid CRDs containing flattened untagged enums by [@&#8203;NickLarsenNZ](https://redirect.github.com/NickLarsenNZ)
        in [#&#8203;1942](https://redirect.github.com/kube-rs/kube/pull/1942)\n\n-
        kube-client: Avoid blocking tokio worker during exec auth token refresh by
        [@&#8203;blakelawson](https://redirect.github.com/blakelawson) in [#&#8203;1950](https://redirect.github.com/kube-rs/kube/pull/1950)\n\n-
        [@&#8203;abustany](https://redirect.github.com/abustany) made their first
        contribution in [#&#8203;1939](https://redirect.github.com/kube-rs/kube/pull/1939)\n\n-
        [@&#8203;cchndl](https://redirect.github.com/cchndl) made their first contribution
        in [#&#8203;1872](https://redirect.github.com/kube-rs/kube/pull/1872)\n\n-
        [@&#8203;Immortal-Beyond-Oblivion](https://redirect.github.com/Immortal-Beyond-Oblivion)
        made their first contribution in [#&#8203;1947](https://redirect.github.com/kube-rs/kube/pull/1947)\n\n-
        [@&#8203;gauravgahlot](https://redirect.github.com/gauravgahlot) made their
        first contribution in [#&#8203;1949](https://redirect.github.com/kube-rs/kube/pull/1949)\n\n-
        [@&#8203;blakelawson](https://redirect.github.com/blakelawson) made their
        first contribution in [#&#8203;1950](https://redirect.github.com/kube-rs/kube/pull/1950)\n\n**Full
        Changelog**: <https://github.com/kube-rs/kube/compare/3.0.1...3.1.0>\n\n###
        [`v3.0.1`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#301--2026-01-30)\n\n[Compare
        Source](https://redirect.github.com/kube-rs/kube/compare/3.0.0...3.0.1)\n\n\\===================\n\n<!--
        Release notes generated using configuration in .github/release.yml at 3.0.1
        -->\n\n#### What's Changed\n\nBugfix release for schemas, admission, and docs.
        Minor internal improvements listed in the [milestone](https://redirect.github.com/kube-rs/kube/milestone/53?closed=1).
        Important fixes below.\n\n##### Fixed\n\n- Update API version of [`AdmissionResponse`](https://docs.rs/kube/3.0.1/kube/core/admission/struct.AdmissionResponse.html)
        created via invalid call by [@&#8203;Magicloud](https://redirect.github.com/Magicloud)
        in [#&#8203;1905](https://redirect.github.com/kube-rs/kube/pull/1905)\n- Fix
        [`OptionalEnum`](https://docs.rs/kube/3.0.1/kube/core/schema/struct.OptionalEnum.html)
        transform skipping schemas with description by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1908](https://redirect.github.com/kube-rs/kube/pull/1908)\n- Remove
        conflicting `additionalProperties: false` from schema by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1920](https://redirect.github.com/kube-rs/kube/pull/1920)\n\n###
        [`v3.0.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#300--2026-01-12)\n\n[Compare
        Source](https://redirect.github.com/kube-rs/kube/compare/2.0.1...3.0.0)\n\n\\===================\n\n<!--
        Release notes generated using configuration in .github/release.yml at 3.0.0
        -->\n\n#### New Major\n\nAs per the new release schedule to match up with
        the new Kubernetes release.\nLots of additions, fixes and improvements. Thanks
        to everyone who contributed so heavily over the holidays! Happy new year.\n\n####
        Breaking Changes\n\n##### Kubernetes `v1_35` support via k8s-openapi [0.27](https://redirect.github.com/Arnavion/k8s-openapi/releases/tag/v0.27.0)\n\nPlease
        [upgrade k8s-openapi along with kube](https://kube.rs/upgrading/) to avoid
        conflicts.\n\n##### `jiff` replaces `chrono`\n\nMatching k8s-openapi's [change](https://redirect.github.com/Arnavion/k8s-openapi/commit/8c1b6fccb7258eb487ed8c829791d427a4b16216),
        kube has also swapped out `chrono`. The biggest impact of this is for interacting
        with timestamps in `metadata`, but it also updates 2 smaller public interfaces
        in [`LogParams`](https://docs.rs/kube/latest/kube/api/struct.LogParams.html#structfield.since_time),
        [`Client::with_valid_until`](https://docs.rs/kube/latest/kube/struct.Client.html#method.with_valid_until).
        \ See [controller-rs#217](https://redirect.github.com/kube-rs/controller-rs/pull/217/changes)
        for an example change.\n\nChanges: [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)
        + [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n\n####
        `ErrorResponse` has been replaced with [`Status`](https://docs.rs/kube/latest/kube/core/struct.Status.html)\n\n`ErrorResponse`
        served as a partial metav1/Status replacement which ended up hiding error
        information to users. These structs have merged, more information is available
        on errors, and a type alias with a deprecation warning is in place for [`ErrorResponse`](https://docs.rs/kube/latest/kube/core/type.ErrorResponse.html)
        which will be removed in a later version.\n\nThis creates a small breaking
        change for users matching on specific [`Error::Api`](https://docs.rs/kube/latest/kube/enum.Error.html#variant.Api)
        codes;\n\n```diff\n     .map_err(|error| match error {\n-        kube::Error::Api(kube::error::ErrorResponse
        { code: 403, .. }) => {\n-            Error::UnauthorizedToPatch(obj)\n-        }\n+
        \       kube::Error::Api(s) if s.is_forbidden() => Error::UnauthorizedToPatch(obj),\n
        \        other => Error::Other(other),\n     })?;\n```\n\n[#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)
        + [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883) + [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891).\n\n####
        Predicates now has a TTL Cache\n\nThis prevents unbounded memory for controllers,
        particularly affecting ones watching quickly rotating objects with generated
        names (e.g. pods). By default the TTL is `1h`. It can be configured via new
        [`PredicateConfig`](https://docs.rs/kube/latest/kube/runtime/struct.PredicateConfig.html)
        parameter. To use the default;\n\n```diff\n-        .predicate_filter(predicates::resource_version);\n+
        \       .predicate_filter(predicates::resource_version, Default::default());\n```\n\nChange
        in [#&#8203;1836](https://redirect.github.com/kube-rs/kube/pull/1836). This
        helped expose and fix a bug in watches with streaming\\_lists now fixed in
        [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882).\n\n####
        Subresource Api\n\nSome subresource write methods were public with inconsistent
        signatures that required less ergonomic use than any other write methods.
        They took a `Vec<u8>` for the post body, now they take a `&K: Serialize` or
        the actual subresource.\nThere affect `Api::create_subresource`, `Api::replace_subresource`,
        [`Api::replace_status`](https://docs.rs/kube/latest/kube/struct.Api.html#method.replace_status),
        `Api::replace_scale`. In essence this generally means you do not have to wrap
        raw objects in `json!` and `serde_json::to_vec` for these calls and lean more
        on rust's typed objects rather than `json!` blobs which has some [footguns](https://redirect.github.com/kube-rs/kube/pull/1884#discussion_r2680782556)
        for subresources.\n\n```diff\n-    let o = foos.replace_status(\"qux\", &pp,
        serde_json::to_vec(&object)?).await?;\n+    let o = foos.replace_status(\"qux\",
        &pp, &object).await?;\n```\n\nSee some more shifts in examples in the implementation;
        [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n\n####
        Improvements\n\n##### Support Kubernetes 1.30 [Aggregated Discovery](https://kubernetes.io/docs/concepts/overview/kubernetes-api/#aggregated-discovery)\n\nSpeeds
        up api discovery **significantly** by using the newer api with much less round-tripping.\nTo
        opt-in change `Discovery::run()` to [`Discovery::run_aggregated()`](https://docs.rs/kube/latest/kube/struct.Discovery.html#method.run_aggregated)\n\nChanges;
        [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876) + [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)
        + [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
        Rust 2024\n\nWhile this is mostly for internal ergonomics, we would like to
        highlight this also simplifies the [`Condition`](https://docs.rs/kube/latest/kube/runtime/wait/conditions/trait.Condition.html)
        implementors which had to deal with a lot of options;\n\n```diff\n    pub
        fn is_job_completed() -> impl Condition<Job> {\n        |obj: Option<&Job>|
        {\n-            if let Some(job) = &obj {\n-                if let Some(s)
        = &job.status {\n-                    if let Some(conds) = &s.conditions {\n-
        \                       if let Some(pcond) = conds.iter().find(|c| c.type_
        == \"Complete\") {\n-                            return pcond.status == \"True\";\n-
        \                       }\n-                    }\n-                }\n+            if
        let Some(job) = &obj\n+                && let Some(s) = &job.status\n+                &&
        let Some(conds) = &s.conditions\n+                && let Some(pcond) = conds.iter().find(|c|
        c.type_ == \"Complete\")\n+            {\n+                return pcond.status
        == \"True\";\n```\n\nChange [#&#8203;1856](https://redirect.github.com/kube-rs/kube/pull/1856)
        + [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n\n#####
        New Client [`RetryPolicy`](https://docs.rs/kube/latest/kube/client/retry/struct.RetryPolicy.html)
        opt-in\n\nAllows custom clients (for now) to enable exponential backoff'd
        retries for retryable errors by exposing a [`tower::retry::Policy`](https://tower-rs.github.io/tower/tower/retry/trait.Policy.html)
        for a [`tower::retry::Layer`](https://tower-rs.github.io/tower/tower/retry/struct.RetryLayer.html).
        See the new [custom\\_client\\_retry](https://redirect.github.com/kube-rs/kube/blob/main/examples/custom_client_retry.rs#L24-L37)
        example for details.\n\nEnabled by a [cloneable body](https://redirect.github.com/kube-rs/kube/pull/1867)
        + the new [RetryPolicy](https://redirect.github.com/kube-rs/kube/pull/1894)
        based on mirrord's solution[\\*](https://redirect.github.com/metalbear-co/mirrord/blob/a9e4c52a720fd5a833e30aee1ac650360031b7a7/mirrord/kube/src/retry.rs#L41-L135).\n\n####
        Fixes\n\n- streaming list bug fix - [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
        watcher jitter bug fix - [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n-
        schema fix for IntOrString - [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
        schema fix for optional enums - [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
        websocket keepalives for long running attaches - [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
        More\n\n- `Resize` subresource impl for `Pod` - [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
        add `#[kube(attr=\"...\")` to allow custom attrs on derives - [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
        example updates for admission w/axum - [#&#8203;1859](https://redirect.github.com/kube-rs/kube/pull/1859)\n\n####
        What's Changed\n\n##### Added\n\n- Add `Resize` subresource for `Pod` by [@&#8203;hugoponthieu](https://redirect.github.com/hugoponthieu)
        in [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n- feat:
        add #\\[kube(attr=\"...\")] attribute helper to set attribute helper on the
        CR root type by [@&#8203;ngergs](https://redirect.github.com/ngergs) in [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
        Rust 2024 let-chains to simplify wait Conditions by [@&#8203;clux](https://redirect.github.com/clux)
        in [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n- Adds
        a `try_clone` method for `kube_client::client::Body` when it's `Kind::Once`
        by [@&#8203;meowjesty](https://redirect.github.com/meowjesty) in [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
        Implement client aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)\n- Implement
        aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876)\n- Permit
        older version of API for v2 discovery for k8s < 1.30 (down to 1.27) by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
        in [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n- Add
        RetryPolicy for client-level request retries by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1894](https://redirect.github.com/kube-rs/kube/pull/1894)\n\n#####
        Changed\n\n- Update tokio-tungstenite requirement from 0.27.0 to 0.28.0 by
        [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot] in [#&#8203;1829](https://redirect.github.com/kube-rs/kube/pull/1829)\n-
        Predicates: add configurable cache TTL for `predicate_filter` by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1838](https://redirect.github.com/kube-rs/kube/pull/1838)\n- Update
        darling requirement from 0.21.0 to 0.23.0 by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot]
        in [#&#8203;1861](https://redirect.github.com/kube-rs/kube/pull/1861)\n- update
        to jsonpath-rust 1 by [@&#8203;tottoto](https://redirect.github.com/tottoto)
        in [#&#8203;1863](https://redirect.github.com/kube-rs/kube/pull/1863)\n- Replace
        `chrono` with `jiff` by [@&#8203;ngergs](https://redirect.github.com/ngergs)
        in [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)\n- Merge
        ErrorResponse and Status by [@&#8203;imp](https://redirect.github.com/imp)
        in [#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)\n- Make
        subresource methods more ergonomic by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n- Drop
        k8s v1.30, crono->jiff replacement for runtime & examples by [@&#8203;ngergs](https://redirect.github.com/ngergs)
        in [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n- Add
        a metadata field to Status by [@&#8203;ryanpbrewster](https://redirect.github.com/ryanpbrewster)
        in [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891)\n- Bump
        `k8s-openapi` for Kubernetes 1.35 by [@&#8203;clux](https://redirect.github.com/clux)
        in [#&#8203;1898](https://redirect.github.com/kube-rs/kube/pull/1898)\n\n#####
        Fixed\n\n- fix: add use<> to kubelet\\_node\\_logs for rust edition 2024 by
        [@&#8203;co42](https://redirect.github.com/co42) in [#&#8203;1849](https://redirect.github.com/kube-rs/kube/pull/1849)\n-
        Transform optional enums to match pre kube 2.0.0 format by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
        in [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n- Distinguish
        between initial and resumed watch phases for streaming lists by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n- Re-export
        deprecated type alias and improve deprecation guidance by [@&#8203;clux](https://redirect.github.com/clux)
        in [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883)\n- Add
        nullable to optional fields with x-kubernetes-int-or-string by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1885](https://redirect.github.com/kube-rs/kube/pull/1885)\n- send
        websocket ping to keep idle connections alive by [@&#8203;inqode-lars](https://redirect.github.com/inqode-lars)
        in [#&#8203;1887](https://redirect.github.com/kube-rs/kube/pull/1887)\n- Fix
        watcher ExponentialBackoff jitter ignored by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n\n###
        [`v2.0.1`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#201--2025-09-12)\n\n[Compare
        Source](https://redirect.github.com/kube-rs/kube/compare/2.0.0...2.0.1)\n\n\\===================\n\n<!--
        Release notes generated using configuration in .github/release.yml at 2.0.1
        -->\n\n#### What's Changed\n\nFixes an accidental inclusion of a constraint
        added to `Api::log_stream` introduced in the 2.0.0 Rust 2024 upgrade.\n\n#####
        Fixed\n\n- Remove unused use<'\\_> from log\\_stream() by [@&#8203;pgerber](https://redirect.github.com/pgerber)
        in [#&#8203;1824](https://redirect.github.com/kube-rs/kube/pull/1824)\n\n###
        [`v2.0.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#300--2026-01-12)\n\n[Compare
        Source](https://redirect.github.com/kube-rs/kube/compare/1.1.0...2.0.0)\n\n\\===================\n\n<!--
        Release notes generated using configuration in .github/release.yml at 3.0.0
        -->\n\n#### New Major\n\nAs per the new release schedule to match up with
        the new Kubernetes release.\nLots of additions, fixes and improvements. Thanks
        to everyone who contributed so heavily over the holidays! Happy new year.\n\n####
        Breaking Changes\n\n##### Kubernetes `v1_35` support via k8s-openapi [0.27](https://redirect.github.com/Arnavion/k8s-openapi/releases/tag/v0.27.0)\n\nPlease
        [upgrade k8s-openapi along with kube](https://kube.rs/upgrading/) to avoid
        conflicts.\n\n##### `jiff` replaces `chrono`\n\nMatching k8s-openapi's [change](https://redirect.github.com/Arnavion/k8s-openapi/commit/8c1b6fccb7258eb487ed8c829791d427a4b16216),
        kube has also swapped out `chrono`. The biggest impact of this is for interacting
        with timestamps in `metadata`, but it also updates 2 smaller public interfaces
        in [`LogParams`](https://docs.rs/kube/latest/kube/api/struct.LogParams.html#structfield.since_time),
        [`Client::with_valid_until`](https://docs.rs/kube/latest/kube/struct.Client.html#method.with_valid_until).
        \ See [controller-rs#217](https://redirect.github.com/kube-rs/controller-rs/pull/217/changes)
        for an example change.\n\nChanges: [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)
        + [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n\n####
        `ErrorResponse` has been replaced with [`Status`](https://docs.rs/kube/latest/kube/core/struct.Status.html)\n\n`ErrorResponse`
        served as a partial metav1/Status replacement which ended up hiding error
        information to users. These structs have merged, more information is available
        on errors, and a type alias with a deprecation warning is in place for [`ErrorResponse`](https://docs.rs/kube/latest/kube/core/type.ErrorResponse.html)
        which will be removed in a later version.\n\nThis creates a small breaking
        change for users matching on specific [`Error::Api`](https://docs.rs/kube/latest/kube/enum.Error.html#variant.Api)
        codes;\n\n```diff\n     .map_err(|error| match error {\n-        kube::Error::Api(kube::error::ErrorResponse
        { code: 403, .. }) => {\n-            Error::UnauthorizedToPatch(obj)\n-        }\n+
        \       kube::Error::Api(s) if s.is_forbidden() => Error::UnauthorizedToPatch(obj),\n
        \        other => Error::Other(other),\n     })?;\n```\n\n[#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)
        + [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883) + [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891).\n\n####
        Predicates now has a TTL Cache\n\nThis prevents unbounded memory for controllers,
        particularly affecting ones watching quickly rotating objects with generated
        names (e.g. pods). By default the TTL is `1h`. It can be configured via new
        [`PredicateConfig`](https://docs.rs/kube/latest/kube/runtime/struct.PredicateConfig.html)
        parameter. To use the default;\n\n```diff\n-        .predicate_filter(predicates::resource_version);\n+
        \       .predicate_filter(predicates::resource_version, Default::default());\n```\n\nChange
        in [#&#8203;1836](https://redirect.github.com/kube-rs/kube/pull/1836). This
        helped expose and fix a bug in watches with streaming\\_lists now fixed in
        [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882).\n\n####
        Subresource Api\n\nSome subresource write methods were public with inconsistent
        signatures that required less ergonomic use than any other write methods.
        They took a `Vec<u8>` for the post body, now they take a `&K: Serialize` or
        the actual subresource.\nThere affect `Api::create_subresource`, `Api::replace_subresource`,
        [`Api::replace_status`](https://docs.rs/kube/latest/kube/struct.Api.html#method.replace_status),
        `Api::replace_scale`. In essence this generally means you do not have to wrap
        raw objects in `json!` and `serde_json::to_vec` for these calls and lean more
        on rust's typed objects rather than `json!` blobs which has some [footguns](https://redirect.github.com/kube-rs/kube/pull/1884#discussion_r2680782556)
        for subresources.\n\n```diff\n-    let o = foos.replace_status(\"qux\", &pp,
        serde_json::to_vec(&object)?).await?;\n+    let o = foos.replace_status(\"qux\",
        &pp, &object).await?;\n```\n\nSee some more shifts in examples in the implementation;
        [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n\n####
        Improvements\n\n##### Support Kubernetes 1.30 [Aggregated Discovery](https://kubernetes.io/docs/concepts/overview/kubernetes-api/#aggregated-discovery)\n\nSpeeds
        up api discovery **significantly** by using the newer api with much less round-tripping.\nTo
        opt-in change `Discovery::run()` to [`Discovery::run_aggregated()`](https://docs.rs/kube/latest/kube/struct.Discovery.html#method.run_aggregated)\n\nChanges;
        [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876) + [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)
        + [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
        Rust 2024\n\nWhile this is mostly for internal ergonomics, we would like to
        highlight this also simplifies the [`Condition`](https://docs.rs/kube/latest/kube/runtime/wait/conditions/trait.Condition.html)
        implementors which had to deal with a lot of options;\n\n```diff\n    pub
        fn is_job_completed() -> impl Condition<Job> {\n        |obj: Option<&Job>|
        {\n-            if let Some(job) = &obj {\n-                if let Some(s)
        = &job.status {\n-                    if let Some(conds) = &s.conditions {\n-
        \                       if let Some(pcond) = conds.iter().find(|c| c.type_
        == \"Complete\") {\n-                            return pcond.status == \"True\";\n-
        \                       }\n-                    }\n-                }\n+            if
        let Some(job) = &obj\n+                && let Some(s) = &job.status\n+                &&
        let Some(conds) = &s.conditions\n+                && let Some(pcond) = conds.iter().find(|c|
        c.type_ == \"Complete\")\n+            {\n+                return pcond.status
        == \"True\";\n```\n\nChange [#&#8203;1856](https://redirect.github.com/kube-rs/kube/pull/1856)
        + [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n\n#####
        New Client [`RetryPolicy`](https://docs.rs/kube/latest/kube/client/retry/struct.RetryPolicy.html)
        opt-in\n\nAllows custom clients (for now) to enable exponential backoff'd
        retries for retryable errors by exposing a [`tower::retry::Policy`](https://tower-rs.github.io/tower/tower/retry/trait.Policy.html)
        for a [`tower::retry::Layer`](https://tower-rs.github.io/tower/tower/retry/struct.RetryLayer.html).
        See the new [custom\\_client\\_retry](https://redirect.github.com/kube-rs/kube/blob/main/examples/custom_client_retry.rs#L24-L37)
        example for details.\n\nEnabled by a [cloneable body](https://redirect.github.com/kube-rs/kube/pull/1867)
        + the new [RetryPolicy](https://redirect.github.com/kube-rs/kube/pull/1894)
        based on mirrord's solution[\\*](https://redirect.github.com/metalbear-co/mirrord/blob/a9e4c52a720fd5a833e30aee1ac650360031b7a7/mirrord/kube/src/retry.rs#L41-L135).\n\n####
        Fixes\n\n- streaming list bug fix - [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
        watcher jitter bug fix - [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n-
        schema fix for IntOrString - [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
        schema fix for optional enums - [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
        websocket keepalives for long running attaches - [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
        More\n\n- `Resize` subresource impl for `Pod` - [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
        add `#[kube(attr=\"...\")` to allow custom attrs on derives - [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
        example updates for admission w/axum - [#&#8203;1859](https://redirect.github.com/kube-rs/kube/pull/1859)\n\n####
        What's Changed\n\n##### Added\n\n- Add `Resize` subresource for `Pod` by [@&#8203;hugoponthieu](https://redirect.github.com/hugoponthieu)
        in [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n- feat:
        add #\\[kube(attr=\"...\")] attribute helper to set attribute helper on the
        CR root type by [@&#8203;ngergs](https://redirect.github.com/ngergs) in [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
        Rust 2024 let-chains to simplify wait Conditions by [@&#8203;clux](https://redirect.github.com/clux)
        in [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n- Adds
        a `try_clone` method for `kube_client::client::Body` when it's `Kind::Once`
        by [@&#8203;meowjesty](https://redirect.github.com/meowjesty) in [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
        Implement client aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)\n- Implement
        aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876)\n- Permit
        older version of API for v2 discovery for k8s < 1.30 (down to 1.27) by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
        in [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n- Add
        RetryPolicy for client-level request retries by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1894](https://redirect.github.com/kube-rs/kube/pull/1894)\n\n#####
        Changed\n\n- Update tokio-tungstenite requirement from 0.27.0 to 0.28.0 by
        [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot] in [#&#8203;1829](https://redirect.github.com/kube-rs/kube/pull/1829)\n-
        Predicates: add configurable cache TTL for `predicate_filter` by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1838](https://redirect.github.com/kube-rs/kube/pull/1838)\n- Update
        darling requirement from 0.21.0 to 0.23.0 by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot]
        in [#&#8203;1861](https://redirect.github.com/kube-rs/kube/pull/1861)\n- update
        to jsonpath-rust 1 by [@&#8203;tottoto](https://redirect.github.com/tottoto)
        in [#&#8203;1863](https://redirect.github.com/kube-rs/kube/pull/1863)\n- Replace
        `chrono` with `jiff` by [@&#8203;ngergs](https://redirect.github.com/ngergs)
        in [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)\n- Merge
        ErrorResponse and Status by [@&#8203;imp](https://redirect.github.com/imp)
        in [#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)\n- Make
        subresource methods more ergonomic by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n- Drop
        k8s v1.30, crono->jiff replacement for runtime & examples by [@&#8203;ngergs](https://redirect.github.com/ngergs)
        in [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n- Add
        a metadata field to Status by [@&#8203;ryanpbrewster](https://redirect.github.com/ryanpbrewster)
        in [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891)\n- Bump
        `k8s-openapi` for Kubernetes 1.35 by [@&#8203;clux](https://redirect.github.com/clux)
        in [#&#8203;1898](https://redirect.github.com/kube-rs/kube/pull/1898)\n\n#####
        Fixed\n\n- fix: add use<> to kubelet\\_node\\_logs for rust edition 2024 by
        [@&#8203;co42](https://redirect.github.com/co42) in [#&#8203;1849](https://redirect.github.com/kube-rs/kube/pull/1849)\n-
        Transform optional enums to match pre kube 2.0.0 format by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
        in [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n- Distinguish
        between initial and resumed watch phases for streaming lists by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n- Re-export
        deprecated type alias and improve deprecation guidance by [@&#8203;clux](https://redirect.github.com/clux)
        in [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883)\n- Add
        nullable to optional fields with x-kubernetes-int-or-string by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1885](https://redirect.github.com/kube-rs/kube/pull/1885)\n- send
        websocket ping to keep idle connections alive by [@&#8203;inqode-lars](https://redirect.github.com/inqode-lars)
        in [#&#8203;1887](https://redirect.github.com/kube-rs/kube/pull/1887)\n- Fix
        watcher ExponentialBackoff jitter ignored by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
        in [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n\n</details>\n\n---\n\n###
        Configuration\n\n\U0001F4C5 **Schedule**: Branch creation - At any time (no
        schedule defined), Automerge - At any time (no schedule defined).\n\n\U0001F6A6
        **Automerge**: Disabled by config. Please merge this manually once you are
        satisfied.\n\n\u267B **Rebasing**: Whenever PR is behind base branch, or you
        tick the rebase/retry checkbox.\n\n\U0001F515 **Ignore**: Close this PR and
        you won't be reminded about this update again.\n\n---\n\n - [ ] <!-- rebase-check
        -->If you want to rebase/retry this PR, check this box\n\n---\n\nThis PR was
        generated by [Mend Renovate](https://mend.io/renovate/). View the [repository
        job log](https://developer.mend.io/github/vexxhost/magnum-cluster-api).\n<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0MC4xMS45IiwidXBkYXRlZEluVmVyIjoiNDMuNjYuNCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==-->\n"
      change_url: https://github.com/vexxhost/magnum-cluster-api/pull/702
      child_jobs: []
      commit_id: ba7a6fc9b0c447bcf908b92d6b7b9731dc91da42
      event_id: 26230460-28a5-11f1-9f2e-34e675290056
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/a8a2f990a80b4c9085ad3ab798003a72/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/a8a2f990a80b4c9085ad3ab798003a72/work/logs
        result_data_file: /var/lib/zuul/builds/a8a2f990a80b4c9085ad3ab798003a72/work/results.json
        src_root: /var/lib/zuul/builds/a8a2f990a80b4c9085ad3ab798003a72/work/src
        work_root: /var/lib/zuul/builds/a8a2f990a80b4c9085ad3ab798003a72/work
      include_vars: []
      items:
      - branch: main
        change: '702'
        change_message: "fix(deps): update rust crate kube to v3\n\nThis PR contains
          the following updates:\n\n| Package | Type | Update | Change |\n|---|---|---|---|\n|
          [kube](https://redirect.github.com/kube-rs/kube) | dependencies | major
          | `1.0.0` \u2192 `3.0.0` |\n\n---\n\n### Release Notes\n\n<details>\n<summary>kube-rs/kube
          (kube)</summary>\n\n### [`v3.1.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#310--2026-03-17)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/3.0.1...3.1.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.1.0
          -->\n\n#### What's Changed\n\nMaintenance release with fixes for schemas/validation,
          client exec blocking and proxy handling, as well as some smaller new features
          listed below. Internal changes and documentation improvements listed in
          the [milestone](https://redirect.github.com/kube-rs/kube/milestone/54?closed=1).\n\n#####
          Added\n\n- allow empty body in const context by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1927](https://redirect.github.com/kube-rs/kube/pull/1927)\n-
          Add typed printcolumn argument to derive macro by [@&#8203;cchndl](https://redirect.github.com/cchndl)
          in [#&#8203;1872](https://redirect.github.com/kube-rs/kube/pull/1872)\n-
          kube-core: add optionalOldSelf to CEL `Rule` by [@&#8203;Immortal-Beyond-Oblivion](https://redirect.github.com/Immortal-Beyond-Oblivion)
          in [#&#8203;1947](https://redirect.github.com/kube-rs/kube/pull/1947)\n-
          Re-add support for basic auth in Proxy by [@&#8203;goenning](https://redirect.github.com/goenning)
          in [#&#8203;1959](https://redirect.github.com/kube-rs/kube/pull/1959)\n\n#####
          Fixed\n\n- Fix OptionalEnum transform for complex enums by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1934](https://redirect.github.com/kube-rs/kube/pull/1934)\n\n-
          Bump tower-http dependency to 0.6.4 by [@&#8203;abustany](https://redirect.github.com/abustany)
          in [#&#8203;1939](https://redirect.github.com/kube-rs/kube/pull/1939)\n\n-
          Add minimal-versions CI check by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1940](https://redirect.github.com/kube-rs/kube/pull/1940)\n\n-
          fix: Produce valid CRDs containing flattened untagged enums by [@&#8203;NickLarsenNZ](https://redirect.github.com/NickLarsenNZ)
          in [#&#8203;1942](https://redirect.github.com/kube-rs/kube/pull/1942)\n\n-
          kube-client: Avoid blocking tokio worker during exec auth token refresh
          by [@&#8203;blakelawson](https://redirect.github.com/blakelawson) in [#&#8203;1950](https://redirect.github.com/kube-rs/kube/pull/1950)\n\n-
          [@&#8203;abustany](https://redirect.github.com/abustany) made their first
          contribution in [#&#8203;1939](https://redirect.github.com/kube-rs/kube/pull/1939)\n\n-
          [@&#8203;cchndl](https://redirect.github.com/cchndl) made their first contribution
          in [#&#8203;1872](https://redirect.github.com/kube-rs/kube/pull/1872)\n\n-
          [@&#8203;Immortal-Beyond-Oblivion](https://redirect.github.com/Immortal-Beyond-Oblivion)
          made their first contribution in [#&#8203;1947](https://redirect.github.com/kube-rs/kube/pull/1947)\n\n-
          [@&#8203;gauravgahlot](https://redirect.github.com/gauravgahlot) made their
          first contribution in [#&#8203;1949](https://redirect.github.com/kube-rs/kube/pull/1949)\n\n-
          [@&#8203;blakelawson](https://redirect.github.com/blakelawson) made their
          first contribution in [#&#8203;1950](https://redirect.github.com/kube-rs/kube/pull/1950)\n\n**Full
          Changelog**: <https://github.com/kube-rs/kube/compare/3.0.1...3.1.0>\n\n###
          [`v3.0.1`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#301--2026-01-30)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/3.0.0...3.0.1)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.1
          -->\n\n#### What's Changed\n\nBugfix release for schemas, admission, and
          docs. Minor internal improvements listed in the [milestone](https://redirect.github.com/kube-rs/kube/milestone/53?closed=1).
          Important fixes below.\n\n##### Fixed\n\n- Update API version of [`AdmissionResponse`](https://docs.rs/kube/3.0.1/kube/core/admission/struct.AdmissionResponse.html)
          created via invalid call by [@&#8203;Magicloud](https://redirect.github.com/Magicloud)
          in [#&#8203;1905](https://redirect.github.com/kube-rs/kube/pull/1905)\n-
          Fix [`OptionalEnum`](https://docs.rs/kube/3.0.1/kube/core/schema/struct.OptionalEnum.html)
          transform skipping schemas with description by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1908](https://redirect.github.com/kube-rs/kube/pull/1908)\n-
          Remove conflicting `additionalProperties: false` from schema by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1920](https://redirect.github.com/kube-rs/kube/pull/1920)\n\n###
          [`v3.0.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#300--2026-01-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/2.0.1...3.0.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.0
          -->\n\n#### New Major\n\nAs per the new release schedule to match up with
          the new Kubernetes release.\nLots of additions, fixes and improvements.
          Thanks to everyone who contributed so heavily over the holidays! Happy new
          year.\n\n#### Breaking Changes\n\n##### Kubernetes `v1_35` support via k8s-openapi
          [0.27](https://redirect.github.com/Arnavion/k8s-openapi/releases/tag/v0.27.0)\n\nPlease
          [upgrade k8s-openapi along with kube](https://kube.rs/upgrading/) to avoid
          conflicts.\n\n##### `jiff` replaces `chrono`\n\nMatching k8s-openapi's [change](https://redirect.github.com/Arnavion/k8s-openapi/commit/8c1b6fccb7258eb487ed8c829791d427a4b16216),
          kube has also swapped out `chrono`. The biggest impact of this is for interacting
          with timestamps in `metadata`, but it also updates 2 smaller public interfaces
          in [`LogParams`](https://docs.rs/kube/latest/kube/api/struct.LogParams.html#structfield.since_time),
          [`Client::with_valid_until`](https://docs.rs/kube/latest/kube/struct.Client.html#method.with_valid_until).
          \ See [controller-rs#217](https://redirect.github.com/kube-rs/controller-rs/pull/217/changes)
          for an example change.\n\nChanges: [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)
          + [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n\n####
          `ErrorResponse` has been replaced with [`Status`](https://docs.rs/kube/latest/kube/core/struct.Status.html)\n\n`ErrorResponse`
          served as a partial metav1/Status replacement which ended up hiding error
          information to users. These structs have merged, more information is available
          on errors, and a type alias with a deprecation warning is in place for [`ErrorResponse`](https://docs.rs/kube/latest/kube/core/type.ErrorResponse.html)
          which will be removed in a later version.\n\nThis creates a small breaking
          change for users matching on specific [`Error::Api`](https://docs.rs/kube/latest/kube/enum.Error.html#variant.Api)
          codes;\n\n```diff\n     .map_err(|error| match error {\n-        kube::Error::Api(kube::error::ErrorResponse
          { code: 403, .. }) => {\n-            Error::UnauthorizedToPatch(obj)\n-
          \       }\n+        kube::Error::Api(s) if s.is_forbidden() => Error::UnauthorizedToPatch(obj),\n
          \        other => Error::Other(other),\n     })?;\n```\n\n[#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)
          + [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883) + [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891).\n\n####
          Predicates now has a TTL Cache\n\nThis prevents unbounded memory for controllers,
          particularly affecting ones watching quickly rotating objects with generated
          names (e.g. pods). By default the TTL is `1h`. It can be configured via
          new [`PredicateConfig`](https://docs.rs/kube/latest/kube/runtime/struct.PredicateConfig.html)
          parameter. To use the default;\n\n```diff\n-        .predicate_filter(predicates::resource_version);\n+
          \       .predicate_filter(predicates::resource_version, Default::default());\n```\n\nChange
          in [#&#8203;1836](https://redirect.github.com/kube-rs/kube/pull/1836). This
          helped expose and fix a bug in watches with streaming\\_lists now fixed
          in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882).\n\n####
          Subresource Api\n\nSome subresource write methods were public with inconsistent
          signatures that required less ergonomic use than any other write methods.
          They took a `Vec<u8>` for the post body, now they take a `&K: Serialize`
          or the actual subresource.\nThere affect `Api::create_subresource`, `Api::replace_subresource`,
          [`Api::replace_status`](https://docs.rs/kube/latest/kube/struct.Api.html#method.replace_status),
          `Api::replace_scale`. In essence this generally means you do not have to
          wrap raw objects in `json!` and `serde_json::to_vec` for these calls and
          lean more on rust's typed objects rather than `json!` blobs which has some
          [footguns](https://redirect.github.com/kube-rs/kube/pull/1884#discussion_r2680782556)
          for subresources.\n\n```diff\n-    let o = foos.replace_status(\"qux\",
          &pp, serde_json::to_vec(&object)?).await?;\n+    let o = foos.replace_status(\"qux\",
          &pp, &object).await?;\n```\n\nSee some more shifts in examples in the implementation;
          [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n\n####
          Improvements\n\n##### Support Kubernetes 1.30 [Aggregated Discovery](https://kubernetes.io/docs/concepts/overview/kubernetes-api/#aggregated-discovery)\n\nSpeeds
          up api discovery **significantly** by using the newer api with much less
          round-tripping.\nTo opt-in change `Discovery::run()` to [`Discovery::run_aggregated()`](https://docs.rs/kube/latest/kube/struct.Discovery.html#method.run_aggregated)\n\nChanges;
          [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876) + [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)
          + [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          Rust 2024\n\nWhile this is mostly for internal ergonomics, we would like
          to highlight this also simplifies the [`Condition`](https://docs.rs/kube/latest/kube/runtime/wait/conditions/trait.Condition.html)
          implementors which had to deal with a lot of options;\n\n```diff\n    pub
          fn is_job_completed() -> impl Condition<Job> {\n        |obj: Option<&Job>|
          {\n-            if let Some(job) = &obj {\n-                if let Some(s)
          = &job.status {\n-                    if let Some(conds) = &s.conditions
          {\n-                        if let Some(pcond) = conds.iter().find(|c| c.type_
          == \"Complete\") {\n-                            return pcond.status ==
          \"True\";\n-                        }\n-                    }\n-                }\n+
          \           if let Some(job) = &obj\n+                && let Some(s) = &job.status\n+
          \               && let Some(conds) = &s.conditions\n+                &&
          let Some(pcond) = conds.iter().find(|c| c.type_ == \"Complete\")\n+            {\n+
          \               return pcond.status == \"True\";\n```\n\nChange [#&#8203;1856](https://redirect.github.com/kube-rs/kube/pull/1856)
          + [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n\n#####
          New Client [`RetryPolicy`](https://docs.rs/kube/latest/kube/client/retry/struct.RetryPolicy.html)
          opt-in\n\nAllows custom clients (for now) to enable exponential backoff'd
          retries for retryable errors by exposing a [`tower::retry::Policy`](https://tower-rs.github.io/tower/tower/retry/trait.Policy.html)
          for a [`tower::retry::Layer`](https://tower-rs.github.io/tower/tower/retry/struct.RetryLayer.html).
          See the new [custom\\_client\\_retry](https://redirect.github.com/kube-rs/kube/blob/main/examples/custom_client_retry.rs#L24-L37)
          example for details.\n\nEnabled by a [cloneable body](https://redirect.github.com/kube-rs/kube/pull/1867)
          + the new [RetryPolicy](https://redirect.github.com/kube-rs/kube/pull/1894)
          based on mirrord's solution[\\*](https://redirect.github.com/metalbear-co/mirrord/blob/a9e4c52a720fd5a833e30aee1ac650360031b7a7/mirrord/kube/src/retry.rs#L41-L135).\n\n####
          Fixes\n\n- streaming list bug fix - [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          watcher jitter bug fix - [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n-
          schema fix for IntOrString - [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          schema fix for optional enums - [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          websocket keepalives for long running attaches - [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          More\n\n- `Resize` subresource impl for `Pod` - [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          add `#[kube(attr=\"...\")` to allow custom attrs on derives - [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          example updates for admission w/axum - [#&#8203;1859](https://redirect.github.com/kube-rs/kube/pull/1859)\n\n####
          What's Changed\n\n##### Added\n\n- Add `Resize` subresource for `Pod` by
          [@&#8203;hugoponthieu](https://redirect.github.com/hugoponthieu) in [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          feat: add #\\[kube(attr=\"...\")] attribute helper to set attribute helper
          on the CR root type by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          Rust 2024 let-chains to simplify wait Conditions by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n-
          Adds a `try_clone` method for `kube_client::client::Body` when it's `Kind::Once`
          by [@&#8203;meowjesty](https://redirect.github.com/meowjesty) in [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          Implement client aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)\n-
          Implement aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876)\n-
          Permit older version of API for v2 discovery for k8s < 1.30 (down to 1.27)
          by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n-
          Add RetryPolicy for client-level request retries by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1894](https://redirect.github.com/kube-rs/kube/pull/1894)\n\n#####
          Changed\n\n- Update tokio-tungstenite requirement from 0.27.0 to 0.28.0
          by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot] in
          [#&#8203;1829](https://redirect.github.com/kube-rs/kube/pull/1829)\n- Predicates:
          add configurable cache TTL for `predicate_filter` by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1838](https://redirect.github.com/kube-rs/kube/pull/1838)\n-
          Update darling requirement from 0.21.0 to 0.23.0 by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot]
          in [#&#8203;1861](https://redirect.github.com/kube-rs/kube/pull/1861)\n-
          update to jsonpath-rust 1 by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1863](https://redirect.github.com/kube-rs/kube/pull/1863)\n-
          Replace `chrono` with `jiff` by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)\n-
          Merge ErrorResponse and Status by [@&#8203;imp](https://redirect.github.com/imp)
          in [#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)\n-
          Make subresource methods more ergonomic by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n-
          Drop k8s v1.30, crono->jiff replacement for runtime & examples by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n-
          Add a metadata field to Status by [@&#8203;ryanpbrewster](https://redirect.github.com/ryanpbrewster)
          in [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891)\n-
          Bump `k8s-openapi` for Kubernetes 1.35 by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1898](https://redirect.github.com/kube-rs/kube/pull/1898)\n\n#####
          Fixed\n\n- fix: add use<> to kubelet\\_node\\_logs for rust edition 2024
          by [@&#8203;co42](https://redirect.github.com/co42) in [#&#8203;1849](https://redirect.github.com/kube-rs/kube/pull/1849)\n-
          Transform optional enums to match pre kube 2.0.0 format by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          Distinguish between initial and resumed watch phases for streaming lists
          by [@&#8203;doxxx93](https://redirect.github.com/doxxx93) in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          Re-export deprecated type alias and improve deprecation guidance by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883)\n-
          Add nullable to optional fields with x-kubernetes-int-or-string by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1885](https://redirect.github.com/kube-rs/kube/pull/1885)\n-
          send websocket ping to keep idle connections alive by [@&#8203;inqode-lars](https://redirect.github.com/inqode-lars)
          in [#&#8203;1887](https://redirect.github.com/kube-rs/kube/pull/1887)\n-
          Fix watcher ExponentialBackoff jitter ignored by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n\n###
          [`v2.0.1`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#201--2025-09-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/2.0.0...2.0.1)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 2.0.1
          -->\n\n#### What's Changed\n\nFixes an accidental inclusion of a constraint
          added to `Api::log_stream` introduced in the 2.0.0 Rust 2024 upgrade.\n\n#####
          Fixed\n\n- Remove unused use<'\\_> from log\\_stream() by [@&#8203;pgerber](https://redirect.github.com/pgerber)
          in [#&#8203;1824](https://redirect.github.com/kube-rs/kube/pull/1824)\n\n###
          [`v2.0.0`](https://redirect.github.com/kube-rs/kube/blob/HEAD/CHANGELOG.md#300--2026-01-12)\n\n[Compare
          Source](https://redirect.github.com/kube-rs/kube/compare/1.1.0...2.0.0)\n\n\\===================\n\n<!--
          Release notes generated using configuration in .github/release.yml at 3.0.0
          -->\n\n#### New Major\n\nAs per the new release schedule to match up with
          the new Kubernetes release.\nLots of additions, fixes and improvements.
          Thanks to everyone who contributed so heavily over the holidays! Happy new
          year.\n\n#### Breaking Changes\n\n##### Kubernetes `v1_35` support via k8s-openapi
          [0.27](https://redirect.github.com/Arnavion/k8s-openapi/releases/tag/v0.27.0)\n\nPlease
          [upgrade k8s-openapi along with kube](https://kube.rs/upgrading/) to avoid
          conflicts.\n\n##### `jiff` replaces `chrono`\n\nMatching k8s-openapi's [change](https://redirect.github.com/Arnavion/k8s-openapi/commit/8c1b6fccb7258eb487ed8c829791d427a4b16216),
          kube has also swapped out `chrono`. The biggest impact of this is for interacting
          with timestamps in `metadata`, but it also updates 2 smaller public interfaces
          in [`LogParams`](https://docs.rs/kube/latest/kube/api/struct.LogParams.html#structfield.since_time),
          [`Client::with_valid_until`](https://docs.rs/kube/latest/kube/struct.Client.html#method.with_valid_until).
          \ See [controller-rs#217](https://redirect.github.com/kube-rs/controller-rs/pull/217/changes)
          for an example change.\n\nChanges: [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)
          + [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n\n####
          `ErrorResponse` has been replaced with [`Status`](https://docs.rs/kube/latest/kube/core/struct.Status.html)\n\n`ErrorResponse`
          served as a partial metav1/Status replacement which ended up hiding error
          information to users. These structs have merged, more information is available
          on errors, and a type alias with a deprecation warning is in place for [`ErrorResponse`](https://docs.rs/kube/latest/kube/core/type.ErrorResponse.html)
          which will be removed in a later version.\n\nThis creates a small breaking
          change for users matching on specific [`Error::Api`](https://docs.rs/kube/latest/kube/enum.Error.html#variant.Api)
          codes;\n\n```diff\n     .map_err(|error| match error {\n-        kube::Error::Api(kube::error::ErrorResponse
          { code: 403, .. }) => {\n-            Error::UnauthorizedToPatch(obj)\n-
          \       }\n+        kube::Error::Api(s) if s.is_forbidden() => Error::UnauthorizedToPatch(obj),\n
          \        other => Error::Other(other),\n     })?;\n```\n\n[#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)
          + [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883) + [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891).\n\n####
          Predicates now has a TTL Cache\n\nThis prevents unbounded memory for controllers,
          particularly affecting ones watching quickly rotating objects with generated
          names (e.g. pods). By default the TTL is `1h`. It can be configured via
          new [`PredicateConfig`](https://docs.rs/kube/latest/kube/runtime/struct.PredicateConfig.html)
          parameter. To use the default;\n\n```diff\n-        .predicate_filter(predicates::resource_version);\n+
          \       .predicate_filter(predicates::resource_version, Default::default());\n```\n\nChange
          in [#&#8203;1836](https://redirect.github.com/kube-rs/kube/pull/1836). This
          helped expose and fix a bug in watches with streaming\\_lists now fixed
          in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882).\n\n####
          Subresource Api\n\nSome subresource write methods were public with inconsistent
          signatures that required less ergonomic use than any other write methods.
          They took a `Vec<u8>` for the post body, now they take a `&K: Serialize`
          or the actual subresource.\nThere affect `Api::create_subresource`, `Api::replace_subresource`,
          [`Api::replace_status`](https://docs.rs/kube/latest/kube/struct.Api.html#method.replace_status),
          `Api::replace_scale`. In essence this generally means you do not have to
          wrap raw objects in `json!` and `serde_json::to_vec` for these calls and
          lean more on rust's typed objects rather than `json!` blobs which has some
          [footguns](https://redirect.github.com/kube-rs/kube/pull/1884#discussion_r2680782556)
          for subresources.\n\n```diff\n-    let o = foos.replace_status(\"qux\",
          &pp, serde_json::to_vec(&object)?).await?;\n+    let o = foos.replace_status(\"qux\",
          &pp, &object).await?;\n```\n\nSee some more shifts in examples in the implementation;
          [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n\n####
          Improvements\n\n##### Support Kubernetes 1.30 [Aggregated Discovery](https://kubernetes.io/docs/concepts/overview/kubernetes-api/#aggregated-discovery)\n\nSpeeds
          up api discovery **significantly** by using the newer api with much less
          round-tripping.\nTo opt-in change `Discovery::run()` to [`Discovery::run_aggregated()`](https://docs.rs/kube/latest/kube/struct.Discovery.html#method.run_aggregated)\n\nChanges;
          [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876) + [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)
          + [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          Rust 2024\n\nWhile this is mostly for internal ergonomics, we would like
          to highlight this also simplifies the [`Condition`](https://docs.rs/kube/latest/kube/runtime/wait/conditions/trait.Condition.html)
          implementors which had to deal with a lot of options;\n\n```diff\n    pub
          fn is_job_completed() -> impl Condition<Job> {\n        |obj: Option<&Job>|
          {\n-            if let Some(job) = &obj {\n-                if let Some(s)
          = &job.status {\n-                    if let Some(conds) = &s.conditions
          {\n-                        if let Some(pcond) = conds.iter().find(|c| c.type_
          == \"Complete\") {\n-                            return pcond.status ==
          \"True\";\n-                        }\n-                    }\n-                }\n+
          \           if let Some(job) = &obj\n+                && let Some(s) = &job.status\n+
          \               && let Some(conds) = &s.conditions\n+                &&
          let Some(pcond) = conds.iter().find(|c| c.type_ == \"Complete\")\n+            {\n+
          \               return pcond.status == \"True\";\n```\n\nChange [#&#8203;1856](https://redirect.github.com/kube-rs/kube/pull/1856)
          + [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n\n#####
          New Client [`RetryPolicy`](https://docs.rs/kube/latest/kube/client/retry/struct.RetryPolicy.html)
          opt-in\n\nAllows custom clients (for now) to enable exponential backoff'd
          retries for retryable errors by exposing a [`tower::retry::Policy`](https://tower-rs.github.io/tower/tower/retry/trait.Policy.html)
          for a [`tower::retry::Layer`](https://tower-rs.github.io/tower/tower/retry/struct.RetryLayer.html).
          See the new [custom\\_client\\_retry](https://redirect.github.com/kube-rs/kube/blob/main/examples/custom_client_retry.rs#L24-L37)
          example for details.\n\nEnabled by a [cloneable body](https://redirect.github.com/kube-rs/kube/pull/1867)
          + the new [RetryPolicy](https://redirect.github.com/kube-rs/kube/pull/1894)
          based on mirrord's solution[\\*](https://redirect.github.com/metalbear-co/mirrord/blob/a9e4c52a720fd5a833e30aee1ac650360031b7a7/mirrord/kube/src/retry.rs#L41-L135).\n\n####
          Fixes\n\n- streaming list bug fix - [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          watcher jitter bug fix - [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n-
          schema fix for IntOrString - [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          schema fix for optional enums - [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          websocket keepalives for long running attaches - [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n\n#####
          More\n\n- `Resize` subresource impl for `Pod` - [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          add `#[kube(attr=\"...\")` to allow custom attrs on derives - [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          example updates for admission w/axum - [#&#8203;1859](https://redirect.github.com/kube-rs/kube/pull/1859)\n\n####
          What's Changed\n\n##### Added\n\n- Add `Resize` subresource for `Pod` by
          [@&#8203;hugoponthieu](https://redirect.github.com/hugoponthieu) in [#&#8203;1851](https://redirect.github.com/kube-rs/kube/pull/1851)\n-
          feat: add #\\[kube(attr=\"...\")] attribute helper to set attribute helper
          on the CR root type by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1850](https://redirect.github.com/kube-rs/kube/pull/1850)\n-
          Rust 2024 let-chains to simplify wait Conditions by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1792](https://redirect.github.com/kube-rs/kube/pull/1792)\n-
          Adds a `try_clone` method for `kube_client::client::Body` when it's `Kind::Once`
          by [@&#8203;meowjesty](https://redirect.github.com/meowjesty) in [#&#8203;1867](https://redirect.github.com/kube-rs/kube/pull/1867)\n-
          Implement client aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1873](https://redirect.github.com/kube-rs/kube/pull/1873)\n-
          Implement aggregated discovery API methods by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1876](https://redirect.github.com/kube-rs/kube/pull/1876)\n-
          Permit older version of API for v2 discovery for k8s < 1.30 (down to 1.27)
          by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1889](https://redirect.github.com/kube-rs/kube/pull/1889)\n-
          Add RetryPolicy for client-level request retries by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1894](https://redirect.github.com/kube-rs/kube/pull/1894)\n\n#####
          Changed\n\n- Update tokio-tungstenite requirement from 0.27.0 to 0.28.0
          by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot] in
          [#&#8203;1829](https://redirect.github.com/kube-rs/kube/pull/1829)\n- Predicates:
          add configurable cache TTL for `predicate_filter` by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1838](https://redirect.github.com/kube-rs/kube/pull/1838)\n-
          Update darling requirement from 0.21.0 to 0.23.0 by [@&#8203;dependabot](https://redirect.github.com/dependabot)\\[bot]
          in [#&#8203;1861](https://redirect.github.com/kube-rs/kube/pull/1861)\n-
          update to jsonpath-rust 1 by [@&#8203;tottoto](https://redirect.github.com/tottoto)
          in [#&#8203;1863](https://redirect.github.com/kube-rs/kube/pull/1863)\n-
          Replace `chrono` with `jiff` by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1868](https://redirect.github.com/kube-rs/kube/pull/1868)\n-
          Merge ErrorResponse and Status by [@&#8203;imp](https://redirect.github.com/imp)
          in [#&#8203;1875](https://redirect.github.com/kube-rs/kube/pull/1875)\n-
          Make subresource methods more ergonomic by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1884](https://redirect.github.com/kube-rs/kube/pull/1884)\n-
          Drop k8s v1.30, crono->jiff replacement for runtime & examples by [@&#8203;ngergs](https://redirect.github.com/ngergs)
          in [#&#8203;1870](https://redirect.github.com/kube-rs/kube/pull/1870)\n-
          Add a metadata field to Status by [@&#8203;ryanpbrewster](https://redirect.github.com/ryanpbrewster)
          in [#&#8203;1891](https://redirect.github.com/kube-rs/kube/pull/1891)\n-
          Bump `k8s-openapi` for Kubernetes 1.35 by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1898](https://redirect.github.com/kube-rs/kube/pull/1898)\n\n#####
          Fixed\n\n- fix: add use<> to kubelet\\_node\\_logs for rust edition 2024
          by [@&#8203;co42](https://redirect.github.com/co42) in [#&#8203;1849](https://redirect.github.com/kube-rs/kube/pull/1849)\n-
          Transform optional enums to match pre kube 2.0.0 format by [@&#8203;Danil-Grigorev](https://redirect.github.com/Danil-Grigorev)
          in [#&#8203;1853](https://redirect.github.com/kube-rs/kube/pull/1853)\n-
          Distinguish between initial and resumed watch phases for streaming lists
          by [@&#8203;doxxx93](https://redirect.github.com/doxxx93) in [#&#8203;1882](https://redirect.github.com/kube-rs/kube/pull/1882)\n-
          Re-export deprecated type alias and improve deprecation guidance by [@&#8203;clux](https://redirect.github.com/clux)
          in [#&#8203;1883](https://redirect.github.com/kube-rs/kube/pull/1883)\n-
          Add nullable to optional fields with x-kubernetes-int-or-string by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1885](https://redirect.github.com/kube-rs/kube/pull/1885)\n-
          send websocket ping to keep idle connections alive by [@&#8203;inqode-lars](https://redirect.github.com/inqode-lars)
          in [#&#8203;1887](https://redirect.github.com/kube-rs/kube/pull/1887)\n-
          Fix watcher ExponentialBackoff jitter ignored by [@&#8203;doxxx93](https://redirect.github.com/doxxx93)
          in [#&#8203;1897](https://redirect.github.com/kube-rs/kube/pull/1897)\n\n</details>\n\n---\n\n###
          Configuration\n\n\U0001F4C5 **Schedule**: Branch creation - At any time
          (no schedule defined), Automerge - At any time (no schedule defined).\n\n\U0001F6A6
          **Automerge**: Disabled by config. Please merge this manually once you are
          satisfied.\n\n\u267B **Rebasing**: Whenever PR is behind base branch, or
          you tick the rebase/retry checkbox.\n\n\U0001F515 **Ignore**: Close this
          PR and you won't be reminded about this update again.\n\n---\n\n - [ ] <!--
          rebase-check -->If you want to rebase/retry this PR, check this box\n\n---\n\nThis
          PR was generated by [Mend Renovate](https://mend.io/renovate/). View the
          [repository job log](https://developer.mend.io/github/vexxhost/magnum-cluster-api).\n<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0MC4xMS45IiwidXBkYXRlZEluVmVyIjoiNDMuNjYuNCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==-->\n"
        change_url: https://github.com/vexxhost/magnum-cluster-api/pull/702
        commit_id: ba7a6fc9b0c447bcf908b92d6b7b9731dc91da42
        patchset: 12fec567ed329a015d3964c475e25b8e5275f3eb
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/magnum-cluster-api
          name: vexxhost/magnum-cluster-api
          short_name: magnum-cluster-api
          src_dir: src/github.com/vexxhost/magnum-cluster-api
        topic: null
      job: magnum-cluster-api-hydrophone-v1.33.9-cilium
      jobtags: []
      max_attempts: 3
      message: Zml4KGRlcHMpOiB1cGRhdGUgcnVzdCBjcmF0ZSBrdWJlIHRvIHYzCgpUaGlzIFBSIGNvbnRhaW5zIHRoZSBmb2xsb3dpbmcgdXBkYXRlczoKCnwgUGFja2FnZSB8IFR5cGUgfCBVcGRhdGUgfCBDaGFuZ2UgfAp8LS0tfC0tLXwtLS18LS0tfAp8IFtrdWJlXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlKSB8IGRlcGVuZGVuY2llcyB8IG1ham9yIHwgYDEuMC4wYCDihpIgYDMuMC4wYCB8CgotLS0KCiMjIyBSZWxlYXNlIE5vdGVzCgo8ZGV0YWlscz4KPHN1bW1hcnk+a3ViZS1ycy9rdWJlIChrdWJlKTwvc3VtbWFyeT4KCiMjIyBbYHYzLjEuMGBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvYmxvYi9IRUFEL0NIQU5HRUxPRy5tZCMzMTAtLTIwMjYtMDMtMTcpCgpbQ29tcGFyZSBTb3VyY2VdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvY29tcGFyZS8zLjAuMS4uLjMuMS4wKQoKXD09PT09PT09PT09PT09PT09PT0KCjwhLS0gUmVsZWFzZSBub3RlcyBnZW5lcmF0ZWQgdXNpbmcgY29uZmlndXJhdGlvbiBpbiAuZ2l0aHViL3JlbGVhc2UueW1sIGF0IDMuMS4wIC0tPgoKIyMjIyBXaGF0J3MgQ2hhbmdlZAoKTWFpbnRlbmFuY2UgcmVsZWFzZSB3aXRoIGZpeGVzIGZvciBzY2hlbWFzL3ZhbGlkYXRpb24sIGNsaWVudCBleGVjIGJsb2NraW5nIGFuZCBwcm94eSBoYW5kbGluZywgYXMgd2VsbCBhcyBzb21lIHNtYWxsZXIgbmV3IGZlYXR1cmVzIGxpc3RlZCBiZWxvdy4gSW50ZXJuYWwgY2hhbmdlcyBhbmQgZG9jdW1lbnRhdGlvbiBpbXByb3ZlbWVudHMgbGlzdGVkIGluIHRoZSBbbWlsZXN0b25lXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL21pbGVzdG9uZS81ND9jbG9zZWQ9MSkuCgojIyMjIyBBZGRlZAoKLSBhbGxvdyBlbXB0eSBib2R5IGluIGNvbnN0IGNvbnRleHQgYnkgW0AmIzgyMDM7dG90dG90b10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3RvdHRvdG8pIGluIFsjJiM4MjAzOzE5MjddKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xOTI3KQotIEFkZCB0eXBlZCBwcmludGNvbHVtbiBhcmd1bWVudCB0byBkZXJpdmUgbWFjcm8gYnkgW0AmIzgyMDM7Y2NobmRsXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vY2NobmRsKSBpbiBbIyYjODIwMzsxODcyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg3MikKLSBrdWJlLWNvcmU6IGFkZCBvcHRpb25hbE9sZFNlbGYgdG8gQ0VMIGBSdWxlYCBieSBbQCYjODIwMztJbW1vcnRhbC1CZXlvbmQtT2JsaXZpb25dKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9JbW1vcnRhbC1CZXlvbmQtT2JsaXZpb24pIGluIFsjJiM4MjAzOzE5NDddKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xOTQ3KQotIFJlLWFkZCBzdXBwb3J0IGZvciBiYXNpYyBhdXRoIGluIFByb3h5IGJ5IFtAJiM4MjAzO2dvZW5uaW5nXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vZ29lbm5pbmcpIGluIFsjJiM4MjAzOzE5NTldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xOTU5KQoKIyMjIyMgRml4ZWQKCi0gRml4IE9wdGlvbmFsRW51bSB0cmFuc2Zvcm0gZm9yIGNvbXBsZXggZW51bXMgYnkgW0AmIzgyMDM7ZG94eHg5M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RveHh4OTMpIGluIFsjJiM4MjAzOzE5MzRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xOTM0KQoKLSBCdW1wIHRvd2VyLWh0dHAgZGVwZW5kZW5jeSB0byAwLjYuNCBieSBbQCYjODIwMzthYnVzdGFueV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2FidXN0YW55KSBpbiBbIyYjODIwMzsxOTM5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTkzOSkKCi0gQWRkIG1pbmltYWwtdmVyc2lvbnMgQ0kgY2hlY2sgYnkgW0AmIzgyMDM7ZG94eHg5M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RveHh4OTMpIGluIFsjJiM4MjAzOzE5NDBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xOTQwKQoKLSBmaXg6IFByb2R1Y2UgdmFsaWQgQ1JEcyBjb250YWluaW5nIGZsYXR0ZW5lZCB1bnRhZ2dlZCBlbnVtcyBieSBbQCYjODIwMztOaWNrTGFyc2VuTlpdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9OaWNrTGFyc2VuTlopIGluIFsjJiM4MjAzOzE5NDJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xOTQyKQoKLSBrdWJlLWNsaWVudDogQXZvaWQgYmxvY2tpbmcgdG9raW8gd29ya2VyIGR1cmluZyBleGVjIGF1dGggdG9rZW4gcmVmcmVzaCBieSBbQCYjODIwMztibGFrZWxhd3Nvbl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2JsYWtlbGF3c29uKSBpbiBbIyYjODIwMzsxOTUwXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTk1MCkKCi0gW0AmIzgyMDM7YWJ1c3RhbnldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9hYnVzdGFueSkgbWFkZSB0aGVpciBmaXJzdCBjb250cmlidXRpb24gaW4gWyMmIzgyMDM7MTkzOV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE5MzkpCgotIFtAJiM4MjAzO2NjaG5kbF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2NjaG5kbCkgbWFkZSB0aGVpciBmaXJzdCBjb250cmlidXRpb24gaW4gWyMmIzgyMDM7MTg3Ml0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NzIpCgotIFtAJiM4MjAzO0ltbW9ydGFsLUJleW9uZC1PYmxpdmlvbl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL0ltbW9ydGFsLUJleW9uZC1PYmxpdmlvbikgbWFkZSB0aGVpciBmaXJzdCBjb250cmlidXRpb24gaW4gWyMmIzgyMDM7MTk0N10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE5NDcpCgotIFtAJiM4MjAzO2dhdXJhdmdhaGxvdF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2dhdXJhdmdhaGxvdCkgbWFkZSB0aGVpciBmaXJzdCBjb250cmlidXRpb24gaW4gWyMmIzgyMDM7MTk0OV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE5NDkpCgotIFtAJiM4MjAzO2JsYWtlbGF3c29uXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vYmxha2VsYXdzb24pIG1hZGUgdGhlaXIgZmlyc3QgY29udHJpYnV0aW9uIGluIFsjJiM4MjAzOzE5NTBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xOTUwKQoKKipGdWxsIENoYW5nZWxvZyoqOiA8aHR0cHM6Ly9naXRodWIuY29tL2t1YmUtcnMva3ViZS9jb21wYXJlLzMuMC4xLi4uMy4xLjA+CgojIyMgW2B2My4wLjFgXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL2Jsb2IvSEVBRC9DSEFOR0VMT0cubWQjMzAxLS0yMDI2LTAxLTMwKQoKW0NvbXBhcmUgU291cmNlXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL2NvbXBhcmUvMy4wLjAuLi4zLjAuMSkKClw9PT09PT09PT09PT09PT09PT09Cgo8IS0tIFJlbGVhc2Ugbm90ZXMgZ2VuZXJhdGVkIHVzaW5nIGNvbmZpZ3VyYXRpb24gaW4gLmdpdGh1Yi9yZWxlYXNlLnltbCBhdCAzLjAuMSAtLT4KCiMjIyMgV2hhdCdzIENoYW5nZWQKCkJ1Z2ZpeCByZWxlYXNlIGZvciBzY2hlbWFzLCBhZG1pc3Npb24sIGFuZCBkb2NzLiBNaW5vciBpbnRlcm5hbCBpbXByb3ZlbWVudHMgbGlzdGVkIGluIHRoZSBbbWlsZXN0b25lXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL21pbGVzdG9uZS81Mz9jbG9zZWQ9MSkuIEltcG9ydGFudCBmaXhlcyBiZWxvdy4KCiMjIyMjIEZpeGVkCgotIFVwZGF0ZSBBUEkgdmVyc2lvbiBvZiBbYEFkbWlzc2lvblJlc3BvbnNlYF0oaHR0cHM6Ly9kb2NzLnJzL2t1YmUvMy4wLjEva3ViZS9jb3JlL2FkbWlzc2lvbi9zdHJ1Y3QuQWRtaXNzaW9uUmVzcG9uc2UuaHRtbCkgY3JlYXRlZCB2aWEgaW52YWxpZCBjYWxsIGJ5IFtAJiM4MjAzO01hZ2ljbG91ZF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL01hZ2ljbG91ZCkgaW4gWyMmIzgyMDM7MTkwNV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE5MDUpCi0gRml4IFtgT3B0aW9uYWxFbnVtYF0oaHR0cHM6Ly9kb2NzLnJzL2t1YmUvMy4wLjEva3ViZS9jb3JlL3NjaGVtYS9zdHJ1Y3QuT3B0aW9uYWxFbnVtLmh0bWwpIHRyYW5zZm9ybSBza2lwcGluZyBzY2hlbWFzIHdpdGggZGVzY3JpcHRpb24gYnkgW0AmIzgyMDM7ZG94eHg5M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RveHh4OTMpIGluIFsjJiM4MjAzOzE5MDhdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xOTA4KQotIFJlbW92ZSBjb25mbGljdGluZyBgYWRkaXRpb25hbFByb3BlcnRpZXM6IGZhbHNlYCBmcm9tIHNjaGVtYSBieSBbQCYjODIwMztkb3h4eDkzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vZG94eHg5MykgaW4gWyMmIzgyMDM7MTkyMF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE5MjApCgojIyMgW2B2My4wLjBgXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL2Jsb2IvSEVBRC9DSEFOR0VMT0cubWQjMzAwLS0yMDI2LTAxLTEyKQoKW0NvbXBhcmUgU291cmNlXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL2NvbXBhcmUvMi4wLjEuLi4zLjAuMCkKClw9PT09PT09PT09PT09PT09PT09Cgo8IS0tIFJlbGVhc2Ugbm90ZXMgZ2VuZXJhdGVkIHVzaW5nIGNvbmZpZ3VyYXRpb24gaW4gLmdpdGh1Yi9yZWxlYXNlLnltbCBhdCAzLjAuMCAtLT4KCiMjIyMgTmV3IE1ham9yCgpBcyBwZXIgdGhlIG5ldyByZWxlYXNlIHNjaGVkdWxlIHRvIG1hdGNoIHVwIHdpdGggdGhlIG5ldyBLdWJlcm5ldGVzIHJlbGVhc2UuCkxvdHMgb2YgYWRkaXRpb25zLCBmaXhlcyBhbmQgaW1wcm92ZW1lbnRzLiBUaGFua3MgdG8gZXZlcnlvbmUgd2hvIGNvbnRyaWJ1dGVkIHNvIGhlYXZpbHkgb3ZlciB0aGUgaG9saWRheXMhIEhhcHB5IG5ldyB5ZWFyLgoKIyMjIyBCcmVha2luZyBDaGFuZ2VzCgojIyMjIyBLdWJlcm5ldGVzIGB2MV8zNWAgc3VwcG9ydCB2aWEgazhzLW9wZW5hcGkgWzAuMjddKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9Bcm5hdmlvbi9rOHMtb3BlbmFwaS9yZWxlYXNlcy90YWcvdjAuMjcuMCkKClBsZWFzZSBbdXBncmFkZSBrOHMtb3BlbmFwaSBhbG9uZyB3aXRoIGt1YmVdKGh0dHBzOi8va3ViZS5ycy91cGdyYWRpbmcvKSB0byBhdm9pZCBjb25mbGljdHMuCgojIyMjIyBgamlmZmAgcmVwbGFjZXMgYGNocm9ub2AKCk1hdGNoaW5nIGs4cy1vcGVuYXBpJ3MgW2NoYW5nZV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL0FybmF2aW9uL2s4cy1vcGVuYXBpL2NvbW1pdC84YzFiNmZjY2I3MjU4ZWI0ODdlZDhjODI5NzkxZDQyN2E0YjE2MjE2KSwga3ViZSBoYXMgYWxzbyBzd2FwcGVkIG91dCBgY2hyb25vYC4gVGhlIGJpZ2dlc3QgaW1wYWN0IG9mIHRoaXMgaXMgZm9yIGludGVyYWN0aW5nIHdpdGggdGltZXN0YW1wcyBpbiBgbWV0YWRhdGFgLCBidXQgaXQgYWxzbyB1cGRhdGVzIDIgc21hbGxlciBwdWJsaWMgaW50ZXJmYWNlcyBpbiBbYExvZ1BhcmFtc2BdKGh0dHBzOi8vZG9jcy5ycy9rdWJlL2xhdGVzdC9rdWJlL2FwaS9zdHJ1Y3QuTG9nUGFyYW1zLmh0bWwjc3RydWN0ZmllbGQuc2luY2VfdGltZSksIFtgQ2xpZW50Ojp3aXRoX3ZhbGlkX3VudGlsYF0oaHR0cHM6Ly9kb2NzLnJzL2t1YmUvbGF0ZXN0L2t1YmUvc3RydWN0LkNsaWVudC5odG1sI21ldGhvZC53aXRoX3ZhbGlkX3VudGlsKS4gIFNlZSBbY29udHJvbGxlci1ycyMyMTddKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2NvbnRyb2xsZXItcnMvcHVsbC8yMTcvY2hhbmdlcykgZm9yIGFuIGV4YW1wbGUgY2hhbmdlLgoKQ2hhbmdlczogWyMmIzgyMDM7MTg2OF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NjgpICsgWyMmIzgyMDM7MTg3MF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NzApCgojIyMjIGBFcnJvclJlc3BvbnNlYCBoYXMgYmVlbiByZXBsYWNlZCB3aXRoIFtgU3RhdHVzYF0oaHR0cHM6Ly9kb2NzLnJzL2t1YmUvbGF0ZXN0L2t1YmUvY29yZS9zdHJ1Y3QuU3RhdHVzLmh0bWwpCgpgRXJyb3JSZXNwb25zZWAgc2VydmVkIGFzIGEgcGFydGlhbCBtZXRhdjEvU3RhdHVzIHJlcGxhY2VtZW50IHdoaWNoIGVuZGVkIHVwIGhpZGluZyBlcnJvciBpbmZvcm1hdGlvbiB0byB1c2Vycy4gVGhlc2Ugc3RydWN0cyBoYXZlIG1lcmdlZCwgbW9yZSBpbmZvcm1hdGlvbiBpcyBhdmFpbGFibGUgb24gZXJyb3JzLCBhbmQgYSB0eXBlIGFsaWFzIHdpdGggYSBkZXByZWNhdGlvbiB3YXJuaW5nIGlzIGluIHBsYWNlIGZvciBbYEVycm9yUmVzcG9uc2VgXShodHRwczovL2RvY3MucnMva3ViZS9sYXRlc3Qva3ViZS9jb3JlL3R5cGUuRXJyb3JSZXNwb25zZS5odG1sKSB3aGljaCB3aWxsIGJlIHJlbW92ZWQgaW4gYSBsYXRlciB2ZXJzaW9uLgoKVGhpcyBjcmVhdGVzIGEgc21hbGwgYnJlYWtpbmcgY2hhbmdlIGZvciB1c2VycyBtYXRjaGluZyBvbiBzcGVjaWZpYyBbYEVycm9yOjpBcGlgXShodHRwczovL2RvY3MucnMva3ViZS9sYXRlc3Qva3ViZS9lbnVtLkVycm9yLmh0bWwjdmFyaWFudC5BcGkpIGNvZGVzOwoKYGBgZGlmZgogICAgIC5tYXBfZXJyKHxlcnJvcnwgbWF0Y2ggZXJyb3IgewotICAgICAgICBrdWJlOjpFcnJvcjo6QXBpKGt1YmU6OmVycm9yOjpFcnJvclJlc3BvbnNlIHsgY29kZTogNDAzLCAuLiB9KSA9PiB7Ci0gICAgICAgICAgICBFcnJvcjo6VW5hdXRob3JpemVkVG9QYXRjaChvYmopCi0gICAgICAgIH0KKyAgICAgICAga3ViZTo6RXJyb3I6OkFwaShzKSBpZiBzLmlzX2ZvcmJpZGRlbigpID0+IEVycm9yOjpVbmF1dGhvcml6ZWRUb1BhdGNoKG9iaiksCiAgICAgICAgIG90aGVyID0+IEVycm9yOjpPdGhlcihvdGhlciksCiAgICAgfSk/OwpgYGAKClsjJiM4MjAzOzE4NzVdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODc1KSArIFsjJiM4MjAzOzE4ODNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODgzKSArIFsjJiM4MjAzOzE4OTFdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODkxKS4KCiMjIyMgUHJlZGljYXRlcyBub3cgaGFzIGEgVFRMIENhY2hlCgpUaGlzIHByZXZlbnRzIHVuYm91bmRlZCBtZW1vcnkgZm9yIGNvbnRyb2xsZXJzLCBwYXJ0aWN1bGFybHkgYWZmZWN0aW5nIG9uZXMgd2F0Y2hpbmcgcXVpY2tseSByb3RhdGluZyBvYmplY3RzIHdpdGggZ2VuZXJhdGVkIG5hbWVzIChlLmcuIHBvZHMpLiBCeSBkZWZhdWx0IHRoZSBUVEwgaXMgYDFoYC4gSXQgY2FuIGJlIGNvbmZpZ3VyZWQgdmlhIG5ldyBbYFByZWRpY2F0ZUNvbmZpZ2BdKGh0dHBzOi8vZG9jcy5ycy9rdWJlL2xhdGVzdC9rdWJlL3J1bnRpbWUvc3RydWN0LlByZWRpY2F0ZUNvbmZpZy5odG1sKSBwYXJhbWV0ZXIuIFRvIHVzZSB0aGUgZGVmYXVsdDsKCmBgYGRpZmYKLSAgICAgICAgLnByZWRpY2F0ZV9maWx0ZXIocHJlZGljYXRlczo6cmVzb3VyY2VfdmVyc2lvbik7CisgICAgICAgIC5wcmVkaWNhdGVfZmlsdGVyKHByZWRpY2F0ZXM6OnJlc291cmNlX3ZlcnNpb24sIERlZmF1bHQ6OmRlZmF1bHQoKSk7CmBgYAoKQ2hhbmdlIGluIFsjJiM4MjAzOzE4MzZdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODM2KS4gVGhpcyBoZWxwZWQgZXhwb3NlIGFuZCBmaXggYSBidWcgaW4gd2F0Y2hlcyB3aXRoIHN0cmVhbWluZ1xfbGlzdHMgbm93IGZpeGVkIGluIFsjJiM4MjAzOzE4ODJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODgyKS4KCiMjIyMgU3VicmVzb3VyY2UgQXBpCgpTb21lIHN1YnJlc291cmNlIHdyaXRlIG1ldGhvZHMgd2VyZSBwdWJsaWMgd2l0aCBpbmNvbnNpc3RlbnQgc2lnbmF0dXJlcyB0aGF0IHJlcXVpcmVkIGxlc3MgZXJnb25vbWljIHVzZSB0aGFuIGFueSBvdGhlciB3cml0ZSBtZXRob2RzLiBUaGV5IHRvb2sgYSBgVmVjPHU4PmAgZm9yIHRoZSBwb3N0IGJvZHksIG5vdyB0aGV5IHRha2UgYSBgJks6IFNlcmlhbGl6ZWAgb3IgdGhlIGFjdHVhbCBzdWJyZXNvdXJjZS4KVGhlcmUgYWZmZWN0IGBBcGk6OmNyZWF0ZV9zdWJyZXNvdXJjZWAsIGBBcGk6OnJlcGxhY2Vfc3VicmVzb3VyY2VgLCBbYEFwaTo6cmVwbGFjZV9zdGF0dXNgXShodHRwczovL2RvY3MucnMva3ViZS9sYXRlc3Qva3ViZS9zdHJ1Y3QuQXBpLmh0bWwjbWV0aG9kLnJlcGxhY2Vfc3RhdHVzKSwgYEFwaTo6cmVwbGFjZV9zY2FsZWAuIEluIGVzc2VuY2UgdGhpcyBnZW5lcmFsbHkgbWVhbnMgeW91IGRvIG5vdCBoYXZlIHRvIHdyYXAgcmF3IG9iamVjdHMgaW4gYGpzb24hYCBhbmQgYHNlcmRlX2pzb246OnRvX3ZlY2AgZm9yIHRoZXNlIGNhbGxzIGFuZCBsZWFuIG1vcmUgb24gcnVzdCdzIHR5cGVkIG9iamVjdHMgcmF0aGVyIHRoYW4gYGpzb24hYCBibG9icyB3aGljaCBoYXMgc29tZSBbZm9vdGd1bnNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODg0I2Rpc2N1c3Npb25fcjI2ODA3ODI1NTYpIGZvciBzdWJyZXNvdXJjZXMuCgpgYGBkaWZmCi0gICAgbGV0IG8gPSBmb29zLnJlcGxhY2Vfc3RhdHVzKCJxdXgiLCAmcHAsIHNlcmRlX2pzb246OnRvX3ZlYygmb2JqZWN0KT8pLmF3YWl0PzsKKyAgICBsZXQgbyA9IGZvb3MucmVwbGFjZV9zdGF0dXMoInF1eCIsICZwcCwgJm9iamVjdCkuYXdhaXQ/OwpgYGAKClNlZSBzb21lIG1vcmUgc2hpZnRzIGluIGV4YW1wbGVzIGluIHRoZSBpbXBsZW1lbnRhdGlvbjsgWyMmIzgyMDM7MTg4NF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4ODQpCgojIyMjIEltcHJvdmVtZW50cwoKIyMjIyMgU3VwcG9ydCBLdWJlcm5ldGVzIDEuMzAgW0FnZ3JlZ2F0ZWQgRGlzY292ZXJ5XShodHRwczovL2t1YmVybmV0ZXMuaW8vZG9jcy9jb25jZXB0cy9vdmVydmlldy9rdWJlcm5ldGVzLWFwaS8jYWdncmVnYXRlZC1kaXNjb3ZlcnkpCgpTcGVlZHMgdXAgYXBpIGRpc2NvdmVyeSAqKnNpZ25pZmljYW50bHkqKiBieSB1c2luZyB0aGUgbmV3ZXIgYXBpIHdpdGggbXVjaCBsZXNzIHJvdW5kLXRyaXBwaW5nLgpUbyBvcHQtaW4gY2hhbmdlIGBEaXNjb3Zlcnk6OnJ1bigpYCB0byBbYERpc2NvdmVyeTo6cnVuX2FnZ3JlZ2F0ZWQoKWBdKGh0dHBzOi8vZG9jcy5ycy9rdWJlL2xhdGVzdC9rdWJlL3N0cnVjdC5EaXNjb3ZlcnkuaHRtbCNtZXRob2QucnVuX2FnZ3JlZ2F0ZWQpCgpDaGFuZ2VzOyBbIyYjODIwMzsxODc2XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg3NikgKyBbIyYjODIwMzsxODczXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg3MykgKyBbIyYjODIwMzsxODg5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4OSkKCiMjIyMjIFJ1c3QgMjAyNAoKV2hpbGUgdGhpcyBpcyBtb3N0bHkgZm9yIGludGVybmFsIGVyZ29ub21pY3MsIHdlIHdvdWxkIGxpa2UgdG8gaGlnaGxpZ2h0IHRoaXMgYWxzbyBzaW1wbGlmaWVzIHRoZSBbYENvbmRpdGlvbmBdKGh0dHBzOi8vZG9jcy5ycy9rdWJlL2xhdGVzdC9rdWJlL3J1bnRpbWUvd2FpdC9jb25kaXRpb25zL3RyYWl0LkNvbmRpdGlvbi5odG1sKSBpbXBsZW1lbnRvcnMgd2hpY2ggaGFkIHRvIGRlYWwgd2l0aCBhIGxvdCBvZiBvcHRpb25zOwoKYGBgZGlmZgogICAgcHViIGZuIGlzX2pvYl9jb21wbGV0ZWQoKSAtPiBpbXBsIENvbmRpdGlvbjxKb2I+IHsKICAgICAgICB8b2JqOiBPcHRpb248JkpvYj58IHsKLSAgICAgICAgICAgIGlmIGxldCBTb21lKGpvYikgPSAmb2JqIHsKLSAgICAgICAgICAgICAgICBpZiBsZXQgU29tZShzKSA9ICZqb2Iuc3RhdHVzIHsKLSAgICAgICAgICAgICAgICAgICAgaWYgbGV0IFNvbWUoY29uZHMpID0gJnMuY29uZGl0aW9ucyB7Ci0gICAgICAgICAgICAgICAgICAgICAgICBpZiBsZXQgU29tZShwY29uZCkgPSBjb25kcy5pdGVyKCkuZmluZCh8Y3wgYy50eXBlXyA9PSAiQ29tcGxldGUiKSB7Ci0gICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHBjb25kLnN0YXR1cyA9PSAiVHJ1ZSI7Ci0gICAgICAgICAgICAgICAgICAgICAgICB9Ci0gICAgICAgICAgICAgICAgICAgIH0KLSAgICAgICAgICAgICAgICB9CisgICAgICAgICAgICBpZiBsZXQgU29tZShqb2IpID0gJm9iagorICAgICAgICAgICAgICAgICYmIGxldCBTb21lKHMpID0gJmpvYi5zdGF0dXMKKyAgICAgICAgICAgICAgICAmJiBsZXQgU29tZShjb25kcykgPSAmcy5jb25kaXRpb25zCisgICAgICAgICAgICAgICAgJiYgbGV0IFNvbWUocGNvbmQpID0gY29uZHMuaXRlcigpLmZpbmQofGN8IGMudHlwZV8gPT0gIkNvbXBsZXRlIikKKyAgICAgICAgICAgIHsKKyAgICAgICAgICAgICAgICByZXR1cm4gcGNvbmQuc3RhdHVzID09ICJUcnVlIjsKYGBgCgpDaGFuZ2UgWyMmIzgyMDM7MTg1Nl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NTYpICsgWyMmIzgyMDM7MTc5Ml0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE3OTIpCgojIyMjIyBOZXcgQ2xpZW50IFtgUmV0cnlQb2xpY3lgXShodHRwczovL2RvY3MucnMva3ViZS9sYXRlc3Qva3ViZS9jbGllbnQvcmV0cnkvc3RydWN0LlJldHJ5UG9saWN5Lmh0bWwpIG9wdC1pbgoKQWxsb3dzIGN1c3RvbSBjbGllbnRzIChmb3Igbm93KSB0byBlbmFibGUgZXhwb25lbnRpYWwgYmFja29mZidkIHJldHJpZXMgZm9yIHJldHJ5YWJsZSBlcnJvcnMgYnkgZXhwb3NpbmcgYSBbYHRvd2VyOjpyZXRyeTo6UG9saWN5YF0oaHR0cHM6Ly90b3dlci1ycy5naXRodWIuaW8vdG93ZXIvdG93ZXIvcmV0cnkvdHJhaXQuUG9saWN5Lmh0bWwpIGZvciBhIFtgdG93ZXI6OnJldHJ5OjpMYXllcmBdKGh0dHBzOi8vdG93ZXItcnMuZ2l0aHViLmlvL3Rvd2VyL3Rvd2VyL3JldHJ5L3N0cnVjdC5SZXRyeUxheWVyLmh0bWwpLiBTZWUgdGhlIG5ldyBbY3VzdG9tXF9jbGllbnRcX3JldHJ5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL2Jsb2IvbWFpbi9leGFtcGxlcy9jdXN0b21fY2xpZW50X3JldHJ5LnJzI0wyNC1MMzcpIGV4YW1wbGUgZm9yIGRldGFpbHMuCgpFbmFibGVkIGJ5IGEgW2Nsb25lYWJsZSBib2R5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg2NykgKyB0aGUgbmV3IFtSZXRyeVBvbGljeV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4OTQpIGJhc2VkIG9uIG1pcnJvcmQncyBzb2x1dGlvbltcKl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL21ldGFsYmVhci1jby9taXJyb3JkL2Jsb2IvYTllNGM1MmE3MjBmZDVhODMzZTMwYWVlMWFjNjUwMzYwMDMxYjdhNy9taXJyb3JkL2t1YmUvc3JjL3JldHJ5LnJzI0w0MS1MMTM1KS4KCiMjIyMgRml4ZXMKCi0gc3RyZWFtaW5nIGxpc3QgYnVnIGZpeCAtIFsjJiM4MjAzOzE4ODJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODgyKQotIHdhdGNoZXIgaml0dGVyIGJ1ZyBmaXggLSBbIyYjODIwMzsxODk3XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg5NykKLSBzY2hlbWEgZml4IGZvciBJbnRPclN0cmluZyAtIFsjJiM4MjAzOzE4NjddKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODY3KQotIHNjaGVtYSBmaXggZm9yIG9wdGlvbmFsIGVudW1zIC0gWyMmIzgyMDM7MTg1M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NTMpCi0gd2Vic29ja2V0IGtlZXBhbGl2ZXMgZm9yIGxvbmcgcnVubmluZyBhdHRhY2hlcyAtIFsjJiM4MjAzOzE4ODldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODg5KQoKIyMjIyMgTW9yZQoKLSBgUmVzaXplYCBzdWJyZXNvdXJjZSBpbXBsIGZvciBgUG9kYCAtIFsjJiM4MjAzOzE4NTFdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODUxKQotIGFkZCBgI1trdWJlKGF0dHI9Ii4uLiIpYCB0byBhbGxvdyBjdXN0b20gYXR0cnMgb24gZGVyaXZlcyAtIFsjJiM4MjAzOzE4NTBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODUwKQotIGV4YW1wbGUgdXBkYXRlcyBmb3IgYWRtaXNzaW9uIHcvYXh1bSAtIFsjJiM4MjAzOzE4NTldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODU5KQoKIyMjIyBXaGF0J3MgQ2hhbmdlZAoKIyMjIyMgQWRkZWQKCi0gQWRkIGBSZXNpemVgIHN1YnJlc291cmNlIGZvciBgUG9kYCBieSBbQCYjODIwMztodWdvcG9udGhpZXVdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9odWdvcG9udGhpZXUpIGluIFsjJiM4MjAzOzE4NTFdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODUxKQotIGZlYXQ6IGFkZCAjXFtrdWJlKGF0dHI9Ii4uLiIpXSBhdHRyaWJ1dGUgaGVscGVyIHRvIHNldCBhdHRyaWJ1dGUgaGVscGVyIG9uIHRoZSBDUiByb290IHR5cGUgYnkgW0AmIzgyMDM7bmdlcmdzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vbmdlcmdzKSBpbiBbIyYjODIwMzsxODUwXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg1MCkKLSBSdXN0IDIwMjQgbGV0LWNoYWlucyB0byBzaW1wbGlmeSB3YWl0IENvbmRpdGlvbnMgYnkgW0AmIzgyMDM7Y2x1eF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2NsdXgpIGluIFsjJiM4MjAzOzE3OTJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xNzkyKQotIEFkZHMgYSBgdHJ5X2Nsb25lYCBtZXRob2QgZm9yIGBrdWJlX2NsaWVudDo6Y2xpZW50OjpCb2R5YCB3aGVuIGl0J3MgYEtpbmQ6Ok9uY2VgIGJ5IFtAJiM4MjAzO21lb3dqZXN0eV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL21lb3dqZXN0eSkgaW4gWyMmIzgyMDM7MTg2N10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NjcpCi0gSW1wbGVtZW50IGNsaWVudCBhZ2dyZWdhdGVkIGRpc2NvdmVyeSBBUEkgbWV0aG9kcyBieSBbQCYjODIwMztkb3h4eDkzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vZG94eHg5MykgaW4gWyMmIzgyMDM7MTg3M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NzMpCi0gSW1wbGVtZW50IGFnZ3JlZ2F0ZWQgZGlzY292ZXJ5IEFQSSBtZXRob2RzIGJ5IFtAJiM4MjAzO2RveHh4OTNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9kb3h4eDkzKSBpbiBbIyYjODIwMzsxODc2XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg3NikKLSBQZXJtaXQgb2xkZXIgdmVyc2lvbiBvZiBBUEkgZm9yIHYyIGRpc2NvdmVyeSBmb3IgazhzIDwgMS4zMCAoZG93biB0byAxLjI3KSBieSBbQCYjODIwMztEYW5pbC1Hcmlnb3Jldl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL0RhbmlsLUdyaWdvcmV2KSBpbiBbIyYjODIwMzsxODg5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4OSkKLSBBZGQgUmV0cnlQb2xpY3kgZm9yIGNsaWVudC1sZXZlbCByZXF1ZXN0IHJldHJpZXMgYnkgW0AmIzgyMDM7ZG94eHg5M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RveHh4OTMpIGluIFsjJiM4MjAzOzE4OTRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODk0KQoKIyMjIyMgQ2hhbmdlZAoKLSBVcGRhdGUgdG9raW8tdHVuZ3N0ZW5pdGUgcmVxdWlyZW1lbnQgZnJvbSAwLjI3LjAgdG8gMC4yOC4wIGJ5IFtAJiM4MjAzO2RlcGVuZGFib3RdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9kZXBlbmRhYm90KVxbYm90XSBpbiBbIyYjODIwMzsxODI5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTgyOSkKLSBQcmVkaWNhdGVzOiBhZGQgY29uZmlndXJhYmxlIGNhY2hlIFRUTCBmb3IgYHByZWRpY2F0ZV9maWx0ZXJgIGJ5IFtAJiM4MjAzO2RveHh4OTNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9kb3h4eDkzKSBpbiBbIyYjODIwMzsxODM4XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTgzOCkKLSBVcGRhdGUgZGFybGluZyByZXF1aXJlbWVudCBmcm9tIDAuMjEuMCB0byAwLjIzLjAgYnkgW0AmIzgyMDM7ZGVwZW5kYWJvdF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RlcGVuZGFib3QpXFtib3RdIGluIFsjJiM4MjAzOzE4NjFdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODYxKQotIHVwZGF0ZSB0byBqc29ucGF0aC1ydXN0IDEgYnkgW0AmIzgyMDM7dG90dG90b10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3RvdHRvdG8pIGluIFsjJiM4MjAzOzE4NjNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODYzKQotIFJlcGxhY2UgYGNocm9ub2Agd2l0aCBgamlmZmAgYnkgW0AmIzgyMDM7bmdlcmdzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vbmdlcmdzKSBpbiBbIyYjODIwMzsxODY4XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg2OCkKLSBNZXJnZSBFcnJvclJlc3BvbnNlIGFuZCBTdGF0dXMgYnkgW0AmIzgyMDM7aW1wXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vaW1wKSBpbiBbIyYjODIwMzsxODc1XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg3NSkKLSBNYWtlIHN1YnJlc291cmNlIG1ldGhvZHMgbW9yZSBlcmdvbm9taWMgYnkgW0AmIzgyMDM7ZG94eHg5M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RveHh4OTMpIGluIFsjJiM4MjAzOzE4ODRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODg0KQotIERyb3AgazhzIHYxLjMwLCBjcm9uby0+amlmZiByZXBsYWNlbWVudCBmb3IgcnVudGltZSAmIGV4YW1wbGVzIGJ5IFtAJiM4MjAzO25nZXJnc10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL25nZXJncykgaW4gWyMmIzgyMDM7MTg3MF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NzApCi0gQWRkIGEgbWV0YWRhdGEgZmllbGQgdG8gU3RhdHVzIGJ5IFtAJiM4MjAzO3J5YW5wYnJld3N0ZXJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9yeWFucGJyZXdzdGVyKSBpbiBbIyYjODIwMzsxODkxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg5MSkKLSBCdW1wIGBrOHMtb3BlbmFwaWAgZm9yIEt1YmVybmV0ZXMgMS4zNSBieSBbQCYjODIwMztjbHV4XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vY2x1eCkgaW4gWyMmIzgyMDM7MTg5OF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4OTgpCgojIyMjIyBGaXhlZAoKLSBmaXg6IGFkZCB1c2U8PiB0byBrdWJlbGV0XF9ub2RlXF9sb2dzIGZvciBydXN0IGVkaXRpb24gMjAyNCBieSBbQCYjODIwMztjbzQyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vY280MikgaW4gWyMmIzgyMDM7MTg0OV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NDkpCi0gVHJhbnNmb3JtIG9wdGlvbmFsIGVudW1zIHRvIG1hdGNoIHByZSBrdWJlIDIuMC4wIGZvcm1hdCBieSBbQCYjODIwMztEYW5pbC1Hcmlnb3Jldl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL0RhbmlsLUdyaWdvcmV2KSBpbiBbIyYjODIwMzsxODUzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg1MykKLSBEaXN0aW5ndWlzaCBiZXR3ZWVuIGluaXRpYWwgYW5kIHJlc3VtZWQgd2F0Y2ggcGhhc2VzIGZvciBzdHJlYW1pbmcgbGlzdHMgYnkgW0AmIzgyMDM7ZG94eHg5M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RveHh4OTMpIGluIFsjJiM4MjAzOzE4ODJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODgyKQotIFJlLWV4cG9ydCBkZXByZWNhdGVkIHR5cGUgYWxpYXMgYW5kIGltcHJvdmUgZGVwcmVjYXRpb24gZ3VpZGFuY2UgYnkgW0AmIzgyMDM7Y2x1eF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2NsdXgpIGluIFsjJiM4MjAzOzE4ODNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODgzKQotIEFkZCBudWxsYWJsZSB0byBvcHRpb25hbCBmaWVsZHMgd2l0aCB4LWt1YmVybmV0ZXMtaW50LW9yLXN0cmluZyBieSBbQCYjODIwMztkb3h4eDkzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vZG94eHg5MykgaW4gWyMmIzgyMDM7MTg4NV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4ODUpCi0gc2VuZCB3ZWJzb2NrZXQgcGluZyB0byBrZWVwIGlkbGUgY29ubmVjdGlvbnMgYWxpdmUgYnkgW0AmIzgyMDM7aW5xb2RlLWxhcnNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9pbnFvZGUtbGFycykgaW4gWyMmIzgyMDM7MTg4N10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4ODcpCi0gRml4IHdhdGNoZXIgRXhwb25lbnRpYWxCYWNrb2ZmIGppdHRlciBpZ25vcmVkIGJ5IFtAJiM4MjAzO2RveHh4OTNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9kb3h4eDkzKSBpbiBbIyYjODIwMzsxODk3XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg5NykKCiMjIyBbYHYyLjAuMWBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvYmxvYi9IRUFEL0NIQU5HRUxPRy5tZCMyMDEtLTIwMjUtMDktMTIpCgpbQ29tcGFyZSBTb3VyY2VdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvY29tcGFyZS8yLjAuMC4uLjIuMC4xKQoKXD09PT09PT09PT09PT09PT09PT0KCjwhLS0gUmVsZWFzZSBub3RlcyBnZW5lcmF0ZWQgdXNpbmcgY29uZmlndXJhdGlvbiBpbiAuZ2l0aHViL3JlbGVhc2UueW1sIGF0IDIuMC4xIC0tPgoKIyMjIyBXaGF0J3MgQ2hhbmdlZAoKRml4ZXMgYW4gYWNjaWRlbnRhbCBpbmNsdXNpb24gb2YgYSBjb25zdHJhaW50IGFkZGVkIHRvIGBBcGk6OmxvZ19zdHJlYW1gIGludHJvZHVjZWQgaW4gdGhlIDIuMC4wIFJ1c3QgMjAyNCB1cGdyYWRlLgoKIyMjIyMgRml4ZWQKCi0gUmVtb3ZlIHVudXNlZCB1c2U8J1xfPiBmcm9tIGxvZ1xfc3RyZWFtKCkgYnkgW0AmIzgyMDM7cGdlcmJlcl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL3BnZXJiZXIpIGluIFsjJiM4MjAzOzE4MjRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODI0KQoKIyMjIFtgdjIuMC4wYF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9ibG9iL0hFQUQvQ0hBTkdFTE9HLm1kIzMwMC0tMjAyNi0wMS0xMikKCltDb21wYXJlIFNvdXJjZV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9jb21wYXJlLzEuMS4wLi4uMi4wLjApCgpcPT09PT09PT09PT09PT09PT09PQoKPCEtLSBSZWxlYXNlIG5vdGVzIGdlbmVyYXRlZCB1c2luZyBjb25maWd1cmF0aW9uIGluIC5naXRodWIvcmVsZWFzZS55bWwgYXQgMy4wLjAgLS0+CgojIyMjIE5ldyBNYWpvcgoKQXMgcGVyIHRoZSBuZXcgcmVsZWFzZSBzY2hlZHVsZSB0byBtYXRjaCB1cCB3aXRoIHRoZSBuZXcgS3ViZXJuZXRlcyByZWxlYXNlLgpMb3RzIG9mIGFkZGl0aW9ucywgZml4ZXMgYW5kIGltcHJvdmVtZW50cy4gVGhhbmtzIHRvIGV2ZXJ5b25lIHdobyBjb250cmlidXRlZCBzbyBoZWF2aWx5IG92ZXIgdGhlIGhvbGlkYXlzISBIYXBweSBuZXcgeWVhci4KCiMjIyMgQnJlYWtpbmcgQ2hhbmdlcwoKIyMjIyMgS3ViZXJuZXRlcyBgdjFfMzVgIHN1cHBvcnQgdmlhIGs4cy1vcGVuYXBpIFswLjI3XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vQXJuYXZpb24vazhzLW9wZW5hcGkvcmVsZWFzZXMvdGFnL3YwLjI3LjApCgpQbGVhc2UgW3VwZ3JhZGUgazhzLW9wZW5hcGkgYWxvbmcgd2l0aCBrdWJlXShodHRwczovL2t1YmUucnMvdXBncmFkaW5nLykgdG8gYXZvaWQgY29uZmxpY3RzLgoKIyMjIyMgYGppZmZgIHJlcGxhY2VzIGBjaHJvbm9gCgpNYXRjaGluZyBrOHMtb3BlbmFwaSdzIFtjaGFuZ2VdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9Bcm5hdmlvbi9rOHMtb3BlbmFwaS9jb21taXQvOGMxYjZmY2NiNzI1OGViNDg3ZWQ4YzgyOTc5MWQ0MjdhNGIxNjIxNiksIGt1YmUgaGFzIGFsc28gc3dhcHBlZCBvdXQgYGNocm9ub2AuIFRoZSBiaWdnZXN0IGltcGFjdCBvZiB0aGlzIGlzIGZvciBpbnRlcmFjdGluZyB3aXRoIHRpbWVzdGFtcHMgaW4gYG1ldGFkYXRhYCwgYnV0IGl0IGFsc28gdXBkYXRlcyAyIHNtYWxsZXIgcHVibGljIGludGVyZmFjZXMgaW4gW2BMb2dQYXJhbXNgXShodHRwczovL2RvY3MucnMva3ViZS9sYXRlc3Qva3ViZS9hcGkvc3RydWN0LkxvZ1BhcmFtcy5odG1sI3N0cnVjdGZpZWxkLnNpbmNlX3RpbWUpLCBbYENsaWVudDo6d2l0aF92YWxpZF91bnRpbGBdKGh0dHBzOi8vZG9jcy5ycy9rdWJlL2xhdGVzdC9rdWJlL3N0cnVjdC5DbGllbnQuaHRtbCNtZXRob2Qud2l0aF92YWxpZF91bnRpbCkuICBTZWUgW2NvbnRyb2xsZXItcnMjMjE3XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9jb250cm9sbGVyLXJzL3B1bGwvMjE3L2NoYW5nZXMpIGZvciBhbiBleGFtcGxlIGNoYW5nZS4KCkNoYW5nZXM6IFsjJiM4MjAzOzE4NjhdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODY4KSArIFsjJiM4MjAzOzE4NzBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODcwKQoKIyMjIyBgRXJyb3JSZXNwb25zZWAgaGFzIGJlZW4gcmVwbGFjZWQgd2l0aCBbYFN0YXR1c2BdKGh0dHBzOi8vZG9jcy5ycy9rdWJlL2xhdGVzdC9rdWJlL2NvcmUvc3RydWN0LlN0YXR1cy5odG1sKQoKYEVycm9yUmVzcG9uc2VgIHNlcnZlZCBhcyBhIHBhcnRpYWwgbWV0YXYxL1N0YXR1cyByZXBsYWNlbWVudCB3aGljaCBlbmRlZCB1cCBoaWRpbmcgZXJyb3IgaW5mb3JtYXRpb24gdG8gdXNlcnMuIFRoZXNlIHN0cnVjdHMgaGF2ZSBtZXJnZWQsIG1vcmUgaW5mb3JtYXRpb24gaXMgYXZhaWxhYmxlIG9uIGVycm9ycywgYW5kIGEgdHlwZSBhbGlhcyB3aXRoIGEgZGVwcmVjYXRpb24gd2FybmluZyBpcyBpbiBwbGFjZSBmb3IgW2BFcnJvclJlc3BvbnNlYF0oaHR0cHM6Ly9kb2NzLnJzL2t1YmUvbGF0ZXN0L2t1YmUvY29yZS90eXBlLkVycm9yUmVzcG9uc2UuaHRtbCkgd2hpY2ggd2lsbCBiZSByZW1vdmVkIGluIGEgbGF0ZXIgdmVyc2lvbi4KClRoaXMgY3JlYXRlcyBhIHNtYWxsIGJyZWFraW5nIGNoYW5nZSBmb3IgdXNlcnMgbWF0Y2hpbmcgb24gc3BlY2lmaWMgW2BFcnJvcjo6QXBpYF0oaHR0cHM6Ly9kb2NzLnJzL2t1YmUvbGF0ZXN0L2t1YmUvZW51bS5FcnJvci5odG1sI3ZhcmlhbnQuQXBpKSBjb2RlczsKCmBgYGRpZmYKICAgICAubWFwX2Vycih8ZXJyb3J8IG1hdGNoIGVycm9yIHsKLSAgICAgICAga3ViZTo6RXJyb3I6OkFwaShrdWJlOjplcnJvcjo6RXJyb3JSZXNwb25zZSB7IGNvZGU6IDQwMywgLi4gfSkgPT4gewotICAgICAgICAgICAgRXJyb3I6OlVuYXV0aG9yaXplZFRvUGF0Y2gob2JqKQotICAgICAgICB9CisgICAgICAgIGt1YmU6OkVycm9yOjpBcGkocykgaWYgcy5pc19mb3JiaWRkZW4oKSA9PiBFcnJvcjo6VW5hdXRob3JpemVkVG9QYXRjaChvYmopLAogICAgICAgICBvdGhlciA9PiBFcnJvcjo6T3RoZXIob3RoZXIpLAogICAgIH0pPzsKYGBgCgpbIyYjODIwMzsxODc1XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg3NSkgKyBbIyYjODIwMzsxODgzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4MykgKyBbIyYjODIwMzsxODkxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg5MSkuCgojIyMjIFByZWRpY2F0ZXMgbm93IGhhcyBhIFRUTCBDYWNoZQoKVGhpcyBwcmV2ZW50cyB1bmJvdW5kZWQgbWVtb3J5IGZvciBjb250cm9sbGVycywgcGFydGljdWxhcmx5IGFmZmVjdGluZyBvbmVzIHdhdGNoaW5nIHF1aWNrbHkgcm90YXRpbmcgb2JqZWN0cyB3aXRoIGdlbmVyYXRlZCBuYW1lcyAoZS5nLiBwb2RzKS4gQnkgZGVmYXVsdCB0aGUgVFRMIGlzIGAxaGAuIEl0IGNhbiBiZSBjb25maWd1cmVkIHZpYSBuZXcgW2BQcmVkaWNhdGVDb25maWdgXShodHRwczovL2RvY3MucnMva3ViZS9sYXRlc3Qva3ViZS9ydW50aW1lL3N0cnVjdC5QcmVkaWNhdGVDb25maWcuaHRtbCkgcGFyYW1ldGVyLiBUbyB1c2UgdGhlIGRlZmF1bHQ7CgpgYGBkaWZmCi0gICAgICAgIC5wcmVkaWNhdGVfZmlsdGVyKHByZWRpY2F0ZXM6OnJlc291cmNlX3ZlcnNpb24pOworICAgICAgICAucHJlZGljYXRlX2ZpbHRlcihwcmVkaWNhdGVzOjpyZXNvdXJjZV92ZXJzaW9uLCBEZWZhdWx0OjpkZWZhdWx0KCkpOwpgYGAKCkNoYW5nZSBpbiBbIyYjODIwMzsxODM2XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTgzNikuIFRoaXMgaGVscGVkIGV4cG9zZSBhbmQgZml4IGEgYnVnIGluIHdhdGNoZXMgd2l0aCBzdHJlYW1pbmdcX2xpc3RzIG5vdyBmaXhlZCBpbiBbIyYjODIwMzsxODgyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4MikuCgojIyMjIFN1YnJlc291cmNlIEFwaQoKU29tZSBzdWJyZXNvdXJjZSB3cml0ZSBtZXRob2RzIHdlcmUgcHVibGljIHdpdGggaW5jb25zaXN0ZW50IHNpZ25hdHVyZXMgdGhhdCByZXF1aXJlZCBsZXNzIGVyZ29ub21pYyB1c2UgdGhhbiBhbnkgb3RoZXIgd3JpdGUgbWV0aG9kcy4gVGhleSB0b29rIGEgYFZlYzx1OD5gIGZvciB0aGUgcG9zdCBib2R5LCBub3cgdGhleSB0YWtlIGEgYCZLOiBTZXJpYWxpemVgIG9yIHRoZSBhY3R1YWwgc3VicmVzb3VyY2UuClRoZXJlIGFmZmVjdCBgQXBpOjpjcmVhdGVfc3VicmVzb3VyY2VgLCBgQXBpOjpyZXBsYWNlX3N1YnJlc291cmNlYCwgW2BBcGk6OnJlcGxhY2Vfc3RhdHVzYF0oaHR0cHM6Ly9kb2NzLnJzL2t1YmUvbGF0ZXN0L2t1YmUvc3RydWN0LkFwaS5odG1sI21ldGhvZC5yZXBsYWNlX3N0YXR1cyksIGBBcGk6OnJlcGxhY2Vfc2NhbGVgLiBJbiBlc3NlbmNlIHRoaXMgZ2VuZXJhbGx5IG1lYW5zIHlvdSBkbyBub3QgaGF2ZSB0byB3cmFwIHJhdyBvYmplY3RzIGluIGBqc29uIWAgYW5kIGBzZXJkZV9qc29uOjp0b192ZWNgIGZvciB0aGVzZSBjYWxscyBhbmQgbGVhbiBtb3JlIG9uIHJ1c3QncyB0eXBlZCBvYmplY3RzIHJhdGhlciB0aGFuIGBqc29uIWAgYmxvYnMgd2hpY2ggaGFzIHNvbWUgW2Zvb3RndW5zXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4NCNkaXNjdXNzaW9uX3IyNjgwNzgyNTU2KSBmb3Igc3VicmVzb3VyY2VzLgoKYGBgZGlmZgotICAgIGxldCBvID0gZm9vcy5yZXBsYWNlX3N0YXR1cygicXV4IiwgJnBwLCBzZXJkZV9qc29uOjp0b192ZWMoJm9iamVjdCk/KS5hd2FpdD87CisgICAgbGV0IG8gPSBmb29zLnJlcGxhY2Vfc3RhdHVzKCJxdXgiLCAmcHAsICZvYmplY3QpLmF3YWl0PzsKYGBgCgpTZWUgc29tZSBtb3JlIHNoaWZ0cyBpbiBleGFtcGxlcyBpbiB0aGUgaW1wbGVtZW50YXRpb247IFsjJiM4MjAzOzE4ODRdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODg0KQoKIyMjIyBJbXByb3ZlbWVudHMKCiMjIyMjIFN1cHBvcnQgS3ViZXJuZXRlcyAxLjMwIFtBZ2dyZWdhdGVkIERpc2NvdmVyeV0oaHR0cHM6Ly9rdWJlcm5ldGVzLmlvL2RvY3MvY29uY2VwdHMvb3ZlcnZpZXcva3ViZXJuZXRlcy1hcGkvI2FnZ3JlZ2F0ZWQtZGlzY292ZXJ5KQoKU3BlZWRzIHVwIGFwaSBkaXNjb3ZlcnkgKipzaWduaWZpY2FudGx5KiogYnkgdXNpbmcgdGhlIG5ld2VyIGFwaSB3aXRoIG11Y2ggbGVzcyByb3VuZC10cmlwcGluZy4KVG8gb3B0LWluIGNoYW5nZSBgRGlzY292ZXJ5OjpydW4oKWAgdG8gW2BEaXNjb3Zlcnk6OnJ1bl9hZ2dyZWdhdGVkKClgXShodHRwczovL2RvY3MucnMva3ViZS9sYXRlc3Qva3ViZS9zdHJ1Y3QuRGlzY292ZXJ5Lmh0bWwjbWV0aG9kLnJ1bl9hZ2dyZWdhdGVkKQoKQ2hhbmdlczsgWyMmIzgyMDM7MTg3Nl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NzYpICsgWyMmIzgyMDM7MTg3M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NzMpICsgWyMmIzgyMDM7MTg4OV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4ODkpCgojIyMjIyBSdXN0IDIwMjQKCldoaWxlIHRoaXMgaXMgbW9zdGx5IGZvciBpbnRlcm5hbCBlcmdvbm9taWNzLCB3ZSB3b3VsZCBsaWtlIHRvIGhpZ2hsaWdodCB0aGlzIGFsc28gc2ltcGxpZmllcyB0aGUgW2BDb25kaXRpb25gXShodHRwczovL2RvY3MucnMva3ViZS9sYXRlc3Qva3ViZS9ydW50aW1lL3dhaXQvY29uZGl0aW9ucy90cmFpdC5Db25kaXRpb24uaHRtbCkgaW1wbGVtZW50b3JzIHdoaWNoIGhhZCB0byBkZWFsIHdpdGggYSBsb3Qgb2Ygb3B0aW9uczsKCmBgYGRpZmYKICAgIHB1YiBmbiBpc19qb2JfY29tcGxldGVkKCkgLT4gaW1wbCBDb25kaXRpb248Sm9iPiB7CiAgICAgICAgfG9iajogT3B0aW9uPCZKb2I+fCB7Ci0gICAgICAgICAgICBpZiBsZXQgU29tZShqb2IpID0gJm9iaiB7Ci0gICAgICAgICAgICAgICAgaWYgbGV0IFNvbWUocykgPSAmam9iLnN0YXR1cyB7Ci0gICAgICAgICAgICAgICAgICAgIGlmIGxldCBTb21lKGNvbmRzKSA9ICZzLmNvbmRpdGlvbnMgewotICAgICAgICAgICAgICAgICAgICAgICAgaWYgbGV0IFNvbWUocGNvbmQpID0gY29uZHMuaXRlcigpLmZpbmQofGN8IGMudHlwZV8gPT0gIkNvbXBsZXRlIikgewotICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBwY29uZC5zdGF0dXMgPT0gIlRydWUiOwotICAgICAgICAgICAgICAgICAgICAgICAgfQotICAgICAgICAgICAgICAgICAgICB9Ci0gICAgICAgICAgICAgICAgfQorICAgICAgICAgICAgaWYgbGV0IFNvbWUoam9iKSA9ICZvYmoKKyAgICAgICAgICAgICAgICAmJiBsZXQgU29tZShzKSA9ICZqb2Iuc3RhdHVzCisgICAgICAgICAgICAgICAgJiYgbGV0IFNvbWUoY29uZHMpID0gJnMuY29uZGl0aW9ucworICAgICAgICAgICAgICAgICYmIGxldCBTb21lKHBjb25kKSA9IGNvbmRzLml0ZXIoKS5maW5kKHxjfCBjLnR5cGVfID09ICJDb21wbGV0ZSIpCisgICAgICAgICAgICB7CisgICAgICAgICAgICAgICAgcmV0dXJuIHBjb25kLnN0YXR1cyA9PSAiVHJ1ZSI7CmBgYAoKQ2hhbmdlIFsjJiM4MjAzOzE4NTZdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODU2KSArIFsjJiM4MjAzOzE3OTJdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xNzkyKQoKIyMjIyMgTmV3IENsaWVudCBbYFJldHJ5UG9saWN5YF0oaHR0cHM6Ly9kb2NzLnJzL2t1YmUvbGF0ZXN0L2t1YmUvY2xpZW50L3JldHJ5L3N0cnVjdC5SZXRyeVBvbGljeS5odG1sKSBvcHQtaW4KCkFsbG93cyBjdXN0b20gY2xpZW50cyAoZm9yIG5vdykgdG8gZW5hYmxlIGV4cG9uZW50aWFsIGJhY2tvZmYnZCByZXRyaWVzIGZvciByZXRyeWFibGUgZXJyb3JzIGJ5IGV4cG9zaW5nIGEgW2B0b3dlcjo6cmV0cnk6OlBvbGljeWBdKGh0dHBzOi8vdG93ZXItcnMuZ2l0aHViLmlvL3Rvd2VyL3Rvd2VyL3JldHJ5L3RyYWl0LlBvbGljeS5odG1sKSBmb3IgYSBbYHRvd2VyOjpyZXRyeTo6TGF5ZXJgXShodHRwczovL3Rvd2VyLXJzLmdpdGh1Yi5pby90b3dlci90b3dlci9yZXRyeS9zdHJ1Y3QuUmV0cnlMYXllci5odG1sKS4gU2VlIHRoZSBuZXcgW2N1c3RvbVxfY2xpZW50XF9yZXRyeV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9ibG9iL21haW4vZXhhbXBsZXMvY3VzdG9tX2NsaWVudF9yZXRyeS5ycyNMMjQtTDM3KSBleGFtcGxlIGZvciBkZXRhaWxzLgoKRW5hYmxlZCBieSBhIFtjbG9uZWFibGUgYm9keV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NjcpICsgdGhlIG5ldyBbUmV0cnlQb2xpY3ldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODk0KSBiYXNlZCBvbiBtaXJyb3JkJ3Mgc29sdXRpb25bXCpdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9tZXRhbGJlYXItY28vbWlycm9yZC9ibG9iL2E5ZTRjNTJhNzIwZmQ1YTgzM2UzMGFlZTFhYzY1MDM2MDAzMWI3YTcvbWlycm9yZC9rdWJlL3NyYy9yZXRyeS5ycyNMNDEtTDEzNSkuCgojIyMjIEZpeGVzCgotIHN0cmVhbWluZyBsaXN0IGJ1ZyBmaXggLSBbIyYjODIwMzsxODgyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4MikKLSB3YXRjaGVyIGppdHRlciBidWcgZml4IC0gWyMmIzgyMDM7MTg5N10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4OTcpCi0gc2NoZW1hIGZpeCBmb3IgSW50T3JTdHJpbmcgLSBbIyYjODIwMzsxODY3XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg2NykKLSBzY2hlbWEgZml4IGZvciBvcHRpb25hbCBlbnVtcyAtIFsjJiM4MjAzOzE4NTNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODUzKQotIHdlYnNvY2tldCBrZWVwYWxpdmVzIGZvciBsb25nIHJ1bm5pbmcgYXR0YWNoZXMgLSBbIyYjODIwMzsxODg5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4OSkKCiMjIyMjIE1vcmUKCi0gYFJlc2l6ZWAgc3VicmVzb3VyY2UgaW1wbCBmb3IgYFBvZGAgLSBbIyYjODIwMzsxODUxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg1MSkKLSBhZGQgYCNba3ViZShhdHRyPSIuLi4iKWAgdG8gYWxsb3cgY3VzdG9tIGF0dHJzIG9uIGRlcml2ZXMgLSBbIyYjODIwMzsxODUwXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg1MCkKLSBleGFtcGxlIHVwZGF0ZXMgZm9yIGFkbWlzc2lvbiB3L2F4dW0gLSBbIyYjODIwMzsxODU5XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg1OSkKCiMjIyMgV2hhdCdzIENoYW5nZWQKCiMjIyMjIEFkZGVkCgotIEFkZCBgUmVzaXplYCBzdWJyZXNvdXJjZSBmb3IgYFBvZGAgYnkgW0AmIzgyMDM7aHVnb3BvbnRoaWV1XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vaHVnb3BvbnRoaWV1KSBpbiBbIyYjODIwMzsxODUxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg1MSkKLSBmZWF0OiBhZGQgI1xba3ViZShhdHRyPSIuLi4iKV0gYXR0cmlidXRlIGhlbHBlciB0byBzZXQgYXR0cmlidXRlIGhlbHBlciBvbiB0aGUgQ1Igcm9vdCB0eXBlIGJ5IFtAJiM4MjAzO25nZXJnc10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL25nZXJncykgaW4gWyMmIzgyMDM7MTg1MF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NTApCi0gUnVzdCAyMDI0IGxldC1jaGFpbnMgdG8gc2ltcGxpZnkgd2FpdCBDb25kaXRpb25zIGJ5IFtAJiM4MjAzO2NsdXhdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9jbHV4KSBpbiBbIyYjODIwMzsxNzkyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTc5MikKLSBBZGRzIGEgYHRyeV9jbG9uZWAgbWV0aG9kIGZvciBga3ViZV9jbGllbnQ6OmNsaWVudDo6Qm9keWAgd2hlbiBpdCdzIGBLaW5kOjpPbmNlYCBieSBbQCYjODIwMzttZW93amVzdHldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9tZW93amVzdHkpIGluIFsjJiM4MjAzOzE4NjddKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODY3KQotIEltcGxlbWVudCBjbGllbnQgYWdncmVnYXRlZCBkaXNjb3ZlcnkgQVBJIG1ldGhvZHMgYnkgW0AmIzgyMDM7ZG94eHg5M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RveHh4OTMpIGluIFsjJiM4MjAzOzE4NzNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODczKQotIEltcGxlbWVudCBhZ2dyZWdhdGVkIGRpc2NvdmVyeSBBUEkgbWV0aG9kcyBieSBbQCYjODIwMztkb3h4eDkzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vZG94eHg5MykgaW4gWyMmIzgyMDM7MTg3Nl0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NzYpCi0gUGVybWl0IG9sZGVyIHZlcnNpb24gb2YgQVBJIGZvciB2MiBkaXNjb3ZlcnkgZm9yIGs4cyA8IDEuMzAgKGRvd24gdG8gMS4yNykgYnkgW0AmIzgyMDM7RGFuaWwtR3JpZ29yZXZdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9EYW5pbC1Hcmlnb3JldikgaW4gWyMmIzgyMDM7MTg4OV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4ODkpCi0gQWRkIFJldHJ5UG9saWN5IGZvciBjbGllbnQtbGV2ZWwgcmVxdWVzdCByZXRyaWVzIGJ5IFtAJiM4MjAzO2RveHh4OTNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9kb3h4eDkzKSBpbiBbIyYjODIwMzsxODk0XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg5NCkKCiMjIyMjIENoYW5nZWQKCi0gVXBkYXRlIHRva2lvLXR1bmdzdGVuaXRlIHJlcXVpcmVtZW50IGZyb20gMC4yNy4wIHRvIDAuMjguMCBieSBbQCYjODIwMztkZXBlbmRhYm90XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vZGVwZW5kYWJvdClcW2JvdF0gaW4gWyMmIzgyMDM7MTgyOV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4MjkpCi0gUHJlZGljYXRlczogYWRkIGNvbmZpZ3VyYWJsZSBjYWNoZSBUVEwgZm9yIGBwcmVkaWNhdGVfZmlsdGVyYCBieSBbQCYjODIwMztkb3h4eDkzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vZG94eHg5MykgaW4gWyMmIzgyMDM7MTgzOF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4MzgpCi0gVXBkYXRlIGRhcmxpbmcgcmVxdWlyZW1lbnQgZnJvbSAwLjIxLjAgdG8gMC4yMy4wIGJ5IFtAJiM4MjAzO2RlcGVuZGFib3RdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9kZXBlbmRhYm90KVxbYm90XSBpbiBbIyYjODIwMzsxODYxXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg2MSkKLSB1cGRhdGUgdG8ganNvbnBhdGgtcnVzdCAxIGJ5IFtAJiM4MjAzO3RvdHRvdG9dKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS90b3R0b3RvKSBpbiBbIyYjODIwMzsxODYzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg2MykKLSBSZXBsYWNlIGBjaHJvbm9gIHdpdGggYGppZmZgIGJ5IFtAJiM4MjAzO25nZXJnc10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL25nZXJncykgaW4gWyMmIzgyMDM7MTg2OF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NjgpCi0gTWVyZ2UgRXJyb3JSZXNwb25zZSBhbmQgU3RhdHVzIGJ5IFtAJiM4MjAzO2ltcF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2ltcCkgaW4gWyMmIzgyMDM7MTg3NV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NzUpCi0gTWFrZSBzdWJyZXNvdXJjZSBtZXRob2RzIG1vcmUgZXJnb25vbWljIGJ5IFtAJiM4MjAzO2RveHh4OTNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9kb3h4eDkzKSBpbiBbIyYjODIwMzsxODg0XShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4NCkKLSBEcm9wIGs4cyB2MS4zMCwgY3Jvbm8tPmppZmYgcmVwbGFjZW1lbnQgZm9yIHJ1bnRpbWUgJiBleGFtcGxlcyBieSBbQCYjODIwMztuZ2VyZ3NdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9uZ2VyZ3MpIGluIFsjJiM4MjAzOzE4NzBdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODcwKQotIEFkZCBhIG1ldGFkYXRhIGZpZWxkIHRvIFN0YXR1cyBieSBbQCYjODIwMztyeWFucGJyZXdzdGVyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vcnlhbnBicmV3c3RlcikgaW4gWyMmIzgyMDM7MTg5MV0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4OTEpCi0gQnVtcCBgazhzLW9wZW5hcGlgIGZvciBLdWJlcm5ldGVzIDEuMzUgYnkgW0AmIzgyMDM7Y2x1eF0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2NsdXgpIGluIFsjJiM4MjAzOzE4OThdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODk4KQoKIyMjIyMgRml4ZWQKCi0gZml4OiBhZGQgdXNlPD4gdG8ga3ViZWxldFxfbm9kZVxfbG9ncyBmb3IgcnVzdCBlZGl0aW9uIDIwMjQgYnkgW0AmIzgyMDM7Y280Ml0oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2NvNDIpIGluIFsjJiM4MjAzOzE4NDldKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODQ5KQotIFRyYW5zZm9ybSBvcHRpb25hbCBlbnVtcyB0byBtYXRjaCBwcmUga3ViZSAyLjAuMCBmb3JtYXQgYnkgW0AmIzgyMDM7RGFuaWwtR3JpZ29yZXZdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9EYW5pbC1Hcmlnb3JldikgaW4gWyMmIzgyMDM7MTg1M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4NTMpCi0gRGlzdGluZ3Vpc2ggYmV0d2VlbiBpbml0aWFsIGFuZCByZXN1bWVkIHdhdGNoIHBoYXNlcyBmb3Igc3RyZWFtaW5nIGxpc3RzIGJ5IFtAJiM4MjAzO2RveHh4OTNdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9kb3h4eDkzKSBpbiBbIyYjODIwMzsxODgyXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4MikKLSBSZS1leHBvcnQgZGVwcmVjYXRlZCB0eXBlIGFsaWFzIGFuZCBpbXByb3ZlIGRlcHJlY2F0aW9uIGd1aWRhbmNlIGJ5IFtAJiM4MjAzO2NsdXhdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9jbHV4KSBpbiBbIyYjODIwMzsxODgzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20va3ViZS1ycy9rdWJlL3B1bGwvMTg4MykKLSBBZGQgbnVsbGFibGUgdG8gb3B0aW9uYWwgZmllbGRzIHdpdGggeC1rdWJlcm5ldGVzLWludC1vci1zdHJpbmcgYnkgW0AmIzgyMDM7ZG94eHg5M10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2RveHh4OTMpIGluIFsjJiM4MjAzOzE4ODVdKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODg1KQotIHNlbmQgd2Vic29ja2V0IHBpbmcgdG8ga2VlcCBpZGxlIGNvbm5lY3Rpb25zIGFsaXZlIGJ5IFtAJiM4MjAzO2lucW9kZS1sYXJzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vaW5xb2RlLWxhcnMpIGluIFsjJiM4MjAzOzE4ODddKGh0dHBzOi8vcmVkaXJlY3QuZ2l0aHViLmNvbS9rdWJlLXJzL2t1YmUvcHVsbC8xODg3KQotIEZpeCB3YXRjaGVyIEV4cG9uZW50aWFsQmFja29mZiBqaXR0ZXIgaWdub3JlZCBieSBbQCYjODIwMztkb3h4eDkzXShodHRwczovL3JlZGlyZWN0LmdpdGh1Yi5jb20vZG94eHg5MykgaW4gWyMmIzgyMDM7MTg5N10oaHR0cHM6Ly9yZWRpcmVjdC5naXRodWIuY29tL2t1YmUtcnMva3ViZS9wdWxsLzE4OTcpCgo8L2RldGFpbHM+CgotLS0KCiMjIyBDb25maWd1cmF0aW9uCgrwn5OFICoqU2NoZWR1bGUqKjogQnJhbmNoIGNyZWF0aW9uIC0gQXQgYW55IHRpbWUgKG5vIHNjaGVkdWxlIGRlZmluZWQpLCBBdXRvbWVyZ2UgLSBBdCBhbnkgdGltZSAobm8gc2NoZWR1bGUgZGVmaW5lZCkuCgrwn5qmICoqQXV0b21lcmdlKio6IERpc2FibGVkIGJ5IGNvbmZpZy4gUGxlYXNlIG1lcmdlIHRoaXMgbWFudWFsbHkgb25jZSB5b3UgYXJlIHNhdGlzZmllZC4KCuKZuyAqKlJlYmFzaW5nKio6IFdoZW5ldmVyIFBSIGlzIGJlaGluZCBiYXNlIGJyYW5jaCwgb3IgeW91IHRpY2sgdGhlIHJlYmFzZS9yZXRyeSBjaGVja2JveC4KCvCflJUgKipJZ25vcmUqKjogQ2xvc2UgdGhpcyBQUiBhbmQgeW91IHdvbid0IGJlIHJlbWluZGVkIGFib3V0IHRoaXMgdXBkYXRlIGFnYWluLgoKLS0tCgogLSBbIF0gPCEtLSByZWJhc2UtY2hlY2sgLS0+SWYgeW91IHdhbnQgdG8gcmViYXNlL3JldHJ5IHRoaXMgUFIsIGNoZWNrIHRoaXMgYm94CgotLS0KClRoaXMgUFIgd2FzIGdlbmVyYXRlZCBieSBbTWVuZCBSZW5vdmF0ZV0oaHR0cHM6Ly9tZW5kLmlvL3Jlbm92YXRlLykuIFZpZXcgdGhlIFtyZXBvc2l0b3J5IGpvYiBsb2ddKGh0dHBzOi8vZGV2ZWxvcGVyLm1lbmQuaW8vZ2l0aHViL3ZleHhob3N0L21hZ251bS1jbHVzdGVyLWFwaSkuCjwhLS1yZW5vdmF0ZS1kZWJ1ZzpleUpqY21WaGRHVmtTVzVXWlhJaU9pSTBNQzR4TVM0NUlpd2lkWEJrWVhSbFpFbHVWbVZ5SWpvaU5ETXVOall1TkNJc0luUmhjbWRsZEVKeVlXNWphQ0k2SW0xaGFXNGlMQ0pzWVdKbGJITWlPbHRkZlE9PS0tPgo=
      override_checkout: master
      patchset: 12fec567ed329a015d3964c475e25b8e5275f3eb
      pipeline: check
      playbook_context:
        playbook_projects:
          trusted/project_0/github.com/vexxhost/zuul-config:
            canonical_name: github.com/vexxhost/zuul-config
            checkout: main
            commit: 9052b5a7781b3346e4cffd452a54448cbff54d8b
          trusted/project_1/opendev.org/zuul/zuul-jobs:
            canonical_name: opendev.org/zuul/zuul-jobs
            checkout: master
            commit: c75fe6ef19c05b98349573c971950c51bbf24758
          trusted/project_2/github.com/vexxhost/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: a6e68243e02ef030ce5e75f8b67630880c475f33
          untrusted/project_0/opendev.org/openstack/devstack:
            canonical_name: opendev.org/openstack/devstack
            checkout: master
            commit: 416d27e89e0c1891921fee2a692086eb8fcd0307
          untrusted/project_1/opendev.org/openstack/openstack-zuul-jobs:
            canonical_name: opendev.org/openstack/openstack-zuul-jobs
            checkout: master
            commit: 3d5175f90e389f3240a8400a792abaaeb51bee3b
          untrusted/project_2/github.com/vexxhost/zuul-config:
            canonical_name: github.com/vexxhost/zuul-config
            checkout: main
            commit: 9052b5a7781b3346e4cffd452a54448cbff54d8b
          untrusted/project_3/opendev.org/zuul/zuul-jobs:
            canonical_name: opendev.org/zuul/zuul-jobs
            checkout: master
            commit: c75fe6ef19c05b98349573c971950c51bbf24758
          untrusted/project_4/github.com/vexxhost/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: a6e68243e02ef030ce5e75f8b67630880c475f33
          untrusted/project_5/github.com/vexxhost/magnum-cluster-api:
            canonical_name: github.com/vexxhost/magnum-cluster-api
            checkout: main
            commit: ba7a6fc9b0c447bcf908b92d6b7b9731dc91da42
        playbooks:
        - path: untrusted/project_5/github.com/vexxhost/magnum-cluster-api/zuul.d/playbooks/hydrophone/run.yml
          roles:
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/playbook_0/role_1/devstack
            link_target: untrusted/project_0/opendev.org/openstack/devstack
            role_path: ansible/playbook_0/role_1/devstack/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/playbook_0/role_2/openstack-zuul-jobs
            link_target: untrusted/project_1/opendev.org/openstack/openstack-zuul-jobs
            role_path: ansible/playbook_0/role_2/openstack-zuul-jobs/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/playbook_0/role_4/zuul-jobs
            link_target: untrusted/project_3/opendev.org/zuul/zuul-jobs
            role_path: ansible/playbook_0/role_4/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/playbook_0/role_5/zuul-jobs
            link_target: untrusted/project_4/github.com/vexxhost/zuul-jobs
            role_path: ansible/playbook_0/role_5/zuul-jobs/roles
        post_playbooks:
        - path: untrusted/project_5/github.com/vexxhost/magnum-cluster-api/zuul.d/playbooks/hydrophone/post.yml
          roles:
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/post_playbook_0/role_1/devstack
            link_target: untrusted/project_0/opendev.org/openstack/devstack
            role_path: ansible/post_playbook_0/role_1/devstack/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/post_playbook_0/role_2/openstack-zuul-jobs
            link_target: untrusted/project_1/opendev.org/openstack/openstack-zuul-jobs
            role_path: ansible/post_playbook_0/role_2/openstack-zuul-jobs/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/post_playbook_0/role_4/zuul-jobs
            link_target: untrusted/project_3/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_0/role_4/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_0/role_5/zuul-jobs
            link_target: untrusted/project_4/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_0/role_5/zuul-jobs/roles
        - path: untrusted/project_0/opendev.org/openstack/devstack/playbooks/post.yaml
          roles:
          - checkout: master
            checkout_description: playbook branch
            link_name: ansible/post_playbook_1/role_0/devstack
            link_target: untrusted/project_0/opendev.org/openstack/devstack
            role_path: ansible/post_playbook_1/role_0/devstack/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/post_playbook_1/role_1/openstack-zuul-jobs
            link_target: untrusted/project_1/opendev.org/openstack/openstack-zuul-jobs
            role_path: ansible/post_playbook_1/role_1/openstack-zuul-jobs/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/post_playbook_1/role_3/zuul-jobs
            link_target: untrusted/project_3/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_1/role_3/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_1/role_4/zuul-jobs
            link_target: untrusted/project_4/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_1/role_4/zuul-jobs/roles
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/post.yaml
          roles:
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/post_playbook_2/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_2/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_2/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_2/role_2/zuul-jobs/roles
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/post-logs.yaml
          roles:
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/post_playbook_3/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_3/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_3/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_3/role_2/zuul-jobs/roles
        pre_playbooks:
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/pre.yaml
          roles:
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/pre_playbook_0/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/pre_playbook_0/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_0/role_2/zuul-jobs/roles
        - path: untrusted/project_0/opendev.org/openstack/devstack/playbooks/pre.yaml
          roles:
          - checkout: master
            checkout_description: playbook branch
            link_name: ansible/pre_playbook_1/role_0/devstack
            link_target: untrusted/project_0/opendev.org/openstack/devstack
            role_path: ansible/pre_playbook_1/role_0/devstack/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/pre_playbook_1/role_1/openstack-zuul-jobs
            link_target: untrusted/project_1/opendev.org/openstack/openstack-zuul-jobs
            role_path: ansible/pre_playbook_1/role_1/openstack-zuul-jobs/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/pre_playbook_1/role_3/zuul-jobs
            link_target: untrusted/project_3/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_1/role_3/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/pre_playbook_1/role_4/zuul-jobs
            link_target: untrusted/project_4/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_1/role_4/zuul-jobs/roles
        - path: untrusted/project_5/github.com/vexxhost/magnum-cluster-api/zuul.d/playbooks/hydrophone/pre.yml
          roles:
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/pre_playbook_2/role_1/devstack
            link_target: untrusted/project_0/opendev.org/openstack/devstack
            role_path: ansible/pre_playbook_2/role_1/devstack/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/pre_playbook_2/role_2/openstack-zuul-jobs
            link_target: untrusted/project_1/opendev.org/openstack/openstack-zuul-jobs
            role_path: ansible/pre_playbook_2/role_2/openstack-zuul-jobs/roles
          - checkout: master
            checkout_description: job override ref
            link_name: ansible/pre_playbook_2/role_4/zuul-jobs
            link_target: untrusted/project_3/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_2/role_4/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/pre_playbook_2/role_5/zuul-jobs
            link_target: untrusted/project_4/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_2/role_5/zuul-jobs/roles
      post_review: false
      post_timeout: null
      pre_timeout: null
      project:
        canonical_hostname: github.com
        canonical_name: github.com/vexxhost/magnum-cluster-api
        name: vexxhost/magnum-cluster-api
        short_name: magnum-cluster-api
        src_dir: src/github.com/vexxhost/magnum-cluster-api
      projects:
        github.com/novnc/novnc:
          canonical_hostname: github.com
          canonical_name: github.com/novnc/novnc
          checkout: master
          checkout_description: job override ref
          commit: 8e1ebdffba02e651c399dacef841f8941f6ad6e4
          name: novnc/novnc
          required: true
          short_name: novnc
          src_dir: src/github.com/novnc/novnc
        github.com/vexxhost/magnum-cluster-api:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/magnum-cluster-api
          checkout: main
          checkout_description: zuul branch
          commit: ba7a6fc9b0c447bcf908b92d6b7b9731dc91da42
          name: vexxhost/magnum-cluster-api
          required: false
          short_name: magnum-cluster-api
          src_dir: src/github.com/vexxhost/magnum-cluster-api
        opendev.org/openstack/barbican:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/barbican
          checkout: master
          checkout_description: job override ref
          commit: f8a331a40eb21e6c8f37e07794d57aa98b120af9
          name: openstack/barbican
          required: true
          short_name: barbican
          src_dir: src/opendev.org/openstack/barbican
        opendev.org/openstack/cinder:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/cinder
          checkout: master
          checkout_description: job override ref
          commit: 2190f0549e1276cb674f26c0ca28fccfecdc0b4c
          name: openstack/cinder
          required: true
          short_name: cinder
          src_dir: src/opendev.org/openstack/cinder
        opendev.org/openstack/devstack:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/devstack
          checkout: master
          checkout_description: job override ref
          commit: 416d27e89e0c1891921fee2a692086eb8fcd0307
          name: openstack/devstack
          required: true
          short_name: devstack
          src_dir: src/opendev.org/openstack/devstack
        opendev.org/openstack/glance:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/glance
          checkout: master
          checkout_description: job override ref
          commit: 8c43caaefd8820e3e45b3c95b60bc6e1c668c55b
          name: openstack/glance
          required: true
          short_name: glance
          src_dir: src/opendev.org/openstack/glance
        opendev.org/openstack/keystone:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/keystone
          checkout: master
          checkout_description: job override ref
          commit: 1e13c5f205bed9b7a2ebe5a437c1cc80b7072ab0
          name: openstack/keystone
          required: true
          short_name: keystone
          src_dir: src/opendev.org/openstack/keystone
        opendev.org/openstack/magnum:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/magnum
          checkout: master
          checkout_description: job override ref
          commit: 75ca7d532cd6894ac79a4633bfa19842547d372c
          name: openstack/magnum
          required: true
          short_name: magnum
          src_dir: src/opendev.org/openstack/magnum
        opendev.org/openstack/manila:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/manila
          checkout: master
          checkout_description: job override ref
          commit: 9b2f3dd900797a70dcb4b8948f67b1a1be8dec2f
          name: openstack/manila
          required: true
          short_name: manila
          src_dir: src/opendev.org/openstack/manila
        opendev.org/openstack/neutron:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/neutron
          checkout: master
          checkout_description: job override ref
          commit: 0cb298d7812fc7ce83145c0ddf914bfec0491b25
          name: openstack/neutron
          required: true
          short_name: neutron
          src_dir: src/opendev.org/openstack/neutron
        opendev.org/openstack/nova:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/nova
          checkout: master
          checkout_description: job override ref
          commit: 327c790ec87e95e81900118537b68ed94e8e4475
          name: openstack/nova
          required: true
          short_name: nova
          src_dir: src/opendev.org/openstack/nova
        opendev.org/openstack/octavia:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/octavia
          checkout: master
          checkout_description: job override ref
          commit: b2e084e8734255a5a7027fd2b8c7ae6831ce8f2f
          name: openstack/octavia
          required: true
          short_name: octavia
          src_dir: src/opendev.org/openstack/octavia
        opendev.org/openstack/os-test-images:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/os-test-images
          checkout: master
          checkout_description: job override ref
          commit: 5d0367e03788764f41da8effffa14e3eac513201
          name: openstack/os-test-images
          required: true
          short_name: os-test-images
          src_dir: src/opendev.org/openstack/os-test-images
        opendev.org/openstack/ovn-octavia-provider:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/ovn-octavia-provider
          checkout: master
          checkout_description: job override ref
          commit: 83b1d9f26be4f4bcd941a5b339a8858ef250e24f
          name: openstack/ovn-octavia-provider
          required: true
          short_name: ovn-octavia-provider
          src_dir: src/opendev.org/openstack/ovn-octavia-provider
        opendev.org/openstack/placement:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/placement
          checkout: master
          checkout_description: job override ref
          commit: e3db398fba279721121892323e6260c6932797c1
          name: openstack/placement
          required: true
          short_name: placement
          src_dir: src/opendev.org/openstack/placement
        opendev.org/openstack/python-magnumclient:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/python-magnumclient
          checkout: master
          checkout_description: job override ref
          commit: bfc9dbc2aa9a113c12e591a87f774a6d986a981f
          name: openstack/python-magnumclient
          required: true
          short_name: python-magnumclient
          src_dir: src/opendev.org/openstack/python-magnumclient
        opendev.org/openstack/requirements:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/requirements
          checkout: master
          checkout_description: job override ref
          commit: 2897d874a900d28bbeb8ed59a78193477c76296c
          name: openstack/requirements
          required: true
          short_name: requirements
          src_dir: src/opendev.org/openstack/requirements
        opendev.org/openstack/swift:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/swift
          checkout: master
          checkout_description: job override ref
          commit: 2d15320f093f7e199f7619aec92b2dd683895c5b
          name: openstack/swift
          required: true
          short_name: swift
          src_dir: src/opendev.org/openstack/swift
      ref: refs/pull/702/head
      resources: {}
      tenant: oss
      timeout: 7200
      topic: null
      voting: true
    zuul_copy_output:
      /etc/ceph: logs
      /etc/glusterfs/glusterd.vol: logs
      /etc/libvirt: logs
      /etc/lvm: logs
      /etc/resolv.conf: logs
      /etc/sudoers: logs
      /etc/sudoers.d: logs
      /var/log/ceph: logs
      /var/log/glusterfs: logs
      /var/log/libvirt: logs
      /var/log/mysql: logs
      /var/log/openvswitch: logs
      /var/log/postgresql: logs
      /var/log/rabbitmq: logs
      /var/log/unbound.log: logs
      '{{ devstack_conf_dir }}/.localrc.auto': logs
      '{{ devstack_conf_dir }}/.stackenv': logs
      '{{ devstack_conf_dir }}/local.conf': logs
      '{{ devstack_conf_dir }}/localrc': logs
      '{{ devstack_full_log}}': logs
      '{{ devstack_log_dir }}/atop': logs
      '{{ devstack_log_dir }}/devstacklog.txt': logs
      '{{ devstack_log_dir }}/devstacklog.txt.summary': logs
      '{{ devstack_log_dir }}/dstat-csv.log': logs
      '{{ devstack_log_dir }}/qemu.coredump': logs
      '{{ devstack_log_dir }}/tcpdump.pcap': logs
      '{{ devstack_log_dir }}/worlddump-latest.txt': logs
      '{{ stage_dir }}/apache': logs
      '{{ stage_dir }}/apache_config': logs
      '{{ stage_dir }}/audit.log': logs
      '{{ stage_dir }}/core': logs
      '{{ stage_dir }}/deprecations.log': logs
      '{{ stage_dir }}/df.txt': logs
      '{{ stage_dir }}/dpkg-l.txt': logs
      '{{ stage_dir }}/etc': logs
      '{{ stage_dir }}/iptables.txt': logs
      '{{ stage_dir }}/listen53.txt': logs
      '{{ stage_dir }}/mount.txt': logs
      '{{ stage_dir }}/performance.json': logs
      '{{ stage_dir }}/pip2-freeze.txt': logs
      '{{ stage_dir }}/pip3-freeze.txt': logs
      '{{ stage_dir }}/rpm-qa.txt': logs
      '{{ stage_dir }}/services.txt': logs
      '{{ stage_dir }}/verify_tempest_conf.log': logs
