Skip to content

Commit

Permalink
Rewrote ISM Policy reconciler
Browse files Browse the repository at this point in the history
  • Loading branch information
rkthtrifork committed Jun 18, 2024
1 parent 56c9c8f commit 4501ff2
Show file tree
Hide file tree
Showing 9 changed files with 199 additions and 153 deletions.
21 changes: 21 additions & 0 deletions .github/workflows/cheetah-release.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
name: Cheetah Release
on:
workflow_dispatch:
push:

concurrency:
group: ${{ github.ref }}-${{ github.workflow }}
cancel-in-progress: true

permissions:
contents: read
packages: write

jobs:
create-snapshot:
uses: ./.github/workflows/docker-create-snapshot.yaml
with:
context: opensearch-operator
image-name: opensearch-k8s-operator
secrets:
TRIFORK_GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }}
55 changes: 55 additions & 0 deletions .github/workflows/docker-create-snapshot.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
name: Docker Create Snapshot

on:
workflow_call:
inputs:
image-name:
description: The name of the image to create a snapshot for
required: true
type: string
context:
description: The directory to run the workflow inside
required: false
type: string
default: .
dockerfile-path:
description: The path to the Dockerfile. Defaults to {context}/Dockerfile
required: false
type: string
secrets:
TRIFORK_GITHUB_PAT:
description: A personal access token with permission to publish a package to the Trifork GitHub container registry
required: true

jobs:
create-snapshot:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4

- name: Log in to the container registry
uses: docker/login-action@1220aa36aaf257e736f1d64e3b87c4878665836f
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.TRIFORK_GITHUB_PAT }}

- name: Get package suffix
id: get-package-suffix
run: echo "branch-name=$(echo '${{ github.ref_name }}' | sed 's/[^a-zA-Z0-9]/-/g')" >> $GITHUB_OUTPUT

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@f95db51fddba0c2d1ec667646a06c2ce06100226 # v3

- name: Build and push Docker image
uses: docker/build-push-action@0565240e2d4ab88bba5387d719585280857ece09 # v5
with:
context: ${{ inputs.context }}
file: ${{ inputs.dockerfile-path }}
platforms: linux/amd64
tags: ghcr.io/trifork/${{ inputs.image-name }}:2.6.0-${{ steps.get-package-suffix.outputs.branch-name }}-SNAPSHOT-${{ github.run_number }}
push: true
secrets: |
GITHUB_ACTOR=${{ github.actor }}
GITHUB_TOKEN=${{ secrets.TRIFORK_GITHUB_PAT }}
9 changes: 3 additions & 6 deletions opensearch-operator/opensearch-gateway/requests/IsmPolicy.go
Original file line number Diff line number Diff line change
@@ -1,14 +1,11 @@
package requests

