Index: /branches/main/array-ingress-controller/Dockerfile
===================================================================
--- /branches/main/array-ingress-controller/Dockerfile	(nonexistent)
+++ /branches/main/array-ingress-controller/Dockerfile	(working copy)
@@ -0,0 +1,12 @@
+FROM ubuntu:22.04
+
+# Install curl and iputils-ping
+RUN apt-get update && \
+    apt-get install -y curl iputils-ping sqlite3 && \
+    rm -rf /var/lib/apt/lists/*
+
+COPY  array-ingress /home/array-ingress
+WORKDIR /home
+
+# Execute the array-ingress binary
+#CMD ["./array-ingress"]
\ No newline at end of file
Index: /branches/main/array-ingress-controller/configstore/README.md
===================================================================
--- /branches/main/array-ingress-controller/configstore/README.md	(nonexistent)
+++ /branches/main/array-ingress-controller/configstore/README.md	(working copy)
@@ -0,0 +1,40 @@
+# SQLite CLI Guide
+
+The SQLite Command-Line Interface (CLI) allows you to interact with SQLite databases from your terminal.
+
+## Starting SQLite CLI
+To start the SQLite CLI, open your terminal and type:
+```bash
+sqlite3 /path/to/DB //example sqlite3 /var/log/array.db
+```
+## SQLite CLI Commands
+
+| Command              | Description                                    |
+|----------------------|------------------------------------------------|
+| `.help`              | Show all available commands                   |
+| `.databases`         | List all open databases                       |
+| `.tables`            | List all tables in the current database       |
+| `.schema`            | Show the schema of the current database       |
+| `.mode column`       | Set output format to columns                  |
+| `.headers on`        | Display column names in query results         |
+| `.quit` or `.exit`   | Exit the SQLite shell                         |
+| `.dump`              | Export the database schema and data           |
+| `.read filename.sql` | Execute commands from a file                  |
+| `.backup 'backup.db'`| Create a backup of the current database       |
+| `.restore 'backup.db'` | Restore a database from a backup            |
+| `.show`              | Display current settings                      |
+
+---
+
+## How to Quit SQLite
+
+To exit the SQLite CLI, use any of the following commands:
+
+```bash
+.quit
+```
+or
+
+```bash
+.exit
+```
\ No newline at end of file
Index: /branches/main/array-ingress-controller/configstore/configstore.go
===================================================================
--- /branches/main/array-ingress-controller/configstore/configstore.go	(revision 9)
+++ /branches/main/array-ingress-controller/configstore/configstore.go	(working copy)
@@ -1,80 +1,90 @@
 /*
 	Copyright 2025 Array Networks
-
 */
 
 package configstore
 
 import (
-    "fmt"
-    "sync"
-    "gorm.io/gorm"
+	"fmt"
+	"sync"
+	"time"
+
+	"gorm.io/gorm"
 )
 
 // ConfigStorePublic interface defines the public methods
 type ConfigStorePublic interface {
-    Create[T any](model T) error
-    ReadAll[T any](models *[]T) error
-    Update[T any](model T) error
-    Delete[T any](model T) error
+	Create(model interface{}) error
+	ReadAll(model interface{}) error
+	Update(model interface{}) error
+	Delete(model interface{}) error
 }
 
 // ConfigStore implements the public interface
 type ConfigStore struct {
-    db *gorm.DB
-    mu sync.RWMutex
+	DB *gorm.DB
+	mu sync.RWMutex
 }
 
 // NewConfigStore creates a new instance of ConfigStore
