Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rename to NGINX terms #48

Merged
merged 1 commit into from
Apr 25, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions internal/application/application_constants.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,9 @@ package application
// 3. Update the NewBorderClient factory method in border_client.go that returns the client;
const (

// ClientTypeTcp creates a TcpBorderClient that uses the Stream* methods of the NGINX Plus client.
ClientTypeTcp = "tcp"
// ClientTypeNginxStream creates a NginxStreamBorderClient that uses the Stream* methods of the NGINX Plus client.
ClientTypeNginxStream = "stream"

// ClientTypeHttp creates an HttpBorderClient that uses the HTTP* methods of the NGINX Plus client.
ClientTypeHttp = "http"
// ClientTypeNginxHttp creates an NginxHttpBorderClient that uses the HTTP* methods of the NGINX Plus client.
ClientTypeNginxHttp = "http"
)
8 changes: 4 additions & 4 deletions internal/application/border_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,11 +31,11 @@ func NewBorderClient(clientType string, borderClient interface{}) (Interface, er
logrus.Debugf(`NewBorderClient for type: %s`, clientType)

switch clientType {
case ClientTypeTcp:
return NewTcpBorderClient(borderClient)
case ClientTypeNginxStream:
return NewNginxStreamBorderClient(borderClient)

case ClientTypeHttp:
return NewHttpBorderClient(borderClient)
case ClientTypeNginxHttp:
return NewNginxHttpBorderClient(borderClient)

default:
borderClient, _ := NewNullBorderClient()
Expand Down
10 changes: 5 additions & 5 deletions internal/application/border_client_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,20 +17,20 @@ func TestBorderClient_CreatesHttpBorderClient(t *testing.T) {
t.Errorf(`error creating border client: %v`, err)
}

if _, ok := client.(*HttpBorderClient); !ok {
t.Errorf(`expected client to be of type HttpBorderClient`)
if _, ok := client.(*NginxHttpBorderClient); !ok {
t.Errorf(`expected client to be of type NginxHttpBorderClient`)
}
}

func TestBorderClient_CreatesTcpBorderClient(t *testing.T) {
borderClient := mocks.MockNginxClient{}
client, err := NewBorderClient("tcp", borderClient)
client, err := NewBorderClient("stream", borderClient)
if err != nil {
t.Errorf(`error creating border client: %v`, err)
}

if _, ok := client.(*TcpBorderClient); !ok {
t.Errorf(`expected client to be of type TcpBorderClient`)
if _, ok := client.(*NginxStreamBorderClient); !ok {
t.Errorf(`expected client to be of type NginxStreamBorderClient`)
}
}

Expand Down
4 changes: 2 additions & 2 deletions internal/application/doc.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ To add a Border Server client...
At this time the only supported Border Servers are NGINX Plus servers.

The two Border Server clients for NGINX Plus are:
- HttpBorderClient: updates NGINX Plus servers using HTTP Upstream methods on the NGINX Plus API.
- TcpBorderClient: updates NGINX Plus servers using Stream Upstream methods on the NGINX Plus API.
- NginxHttpBorderClient: updates NGINX Plus servers using HTTP Upstream methods on the NGINX Plus API.
- NginxStreamBorderClient: updates NGINX Plus servers using Stream Upstream methods on the NGINX Plus API.

Both of these implementations use the NGINX Plus client module to communicate with the NGINX Plus server.

Expand Down
8 changes: 4 additions & 4 deletions internal/application/nginx_client_interface.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,15 @@ import nginxClient "github.com/nginxinc/nginx-plus-go-client/client"

// NginxClientInterface defines the functions used on the NGINX Plus client, abstracting away the full details of that client.
type NginxClientInterface interface {
// DeleteStreamServer is used by the TcpBorderClient.
// DeleteStreamServer is used by the NginxStreamBorderClient.
DeleteStreamServer(upstream string, server string) error

// UpdateStreamServers is used by the TcpBorderClient.
// UpdateStreamServers is used by the NginxStreamBorderClient.
UpdateStreamServers(upstream string, servers []nginxClient.StreamUpstreamServer) ([]nginxClient.StreamUpstreamServer, []nginxClient.StreamUpstreamServer, []nginxClient.StreamUpstreamServer, error)

// DeleteHTTPServer is used by the HttpBorderClient.
// DeleteHTTPServer is used by the NginxHttpBorderClient.
DeleteHTTPServer(upstream string, server string) error

// UpdateHTTPServers is used by the HttpBorderClient.
// UpdateHTTPServers is used by the NginxHttpBorderClient.
UpdateHTTPServers(upstream string, servers []nginxClient.UpstreamServer) ([]nginxClient.UpstreamServer, []nginxClient.UpstreamServer, []nginxClient.UpstreamServer, error)
}
Original file line number Diff line number Diff line change
Expand Up @@ -11,26 +11,26 @@ import (
nginxClient "github.com/nginxinc/nginx-plus-go-client/client"
)

// HttpBorderClient implements the BorderClient interface for HTTP upstreams.
type HttpBorderClient struct {
// NginxHttpBorderClient implements the BorderClient interface for HTTP upstreams.
type NginxHttpBorderClient struct {
BorderClient
nginxClient NginxClientInterface
}

// NewHttpBorderClient is the Factory function for creating an HttpBorderClient.
func NewHttpBorderClient(client interface{}) (Interface, error) {
// NewNginxHttpBorderClient is the Factory function for creating an NginxHttpBorderClient.
func NewNginxHttpBorderClient(client interface{}) (Interface, error) {
ngxClient, ok := client.(NginxClientInterface)
if !ok {
return nil, fmt.Errorf(`expected a NginxClientInterface, got a %v`, client)
}

return &HttpBorderClient{
return &NginxHttpBorderClient{
nginxClient: ngxClient,
}, nil
}

// Update manages the Upstream servers for the Upstream Name given in the ServerUpdateEvent.
func (hbc *HttpBorderClient) Update(event *core.ServerUpdateEvent) error {
func (hbc *NginxHttpBorderClient) Update(event *core.ServerUpdateEvent) error {
httpUpstreamServers := asNginxHttpUpstreamServers(event.UpstreamServers)
_, _, _, err := hbc.nginxClient.UpdateHTTPServers(event.UpstreamName, httpUpstreamServers)
if err != nil {
Expand All @@ -41,7 +41,7 @@ func (hbc *HttpBorderClient) Update(event *core.ServerUpdateEvent) error {
}

// Delete deletes the Upstream server for the Upstream Name given in the ServerUpdateEvent.
func (hbc *HttpBorderClient) Delete(event *core.ServerUpdateEvent) error {
func (hbc *NginxHttpBorderClient) Delete(event *core.ServerUpdateEvent) error {
err := hbc.nginxClient.DeleteHTTPServer(event.UpstreamName, event.UpstreamServers[0].Host)
if err != nil {
return fmt.Errorf(`error occurred deleting the nginx+ upstream server: %w`, err)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,8 @@ import (
)

func TestHttpBorderClient_Delete(t *testing.T) {
event := buildServerUpdateEvent(deletedEventType, ClientTypeHttp)
borderClient, nginxClient, err := buildBorderClient(ClientTypeHttp)
event := buildServerUpdateEvent(deletedEventType, ClientTypeNginxHttp)
borderClient, nginxClient, err := buildBorderClient(ClientTypeNginxHttp)
if err != nil {
t.Fatalf(`error occurred creating a new border client: %v`, err)
}
Expand All @@ -27,8 +27,8 @@ func TestHttpBorderClient_Delete(t *testing.T) {
}

func TestHttpBorderClient_Update(t *testing.T) {
event := buildServerUpdateEvent(createEventType, ClientTypeHttp)
borderClient, nginxClient, err := buildBorderClient(ClientTypeHttp)
event := buildServerUpdateEvent(createEventType, ClientTypeNginxHttp)
borderClient, nginxClient, err := buildBorderClient(ClientTypeNginxHttp)
if err != nil {
t.Fatalf(`error occurred creating a new border client: %v`, err)
}
Expand All @@ -45,15 +45,15 @@ func TestHttpBorderClient_Update(t *testing.T) {

func TestHttpBorderClient_BadNginxClient(t *testing.T) {
var emptyInterface interface{}
_, err := NewBorderClient(ClientTypeHttp, emptyInterface)
_, err := NewBorderClient(ClientTypeNginxHttp, emptyInterface)
if err == nil {
t.Fatalf(`expected an error to occur when creating a new border client`)
}
}

func TestHttpBorderClient_DeleteReturnsError(t *testing.T) {
event := buildServerUpdateEvent(deletedEventType, ClientTypeHttp)
borderClient, _, err := buildTerrorizingBorderClient(ClientTypeHttp)
event := buildServerUpdateEvent(deletedEventType, ClientTypeNginxHttp)
borderClient, _, err := buildTerrorizingBorderClient(ClientTypeNginxHttp)
if err != nil {
t.Fatalf(`error occurred creating a new border client: %v`, err)
}
Expand All @@ -66,8 +66,8 @@ func TestHttpBorderClient_DeleteReturnsError(t *testing.T) {
}

func TestHttpBorderClient_UpdateReturnsError(t *testing.T) {
event := buildServerUpdateEvent(createEventType, ClientTypeHttp)
borderClient, _, err := buildTerrorizingBorderClient(ClientTypeHttp)
event := buildServerUpdateEvent(createEventType, ClientTypeNginxHttp)
borderClient, _, err := buildTerrorizingBorderClient(ClientTypeNginxHttp)
if err != nil {
t.Fatalf(`error occurred creating a new border client: %v`, err)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,26 +11,26 @@ import (
nginxClient "github.com/nginxinc/nginx-plus-go-client/client"
)

// TcpBorderClient implements the BorderClient interface for TCP upstreams.
type TcpBorderClient struct {
// NginxStreamBorderClient implements the BorderClient interface for stream upstreams.
type NginxStreamBorderClient struct {
BorderClient
nginxClient NginxClientInterface
}

// NewTcpBorderClient is the Factory function for creating an TcpBorderClient.
func NewTcpBorderClient(client interface{}) (Interface, error) {
// NewNginxStreamBorderClient is the Factory function for creating an NginxStreamBorderClient.
func NewNginxStreamBorderClient(client interface{}) (Interface, error) {
ngxClient, ok := client.(NginxClientInterface)
if !ok {
return nil, fmt.Errorf(`expected a NginxClientInterface, got a %v`, client)
}

return &TcpBorderClient{
return &NginxStreamBorderClient{
nginxClient: ngxClient,
}, nil
}

// Update manages the Upstream servers for the Upstream Name given in the ServerUpdateEvent.
func (tbc *TcpBorderClient) Update(event *core.ServerUpdateEvent) error {
func (tbc *NginxStreamBorderClient) Update(event *core.ServerUpdateEvent) error {
streamUpstreamServers := asNginxStreamUpstreamServers(event.UpstreamServers)
_, _, _, err := tbc.nginxClient.UpdateStreamServers(event.UpstreamName, streamUpstreamServers)
if err != nil {
Expand All @@ -41,7 +41,7 @@ func (tbc *TcpBorderClient) Update(event *core.ServerUpdateEvent) error {
}

// Delete deletes the Upstream server for the Upstream Name given in the ServerUpdateEvent.
func (tbc *TcpBorderClient) Delete(event *core.ServerUpdateEvent) error {
func (tbc *NginxStreamBorderClient) Delete(event *core.ServerUpdateEvent) error {
err := tbc.nginxClient.DeleteStreamServer(event.UpstreamName, event.UpstreamServers[0].Host)
if err != nil {
return fmt.Errorf(`error occurred deleting the nginx+ upstream server: %w`, err)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,8 @@ import (
)

func TestTcpBorderClient_Delete(t *testing.T) {
event := buildServerUpdateEvent(deletedEventType, ClientTypeTcp)
borderClient, nginxClient, err := buildBorderClient(ClientTypeTcp)
event := buildServerUpdateEvent(deletedEventType, ClientTypeNginxStream)
borderClient, nginxClient, err := buildBorderClient(ClientTypeNginxStream)
if err != nil {
t.Fatalf(`error occurred creating a new border client: %v`, err)
}
Expand All @@ -27,8 +27,8 @@ func TestTcpBorderClient_Delete(t *testing.T) {
}

func TestTcpBorderClient_Update(t *testing.T) {
event := buildServerUpdateEvent(createEventType, ClientTypeTcp)
borderClient, nginxClient, err := buildBorderClient(ClientTypeTcp)
event := buildServerUpdateEvent(createEventType, ClientTypeNginxStream)
borderClient, nginxClient, err := buildBorderClient(ClientTypeNginxStream)
if err != nil {
t.Fatalf(`error occurred creating a new border client: %v`, err)
}
Expand All @@ -45,15 +45,15 @@ func TestTcpBorderClient_Update(t *testing.T) {

func TestTcpBorderClient_BadNginxClient(t *testing.T) {
var emptyInterface interface{}
_, err := NewBorderClient(ClientTypeTcp, emptyInterface)
_, err := NewBorderClient(ClientTypeNginxStream, emptyInterface)
if err == nil {
t.Fatalf(`expected an error to occur when creating a new border client`)
}
}

func TestTcpBorderClient_DeleteReturnsError(t *testing.T) {
event := buildServerUpdateEvent(deletedEventType, ClientTypeTcp)
borderClient, _, err := buildTerrorizingBorderClient(ClientTypeTcp)
event := buildServerUpdateEvent(deletedEventType, ClientTypeNginxStream)
borderClient, _, err := buildTerrorizingBorderClient(ClientTypeNginxStream)
if err != nil {
t.Fatalf(`error occurred creating a new border client: %v`, err)
}
Expand All @@ -66,8 +66,8 @@ func TestTcpBorderClient_DeleteReturnsError(t *testing.T) {
}

func TestTcpBorderClient_UpdateReturnsError(t *testing.T) {
event := buildServerUpdateEvent(createEventType, ClientTypeTcp)
borderClient, _, err := buildTerrorizingBorderClient(ClientTypeTcp)
event := buildServerUpdateEvent(createEventType, ClientTypeNginxStream)
borderClient, _, err := buildTerrorizingBorderClient(ClientTypeNginxStream)
if err != nil {
t.Fatalf(`error occurred creating a new border client: %v`, err)
}
Expand Down
4 changes: 2 additions & 2 deletions internal/translation/translator.go
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ func fixIngressName(name string) string {
return name[4:]
}

// getClientType returns the client type for the port, defaults to ClientTypeHttp if no Annotation is found.
// getClientType returns the client type for the port, defaults to ClientTypeNginxHttp if no Annotation is found.
func getClientType(portName string, annotations map[string]string) string {
key := fmt.Sprintf("%s/%s", configuration.PortAnnotationPrefix, portName)
logrus.Infof("getClientType: key=%s", key)
Expand All @@ -99,5 +99,5 @@ func getClientType(portName string, annotations map[string]string) string {
}
}

return application.ClientTypeHttp
return application.ClientTypeNginxHttp
}