type Policy struct {
PolicyID string `json:"_id,omitempty"`
PrimaryTerm *int `json:"_primary_term,omitempty"`
SequenceNumber *int `json:"_seq_no,omitempty"`
Policy ISMPolicy `json:"policy"`
type ISMPolicy struct {
Policy ISMPolicySpec `json:"policy"`
}

// ISMPolicySpec is the specification for the ISM policy for OS.
type ISMPolicy struct {
type ISMPolicySpec struct {
// The default starting state for each index that uses this policy.
DefaultState string `json:"default_state"`
// A human-readable description of the policy.
Expand Down

This file was deleted.

10 changes: 10 additions & 0 deletions opensearch-operator/opensearch-gateway/responses/IsmPolicy.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
package responses

import "github.com/Opster/opensearch-k8s-operator/opensearch-operator/opensearch-gateway/requests"

type GetISMPolicyResponse struct {
PolicyID string `json:"_id"`
PrimaryTerm int `json:"_primary_term"`
SequenceNumber int `json:"_seq_no"`
Policy requests.ISMPolicySpec
}
33 changes: 10 additions & 23 deletions opensearch-operator/opensearch-gateway/services/os_ism_service.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (
"fmt"

"github.com/Opster/opensearch-k8s-operator/opensearch-operator/opensearch-gateway/requests"
"github.com/Opster/opensearch-k8s-operator/opensearch-operator/opensearch-gateway/responses"
"github.com/google/go-cmp/cmp"
"github.com/google/go-cmp/cmp/cmpopts"
"github.com/opensearch-project/opensearch-go/opensearchutil"
Expand All @@ -16,7 +17,7 @@ import (
var ErrNotFound = errors.New("policy not found")

// ShouldUpdateISMPolicy checks if the passed policy is same as existing or needs update
func ShouldUpdateISMPolicy(ctx context.Context, newPolicy, existingPolicy requests.Policy) (bool, error) {
func ShouldUpdateISMPolicy(ctx context.Context, newPolicy, existingPolicy requests.ISMPolicy) (bool, error) {
if cmp.Equal(newPolicy, existingPolicy, cmpopts.EquateEmpty()) {
return false, nil
}
Expand All @@ -27,34 +28,20 @@ func ShouldUpdateISMPolicy(ctx context.Context, newPolicy, existingPolicy reques
return true, nil
}

// PolicyExists checks if the passed policy already exists or not
func PolicyExists(ctx context.Context, service *OsClusterClient, policyName string) (bool, error) {
resp, err := service.GetISMConfig(ctx, policyName)
if err != nil {
return false, err
}
defer resp.Body.Close()
if resp.StatusCode == 404 {
return false, nil
} else if resp.IsError() {
return false, fmt.Errorf("response from API is %s", resp.Status())
}
return true, nil
}

// GetPolicy fetches the passed policy
func GetPolicy(ctx context.Context, service *OsClusterClient, policyName string) (*requests.Policy, error) {
func GetPolicy(ctx context.Context, service *OsClusterClient, policyName string) (*responses.GetISMPolicyResponse, error) {
resp, err := service.GetISMConfig(ctx, policyName)
if err != nil {
return nil, err
}
defer resp.Body.Close()
if resp.StatusCode == 404 {
return nil, ErrNotFound
} else if resp.IsError() {
}
if resp.IsError() {
return nil, fmt.Errorf("response from API is %s", resp.Status())
}
ismResponse := requests.Policy{}
ismResponse := responses.GetISMPolicyResponse{}
if resp != nil && resp.Body != nil {
err := json.NewDecoder(resp.Body).Decode(&ismResponse)
if err != nil {
Expand All @@ -66,7 +53,7 @@ func GetPolicy(ctx context.Context, service *OsClusterClient, policyName string)
}

// CreateISMPolicy creates the passed policy
func CreateISMPolicy(ctx context.Context, service *OsClusterClient, ismpolicy requests.Policy, policyId string) error {
func CreateISMPolicy(ctx context.Context, service *OsClusterClient, ismpolicy requests.ISMPolicy, policyId string) error {
spec := opensearchutil.NewJSONReader(ismpolicy)
resp, err := service.PutISMConfig(ctx, policyId, spec)
if err != nil {
Expand All @@ -80,15 +67,15 @@ func CreateISMPolicy(ctx context.Context, service *OsClusterClient, ismpolicy re
}

// UpdateISMPolicy updates the given policy
func UpdateISMPolicy(ctx context.Context, service *OsClusterClient, ismpolicy requests.Policy, seqno, primterm *int, policyName string) error {
func UpdateISMPolicy(ctx context.Context, service *OsClusterClient, ismpolicy requests.ISMPolicy, seqno, primterm *int, policyId string) error {
spec := opensearchutil.NewJSONReader(ismpolicy)
resp, err := service.UpdateISMConfig(ctx, policyName, *seqno, *primterm, spec)
resp, err := service.UpdateISMConfig(ctx, policyId, *seqno, *primterm, spec)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.IsError() {
return fmt.Errorf("failed to create ism policy: %s", resp.String())
return fmt.Errorf("failed to update ism policy: %s", resp.String())
}
return nil
}
Expand Down
7 changes: 4 additions & 3 deletions opensearch-operator/pkg/reconcilers/indextemplate.go
Original file line number Diff line number Diff line change
Expand Up @@ -151,9 +151,9 @@ func (r *IndexTemplateReconciler) Reconcile() (result ctrl.Result, err error) {
return
}

templateName = r.instance.Name
if r.instance.Spec.Name != "" {
templateName = r.instance.Spec.Name
templateName = r.instance.Spec.Name
if templateName != "" {
templateName = r.instance.Name
}

// Check index template state to make sure we don't touch preexisting index templates
Expand All @@ -173,6 +173,7 @@ func (r *IndexTemplateReconciler) Reconcile() (result ctrl.Result, err error) {
})
if err != nil {
reason = fmt.Sprintf("failed to update status: %s", err)
// r.logger.Error(retErr, reason) should this be added?
r.recorder.Event(r.instance, "Warning", statusError, reason)
return
}
Expand Down
Loading

0 comments on commit 4501ff2

Please sign in to comment.