-func Get() (*ConfigStore, error) *ConfigStore{
-    db, err := newDBClient()
-    if err != nil {
-        return nil, fmt.Errorf("failed to initialize database client: %v", err)
-    }
-    return &ConfigStore{db: db}, nil
+func Get() (*ConfigStore, error) {
+	DB, err := newDBClient()
+	if err != nil {
+		return nil, fmt.Errorf("failed to initialize database client: %v", err)
+	}
+	return &ConfigStore{DB: DB}, nil
 }
 
 // Create is a public method to create a new record
-func (cs *ConfigStore) Create[T any](model T) error {
+func (cs *ConfigStore) Create(model interface{}) error {
     cs.mu.Lock()
     defer cs.mu.Unlock()
     return RetryFunction(func() error {
-		return cs.db.Create(&model).Error
+		return cs.DB.Create(model).Error
 	}, 3, 100*time.Millisecond, 1)
 }
 
 // ReadAll is a public method to read all records of a specific model type
-func (cs *ConfigStore) ReadAll[T any](models *[]T) error {
-    cs.mu.RLock()
-    defer cs.mu.RUnlock()
-    return RetryFunction(func() error {
-        return cs.db.Find(models).Error
-    }, 3, 100*time.Millisecond, 1)
+func (cs *ConfigStore) ReadAll(model interface{}) error {
+	cs.mu.RLock()
+	defer cs.mu.RUnlock()
+	return RetryFunction(func() error {
+		return cs.DB.Find(model).Error
+	}, 3, 100*time.Millisecond, 1)
 }
 
-// ReadByRouteName retrieves records matching a specific ingress name
-func (cs *ConfigStore) ReadByRouteName[T any](routeName string, models *[]T) error {
-    cs.mu.RLock()
-    defer cs.mu.RUnlock()
-    return RetryFunction(func() error {
-        return cs.db.Where("ingress_name = ?", routeName).Find(models).Error
-    }, 3, 100*time.Millisecond, 1)
+// ReaDByRouteName retrieves records matching a specific ingress name
+func (cs *ConfigStore) ReadByRouteName(routeName string, model interface{}) error {
+	cs.mu.RLock()
+	defer cs.mu.RUnlock()
+	return RetryFunction(func() error {
+		return cs.DB.Where("ingress_name = ?", routeName).Find(model).Error
+	}, 3, 100*time.Millisecond, 1)
+}
+
+// ReadByStatus retrieves records matching a specific status
+func (cs *ConfigStore) ReadByStatus(status string, model interface{}) error {
+	cs.mu.RLock()
+	defer cs.mu.RUnlock()
+	return RetryFunction(func() error {
+		return cs.DB.Where("status = ?", status).Find(model).Error
+	}, 3, 100*time.Millisecond, 1)
 }
 
 // Update is a public method to update a record
-func (cs *ConfigStore) Update[T any](model T) error {
+func (cs *ConfigStore) Update(model interface{}, conditions map[string]interface{}) error {
     cs.mu.Lock()
     defer cs.mu.Unlock()
     return RetryFunction(func() error {
-        return cs.db.Save(&model).Error 
+        return cs.DB.Where(conditions).Save(model).Error 
     }, 3, 100*time.Millisecond, 1)
 }
 
 // Delete is a public method to delete a record
-func (cs *ConfigStore) Delete[T any](model T) error {
+func (cs *ConfigStore) Delete(model interface{}, conditions map[string]interface{}) error {
     cs.mu.Lock()
     defer cs.mu.Unlock()
     return RetryFunction(func() error {
-        return cs.db.Delete(&model).Error
+        return cs.DB.Where(conditions).Delete(model).Error
     }, 3, 100*time.Millisecond, 1)
-}
\ No newline at end of file
+}
Index: /branches/main/array-ingress-controller/configstore/db.go
===================================================================
--- /branches/main/array-ingress-controller/configstore/db.go	(revision 9)
+++ /branches/main/array-ingress-controller/configstore/db.go	(working copy)
@@ -5,48 +5,149 @@
 package configstore
 
 import (
-    "fmt"
-    "gorm.io/driver/sqlite"
-    "gorm.io/gorm"
-    "sync"
+	"sync"
+
+	"gorm.io/driver/sqlite"
+	"gorm.io/gorm"
+
+	"arraynetworks.com/array-ingress-controller/logger"
 )
 
 var (
-    dbClient *gorm.DB
-    once     sync.Once
-    mu       sync.Mutex
+	dbClient *gorm.DB
+	once     sync.Once
+	mu       sync.Mutex
+	log      logger.Logger
 )
 
-func isHealthy(db *gorm.DB){
-    // Perform a ping test by executing a simple query
-    sqlDB, err := db.DB()
-    if err != nil {
-        log.Fatalf("failed to get db from gorm: %v", err)
-    }
-
-    err = sqlDB.Ping()
-    if err != nil {
-        return false
-    }
-    return true
+func init() {
+	log = logger.GetLogger()
+}
+
+func isHealthy(db *gorm.DB) bool {
+	// Perform a ping test by executing a simple query
+	sqlDB, err := db.DB()
+	if err != nil {
+		log.Fatalf("failed to get db from gorm: %v", err)
+	}
+
+	err = sqlDB.Ping()
+	if err != nil {
+		return false
+	}
+	return true
 }
 
 func newDBClient() (*gorm.DB, error) {
-    var err error
-    mu.Lock()
-    defer mu.Unlock()
-    if dbClient == nil || !dbClient.isHealthy(dbClient) {
-        dbName := "./demo_database_for_test.db"
-        dbClient, err = gorm.Open(sqlite.Open(dbName), &gorm.Config{})
-        if err != nil {
-            fmt.Println(err)
-            return
-        }
-    }
-    once.Do(
-		func() {
-            dbClient.AutoMigrate(&Service{}, &Group{})
-        }
-    )
-    return dbClient, err
-}
\ No newline at end of file
+	mu.Lock()
+	var err error
+	defer mu.Unlock()
+
+	if dbClient == nil || !isHealthy(dbClient) {
+		dbName := "/var/log/array.db"
+		dbClient, err = gorm.Open(sqlite.Open(dbName), &gorm.Config{})
+		if err != nil {
+			log.Errorf("DB client creation failed: %s", err)
+			return nil, err
+		}
+	}
+	log.Info("DB Client created")
+
+	once.Do(func() {
+		if dbClient != nil {
+			log.Info("Running DB Migrations...")
+			// Initialize all models
+			if err := dbClient.AutoMigrate(
+				&RealService{},
+				&HealthCheck{},
+				&Group{},
+				&RateLimit{},
+				&AsfRealService{},
+			); err != nil {
+				log.Errorf("AutoMigrate failed: %s", err)
+			}
+
+			// Create triggers after migration
+			createTriggers(dbClient)
+		}
+	})
+	return dbClient, err
+}
+func createTriggers(db *gorm.DB) {
+	triggers := []string{
+		// Trigger for RealService insert
+		`
+        CREATE TRIGGER IF NOT EXISTS check_realservice_port_ip
+        BEFORE INSERT ON real_services
+        BEGIN
+            SELECT 
+                RAISE(FAIL, 'Port and IP combination already exists with status = "waiting"')
+            WHERE EXISTS (
+                SELECT 1 
+                FROM real_services
+                WHERE ip_address = NEW.ip_address 
+                AND port = NEW.port 
+                AND status = 'waiting'
+            );
+        END;
+        `,
+		// Trigger for RealService update
+		`
+        CREATE TRIGGER IF NOT EXISTS check_realservice_port_ip_update
+        BEFORE UPDATE ON real_services
+        BEGIN
+            SELECT 
+                RAISE(FAIL, 'Port and IP combination already exists with status = "waiting"')
+            WHERE EXISTS (
+                SELECT 1 
+                FROM real_services
+                WHERE ip_address = NEW.ip_address 
+                AND port = NEW.port 
+                AND status = 'waiting'
+                AND rowid != NEW.rowid
+            );
+        END;
+        `,
+		// Trigger for AsfRealService insert
+		`
+        CREATE TRIGGER IF NOT EXISTS check_asfrealservice_port_ip
+        BEFORE INSERT ON asf_real_services
+        BEGIN
+            SELECT 
+                RAISE(FAIL, 'Port and IPv4 combination already exists with status = "waiting"')
+            WHERE EXISTS (
+                SELECT 1 
+                FROM asf_real_services
+                WHERE ipv4 = NEW.ipv4 
+                AND port = NEW.port 
+                AND status = 'waiting'
+            );
+        END;
+        `,
+		// Trigger for AsfRealService update
+		`
+        CREATE TRIGGER IF NOT EXISTS check_asfrealservice_port_ip_update
+        BEFORE UPDATE ON asf_real_services
+        BEGIN
+            SELECT 
+                RAISE(FAIL, 'Port and IPv4 combination already exists with status = "waiting"')
+            WHERE EXISTS (
+                SELECT 1 
+                FROM asf_real_services
+                WHERE ipv4 = NEW.ipv4 
+                AND port = NEW.port 
+                AND status = 'waiting'
+                AND rowid != NEW.rowid
+            );
+        END;
+        `,
+	}
+
+	for _, trigger := range triggers {
+		if err := db.Exec(trigger).Error; err != nil {
+			log.Errorf("Failed to create trigger: %s", err)
+		} else {
+			log.Info("Trigger created successfully")
+		}
+	}
+}
Index: /branches/main/array-ingress-controller/configstore/go.mod
===================================================================
--- /branches/main/array-ingress-controller/configstore/go.mod	(revision 9)
+++ /branches/main/array-ingress-controller/configstore/go.mod	(working copy)
@@ -2,6 +2,8 @@
 
 go 1.23.6
 
+replace arraynetworks.com/array-ingress-controller/logger => ../logger
+
 require (
 	github.com/cenkalti/backoff/v4 v4.3.0
 	gorm.io/datatypes v1.2.5
Index: /branches/main/array-ingress-controller/configstore/models.go
===================================================================
--- /branches/main/array-ingress-controller/configstore/models.go	(revision 9)
+++ /branches/main/array-ingress-controller/configstore/models.go	(working copy)
@@ -33,6 +33,9 @@
 	Port          int    `gorm:"column:port;not null" json:"port"`
 	SendInterval  int    `gorm:"column:send_interval;not null" json:"send_interval"`
 	ServerTimeout int    `gorm:"column:server_timeout;not null" json:"server_timeout"`
+	Retries 	  int    `gorm:"column:retries;not null" json:"retries"`
+	Status      string `gorm:"column:status;not null"`
+	CurrentOp   string `gorm:"column:current_op;not null"`
 }
 
 // Group represents the structure for storing group data in SQLite using GORM.
@@ -49,8 +52,29 @@
 }
 
 type RateLimit struct {
-	IngressName   string `gorm:"column:ingress_name;not null"`
-	MaxCPS        int    `gorm:"column:max_cps;not null" json:"max_cps"`
-	SoftBandwidth int    `gorm:"column:soft_bandwidth;not null" json:"soft_bandwidth"`
-	HardBandwidth int    `gorm:"column:hard_bandwidth;not null" json:"hard_bandwidth"`
+	IngressName          string `gorm:"column:ingress_name;not null"`
+	ServiceName          string `gorm:"column:service_name;not null"`
+	MaxCPS               int    `gorm:"column:max_cps;not null" json:"max_cps"`
+	SoftBandwidth        int    `gorm:"column:soft_bandwidth;not null" json:"soft_bandwidth"`
+	HardBandwidth        int    `gorm:"column:hard_bandwidth;not null" json:"hard_bandwidth"`
+	ServiceType          string `gorm:"column:service_type;not null"`
+	ServerConnReuse      bool   `gorm:"column:server_conn_reuse;not null"`
+	MaxReq               int    `gorm:"column:max_req;not null"`
+	Timeout              int    `gorm:"column:timeout;not null"`
+	ServerPersistentConn bool   `gorm:"column:server_persistent_conn;not null"`
+	Status               string `gorm:"column:status;not null"`
+	CurrentOp            string `gorm:"column:current_op;not null"`
+}
+
+type AsfRealService struct {
+	IngressName string `gorm:"column:ingress_name;not null"`
+	ServiceName string `gorm:"column:service_name;not null"`
+	ServiceType string `gorm:"column:service_type;not null"`
+	IPv4        string `gorm:"column:ipv4;not null"`
+	Port        int    `gorm:"column:port;not null"`
+	CheckType   string `gorm:"column:check_type;not null"`
+	HCUp        int    `gorm:"column:hc_up;not null"`
+	HCDown      int    `gorm:"column:hc_down;not null"`
+	Status      string `gorm:"column:status;not null"`
+	CurrentOp   string `gorm:"column:current_op;not null"`
 }
Index: /branches/main/array-ingress-controller/configstore/utils.go
===================================================================
--- /branches/main/array-ingress-controller/configstore/utils.go	(revision 9)
+++ /branches/main/array-ingress-controller/configstore/utils.go	(working copy)
@@ -1,7 +1,9 @@
+/*
+	Copyright 2025 Array Networks
+*/
 package configstore
 
 import (
-	"fmt"
 	"time"
 
 	"github.com/cenkalti/backoff/v4"
@@ -18,7 +20,7 @@
 	// Wrap operation with retry logic
 	err := backoff.Retry(function, expBackoff)
 	if err != nil {
-		return fmt.Errorf("operation failed after retries: %w", err)
+		return err
 	}
 	return nil
 }
Index: /branches/main/array-ingress-controller/go.mod
===================================================================
--- /branches/main/array-ingress-controller/go.mod	(revision 9)
+++ /branches/main/array-ingress-controller/go.mod	(working copy)
@@ -1,53 +1,119 @@
-module arraynetworks.com/array-ingress-controller
+module arraynetworks.com/array-ingress-controller/main
 
 go 1.23.6
 
+replace (
+	arraynetworks.com/array-ingress-controller/apvadapter => ./apvadapter
+	arraynetworks.com/array-ingress-controller/apvadapter/apvurlbuilder => ./apvadapter/apvurlbuilder
+	arraynetworks.com/array-ingress-controller/apvadapter/health => ./apvadapter/annotations/health
+	arraynetworks.com/array-ingress-controller/apvadapter/ratelimit => ./apvadapter/annotations/ratelimit
+	arraynetworks.com/array-ingress-controller/apvadapter/realservice => ./apvadapter/realservice
+	arraynetworks.com/array-ingress-controller/apvadapter/whitelisting => ./apvadapter/annotations/whitelisting
+	arraynetworks.com/array-ingress-controller/apvclient => ./apvadapter/apvclient
+	arraynetworks.com/array-ingress-controller/common => ./common
+	arraynetworks.com/array-ingress-controller/configstore => ./configstore
+	arraynetworks.com/array-ingress-controller/controller => ./controller
+	arraynetworks.com/array-ingress-controller/controller/openshift => ./controller/openshift-controller
+	arraynetworks.com/array-ingress-controller/controller/openshift-controller/handlers => ./controller/openshift-controller/handlers
+	arraynetworks.com/array-ingress-controller/controller/openshift-controller/informers => ./controller/openshift-controller/informers
+	arraynetworks.com/array-ingress-controller/controller/openshift-controller/utils => ./controller/openshift-controller/utils
+	arraynetworks.com/array-ingress-controller/logger => ./logger
+	arraynetworks.com/array-ingress-controller/task-manager/openshift/apv => ./task-manager/openshift/apv
+	arraynetworks.com/array-ingress-controller/task-manager/openshift/asf => ./task-manager/openshift/asf
+	arraynetworks.com/array-ingress-controller/task-manager/task => ./task-manager/task
+	arraynetworks.com/array-ingress-controller/watchtower => ./watchtower
+)
+
 require (
-	github.com/golang/mock v1.6.0
-	github.com/onsi/ginkgo/v2 v2.22.2
-	github.com/onsi/gomega v1.36.2
-	github.com/openshift/api v0.0.0-20250220025300-cfbda0b31000 // indirect
-	go.uber.org/zap v1.27.0
-	gopkg.in/natefinch/lumberjack.v2 v2.2.1
-	gorm.io/driver/sqlite v1.5.7
-	gorm.io/gorm v1.25.12
-	k8s.io/api v0.32.2 // indirect
-	k8s.io/apimachinery v0.32.2 // indirect
-	k8s.io/klog/v2 v2.130.1 // indirect
+	arraynetworks.com/array-ingress-controller/apvadapter v0.0.0-00010101000000-000000000000
+	arraynetworks.com/array-ingress-controller/common v0.0.0-00010101000000-000000000000
+	arraynetworks.com/array-ingress-controller/controller/openshift v0.0.0-00010101000000-000000000000
+	arraynetworks.com/array-ingress-controller/logger v0.0.0-00010101000000-000000000000
+	arraynetworks.com/array-ingress-controller/watchtower v0.0.0-00010101000000-000000000000
+	k8s.io/api v0.32.2
+	k8s.io/apimachinery v0.32.2
+	k8s.io/client-go v0.32.2
+	k8s.io/klog/v2 v2.130.1
+	sigs.k8s.io/controller-runtime v0.20.3
 )
 
 require (
+	arraynetworks.com/array-ingress-controller/apvadapter/apvurlbuilder v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/apvadapter/health v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/apvadapter/realservice v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/apvclient v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/configstore v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/controller/openshift-controller/handlers v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/controller/openshift-controller/informers v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/controller/openshift-controller/utils v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/task-manager/openshift/apv v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/task-manager/openshift/asf v0.0.0-00010101000000-000000000000 // indirect
+	arraynetworks.com/array-ingress-controller/task-manager/task v0.0.0-00010101000000-000000000000 // indirect
+	filippo.io/edwards25519 v1.1.0 // indirect
+	github.com/beorn7/perks v1.0.1 // indirect
+	github.com/cenkalti/backoff/v4 v4.3.0 // indirect
+	github.com/cespare/xxhash/v2 v2.3.0 // indirect
+	github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc // indirect
+	github.com/emicklei/go-restful/v3 v3.11.0 // indirect
+	github.com/evanphx/json-patch/v5 v5.9.11 // indirect
+	github.com/fsnotify/fsnotify v1.7.0 // indirect
 	github.com/fxamacker/cbor/v2 v2.7.0 // indirect
 	github.com/go-logr/logr v1.4.2 // indirect
-	github.com/go-task/slim-sprig/v3 v3.0.0 // indirect
+	github.com/go-openapi/jsonpointer v0.21.0 // indirect
+	github.com/go-openapi/jsonreference v0.20.2 // indirect
+	github.com/go-openapi/swag v0.23.0 // indirect
+	github.com/go-resty/resty/v2 v2.16.5 // indirect
+	github.com/go-sql-driver/mysql v1.8.1 // indirect
 	github.com/gogo/protobuf v1.3.2 // indirect
+	github.com/golang/protobuf v1.5.4 // indirect
+	github.com/google/btree v1.1.3 // indirect
+	github.com/google/gnostic-models v0.6.8 // indirect
 	github.com/google/go-cmp v0.6.0 // indirect
 	github.com/google/gofuzz v1.2.0 // indirect
-	github.com/google/pprof v0.0.0-20241210010833-40e02aabc2ad // indirect
+	github.com/google/uuid v1.6.0 // indirect
 	github.com/jinzhu/inflection v1.0.0 // indirect
 	github.com/jinzhu/now v1.1.5 // indirect
+	github.com/josharian/intern v1.0.0 // indirect
 	github.com/json-iterator/go v1.1.12 // indirect
+	github.com/mailru/easyjson v0.7.7 // indirect
 	github.com/mattn/go-sqlite3 v1.14.22 // indirect
 	github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
 	github.com/modern-go/reflect2 v1.0.2 // indirect
+	github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect
+	github.com/openshift/api v0.0.0-20250305225826-b8da3bfeaf77 // indirect
+	github.com/openshift/client-go v0.0.0-20250131180035-f7ec47e2d87a // indirect
+	github.com/pkg/errors v0.9.1 // indirect
+	github.com/prometheus/client_golang v1.19.1 // indirect
+	github.com/prometheus/client_model v0.6.1 // indirect
+	github.com/prometheus/common v0.55.0 // indirect
+	github.com/prometheus/procfs v0.15.1 // indirect
+	github.com/spf13/pflag v1.0.5 // indirect
 	github.com/x448/float16 v0.8.4 // indirect
-	go.uber.org/multierr v1.10.0 // indirect
+	go.uber.org/multierr v1.11.0 // indirect
+	go.uber.org/zap v1.27.0 // indirect
 	golang.org/x/net v0.33.0 // indirect
+	golang.org/x/oauth2 v0.23.0 // indirect
+	golang.org/x/sync v0.10.0 // indirect
 	golang.org/x/sys v0.28.0 // indirect
+	golang.org/x/term v0.27.0 // indirect
 	golang.org/x/text v0.21.0 // indirect
-	golang.org/x/tools v0.28.0 // indirect
+	golang.org/x/time v0.7.0 // indirect
+	gomodules.xyz/jsonpatch/v2 v2.4.0 // indirect
+	google.golang.org/protobuf v1.35.1 // indirect
+	gopkg.in/alexcesaro/quotedprintable.v3 v3.0.0-20150716171945-2caba252f4dc // indirect
+	gopkg.in/evanphx/json-patch.v4 v4.12.0 // indirect
+	gopkg.in/gomail.v2 v2.0.0-20160411212932-81ebce5c23df // indirect
 	gopkg.in/inf.v0 v0.9.1 // indirect
+	gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect
 	gopkg.in/yaml.v3 v3.0.1 // indirect
+	gorm.io/datatypes v1.2.5 // indirect
+	gorm.io/driver/mysql v1.5.6 // indirect
+	gorm.io/driver/sqlite v1.5.7 // indirect
+	gorm.io/gorm v1.25.12 // indirect
+	k8s.io/apiextensions-apiserver v0.32.1 // indirect
+	k8s.io/kube-openapi v0.0.0-20241105132330-32ad38e42d3f // indirect
 	k8s.io/utils v0.0.0-20241104100929-3ea5e8cea738 // indirect
 	sigs.k8s.io/json v0.0.0-20241010143419-9aa6b5e7a4b3 // indirect
 	sigs.k8s.io/structured-merge-diff/v4 v4.4.2 // indirect
 	sigs.k8s.io/yaml v1.4.0 // indirect
 )
-
-require arraynetworks.com/array-ingress-controller/task-manager/task v0.0.0-00010101000000-000000000000
-
-replace (
-	arraynetworks.com/array-ingress-controller/apvadapter => ./apvadapter
-	arraynetworks.com/array-ingress-controller/controller/openshift-controller/ => ./controller/openshift-controller
-	arraynetworks.com/array-ingress-controller/task-manager/task => ./task-manager/task
-)
Index: /branches/main/array-ingress-controller/go.sum
===================================================================
--- /branches/main/array-ingress-controller/go.sum	(nonexistent)
+++ /branches/main/array-ingress-controller/go.sum	(working copy)
@@ -0,0 +1,246 @@
+filippo.io/edwards25519 v1.1.0 h1:FNf4tywRC1HmFuKW5xopWpigGjJKiJSV0Cqo0cJWDaA=
+filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4VDT4=
+github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM=
+github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=
+github.com/cenkalti/backoff/v4 v4.3.0 h1:MyRJ/UdXutAwSAT+s3wNd7MfTIcy71VQueUuFK343L8=
+github.com/cenkalti/backoff/v4 v4.3.0/go.mod h1:Y3VNntkOUPxTVeUxJ/G5vcM//AlwfmyYozVcomhLiZE=
+github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UFvs=
+github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
+github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E=
+github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc h1:U9qPSI2PIWSS1VwoXQT9A3Wy9MM3WgvqSxFWenqJduM=
+github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/emicklei/go-restful/v3 v3.11.0 h1:rAQeMHw1c7zTmncogyy8VvRZwtkmkZ4FxERmMY4rD+g=
+github.com/emicklei/go-restful/v3 v3.11.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc=
+github.com/evanphx/json-patch v0.5.2 h1:xVCHIVMUu1wtM/VkR9jVZ45N3FhZfYMMYGorLCR8P3k=
+github.com/evanphx/json-patch v0.5.2/go.mod h1:ZWS5hhDbVDyob71nXKNL0+PWn6ToqBHMikGIFbs31qQ=
+github.com/evanphx/json-patch/v5 v5.9.11 h1:/8HVnzMq13/3x9TPvjG08wUGqBTmZBsCWzjTM0wiaDU=
+github.com/evanphx/json-patch/v5 v5.9.11/go.mod h1:3j+LviiESTElxA4p3EMKAB9HXj3/XEtnUf6OZxqIQTM=
+github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA=
+github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM=
+github.com/fxamacker/cbor/v2 v2.7.0 h1:iM5WgngdRBanHcxugY4JySA0nk1wZorNOpTgCMedv5E=
+github.com/fxamacker/cbor/v2 v2.7.0/go.mod h1:pxXPTn3joSm21Gbwsv0w9OSA2y1HFR9qXEeXQVeNoDQ=
+github.com/go-logr/logr v1.4.2 h1:6pFjapn8bFcIbiKo3XT4j/BhANplGihG6tvd+8rYgrY=
+github.com/go-logr/logr v1.4.2/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY=
+github.com/go-logr/zapr v1.3.0 h1:XGdV8XW8zdwFiwOA2Dryh1gj2KRQyOOoNmBy4EplIcQ=
+github.com/go-logr/zapr v1.3.0/go.mod h1:YKepepNBd1u/oyhd/yQmtjVXmm9uML4IXUgMOwR8/Gg=
+github.com/go-openapi/jsonpointer v0.19.6/go.mod h1:osyAmYz/mB/C3I+WsTTSgw1ONzaLJoLCyoi6/zppojs=
+github.com/go-openapi/jsonpointer v0.21.0 h1:YgdVicSA9vH5RiHs9TZW5oyafXZFc6+2Vc1rr/O9oNQ=
+github.com/go-openapi/jsonpointer v0.21.0/go.mod h1:IUyH9l/+uyhIYQ/PXVA41Rexl+kOkAPDdXEYns6fzUY=
+github.com/go-openapi/jsonreference v0.20.2 h1:3sVjiK66+uXK/6oQ8xgcRKcFgQ5KXa2KvnJRumpMGbE=
+github.com/go-openapi/jsonreference v0.20.2/go.mod h1:Bl1zwGIM8/wsvqjsOQLJ/SH+En5Ap4rVB5KVcIDZG2k=
+github.com/go-openapi/swag v0.22.3/go.mod h1:UzaqsxGiab7freDnrUUra0MwWfN/q7tE4j+VcZ0yl14=
+github.com/go-openapi/swag v0.23.0 h1:vsEVJDUo2hPJ2tu0/Xc+4noaxyEffXNIs3cOULZ+GrE=
+github.com/go-openapi/swag v0.23.0/go.mod h1:esZ8ITTYEsH1V2trKHjAN8Ai7xHb8RV+YSZ577vPjgQ=
+github.com/go-resty/resty/v2 v2.16.5 h1:hBKqmWrr7uRc3euHVqmh1HTHcKn99Smr7o5spptdhTM=
+github.com/go-resty/resty/v2 v2.16.5/go.mod h1:hkJtXbA2iKHzJheXYvQ8snQES5ZLGKMwQ07xAwp/fiA=
+github.com/go-sql-driver/mysql v1.7.0/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI=
+github.com/go-sql-driver/mysql v1.8.1 h1:LedoTUt/eveggdHS9qUFC1EFSa8bU2+1pZjSRpvNJ1Y=
+github.com/go-sql-driver/mysql v1.8.1/go.mod h1:wEBSXgmK//2ZFJyE+qWnIsVGmvmEKlqwuVSjsCm7DZg=
+github.com/go-task/slim-sprig/v3 v3.0.0 h1:sUs3vkvUymDpBKi3qH1YSqBQk9+9D/8M2mN1vB6EwHI=
+github.com/go-task/slim-sprig/v3 v3.0.0/go.mod h1:W848ghGpv3Qj3dhTPRyJypKRiqCdHZiAzKg9hl15HA8=
+github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q=
+github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q=
+github.com/golang-sql/civil v0.0.0-20220223132316-b832511892a9 h1:au07oEsX2xN0ktxqI+Sida1w446QrXBRJ0nee3SNZlA=
+github.com/golang-sql/civil v0.0.0-20220223132316-b832511892a9/go.mod h1:8vg3r2VgvsThLBIFL93Qb5yWzgyZWhEmBwUJWevAkK0=
+github.com/golang-sql/sqlexp v0.1.0 h1:ZCD6MBpcuOVfGVqsEmY5/4FtYiKz6tSyUv9LPEDei6A=
+github.com/golang-sql/sqlexp v0.1.0/go.mod h1:J4ad9Vo8ZCWQ2GMrC4UCQy1JpCbwU9m3EOqtpKwwwHI=
+github.com/golang/mock v1.6.0 h1:ErTB+efbowRARo13NNdxyJji2egdxLGQhRaY+DUumQc=
+github.com/golang/mock v1.6.0/go.mod h1:p6yTPP+5HYm5mzsMV8JkE6ZKdX+/wYM6Hr+LicevLPs=
+github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek=
+github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps=
+github.com/google/btree v1.1.3 h1:CVpQJjYgC4VbzxeGVHfvZrv1ctoYCAI8vbl07Fcxlyg=
+github.com/google/btree v1.1.3/go.mod h1:qOPhT0dTNdNzV6Z/lhRX0YXUafgPLFUh+gZMl761Gm4=
+github.com/google/gnostic-models v0.6.8 h1:yo/ABAfM5IMRsS1VnXjTBvUb61tFIHozhlYvRgGre9I=
+github.com/google/gnostic-models v0.6.8/go.mod h1:5n7qKqH0f5wFt+aWF8CW6pZLLNOfYuF5OpfBSENuI8U=
+github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
+github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI=
+github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
+github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
+github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0=
+github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
+github.com/google/pprof v0.0.0-20241210010833-40e02aabc2ad h1:a6HEuzUHeKH6hwfN/ZoQgRgVIWFJljSWa/zetS2WTvg=
+github.com/google/pprof v0.0.0-20241210010833-40e02aabc2ad/go.mod h1:vavhavw2zAxS5dIdcRluK6cSGGPlZynqzFM8NdvU144=
+github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0=
+github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
+github.com/jackc/pgpassfile v1.0.0 h1:/6Hmqy13Ss2zCq62VdNG8tM1wchn8zjSGOBJ6icpsIM=
+github.com/jackc/pgpassfile v1.0.0/go.mod h1:CEx0iS5ambNFdcRtxPj5JhEz+xB6uRky5eyVu/W2HEg=
+github.com/jackc/pgservicefile v0.0.0-20231201235250-de7065d80cb9 h1:L0QtFUgDarD7Fpv9jeVMgy/+Ec0mtnmYuImjTz6dtDA=
+github.com/jackc/pgservicefile v0.0.0-20231201235250-de7065d80cb9/go.mod h1:5TJZWKEWniPve33vlWYSoGYefn3gLQRzjfDlhSJ9ZKM=
+github.com/jackc/pgx/v5 v5.5.5 h1:amBjrZVmksIdNjxGW/IiIMzxMKZFelXbUoPNb+8sjQw=
+github.com/jackc/pgx/v5 v5.5.5/go.mod h1:ez9gk+OAat140fv9ErkZDYFWmXLfV+++K0uAOiwgm1A=
+github.com/jackc/puddle/v2 v2.2.1 h1:RhxXJtFG022u4ibrCSMSiu5aOq1i77R3OHKNJj77OAk=
+github.com/jackc/puddle/v2 v2.2.1/go.mod h1:vriiEXHvEE654aYKXXjOvZM39qJ0q+azkZFrfEOc3H4=
+github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E=
+github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc=
+github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ=
+github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8=
+github.com/josharian/intern v1.0.0 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY=
+github.com/josharian/intern v1.0.0/go.mod h1:5DoeVV0s6jJacbCEi61lwdGj/aVlrQvzHFFd8Hwg//Y=
+github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM=
+github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo=
+github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8=
+github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
+github.com/kr/pretty v0.2.1/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI=
+github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
+github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk=
+github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
+github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
+github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
+github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
+github.com/mailru/easyjson v0.7.7 h1:UGYAvKxe3sBsEDzO8ZeWOSlIQfWFlxbzLZe7hwFURr0=
+github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc=
+github.com/mattn/go-sqlite3 v1.14.22 h1:2gZY6PC6kBnID23Tichd1K+Z0oS6nE/XwU+Vz/5o4kU=
+github.com/mattn/go-sqlite3 v1.14.22/go.mod h1:Uh1q+B4BYcTPb+yiD3kU8Ct7aC0hY9fxUwlHK0RXw+Y=
+github.com/microsoft/go-mssqldb v1.7.2 h1:CHkFJiObW7ItKTJfHo1QX7QBBD1iV+mn1eOyRP3b/PA=
+github.com/microsoft/go-mssqldb v1.7.2/go.mod h1:kOvZKUdrhhFQmxLZqbwUV0rHkNkZpthMITIb2Ko1IoA=
+github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
+github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg=
+github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
+github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M=
+github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk=
+github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 h1:C3w9PqII01/Oq1c1nUAm88MOHcQC9l5mIlSMApZMrHA=
+github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ=
+github.com/onsi/ginkgo/v2 v2.22.2 h1:/3X8Panh8/WwhU/3Ssa6rCKqPLuAkVY2I0RoyDLySlU=
+github.com/onsi/ginkgo/v2 v2.22.2/go.mod h1:oeMosUL+8LtarXBHu/c0bx2D/K9zyQ6uX3cTyztHwsk=
+github.com/onsi/gomega v1.36.2 h1:koNYke6TVk6ZmnyHrCXba/T/MoLBXFjeC1PtvYgw0A8=
+github.com/onsi/gomega v1.36.2/go.mod h1:DdwyADRjrc825LhMEkD76cHR5+pUnjhUN8GlHlRPHzY=
+github.com/openshift/api v0.0.0-20250305225826-b8da3bfeaf77 h1:w6F0sEhlUB1K54Ev4EELsLo5w/xur9pFT19VtemlB4Y=
+github.com/openshift/api v0.0.0-20250305225826-b8da3bfeaf77/go.mod h1:yk60tHAmHhtVpJQo3TwVYq2zpuP70iJIFDCmeKMIzPw=
+github.com/openshift/client-go v0.0.0-20250131180035-f7ec47e2d87a h1:duO3JMrUOqVx50QhzxvDeOYIwTNOB8/EEuRLPyvAMBg=
+github.com/openshift/client-go v0.0.0-20250131180035-f7ec47e2d87a/go.mod h1:Qw3ThpzVZ0bfTILpBNYg4LGyjtNxfyCiGh/uDLOOTP8=
+github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
+github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
+github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 h1:Jamvg5psRIccs7FGNTlIRMkT8wgtp5eCXdBlqhYGL6U=
+github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/prometheus/client_golang v1.19.1 h1:wZWJDwK+NameRJuPGDhlnFgx8e8HN3XHQeLaYJFJBOE=
+github.com/prometheus/client_golang v1.19.1/go.mod h1:mP78NwGzrVks5S2H6ab8+ZZGJLZUq1hoULYBAYBw1Ho=
+github.com/prometheus/client_model v0.6.1 h1:ZKSh/rekM+n3CeS952MLRAdFwIKqeY8b62p8ais2e9E=
+github.com/prometheus/client_model v0.6.1/go.mod h1:OrxVMOVHjw3lKMa8+x6HeMGkHMQyHDk9E3jmP2AmGiY=
+github.com/prometheus/common v0.55.0 h1:KEi6DK7lXW/m7Ig5i47x0vRzuBsHuvJdi5ee6Y3G1dc=
+github.com/prometheus/common v0.55.0/go.mod h1:2SECS4xJG1kd8XF9IcM1gMX6510RAEL65zxzNImwdc8=
+github.com/prometheus/procfs v0.15.1 h1:YagwOFzUgYfKKHX6Dr+sHT7km/hxC76UB0learggepc=
+github.com/prometheus/procfs v0.15.1/go.mod h1:fB45yRUv8NstnjriLhBQLuOUt+WW4BsoGhij/e3PBqk=
+github.com/rogpeppe/go-internal v1.12.0 h1:exVL4IDcn6na9z1rAb56Vxr+CgyK3nn3O+epU5NdKM8=
+github.com/rogpeppe/go-internal v1.12.0/go.mod h1:E+RYuTGaKKdloAfM02xzb0FW3Paa99yedzYV+kq4uf4=
+github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA=
+github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg=
+github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
+github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
+github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo=
+github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
+github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
+github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
+github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
+github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg=
+github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
+github.com/x448/float16 v0.8.4 h1:qLwI1I70+NjRFUR3zs1JPUCgaCXSh3SW62uAKT1mSBM=
+github.com/x448/float16 v0.8.4/go.mod h1:14CWIYCyZA/cWjXOioeEpHeN/83MdbZDRQHoFcYsOfg=
+github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
+github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
+go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto=
+go.uber.org/goleak v1.3.0/go.mod h1:CoHD4mav9JJNrW/WLlf7HGZPjdw8EucARQHekz1X6bE=
+go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0=
+go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y=
+go.uber.org/zap v1.27.0 h1:aJMhYGrd5QSmlpLMr2MftRKl7t8J8PTZPA732ud/XR8=
+go.uber.org/zap v1.27.0/go.mod h1:GB2qFLM7cTU87MWRP2mPIjqfIDnGu+VIO4V/SdhGo2E=
+golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
+golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
+golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
+golang.org/x/crypto v0.31.0 h1:ihbySMvVjLAeSH1IbfcRTkD/iNscyz8rGzjF/E5hV6U=
+golang.org/x/crypto v0.31.0/go.mod h1:kDsLvtWBEx7MV9tJOj9bnXsPbxwJQ6csT/x4KIN4Ssk=
+golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
+golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
+golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
+golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
+golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
+golang.org/x/net v0.33.0 h1:74SYHlV8BIgHIFC/LrYkOGIwL19eTYXQ5wc6TBuO36I=
+golang.org/x/net v0.33.0/go.mod h1:HXLR5J+9DxmrqMwG9qjGCxZ+zKXxBru04zlTvWlWuN4=
+golang.org/x/oauth2 v0.23.0 h1:PbgcYx2W7i4LvjJWEbf0ngHV6qJYr86PkAV3bXdLEbs=
+golang.org/x/oauth2 v0.23.0/go.mod h1:XYTD2NtWslqkgxebSiOHnXEap4TF09sJSc7H1sXbhtI=
+golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.10.0 h1:3NQrjDixjgGwUOCaF8w2+VYHv0Ve/vGYSbdkTa98gmQ=
+golang.org/x/sync v0.10.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
+golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
+golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.28.0 h1:Fksou7UEQUWlKvIdsqzJmUmCX3cZuD2+P3XyyzwMhlA=
+golang.org/x/sys v0.28.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
+golang.org/x/term v0.27.0 h1:WP60Sv1nlK1T6SupCHbXzSaN0b9wUmsPoRS9b61A23Q=
+golang.org/x/term v0.27.0/go.mod h1:iMsnZpn0cago0GOrHO2+Y7u7JPn5AylBrcoWkElMTSM=
+golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
+golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
+golang.org/x/text v0.21.0 h1:zyQAAkrwaneQ066sspRyJaG9VNi/YJ1NfzcGB3hZ/qo=
+golang.org/x/text v0.21.0/go.mod h1:4IBbMaMmOPCJ8SecivzSH54+73PCFmPWxNTLm+vZkEQ=
+golang.org/x/time v0.7.0 h1:ntUhktv3OPE6TgYxXWv9vKvUSJyIFJlyohwbkEwPrKQ=
+golang.org/x/time v0.7.0/go.mod h1:3BpzKBy/shNhVucY/MWOyx10tF3SFh9QdLuxbVysPQM=
+golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
+golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
+golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
+golang.org/x/tools v0.28.0 h1:WuB6qZ4RPCQo5aP3WdKZS7i595EdWqWR8vqJTlwTVK8=
+golang.org/x/tools v0.28.0/go.mod h1:dcIOrVd3mfQKTgrDVQHqCPMWy6lnhfhtX3hLXYVLfRw=
+golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+gomodules.xyz/jsonpatch/v2 v2.4.0 h1:Ci3iUJyx9UeRx7CeFN8ARgGbkESwJK+KB9lLcWxY/Zw=
+gomodules.xyz/jsonpatch/v2 v2.4.0/go.mod h1:AH3dM2RI6uoBZxn3LVrfvJ3E0/9dG4cSrbuBJT4moAY=
+google.golang.org/protobuf v1.35.1 h1:m3LfL6/Ca+fqnjnlqQXNpFPABW1UD7mjh8KO2mKFytA=
+google.golang.org/protobuf v1.35.1/go.mod h1:9fA7Ob0pmnwhb644+1+CVWFRbNajQ6iRojtC/QF5bRE=
+gopkg.in/alexcesaro/quotedprintable.v3 v3.0.0-20150716171945-2caba252f4dc h1:2gGKlE2+asNV9m7xrywl36YYNnBG5ZQ0r/BOOxqPpmk=
+gopkg.in/alexcesaro/quotedprintable.v3 v3.0.0-20150716171945-2caba252f4dc/go.mod h1:m7x9LTH6d71AHyAX77c9yqWCCa3UKHcVEj9y7hAtKDk=
+gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
+gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
+gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q=
+gopkg.in/evanphx/json-patch.v4 v4.12.0 h1:n6jtcsulIzXPJaxegRbvFNNrZDjbij7ny3gmSPG+6V4=
+gopkg.in/evanphx/json-patch.v4 v4.12.0/go.mod h1:p8EYWUEYMpynmqDbY58zCKCFZw8pRWMG4EsWvDvM72M=
+gopkg.in/gomail.v2 v2.0.0-20160411212932-81ebce5c23df h1:n7WqCuqOuCbNr617RXOY0AWRXxgwEyPp2z+p0+hgMuE=
+gopkg.in/gomail.v2 v2.0.0-20160411212932-81ebce5c23df/go.mod h1:LRQQ+SO6ZHR7tOkpBDuZnXENFzX8qRjMDMyPD6BRkCw=
+gopkg.in/inf.v0 v0.9.1 h1:73M5CoZyi3ZLMOyDlQh031Cx6N9NDJ2Vvfl76EDAgDc=
+gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw=
+gopkg.in/natefinch/lumberjack.v2 v2.2.1 h1:bBRl1b0OH9s/DuPhuXpNl+VtCaJXFZ5/uEFST95x9zc=
+gopkg.in/natefinch/lumberjack.v2 v2.2.1/go.mod h1:YD8tP3GAjkrDg1eZH7EGmyESg/lsYskCTPBJVb9jqSc=
+gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
+gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
+gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
+gorm.io/datatypes v1.2.5 h1:9UogU3jkydFVW1bIVVeoYsTpLRgwDVW3rHfJG6/Ek9I=
+gorm.io/datatypes v1.2.5/go.mod h1:I5FUdlKpLb5PMqeMQhm30CQ6jXP8Rj89xkTeCSAaAD4=
+gorm.io/driver/mysql v1.5.6 h1:Ld4mkIickM+EliaQZQx3uOJDJHtrd70MxAUqWqlx3Y8=
+gorm.io/driver/mysql v1.5.6/go.mod h1:sEtPWMiqiN1N1cMXoXmBbd8C6/l+TESwriotuRRpkDM=
+gorm.io/driver/postgres v1.5.0 h1:u2FXTy14l45qc3UeCJ7QaAXZmZfDDv0YrthvmRq1l0U=
+gorm.io/driver/postgres v1.5.0/go.mod h1:FUZXzO+5Uqg5zzwzv4KK49R8lvGIyscBOqYrtI1Ce9A=
+gorm.io/driver/sqlite v1.5.7 h1:8NvsrhP0ifM7LX9G4zPB97NwovUakUxc+2V2uuf3Z1I=
+gorm.io/driver/sqlite v1.5.7/go.mod h1:U+J8craQU6Fzkcvu8oLeAQmi50TkwPEhHDEjQZXDah4=
+gorm.io/driver/sqlserver v1.5.4 h1:xA+Y1KDNspv79q43bPyjDMUgHoYHLhXYmdFcYPobg8g=
+gorm.io/driver/sqlserver v1.5.4/go.mod h1:+frZ/qYmuna11zHPlh5oc2O6ZA/lS88Keb0XSH1Zh/g=
+gorm.io/gorm v1.25.7/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8=
+gorm.io/gorm v1.25.12 h1:I0u8i2hWQItBq1WfE0o2+WuL9+8L21K9e2HHSTE/0f8=
+gorm.io/gorm v1.25.12/go.mod h1:xh7N7RHfYlNc5EmcI/El95gXusucDrQnHXe0+CgWcLQ=
+k8s.io/api v0.32.2 h1:bZrMLEkgizC24G9eViHGOPbW+aRo9duEISRIJKfdJuw=
+k8s.io/api v0.32.2/go.mod h1:hKlhk4x1sJyYnHENsrdCWw31FEmCijNGPJO5WzHiJ6Y=
+k8s.io/apiextensions-apiserver v0.32.1 h1:hjkALhRUeCariC8DiVmb5jj0VjIc1N0DREP32+6UXZw=
+k8s.io/apiextensions-apiserver v0.32.1/go.mod h1:sxWIGuGiYov7Io1fAS2X06NjMIk5CbRHc2StSmbaQto=
+k8s.io/apimachinery v0.32.2 h1:yoQBR9ZGkA6Rgmhbp/yuT9/g+4lxtsGYwW6dR6BDPLQ=
+k8s.io/apimachinery v0.32.2/go.mod h1:GpHVgxoKlTxClKcteaeuF1Ul/lDVb74KpZcxcmLDElE=
+k8s.io/client-go v0.32.2 h1:4dYCD4Nz+9RApM2b/3BtVvBHw54QjMFUl1OLcJG5yOA=
+k8s.io/client-go v0.32.2/go.mod h1:fpZ4oJXclZ3r2nDOv+Ux3XcJutfrwjKTCHz2H3sww94=
+k8s.io/klog/v2 v2.130.1 h1:n9Xl7H1Xvksem4KFG4PYbdQCQxqc/tTUyrgXaOhHSzk=
+k8s.io/klog/v2 v2.130.1/go.mod h1:3Jpz1GvMt720eyJH1ckRHK1EDfpxISzJ7I9OYgaDtPE=
+k8s.io/kube-openapi v0.0.0-20241105132330-32ad38e42d3f h1:GA7//TjRY9yWGy1poLzYYJJ4JRdzg3+O6e8I+e+8T5Y=
+k8s.io/kube-openapi v0.0.0-20241105132330-32ad38e42d3f/go.mod h1:R/HEjbvWI0qdfb8viZUeVZm0X6IZnxAydC7YU42CMw4=
+k8s.io/utils v0.0.0-20241104100929-3ea5e8cea738 h1:M3sRQVHv7vB20Xc2ybTt7ODCeFj6JSWYFzOFnYeS6Ro=
+k8s.io/utils v0.0.0-20241104100929-3ea5e8cea738/go.mod h1:OLgZIPagt7ERELqWJFomSt595RzquPNLL48iOWgYOg0=
+sigs.k8s.io/controller-runtime v0.20.3 h1:I6Ln8JfQjHH7JbtCD2HCYHoIzajoRxPNuvhvcDbZgkI=
+sigs.k8s.io/controller-runtime v0.20.3/go.mod h1:xg2XB0K5ShQzAgsoujxuKN4LNXR2LfwwHsPj7Iaw+XY=
+sigs.k8s.io/json v0.0.0-20241010143419-9aa6b5e7a4b3 h1:/Rv+M11QRah1itp8VhT6HoVx1Ray9eB4DBr+K+/sCJ8=
+sigs.k8s.io/json v0.0.0-20241010143419-9aa6b5e7a4b3/go.mod h1:18nIHnGi6636UCz6m8i4DhaJ65T6EruyzmoQqI2BVDo=
+sigs.k8s.io/structured-merge-diff/v4 v4.4.2 h1:MdmvkGuXi/8io6ixD5wud3vOLwc1rj0aNqRlpuvjmwA=
+sigs.k8s.io/structured-merge-diff/v4 v4.4.2/go.mod h1:N8f93tFZh9U6vpxwRArLiikrE5/2tiu1w1AGfACIGE4=
+sigs.k8s.io/yaml v1.4.0 h1:Mk1wCc2gy/F0THH0TAp1QYyJNzRm2KCLy3o5ASXVI5E=
+sigs.k8s.io/yaml v1.4.0/go.mod h1:Ejl7/uTz7PSA4eKMyQCUTnhZYNmLIl+5c2lQPGR2BPY=
Index: /branches/main/array-ingress-controller/helmchart/array-ingress/.helmignore
===================================================================
--- /branches/main/array-ingress-controller/helmchart/array-ingress/.helmignore	(nonexistent)
+++ /branches/main/array-ingress-controller/helmchart/array-ingress/.helmignore	(working copy)
@@ -0,0 +1,23 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*.orig
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
+.vscode/
Index: /branches/main/array-ingress-controller/helmchart/array-ingress/Chart.yaml
===================================================================
--- /branches/main/array-ingress-controller/helmchart/array-ingress/Chart.yaml	(nonexistent)
+++ /branches/main/array-ingress-controller/helmchart/array-ingress/Chart.yaml	(working copy)
@@ -0,0 +1,24 @@
+apiVersion: v2
+name: array-ingress
+description: A Helm chart for Kubernetes
+
+# A chart can be either an 'application' or a 'library' chart.
+#
+# Application charts are a collection of templates that can be packaged into versioned archives
+# to be deployed.
+#
+# Library charts provide useful utilities or functions for the chart developer. They're included as
+# a dependency of application charts to inject those utilities and functions into the rendering
+# pipeline. Library charts do not define any templates and therefore cannot be deployed.
+type: application
+
+# This is the chart version. This version number should be incremented each time you make changes
+# to the chart and its templates, including the app version.
+# Versions are expected to follow Semantic Versioning (https://semver.org/)
+version: 0.1.0
+
+# This is the version number of the application being deployed. This version number should be
+# incremented each time you make changes to the application. Versions are not expected to
+# follow Semantic Versioning. They should reflect the version the application is using.
+# It is recommended to use it with quotes.
+appVersion: "1.16.0"
Index: /branches/main/array-ingress-controller/helmchart/array-ingress/templates/_helpers.tpl
===================================================================
--- /branches/main/array-ingress-controller/helmchart/array-ingress/templates/_helpers.tpl	(nonexistent)
+++ /branches/main/array-ingress-controller/helmchart/array-ingress/templates/_helpers.tpl	(working copy)
@@ -0,0 +1,62 @@
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "array-ingress.name" -}}
+{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }}
+{{- end }}
+
+{{/*
+Create a default fully qualified app name.
+We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
+If release name contains chart name it will be used as a full name.
+*/}}
+{{- define "array-ingress.fullname" -}}
+{{- if .Values.fullnameOverride }}
+{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }}
+{{- else }}
+{{- $name := default .Chart.Name .Values.nameOverride }}
+{{- if contains $name .Release.Name }}
+{{- .Release.Name | trunc 63 | trimSuffix "-" }}
+{{- else }}
+{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }}
+{{- end }}
+{{- end }}
+{{- end }}
+
+{{/*
+Create chart name and version as used by the chart label.
+*/}}
+{{- define "array-ingress.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }}
+{{- end }}
+
+{{/*
+Common labels
+*/}}
+{{- define "array-ingress.labels" -}}
+helm.sh/chart: {{ include "array-ingress.chart" . }}
+{{ include "array-ingress.selectorLabels" . }}
+{{- if .Chart.AppVersion }}
+app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
+{{- end }}
+app.kubernetes.io/managed-by: {{ .Release.Service }}
+{{- end }}
+
+{{/*
+Selector labels
+*/}}
+{{- define "array-ingress.selectorLabels" -}}
+app.kubernetes.io/name: {{ include "array-ingress.name" . }}
+app.kubernetes.io/instance: {{ .Release.Name }}
+{{- end }}
+
+{{/*
+Create the name of the service account to use
+*/}}
+{{- define "array-ingress.serviceAccountName" -}}
+{{- if .Values.serviceAccount.create }}
+{{- default (include "array-ingress.fullname" .) .Values.serviceAccount.name }}
+{{- else }}
+{{- default "default" .Values.serviceAccount.name }}
+{{- end }}
+{{- end }}
Index: /branches/main/array-ingress-controller/helmchart/array-ingress/templates/deployment.yaml
===================================================================
--- /branches/main/array-ingress-controller/helmchart/array-ingress/templates/deployment.yaml	(nonexistent)
+++ /branches/main/array-ingress-controller/helmchart/array-ingress/templates/deployment.yaml	(working copy)
@@ -0,0 +1,58 @@
+apiVersion: apps/v1
+kind: Deployment
+metadata:
+  name: {{ include "array-ingress.fullname" . }}
+  labels:
+    app: {{ include "array-ingress.name" . }}
+    release: {{ .Release.Name }}
+    chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
+spec:
+  selector:
+    matchLabels:
+      app: {{ include "array-ingress.name" . }}
+      role: array-ingress
+  template:
+    metadata:
+      labels:
+        app: {{ include "array-ingress.name" . }}
+        release: {{ .Release.Name }}
+        role: array-ingress
+    spec:
+      serviceAccountName: {{ .Values.serviceAccount.name }}
+      containers:
+        - name: array-ingress-controller
+          image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
+          imagePullPolicy: {{ .Values.image.pullPolicy }}
+          resources:
+            {{- toYaml .Values.resources | nindent 12 }}
+          command: ["/bin/bash", "-c"]
+          args: ["./array-ingress;"]
+          env:
+          - name: APV_IP
+            value: .Values.apv.ip
+          - name: APV_USERNAME
+            value: .Values.apv.username
+          - name: APV_PASSWORD
+            value: .Values.apv.password
+          - name: APV_INSECURE_SKIP
+            value: .Values.apv.insecureskip
+          - name: APV_TIMEOUT
+            value: .Values.apv.timeout
+          volumeMounts:
+            - name: log-volume
+              mountPath: /var/log/
+      volumes:
+        - name: log-volume
+          persistentVolumeClaim:
+            claimName: array-ingress-log-pvc
+---
+apiVersion: v1
+kind: PersistentVolumeClaim
+metadata:
+  name: array-ingress-log-pvc
+spec:
+  accessModes:
+    - ReadWriteOnce
+  resources:
+    requests:
+      storage: 1Gi
\ No newline at end of file
Index: /branches/main/array-ingress-controller/helmchart/array-ingress/templates/pvc.yaml
===================================================================
--- /branches/main/array-ingress-controller/helmchart/array-ingress/templates/pvc.yaml	(nonexistent)
+++ /branches/main/array-ingress-controller/helmchart/array-ingress/templates/pvc.yaml	(working copy)
@@ -0,0 +1,11 @@
+apiVersion: v1
+kind: PersistentVolumeClaim
+metadata:
+  name: array-ingress-log-pvc
+spec:
+  accessModes:
+    - ReadWriteOnce
+  resources:
+    requests:
+      storage: 1Gi
+
Index: /branches/main/array-ingress-controller/helmchart/array-ingress/templates/serviceaccount.yaml
===================================================================
--- /branches/main/array-ingress-controller/helmchart/array-ingress/templates/serviceaccount.yaml	(nonexistent)
+++ /branches/main/array-ingress-controller/helmchart/array-ingress/templates/serviceaccount.yaml	(working copy)
@@ -0,0 +1,52 @@
+apiVersion: rbac.authorization.k8s.io/v1
+kind: ClusterRole
+metadata:
+  name: ingress-access
+rules:
+- apiGroups: ["networking.k8s.io"]
+  resources: ["ingresses"]
+  verbs: ["get", "list", "watch", "update"]
+- apiGroups: ["route.openshift.io"]
+  resources: ["routes"]
+  verbs: ["get", "list", "watch", "update"]
+- apiGroups: [""]
+  resources: ["services", "pods", "endpoints"]
+  verbs: ["get", "list", "watch", "update"]
+---
+apiVersion: v1
+kind: ServiceAccount
+metadata:
+  name: {{ .Values.serviceAccount.name }}
+  namespace: array-ingress
+---
+apiVersion: rbac.authorization.k8s.io/v1
+kind: ClusterRoleBinding
+metadata:
+  name: ingress-access-binding
+roleRef:
+  apiGroup: rbac.authorization.k8s.io
+  kind: ClusterRole
+  name: ingress-access
+subjects:
+- kind: ServiceAccount
+  name: {{ .Values.serviceAccount.name }}
+  namespace: array-ingress
+---
+apiVersion: security.openshift.io/v1
+kind: SecurityContextConstraints
+metadata:
+  name: ingress-access-scc
+allowPrivilegedContainer: false
+readOnlyRootFilesystem: false
+allowHostPorts: false
+allowHostNetwork: false
+allowHostPID: false
+allowHostIPC: false
+runAsUser:
+  type: RunAsAny
+seLinuxContext:
+  type: RunAsAny
+fsGroup:
+  type: RunAsAny
+users:
+- system:serviceaccount:array-ingress:{{ .Values.serviceAccount.name }}
Index: /branches/main/array-ingress-controller/helmchart/array-ingress/values.yaml
===================================================================
--- /branches/main/array-ingress-controller/helmchart/array-ingress/values.yaml	(nonexistent)
+++ /branches/main/array-ingress-controller/helmchart/array-ingress/values.yaml	(working copy)
@@ -0,0 +1,30 @@
+# Default values for sf-node-manager.
+# This is a YAML-formatted file.
+# Declare variables to be passed into your templates.
+    
+replicaCount: 1
+
+image:
+  repository: vinaynagraj/array-ingress
+  pullPolicy: Always
+  # Overrides the image tag whose default is the chart appVersion.
+  tag: 'latest'
+
+imagePullSecrets: []
+nameOverride: ""
+fullnameOverride: ""
+
+serviceAccount:
+  name: array-ingress-ctrl
+
+resources:
+  requests:
+    cpu: 100m
+    memory: 500Mi
+
+apv:
+  ip: "some_ip"
+  username: "some_username"
+  password: "some_passowrd"
+  insecureskip: "true"
+  timeout: "5s"
Index: /branches/main/array-ingress-controller/main.go
===================================================================
--- /branches/main/array-ingress-controller/main.go	(revision 9)
+++ /branches/main/array-ingress-controller/main.go	(working copy)
@@ -1,34 +1,47 @@
 package main
 
-import(
+import (
+	"context"
+	"time"
 	"arraynetworks.com/array-ingress-controller/apvadapter"
-	"arraynetworks.com/array-ingress-controller/controller/openshift-controller"
+	"arraynetworks.com/array-ingress-controller/controller/openshift"
 	"arraynetworks.com/array-ingress-controller/logger"
-	//"arraynetworks.com/array-ingress-controller/watchtower"
+	"arraynetworks.com/array-ingress-controller/watchtower"
 )
 
 var (
-	log	logger.Logger
+	log logger.Logger
 )
 
-func init(){
-	log	= logger.GetLogger()
+func init() {
+	log = logger.GetLogger()
 }
 
-func main(){
+func main() {
+
 	for {
+		ctx, cancel := context.WithCancel(context.Background()) // Create a context
 		done := make(chan error)
+
 		log.Infof("Starting ApvAdapter...")
 		go apvadapter.StartReconcile()
+
 		log.Infof("Starting Controllers...")
-		go controller. StartControllers()
+		go openshift.StartControllers()
+
+		log.Infof("Starting WatchTower...")
+		go watchtower.StartMonitoring(ctx)
+    
 		// Wait for the goroutines to complete
 		err := <-done
+
 		// Check for errors and restart all modules
 		if err != nil {
 			log.Errorf("Error occurred:", err)
+			cancel()                     // Cancel the context
 			time.Sleep(10 * time.Second) // Wait before restarting
 			continue
 		}
 	}
+
 }
