From 98e6f648c7c12928c1bdc3212301a2fb976be3fa Mon Sep 17 00:00:00 2001 From: Rahmat Hidayat Date: Tue, 23 May 2023 12:17:07 +0700 Subject: [PATCH] feat(provider): encrypt credentials on higher field level --- api/handler/v1beta1/mocks/activityService.go | 59 ++++- api/handler/v1beta1/mocks/appealService.go | 105 ++++++-- api/handler/v1beta1/mocks/approvalService.go | 25 +- api/handler/v1beta1/mocks/policyService.go | 63 ++++- api/handler/v1beta1/mocks/providerService.go | 152 +++++++++--- api/handler/v1beta1/mocks/resourceService.go | 95 ++++++-- core/activity/mocks/auditLogger.go | 28 ++- core/activity/mocks/providerService.go | 31 ++- core/activity/mocks/repository.go | 54 ++++- core/appeal/mocks/approvalService.go | 24 +- core/appeal/mocks/auditLogger.go | 28 ++- core/appeal/mocks/grantService.go | 65 ++++- core/appeal/mocks/iamManager.go | 41 +++- core/appeal/mocks/notifier.go | 24 +- core/appeal/mocks/policyService.go | 45 +++- core/appeal/mocks/providerService.go | 78 ++++-- core/appeal/mocks/repository.go | 63 ++++- core/appeal/mocks/resourceService.go | 45 +++- core/approval/mocks/policyService.go | 18 +- core/approval/mocks/repository.go | 45 +++- core/grant/mocks/auditLogger.go | 28 ++- core/grant/mocks/notifier.go | 24 +- core/grant/mocks/providerService.go | 56 ++++- core/grant/mocks/repository.go | 63 ++++- core/grant/mocks/resourceService.go | 31 ++- core/policy/mocks/auditLogger.go | 28 ++- core/policy/mocks/providerService.go | 46 +++- core/policy/mocks/repository.go | 54 ++++- core/policy/mocks/resourceService.go | 31 ++- core/provider/mocks/activityManager.go | 33 ++- core/provider/mocks/auditLogger.go | 28 ++- core/provider/mocks/client.go | 110 +++++++-- .../provider}/mocks/encryptor.go | 41 +++- core/provider/mocks/repository.go | 98 ++++++-- core/provider/mocks/resourceService.go | 49 +++- core/provider/service.go | 37 ++- core/provider/service_test.go | 27 ++- core/resource/mocks/auditLogger.go | 28 ++- core/resource/mocks/repository.go | 81 +++++-- domain/encryption.go | 4 + domain/mocks/Decryptor.go | 85 +++++++ .../encryptor.go => domain/mocks/Encryptor.go | 77 +++--- domain/provider.go | 43 +++- domain/provider_test.go | 112 +++++++++ internal/server/services.go | 13 +- ...0015_migrate_provider_credentials.down.sql | 0 ...000015_migrate_provider_credentials.up.sql | 0 jobs/mocks/grantService.go | 27 ++- jobs/mocks/providerService.go | 17 +- plugins/providers/bigquery/config.go | 59 +---- plugins/providers/bigquery/config_test.go | 93 +------- .../bigquery/mocks/BigQueryClient.go | 139 ++++++++--- .../bigquery/mocks/cloudLoggingClientI.go | 36 ++- plugins/providers/bigquery/provider.go | 23 +- plugins/providers/bigquery/provider_test.go | 93 ++------ plugins/providers/dataplex/config.go | 53 +---- plugins/providers/dataplex/config_test.go | 95 +------- plugins/providers/dataplex/provider.go | 28 +-- plugins/providers/dataplex/provider_test.go | 77 ++---- plugins/providers/gcloudiam/config.go | 50 +--- plugins/providers/gcloudiam/config_test.go | 94 -------- .../gcloudiam/mocks/GcloudIamClient.go | 63 ++++- .../providers/gcloudiam/mocks/encryptor.go | 41 +++- plugins/providers/gcloudiam/provider.go | 14 +- plugins/providers/gcloudiam/provider_test.go | 108 ++------- plugins/providers/gcs/config.go | 32 +-- plugins/providers/gcs/provider.go | 19 +- plugins/providers/gcs/provider_test.go | 225 +----------------- plugins/providers/grafana/config.go | 50 +--- plugins/providers/grafana/config_test.go | 94 -------- plugins/providers/grafana/provider.go | 17 +- plugins/providers/grafana/provider_test.go | 104 +++----- 72 files changed, 2299 insertions(+), 1667 deletions(-) rename {plugins/providers/bigquery => core/provider}/mocks/encryptor.go (71%) create mode 100644 domain/mocks/Decryptor.go rename plugins/providers/dataplex/mocks/encryptor.go => domain/mocks/Encryptor.go (53%) create mode 100644 domain/provider_test.go create mode 100644 internal/store/postgres/migrations/000015_migrate_provider_credentials.down.sql create mode 100644 internal/store/postgres/migrations/000015_migrate_provider_credentials.up.sql diff --git a/api/handler/v1beta1/mocks/activityService.go b/api/handler/v1beta1/mocks/activityService.go index e3c95b01e..bd131bedf 100644 --- a/api/handler/v1beta1/mocks/activityService.go +++ b/api/handler/v1beta1/mocks/activityService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *ActivityService) Find(_a0 context.Context, _a1 domain.ListProviderActi ret := _m.Called(_a0, _a1) var r0 []*domain.Activity + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListProviderActivitiesFilter) ([]*domain.Activity, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListProviderActivitiesFilter) []*domain.Activity); ok { r0 = rf(_a0, _a1) } else { @@ -35,7 +39,6 @@ func (_m *ActivityService) Find(_a0 context.Context, _a1 domain.ListProviderActi } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListProviderActivitiesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -51,8 +54,8 @@ type ActivityService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListProviderActivitiesFilter +// - _a0 context.Context +// - _a1 domain.ListProviderActivitiesFilter func (_e *ActivityService_Expecter) Find(_a0 interface{}, _a1 interface{}) *ActivityService_Find_Call { return &ActivityService_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -69,11 +72,20 @@ func (_c *ActivityService_Find_Call) Return(_a0 []*domain.Activity, _a1 error) * return _c } +func (_c *ActivityService_Find_Call) RunAndReturn(run func(context.Context, domain.ListProviderActivitiesFilter) ([]*domain.Activity, error)) *ActivityService_Find_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: _a0, _a1 func (_m *ActivityService) GetOne(_a0 context.Context, _a1 string) (*domain.Activity, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Activity + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Activity, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Activity); ok { r0 = rf(_a0, _a1) } else { @@ -82,7 +94,6 @@ func (_m *ActivityService) GetOne(_a0 context.Context, _a1 string) (*domain.Acti } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -98,8 +109,8 @@ type ActivityService_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *ActivityService_Expecter) GetOne(_a0 interface{}, _a1 interface{}) *ActivityService_GetOne_Call { return &ActivityService_GetOne_Call{Call: _e.mock.On("GetOne", _a0, _a1)} } @@ -116,11 +127,20 @@ func (_c *ActivityService_GetOne_Call) Return(_a0 *domain.Activity, _a1 error) * return _c } +func (_c *ActivityService_GetOne_Call) RunAndReturn(run func(context.Context, string) (*domain.Activity, error)) *ActivityService_GetOne_Call { + _c.Call.Return(run) + return _c +} + // Import provides a mock function with given fields: _a0, _a1 func (_m *ActivityService) Import(_a0 context.Context, _a1 domain.ImportActivitiesFilter) ([]*domain.Activity, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Activity + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ImportActivitiesFilter) ([]*domain.Activity, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ImportActivitiesFilter) []*domain.Activity); ok { r0 = rf(_a0, _a1) } else { @@ -129,7 +149,6 @@ func (_m *ActivityService) Import(_a0 context.Context, _a1 domain.ImportActiviti } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ImportActivitiesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -145,8 +164,8 @@ type ActivityService_Import_Call struct { } // Import is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ImportActivitiesFilter +// - _a0 context.Context +// - _a1 domain.ImportActivitiesFilter func (_e *ActivityService_Expecter) Import(_a0 interface{}, _a1 interface{}) *ActivityService_Import_Call { return &ActivityService_Import_Call{Call: _e.mock.On("Import", _a0, _a1)} } @@ -162,3 +181,23 @@ func (_c *ActivityService_Import_Call) Return(_a0 []*domain.Activity, _a1 error) _c.Call.Return(_a0, _a1) return _c } + +func (_c *ActivityService_Import_Call) RunAndReturn(run func(context.Context, domain.ImportActivitiesFilter) ([]*domain.Activity, error)) *ActivityService_Import_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewActivityService interface { + mock.TestingT + Cleanup(func()) +} + +// NewActivityService creates a new instance of ActivityService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewActivityService(t mockConstructorTestingTNewActivityService) *ActivityService { + mock := &ActivityService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/api/handler/v1beta1/mocks/appealService.go b/api/handler/v1beta1/mocks/appealService.go index 141711ed7..02183f30b 100644 --- a/api/handler/v1beta1/mocks/appealService.go +++ b/api/handler/v1beta1/mocks/appealService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.14.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -30,6 +30,10 @@ func (_m *AppealService) AddApprover(ctx context.Context, appealID string, appro ret := _m.Called(ctx, appealID, approvalID, email) var r0 *domain.Appeal + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, string, string) (*domain.Appeal, error)); ok { + return rf(ctx, appealID, approvalID, email) + } if rf, ok := ret.Get(0).(func(context.Context, string, string, string) *domain.Appeal); ok { r0 = rf(ctx, appealID, approvalID, email) } else { @@ -38,7 +42,6 @@ func (_m *AppealService) AddApprover(ctx context.Context, appealID string, appro } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, string, string) error); ok { r1 = rf(ctx, appealID, approvalID, email) } else { @@ -54,10 +57,10 @@ type AppealService_AddApprover_Call struct { } // AddApprover is a helper method to define mock.On call -// - ctx context.Context -// - appealID string -// - approvalID string -// - email string +// - ctx context.Context +// - appealID string +// - approvalID string +// - email string func (_e *AppealService_Expecter) AddApprover(ctx interface{}, appealID interface{}, approvalID interface{}, email interface{}) *AppealService_AddApprover_Call { return &AppealService_AddApprover_Call{Call: _e.mock.On("AddApprover", ctx, appealID, approvalID, email)} } @@ -74,11 +77,20 @@ func (_c *AppealService_AddApprover_Call) Return(_a0 *domain.Appeal, _a1 error) return _c } +func (_c *AppealService_AddApprover_Call) RunAndReturn(run func(context.Context, string, string, string) (*domain.Appeal, error)) *AppealService_AddApprover_Call { + _c.Call.Return(run) + return _c +} + // Cancel provides a mock function with given fields: _a0, _a1 func (_m *AppealService) Cancel(_a0 context.Context, _a1 string) (*domain.Appeal, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Appeal + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Appeal, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Appeal); ok { r0 = rf(_a0, _a1) } else { @@ -87,7 +99,6 @@ func (_m *AppealService) Cancel(_a0 context.Context, _a1 string) (*domain.Appeal } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -103,8 +114,8 @@ type AppealService_Cancel_Call struct { } // Cancel is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *AppealService_Expecter) Cancel(_a0 interface{}, _a1 interface{}) *AppealService_Cancel_Call { return &AppealService_Cancel_Call{Call: _e.mock.On("Cancel", _a0, _a1)} } @@ -121,6 +132,11 @@ func (_c *AppealService_Cancel_Call) Return(_a0 *domain.Appeal, _a1 error) *Appe return _c } +func (_c *AppealService_Cancel_Call) RunAndReturn(run func(context.Context, string) (*domain.Appeal, error)) *AppealService_Cancel_Call { + _c.Call.Return(run) + return _c +} + // Create provides a mock function with given fields: _a0, _a1, _a2 func (_m *AppealService) Create(_a0 context.Context, _a1 []*domain.Appeal, _a2 ...appeal.CreateAppealOption) error { _va := make([]interface{}, len(_a2)) @@ -148,9 +164,9 @@ type AppealService_Create_Call struct { } // Create is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Appeal -// - _a2 ...appeal.CreateAppealOption +// - _a0 context.Context +// - _a1 []*domain.Appeal +// - _a2 ...appeal.CreateAppealOption func (_e *AppealService_Expecter) Create(_a0 interface{}, _a1 interface{}, _a2 ...interface{}) *AppealService_Create_Call { return &AppealService_Create_Call{Call: _e.mock.On("Create", append([]interface{}{_a0, _a1}, _a2...)...)} @@ -174,11 +190,20 @@ func (_c *AppealService_Create_Call) Return(_a0 error) *AppealService_Create_Cal return _c } +func (_c *AppealService_Create_Call) RunAndReturn(run func(context.Context, []*domain.Appeal, ...appeal.CreateAppealOption) error) *AppealService_Create_Call { + _c.Call.Return(run) + return _c +} + // DeleteApprover provides a mock function with given fields: ctx, appealID, approvalID, email func (_m *AppealService) DeleteApprover(ctx context.Context, appealID string, approvalID string, email string) (*domain.Appeal, error) { ret := _m.Called(ctx, appealID, approvalID, email) var r0 *domain.Appeal + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, string, string) (*domain.Appeal, error)); ok { + return rf(ctx, appealID, approvalID, email) + } if rf, ok := ret.Get(0).(func(context.Context, string, string, string) *domain.Appeal); ok { r0 = rf(ctx, appealID, approvalID, email) } else { @@ -187,7 +212,6 @@ func (_m *AppealService) DeleteApprover(ctx context.Context, appealID string, ap } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, string, string) error); ok { r1 = rf(ctx, appealID, approvalID, email) } else { @@ -203,10 +227,10 @@ type AppealService_DeleteApprover_Call struct { } // DeleteApprover is a helper method to define mock.On call -// - ctx context.Context -// - appealID string -// - approvalID string -// - email string +// - ctx context.Context +// - appealID string +// - approvalID string +// - email string func (_e *AppealService_Expecter) DeleteApprover(ctx interface{}, appealID interface{}, approvalID interface{}, email interface{}) *AppealService_DeleteApprover_Call { return &AppealService_DeleteApprover_Call{Call: _e.mock.On("DeleteApprover", ctx, appealID, approvalID, email)} } @@ -223,11 +247,20 @@ func (_c *AppealService_DeleteApprover_Call) Return(_a0 *domain.Appeal, _a1 erro return _c } +func (_c *AppealService_DeleteApprover_Call) RunAndReturn(run func(context.Context, string, string, string) (*domain.Appeal, error)) *AppealService_DeleteApprover_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0, _a1 func (_m *AppealService) Find(_a0 context.Context, _a1 *domain.ListAppealsFilter) ([]*domain.Appeal, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Appeal + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *domain.ListAppealsFilter) ([]*domain.Appeal, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, *domain.ListAppealsFilter) []*domain.Appeal); ok { r0 = rf(_a0, _a1) } else { @@ -236,7 +269,6 @@ func (_m *AppealService) Find(_a0 context.Context, _a1 *domain.ListAppealsFilter } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, *domain.ListAppealsFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -252,8 +284,8 @@ type AppealService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.ListAppealsFilter +// - _a0 context.Context +// - _a1 *domain.ListAppealsFilter func (_e *AppealService_Expecter) Find(_a0 interface{}, _a1 interface{}) *AppealService_Find_Call { return &AppealService_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -270,11 +302,20 @@ func (_c *AppealService_Find_Call) Return(_a0 []*domain.Appeal, _a1 error) *Appe return _c } +func (_c *AppealService_Find_Call) RunAndReturn(run func(context.Context, *domain.ListAppealsFilter) ([]*domain.Appeal, error)) *AppealService_Find_Call { + _c.Call.Return(run) + return _c +} + // GetByID provides a mock function with given fields: _a0, _a1 func (_m *AppealService) GetByID(_a0 context.Context, _a1 string) (*domain.Appeal, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Appeal + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Appeal, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Appeal); ok { r0 = rf(_a0, _a1) } else { @@ -283,7 +324,6 @@ func (_m *AppealService) GetByID(_a0 context.Context, _a1 string) (*domain.Appea } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -299,8 +339,8 @@ type AppealService_GetByID_Call struct { } // GetByID is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *AppealService_Expecter) GetByID(_a0 interface{}, _a1 interface{}) *AppealService_GetByID_Call { return &AppealService_GetByID_Call{Call: _e.mock.On("GetByID", _a0, _a1)} } @@ -317,11 +357,20 @@ func (_c *AppealService_GetByID_Call) Return(_a0 *domain.Appeal, _a1 error) *App return _c } +func (_c *AppealService_GetByID_Call) RunAndReturn(run func(context.Context, string) (*domain.Appeal, error)) *AppealService_GetByID_Call { + _c.Call.Return(run) + return _c +} + // UpdateApproval provides a mock function with given fields: ctx, approvalAction func (_m *AppealService) UpdateApproval(ctx context.Context, approvalAction domain.ApprovalAction) (*domain.Appeal, error) { ret := _m.Called(ctx, approvalAction) var r0 *domain.Appeal + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ApprovalAction) (*domain.Appeal, error)); ok { + return rf(ctx, approvalAction) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ApprovalAction) *domain.Appeal); ok { r0 = rf(ctx, approvalAction) } else { @@ -330,7 +379,6 @@ func (_m *AppealService) UpdateApproval(ctx context.Context, approvalAction doma } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ApprovalAction) error); ok { r1 = rf(ctx, approvalAction) } else { @@ -346,8 +394,8 @@ type AppealService_UpdateApproval_Call struct { } // UpdateApproval is a helper method to define mock.On call -// - ctx context.Context -// - approvalAction domain.ApprovalAction +// - ctx context.Context +// - approvalAction domain.ApprovalAction func (_e *AppealService_Expecter) UpdateApproval(ctx interface{}, approvalAction interface{}) *AppealService_UpdateApproval_Call { return &AppealService_UpdateApproval_Call{Call: _e.mock.On("UpdateApproval", ctx, approvalAction)} } @@ -364,6 +412,11 @@ func (_c *AppealService_UpdateApproval_Call) Return(_a0 *domain.Appeal, _a1 erro return _c } +func (_c *AppealService_UpdateApproval_Call) RunAndReturn(run func(context.Context, domain.ApprovalAction) (*domain.Appeal, error)) *AppealService_UpdateApproval_Call { + _c.Call.Return(run) + return _c +} + type mockConstructorTestingTNewAppealService interface { mock.TestingT Cleanup(func()) diff --git a/api/handler/v1beta1/mocks/approvalService.go b/api/handler/v1beta1/mocks/approvalService.go index 594ac80a4..178c74f79 100644 --- a/api/handler/v1beta1/mocks/approvalService.go +++ b/api/handler/v1beta1/mocks/approvalService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.14.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type ApprovalService_BulkInsert_Call struct { } // BulkInsert is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Approval +// - _a0 context.Context +// - _a1 []*domain.Approval func (_e *ApprovalService_Expecter) BulkInsert(_a0 interface{}, _a1 interface{}) *ApprovalService_BulkInsert_Call { return &ApprovalService_BulkInsert_Call{Call: _e.mock.On("BulkInsert", _a0, _a1)} } @@ -60,11 +60,20 @@ func (_c *ApprovalService_BulkInsert_Call) Return(_a0 error) *ApprovalService_Bu return _c } +func (_c *ApprovalService_BulkInsert_Call) RunAndReturn(run func(context.Context, []*domain.Approval) error) *ApprovalService_BulkInsert_Call { + _c.Call.Return(run) + return _c +} + // ListApprovals provides a mock function with given fields: _a0, _a1 func (_m *ApprovalService) ListApprovals(_a0 context.Context, _a1 *domain.ListApprovalsFilter) ([]*domain.Approval, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Approval + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *domain.ListApprovalsFilter) ([]*domain.Approval, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, *domain.ListApprovalsFilter) []*domain.Approval); ok { r0 = rf(_a0, _a1) } else { @@ -73,7 +82,6 @@ func (_m *ApprovalService) ListApprovals(_a0 context.Context, _a1 *domain.ListAp } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, *domain.ListApprovalsFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -89,8 +97,8 @@ type ApprovalService_ListApprovals_Call struct { } // ListApprovals is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.ListApprovalsFilter +// - _a0 context.Context +// - _a1 *domain.ListApprovalsFilter func (_e *ApprovalService_Expecter) ListApprovals(_a0 interface{}, _a1 interface{}) *ApprovalService_ListApprovals_Call { return &ApprovalService_ListApprovals_Call{Call: _e.mock.On("ListApprovals", _a0, _a1)} } @@ -107,6 +115,11 @@ func (_c *ApprovalService_ListApprovals_Call) Return(_a0 []*domain.Approval, _a1 return _c } +func (_c *ApprovalService_ListApprovals_Call) RunAndReturn(run func(context.Context, *domain.ListApprovalsFilter) ([]*domain.Approval, error)) *ApprovalService_ListApprovals_Call { + _c.Call.Return(run) + return _c +} + type mockConstructorTestingTNewApprovalService interface { mock.TestingT Cleanup(func()) diff --git a/api/handler/v1beta1/mocks/policyService.go b/api/handler/v1beta1/mocks/policyService.go index cb3fe9cc4..2a2818b3f 100644 --- a/api/handler/v1beta1/mocks/policyService.go +++ b/api/handler/v1beta1/mocks/policyService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type PolicyService_Create_Call struct { } // Create is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Policy +// - _a0 context.Context +// - _a1 *domain.Policy func (_e *PolicyService_Expecter) Create(_a0 interface{}, _a1 interface{}) *PolicyService_Create_Call { return &PolicyService_Create_Call{Call: _e.mock.On("Create", _a0, _a1)} } @@ -60,11 +60,20 @@ func (_c *PolicyService_Create_Call) Return(_a0 error) *PolicyService_Create_Cal return _c } +func (_c *PolicyService_Create_Call) RunAndReturn(run func(context.Context, *domain.Policy) error) *PolicyService_Create_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0 func (_m *PolicyService) Find(_a0 context.Context) ([]*domain.Policy, error) { ret := _m.Called(_a0) var r0 []*domain.Policy + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]*domain.Policy, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []*domain.Policy); ok { r0 = rf(_a0) } else { @@ -73,7 +82,6 @@ func (_m *PolicyService) Find(_a0 context.Context) ([]*domain.Policy, error) { } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -89,7 +97,7 @@ type PolicyService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *PolicyService_Expecter) Find(_a0 interface{}) *PolicyService_Find_Call { return &PolicyService_Find_Call{Call: _e.mock.On("Find", _a0)} } @@ -106,11 +114,20 @@ func (_c *PolicyService_Find_Call) Return(_a0 []*domain.Policy, _a1 error) *Poli return _c } +func (_c *PolicyService_Find_Call) RunAndReturn(run func(context.Context) ([]*domain.Policy, error)) *PolicyService_Find_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: ctx, id, version func (_m *PolicyService) GetOne(ctx context.Context, id string, version uint) (*domain.Policy, error) { ret := _m.Called(ctx, id, version) var r0 *domain.Policy + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, uint) (*domain.Policy, error)); ok { + return rf(ctx, id, version) + } if rf, ok := ret.Get(0).(func(context.Context, string, uint) *domain.Policy); ok { r0 = rf(ctx, id, version) } else { @@ -119,7 +136,6 @@ func (_m *PolicyService) GetOne(ctx context.Context, id string, version uint) (* } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, uint) error); ok { r1 = rf(ctx, id, version) } else { @@ -135,9 +151,9 @@ type PolicyService_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - ctx context.Context -// - id string -// - version uint +// - ctx context.Context +// - id string +// - version uint func (_e *PolicyService_Expecter) GetOne(ctx interface{}, id interface{}, version interface{}) *PolicyService_GetOne_Call { return &PolicyService_GetOne_Call{Call: _e.mock.On("GetOne", ctx, id, version)} } @@ -154,6 +170,11 @@ func (_c *PolicyService_GetOne_Call) Return(_a0 *domain.Policy, _a1 error) *Poli return _c } +func (_c *PolicyService_GetOne_Call) RunAndReturn(run func(context.Context, string, uint) (*domain.Policy, error)) *PolicyService_GetOne_Call { + _c.Call.Return(run) + return _c +} + // Update provides a mock function with given fields: _a0, _a1 func (_m *PolicyService) Update(_a0 context.Context, _a1 *domain.Policy) error { ret := _m.Called(_a0, _a1) @@ -174,8 +195,8 @@ type PolicyService_Update_Call struct { } // Update is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Policy +// - _a0 context.Context +// - _a1 *domain.Policy func (_e *PolicyService_Expecter) Update(_a0 interface{}, _a1 interface{}) *PolicyService_Update_Call { return &PolicyService_Update_Call{Call: _e.mock.On("Update", _a0, _a1)} } @@ -191,3 +212,23 @@ func (_c *PolicyService_Update_Call) Return(_a0 error) *PolicyService_Update_Cal _c.Call.Return(_a0) return _c } + +func (_c *PolicyService_Update_Call) RunAndReturn(run func(context.Context, *domain.Policy) error) *PolicyService_Update_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewPolicyService interface { + mock.TestingT + Cleanup(func()) +} + +// NewPolicyService creates a new instance of PolicyService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewPolicyService(t mockConstructorTestingTNewPolicyService) *PolicyService { + mock := &PolicyService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/api/handler/v1beta1/mocks/providerService.go b/api/handler/v1beta1/mocks/providerService.go index 07b1dec5f..143ba2809 100644 --- a/api/handler/v1beta1/mocks/providerService.go +++ b/api/handler/v1beta1/mocks/providerService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type ProviderService_Create_Call struct { } // Create is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Provider +// - _a0 context.Context +// - _a1 *domain.Provider func (_e *ProviderService_Expecter) Create(_a0 interface{}, _a1 interface{}) *ProviderService_Create_Call { return &ProviderService_Create_Call{Call: _e.mock.On("Create", _a0, _a1)} } @@ -60,6 +60,11 @@ func (_c *ProviderService_Create_Call) Return(_a0 error) *ProviderService_Create return _c } +func (_c *ProviderService_Create_Call) RunAndReturn(run func(context.Context, *domain.Provider) error) *ProviderService_Create_Call { + _c.Call.Return(run) + return _c +} + // Delete provides a mock function with given fields: _a0, _a1 func (_m *ProviderService) Delete(_a0 context.Context, _a1 string) error { ret := _m.Called(_a0, _a1) @@ -80,8 +85,8 @@ type ProviderService_Delete_Call struct { } // Delete is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *ProviderService_Expecter) Delete(_a0 interface{}, _a1 interface{}) *ProviderService_Delete_Call { return &ProviderService_Delete_Call{Call: _e.mock.On("Delete", _a0, _a1)} } @@ -98,6 +103,11 @@ func (_c *ProviderService_Delete_Call) Return(_a0 error) *ProviderService_Delete return _c } +func (_c *ProviderService_Delete_Call) RunAndReturn(run func(context.Context, string) error) *ProviderService_Delete_Call { + _c.Call.Return(run) + return _c +} + // FetchResources provides a mock function with given fields: _a0 func (_m *ProviderService) FetchResources(_a0 context.Context) error { ret := _m.Called(_a0) @@ -118,7 +128,7 @@ type ProviderService_FetchResources_Call struct { } // FetchResources is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *ProviderService_Expecter) FetchResources(_a0 interface{}) *ProviderService_FetchResources_Call { return &ProviderService_FetchResources_Call{Call: _e.mock.On("FetchResources", _a0)} } @@ -135,11 +145,20 @@ func (_c *ProviderService_FetchResources_Call) Return(_a0 error) *ProviderServic return _c } +func (_c *ProviderService_FetchResources_Call) RunAndReturn(run func(context.Context) error) *ProviderService_FetchResources_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0 func (_m *ProviderService) Find(_a0 context.Context) ([]*domain.Provider, error) { ret := _m.Called(_a0) var r0 []*domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]*domain.Provider, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []*domain.Provider); ok { r0 = rf(_a0) } else { @@ -148,7 +167,6 @@ func (_m *ProviderService) Find(_a0 context.Context) ([]*domain.Provider, error) } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -164,7 +182,7 @@ type ProviderService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *ProviderService_Expecter) Find(_a0 interface{}) *ProviderService_Find_Call { return &ProviderService_Find_Call{Call: _e.mock.On("Find", _a0)} } @@ -181,11 +199,20 @@ func (_c *ProviderService_Find_Call) Return(_a0 []*domain.Provider, _a1 error) * return _c } +func (_c *ProviderService_Find_Call) RunAndReturn(run func(context.Context) ([]*domain.Provider, error)) *ProviderService_Find_Call { + _c.Call.Return(run) + return _c +} + // GetByID provides a mock function with given fields: _a0, _a1 func (_m *ProviderService) GetByID(_a0 context.Context, _a1 string) (*domain.Provider, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Provider, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Provider); ok { r0 = rf(_a0, _a1) } else { @@ -194,7 +221,6 @@ func (_m *ProviderService) GetByID(_a0 context.Context, _a1 string) (*domain.Pro } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -210,8 +236,8 @@ type ProviderService_GetByID_Call struct { } // GetByID is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *ProviderService_Expecter) GetByID(_a0 interface{}, _a1 interface{}) *ProviderService_GetByID_Call { return &ProviderService_GetByID_Call{Call: _e.mock.On("GetByID", _a0, _a1)} } @@ -228,11 +254,20 @@ func (_c *ProviderService_GetByID_Call) Return(_a0 *domain.Provider, _a1 error) return _c } +func (_c *ProviderService_GetByID_Call) RunAndReturn(run func(context.Context, string) (*domain.Provider, error)) *ProviderService_GetByID_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: ctx, pType, urn func (_m *ProviderService) GetOne(ctx context.Context, pType string, urn string) (*domain.Provider, error) { ret := _m.Called(ctx, pType, urn) var r0 *domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, string) (*domain.Provider, error)); ok { + return rf(ctx, pType, urn) + } if rf, ok := ret.Get(0).(func(context.Context, string, string) *domain.Provider); ok { r0 = rf(ctx, pType, urn) } else { @@ -241,7 +276,6 @@ func (_m *ProviderService) GetOne(ctx context.Context, pType string, urn string) } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, string) error); ok { r1 = rf(ctx, pType, urn) } else { @@ -257,9 +291,9 @@ type ProviderService_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - ctx context.Context -// - pType string -// - urn string +// - ctx context.Context +// - pType string +// - urn string func (_e *ProviderService_Expecter) GetOne(ctx interface{}, pType interface{}, urn interface{}) *ProviderService_GetOne_Call { return &ProviderService_GetOne_Call{Call: _e.mock.On("GetOne", ctx, pType, urn)} } @@ -276,11 +310,20 @@ func (_c *ProviderService_GetOne_Call) Return(_a0 *domain.Provider, _a1 error) * return _c } +func (_c *ProviderService_GetOne_Call) RunAndReturn(run func(context.Context, string, string) (*domain.Provider, error)) *ProviderService_GetOne_Call { + _c.Call.Return(run) + return _c +} + // GetRoles provides a mock function with given fields: ctx, id, resourceType func (_m *ProviderService) GetRoles(ctx context.Context, id string, resourceType string) ([]*domain.Role, error) { ret := _m.Called(ctx, id, resourceType) var r0 []*domain.Role + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, string) ([]*domain.Role, error)); ok { + return rf(ctx, id, resourceType) + } if rf, ok := ret.Get(0).(func(context.Context, string, string) []*domain.Role); ok { r0 = rf(ctx, id, resourceType) } else { @@ -289,7 +332,6 @@ func (_m *ProviderService) GetRoles(ctx context.Context, id string, resourceType } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, string) error); ok { r1 = rf(ctx, id, resourceType) } else { @@ -305,9 +347,9 @@ type ProviderService_GetRoles_Call struct { } // GetRoles is a helper method to define mock.On call -// - ctx context.Context -// - id string -// - resourceType string +// - ctx context.Context +// - id string +// - resourceType string func (_e *ProviderService_Expecter) GetRoles(ctx interface{}, id interface{}, resourceType interface{}) *ProviderService_GetRoles_Call { return &ProviderService_GetRoles_Call{Call: _e.mock.On("GetRoles", ctx, id, resourceType)} } @@ -324,11 +366,20 @@ func (_c *ProviderService_GetRoles_Call) Return(_a0 []*domain.Role, _a1 error) * return _c } +func (_c *ProviderService_GetRoles_Call) RunAndReturn(run func(context.Context, string, string) ([]*domain.Role, error)) *ProviderService_GetRoles_Call { + _c.Call.Return(run) + return _c +} + // GetTypes provides a mock function with given fields: _a0 func (_m *ProviderService) GetTypes(_a0 context.Context) ([]domain.ProviderType, error) { ret := _m.Called(_a0) var r0 []domain.ProviderType + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]domain.ProviderType, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []domain.ProviderType); ok { r0 = rf(_a0) } else { @@ -337,7 +388,6 @@ func (_m *ProviderService) GetTypes(_a0 context.Context) ([]domain.ProviderType, } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -353,7 +403,7 @@ type ProviderService_GetTypes_Call struct { } // GetTypes is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *ProviderService_Expecter) GetTypes(_a0 interface{}) *ProviderService_GetTypes_Call { return &ProviderService_GetTypes_Call{Call: _e.mock.On("GetTypes", _a0)} } @@ -370,6 +420,11 @@ func (_c *ProviderService_GetTypes_Call) Return(_a0 []domain.ProviderType, _a1 e return _c } +func (_c *ProviderService_GetTypes_Call) RunAndReturn(run func(context.Context) ([]domain.ProviderType, error)) *ProviderService_GetTypes_Call { + _c.Call.Return(run) + return _c +} + // GrantAccess provides a mock function with given fields: _a0, _a1 func (_m *ProviderService) GrantAccess(_a0 context.Context, _a1 domain.Grant) error { ret := _m.Called(_a0, _a1) @@ -390,8 +445,8 @@ type ProviderService_GrantAccess_Call struct { } // GrantAccess is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.Grant +// - _a0 context.Context +// - _a1 domain.Grant func (_e *ProviderService_Expecter) GrantAccess(_a0 interface{}, _a1 interface{}) *ProviderService_GrantAccess_Call { return &ProviderService_GrantAccess_Call{Call: _e.mock.On("GrantAccess", _a0, _a1)} } @@ -408,6 +463,11 @@ func (_c *ProviderService_GrantAccess_Call) Return(_a0 error) *ProviderService_G return _c } +func (_c *ProviderService_GrantAccess_Call) RunAndReturn(run func(context.Context, domain.Grant) error) *ProviderService_GrantAccess_Call { + _c.Call.Return(run) + return _c +} + // RevokeAccess provides a mock function with given fields: _a0, _a1 func (_m *ProviderService) RevokeAccess(_a0 context.Context, _a1 domain.Grant) error { ret := _m.Called(_a0, _a1) @@ -428,8 +488,8 @@ type ProviderService_RevokeAccess_Call struct { } // RevokeAccess is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.Grant +// - _a0 context.Context +// - _a1 domain.Grant func (_e *ProviderService_Expecter) RevokeAccess(_a0 interface{}, _a1 interface{}) *ProviderService_RevokeAccess_Call { return &ProviderService_RevokeAccess_Call{Call: _e.mock.On("RevokeAccess", _a0, _a1)} } @@ -446,6 +506,11 @@ func (_c *ProviderService_RevokeAccess_Call) Return(_a0 error) *ProviderService_ return _c } +func (_c *ProviderService_RevokeAccess_Call) RunAndReturn(run func(context.Context, domain.Grant) error) *ProviderService_RevokeAccess_Call { + _c.Call.Return(run) + return _c +} + // Update provides a mock function with given fields: _a0, _a1 func (_m *ProviderService) Update(_a0 context.Context, _a1 *domain.Provider) error { ret := _m.Called(_a0, _a1) @@ -466,8 +531,8 @@ type ProviderService_Update_Call struct { } // Update is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Provider +// - _a0 context.Context +// - _a1 *domain.Provider func (_e *ProviderService_Expecter) Update(_a0 interface{}, _a1 interface{}) *ProviderService_Update_Call { return &ProviderService_Update_Call{Call: _e.mock.On("Update", _a0, _a1)} } @@ -484,6 +549,11 @@ func (_c *ProviderService_Update_Call) Return(_a0 error) *ProviderService_Update return _c } +func (_c *ProviderService_Update_Call) RunAndReturn(run func(context.Context, *domain.Provider) error) *ProviderService_Update_Call { + _c.Call.Return(run) + return _c +} + // ValidateAppeal provides a mock function with given fields: _a0, _a1, _a2, _a3 func (_m *ProviderService) ValidateAppeal(_a0 context.Context, _a1 *domain.Appeal, _a2 *domain.Provider, _a3 *domain.Policy) error { ret := _m.Called(_a0, _a1, _a2, _a3) @@ -504,10 +574,10 @@ type ProviderService_ValidateAppeal_Call struct { } // ValidateAppeal is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Appeal -// - _a2 *domain.Provider -// - _a3 *domain.Policy +// - _a0 context.Context +// - _a1 *domain.Appeal +// - _a2 *domain.Provider +// - _a3 *domain.Policy func (_e *ProviderService_Expecter) ValidateAppeal(_a0 interface{}, _a1 interface{}, _a2 interface{}, _a3 interface{}) *ProviderService_ValidateAppeal_Call { return &ProviderService_ValidateAppeal_Call{Call: _e.mock.On("ValidateAppeal", _a0, _a1, _a2, _a3)} } @@ -523,3 +593,23 @@ func (_c *ProviderService_ValidateAppeal_Call) Return(_a0 error) *ProviderServic _c.Call.Return(_a0) return _c } + +func (_c *ProviderService_ValidateAppeal_Call) RunAndReturn(run func(context.Context, *domain.Appeal, *domain.Provider, *domain.Policy) error) *ProviderService_ValidateAppeal_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewProviderService interface { + mock.TestingT + Cleanup(func()) +} + +// NewProviderService creates a new instance of ProviderService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewProviderService(t mockConstructorTestingTNewProviderService) *ProviderService { + mock := &ProviderService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/api/handler/v1beta1/mocks/resourceService.go b/api/handler/v1beta1/mocks/resourceService.go index 26882ee6b..4d3e00239 100644 --- a/api/handler/v1beta1/mocks/resourceService.go +++ b/api/handler/v1beta1/mocks/resourceService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type ResourceService_BatchDelete_Call struct { } // BatchDelete is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []string +// - _a0 context.Context +// - _a1 []string func (_e *ResourceService_Expecter) BatchDelete(_a0 interface{}, _a1 interface{}) *ResourceService_BatchDelete_Call { return &ResourceService_BatchDelete_Call{Call: _e.mock.On("BatchDelete", _a0, _a1)} } @@ -60,6 +60,11 @@ func (_c *ResourceService_BatchDelete_Call) Return(_a0 error) *ResourceService_B return _c } +func (_c *ResourceService_BatchDelete_Call) RunAndReturn(run func(context.Context, []string) error) *ResourceService_BatchDelete_Call { + _c.Call.Return(run) + return _c +} + // BulkUpsert provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) BulkUpsert(_a0 context.Context, _a1 []*domain.Resource) error { ret := _m.Called(_a0, _a1) @@ -80,8 +85,8 @@ type ResourceService_BulkUpsert_Call struct { } // BulkUpsert is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Resource +// - _a0 context.Context +// - _a1 []*domain.Resource func (_e *ResourceService_Expecter) BulkUpsert(_a0 interface{}, _a1 interface{}) *ResourceService_BulkUpsert_Call { return &ResourceService_BulkUpsert_Call{Call: _e.mock.On("BulkUpsert", _a0, _a1)} } @@ -98,6 +103,11 @@ func (_c *ResourceService_BulkUpsert_Call) Return(_a0 error) *ResourceService_Bu return _c } +func (_c *ResourceService_BulkUpsert_Call) RunAndReturn(run func(context.Context, []*domain.Resource) error) *ResourceService_BulkUpsert_Call { + _c.Call.Return(run) + return _c +} + // Delete provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) Delete(_a0 context.Context, _a1 string) error { ret := _m.Called(_a0, _a1) @@ -118,8 +128,8 @@ type ResourceService_Delete_Call struct { } // Delete is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *ResourceService_Expecter) Delete(_a0 interface{}, _a1 interface{}) *ResourceService_Delete_Call { return &ResourceService_Delete_Call{Call: _e.mock.On("Delete", _a0, _a1)} } @@ -136,11 +146,20 @@ func (_c *ResourceService_Delete_Call) Return(_a0 error) *ResourceService_Delete return _c } +func (_c *ResourceService_Delete_Call) RunAndReturn(run func(context.Context, string) error) *ResourceService_Delete_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) Find(_a0 context.Context, _a1 domain.ListResourcesFilter) ([]*domain.Resource, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) []*domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -149,7 +168,6 @@ func (_m *ResourceService) Find(_a0 context.Context, _a1 domain.ListResourcesFil } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListResourcesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -165,8 +183,8 @@ type ResourceService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListResourcesFilter +// - _a0 context.Context +// - _a1 domain.ListResourcesFilter func (_e *ResourceService_Expecter) Find(_a0 interface{}, _a1 interface{}) *ResourceService_Find_Call { return &ResourceService_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -183,11 +201,20 @@ func (_c *ResourceService_Find_Call) Return(_a0 []*domain.Resource, _a1 error) * return _c } +func (_c *ResourceService_Find_Call) RunAndReturn(run func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)) *ResourceService_Find_Call { + _c.Call.Return(run) + return _c +} + // Get provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) Get(_a0 context.Context, _a1 *domain.ResourceIdentifier) (*domain.Resource, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *domain.ResourceIdentifier) (*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, *domain.ResourceIdentifier) *domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -196,7 +223,6 @@ func (_m *ResourceService) Get(_a0 context.Context, _a1 *domain.ResourceIdentifi } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, *domain.ResourceIdentifier) error); ok { r1 = rf(_a0, _a1) } else { @@ -212,8 +238,8 @@ type ResourceService_Get_Call struct { } // Get is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.ResourceIdentifier +// - _a0 context.Context +// - _a1 *domain.ResourceIdentifier func (_e *ResourceService_Expecter) Get(_a0 interface{}, _a1 interface{}) *ResourceService_Get_Call { return &ResourceService_Get_Call{Call: _e.mock.On("Get", _a0, _a1)} } @@ -230,11 +256,20 @@ func (_c *ResourceService_Get_Call) Return(_a0 *domain.Resource, _a1 error) *Res return _c } +func (_c *ResourceService_Get_Call) RunAndReturn(run func(context.Context, *domain.ResourceIdentifier) (*domain.Resource, error)) *ResourceService_Get_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) GetOne(_a0 context.Context, _a1 string) (*domain.Resource, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -243,7 +278,6 @@ func (_m *ResourceService) GetOne(_a0 context.Context, _a1 string) (*domain.Reso } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -259,8 +293,8 @@ type ResourceService_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *ResourceService_Expecter) GetOne(_a0 interface{}, _a1 interface{}) *ResourceService_GetOne_Call { return &ResourceService_GetOne_Call{Call: _e.mock.On("GetOne", _a0, _a1)} } @@ -277,6 +311,11 @@ func (_c *ResourceService_GetOne_Call) Return(_a0 *domain.Resource, _a1 error) * return _c } +func (_c *ResourceService_GetOne_Call) RunAndReturn(run func(context.Context, string) (*domain.Resource, error)) *ResourceService_GetOne_Call { + _c.Call.Return(run) + return _c +} + // Update provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) Update(_a0 context.Context, _a1 *domain.Resource) error { ret := _m.Called(_a0, _a1) @@ -297,8 +336,8 @@ type ResourceService_Update_Call struct { } // Update is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Resource +// - _a0 context.Context +// - _a1 *domain.Resource func (_e *ResourceService_Expecter) Update(_a0 interface{}, _a1 interface{}) *ResourceService_Update_Call { return &ResourceService_Update_Call{Call: _e.mock.On("Update", _a0, _a1)} } @@ -314,3 +353,23 @@ func (_c *ResourceService_Update_Call) Return(_a0 error) *ResourceService_Update _c.Call.Return(_a0) return _c } + +func (_c *ResourceService_Update_Call) RunAndReturn(run func(context.Context, *domain.Resource) error) *ResourceService_Update_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewResourceService interface { + mock.TestingT + Cleanup(func()) +} + +// NewResourceService creates a new instance of ResourceService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewResourceService(t mockConstructorTestingTNewResourceService) *ResourceService { + mock := &ResourceService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/activity/mocks/auditLogger.go b/core/activity/mocks/auditLogger.go index 421d831ee..5c791a405 100644 --- a/core/activity/mocks/auditLogger.go +++ b/core/activity/mocks/auditLogger.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -41,9 +41,9 @@ type AuditLogger_Log_Call struct { } // Log is a helper method to define mock.On call -// - ctx context.Context -// - action string -// - data interface{} +// - ctx context.Context +// - action string +// - data interface{} func (_e *AuditLogger_Expecter) Log(ctx interface{}, action interface{}, data interface{}) *AuditLogger_Log_Call { return &AuditLogger_Log_Call{Call: _e.mock.On("Log", ctx, action, data)} } @@ -59,3 +59,23 @@ func (_c *AuditLogger_Log_Call) Return(_a0 error) *AuditLogger_Log_Call { _c.Call.Return(_a0) return _c } + +func (_c *AuditLogger_Log_Call) RunAndReturn(run func(context.Context, string, interface{}) error) *AuditLogger_Log_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewAuditLogger interface { + mock.TestingT + Cleanup(func()) +} + +// NewAuditLogger creates a new instance of AuditLogger. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewAuditLogger(t mockConstructorTestingTNewAuditLogger) *AuditLogger { + mock := &AuditLogger{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/activity/mocks/providerService.go b/core/activity/mocks/providerService.go index cbf0209c2..0f01ce062 100644 --- a/core/activity/mocks/providerService.go +++ b/core/activity/mocks/providerService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *ProviderService) ImportActivities(_a0 context.Context, _a1 domain.Impo ret := _m.Called(_a0, _a1) var r0 []*domain.Activity + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ImportActivitiesFilter) ([]*domain.Activity, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ImportActivitiesFilter) []*domain.Activity); ok { r0 = rf(_a0, _a1) } else { @@ -35,7 +39,6 @@ func (_m *ProviderService) ImportActivities(_a0 context.Context, _a1 domain.Impo } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ImportActivitiesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -51,8 +54,8 @@ type ProviderService_ImportActivities_Call struct { } // ImportActivities is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ImportActivitiesFilter +// - _a0 context.Context +// - _a1 domain.ImportActivitiesFilter func (_e *ProviderService_Expecter) ImportActivities(_a0 interface{}, _a1 interface{}) *ProviderService_ImportActivities_Call { return &ProviderService_ImportActivities_Call{Call: _e.mock.On("ImportActivities", _a0, _a1)} } @@ -68,3 +71,23 @@ func (_c *ProviderService_ImportActivities_Call) Return(_a0 []*domain.Activity, _c.Call.Return(_a0, _a1) return _c } + +func (_c *ProviderService_ImportActivities_Call) RunAndReturn(run func(context.Context, domain.ImportActivitiesFilter) ([]*domain.Activity, error)) *ProviderService_ImportActivities_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewProviderService interface { + mock.TestingT + Cleanup(func()) +} + +// NewProviderService creates a new instance of ProviderService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewProviderService(t mockConstructorTestingTNewProviderService) *ProviderService { + mock := &ProviderService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/activity/mocks/repository.go b/core/activity/mocks/repository.go index 9dfa96b67..973d623d3 100644 --- a/core/activity/mocks/repository.go +++ b/core/activity/mocks/repository.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type Repository_BulkUpsert_Call struct { } // BulkUpsert is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Activity +// - _a0 context.Context +// - _a1 []*domain.Activity func (_e *Repository_Expecter) BulkUpsert(_a0 interface{}, _a1 interface{}) *Repository_BulkUpsert_Call { return &Repository_BulkUpsert_Call{Call: _e.mock.On("BulkUpsert", _a0, _a1)} } @@ -60,11 +60,20 @@ func (_c *Repository_BulkUpsert_Call) Return(_a0 error) *Repository_BulkUpsert_C return _c } +func (_c *Repository_BulkUpsert_Call) RunAndReturn(run func(context.Context, []*domain.Activity) error) *Repository_BulkUpsert_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0, _a1 func (_m *Repository) Find(_a0 context.Context, _a1 domain.ListProviderActivitiesFilter) ([]*domain.Activity, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Activity + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListProviderActivitiesFilter) ([]*domain.Activity, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListProviderActivitiesFilter) []*domain.Activity); ok { r0 = rf(_a0, _a1) } else { @@ -73,7 +82,6 @@ func (_m *Repository) Find(_a0 context.Context, _a1 domain.ListProviderActivitie } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListProviderActivitiesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -89,8 +97,8 @@ type Repository_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListProviderActivitiesFilter +// - _a0 context.Context +// - _a1 domain.ListProviderActivitiesFilter func (_e *Repository_Expecter) Find(_a0 interface{}, _a1 interface{}) *Repository_Find_Call { return &Repository_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -107,11 +115,20 @@ func (_c *Repository_Find_Call) Return(_a0 []*domain.Activity, _a1 error) *Repos return _c } +func (_c *Repository_Find_Call) RunAndReturn(run func(context.Context, domain.ListProviderActivitiesFilter) ([]*domain.Activity, error)) *Repository_Find_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: _a0, _a1 func (_m *Repository) GetOne(_a0 context.Context, _a1 string) (*domain.Activity, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Activity + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Activity, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Activity); ok { r0 = rf(_a0, _a1) } else { @@ -120,7 +137,6 @@ func (_m *Repository) GetOne(_a0 context.Context, _a1 string) (*domain.Activity, } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -136,8 +152,8 @@ type Repository_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *Repository_Expecter) GetOne(_a0 interface{}, _a1 interface{}) *Repository_GetOne_Call { return &Repository_GetOne_Call{Call: _e.mock.On("GetOne", _a0, _a1)} } @@ -153,3 +169,23 @@ func (_c *Repository_GetOne_Call) Return(_a0 *domain.Activity, _a1 error) *Repos _c.Call.Return(_a0, _a1) return _c } + +func (_c *Repository_GetOne_Call) RunAndReturn(run func(context.Context, string) (*domain.Activity, error)) *Repository_GetOne_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewRepository interface { + mock.TestingT + Cleanup(func()) +} + +// NewRepository creates a new instance of Repository. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewRepository(t mockConstructorTestingTNewRepository) *Repository { + mock := &Repository{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/appeal/mocks/approvalService.go b/core/appeal/mocks/approvalService.go index af1f50cbb..f03c9da32 100644 --- a/core/appeal/mocks/approvalService.go +++ b/core/appeal/mocks/approvalService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.14.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -41,9 +41,9 @@ type ApprovalService_AddApprover_Call struct { } // AddApprover is a helper method to define mock.On call -// - ctx context.Context -// - approvalID string -// - email string +// - ctx context.Context +// - approvalID string +// - email string func (_e *ApprovalService_Expecter) AddApprover(ctx interface{}, approvalID interface{}, email interface{}) *ApprovalService_AddApprover_Call { return &ApprovalService_AddApprover_Call{Call: _e.mock.On("AddApprover", ctx, approvalID, email)} } @@ -60,6 +60,11 @@ func (_c *ApprovalService_AddApprover_Call) Return(_a0 error) *ApprovalService_A return _c } +func (_c *ApprovalService_AddApprover_Call) RunAndReturn(run func(context.Context, string, string) error) *ApprovalService_AddApprover_Call { + _c.Call.Return(run) + return _c +} + // DeleteApprover provides a mock function with given fields: ctx, approvalID, email func (_m *ApprovalService) DeleteApprover(ctx context.Context, approvalID string, email string) error { ret := _m.Called(ctx, approvalID, email) @@ -80,9 +85,9 @@ type ApprovalService_DeleteApprover_Call struct { } // DeleteApprover is a helper method to define mock.On call -// - ctx context.Context -// - approvalID string -// - email string +// - ctx context.Context +// - approvalID string +// - email string func (_e *ApprovalService_Expecter) DeleteApprover(ctx interface{}, approvalID interface{}, email interface{}) *ApprovalService_DeleteApprover_Call { return &ApprovalService_DeleteApprover_Call{Call: _e.mock.On("DeleteApprover", ctx, approvalID, email)} } @@ -99,6 +104,11 @@ func (_c *ApprovalService_DeleteApprover_Call) Return(_a0 error) *ApprovalServic return _c } +func (_c *ApprovalService_DeleteApprover_Call) RunAndReturn(run func(context.Context, string, string) error) *ApprovalService_DeleteApprover_Call { + _c.Call.Return(run) + return _c +} + type mockConstructorTestingTNewApprovalService interface { mock.TestingT Cleanup(func()) diff --git a/core/appeal/mocks/auditLogger.go b/core/appeal/mocks/auditLogger.go index 421d831ee..5c791a405 100644 --- a/core/appeal/mocks/auditLogger.go +++ b/core/appeal/mocks/auditLogger.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -41,9 +41,9 @@ type AuditLogger_Log_Call struct { } // Log is a helper method to define mock.On call -// - ctx context.Context -// - action string -// - data interface{} +// - ctx context.Context +// - action string +// - data interface{} func (_e *AuditLogger_Expecter) Log(ctx interface{}, action interface{}, data interface{}) *AuditLogger_Log_Call { return &AuditLogger_Log_Call{Call: _e.mock.On("Log", ctx, action, data)} } @@ -59,3 +59,23 @@ func (_c *AuditLogger_Log_Call) Return(_a0 error) *AuditLogger_Log_Call { _c.Call.Return(_a0) return _c } + +func (_c *AuditLogger_Log_Call) RunAndReturn(run func(context.Context, string, interface{}) error) *AuditLogger_Log_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewAuditLogger interface { + mock.TestingT + Cleanup(func()) +} + +// NewAuditLogger creates a new instance of AuditLogger. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewAuditLogger(t mockConstructorTestingTNewAuditLogger) *AuditLogger { + mock := &AuditLogger{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/appeal/mocks/grantService.go b/core/appeal/mocks/grantService.go index 8143f6c04..da36e6b98 100644 --- a/core/appeal/mocks/grantService.go +++ b/core/appeal/mocks/grantService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -29,6 +29,10 @@ func (_m *GrantService) List(_a0 context.Context, _a1 domain.ListGrantsFilter) ( ret := _m.Called(_a0, _a1) var r0 []domain.Grant + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListGrantsFilter) ([]domain.Grant, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListGrantsFilter) []domain.Grant); ok { r0 = rf(_a0, _a1) } else { @@ -37,7 +41,6 @@ func (_m *GrantService) List(_a0 context.Context, _a1 domain.ListGrantsFilter) ( } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListGrantsFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -53,8 +56,8 @@ type GrantService_List_Call struct { } // List is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListGrantsFilter +// - _a0 context.Context +// - _a1 domain.ListGrantsFilter func (_e *GrantService_Expecter) List(_a0 interface{}, _a1 interface{}) *GrantService_List_Call { return &GrantService_List_Call{Call: _e.mock.On("List", _a0, _a1)} } @@ -71,11 +74,20 @@ func (_c *GrantService_List_Call) Return(_a0 []domain.Grant, _a1 error) *GrantSe return _c } +func (_c *GrantService_List_Call) RunAndReturn(run func(context.Context, domain.ListGrantsFilter) ([]domain.Grant, error)) *GrantService_List_Call { + _c.Call.Return(run) + return _c +} + // Prepare provides a mock function with given fields: _a0, _a1 func (_m *GrantService) Prepare(_a0 context.Context, _a1 domain.Appeal) (*domain.Grant, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Grant + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.Appeal) (*domain.Grant, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.Appeal) *domain.Grant); ok { r0 = rf(_a0, _a1) } else { @@ -84,7 +96,6 @@ func (_m *GrantService) Prepare(_a0 context.Context, _a1 domain.Appeal) (*domain } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.Appeal) error); ok { r1 = rf(_a0, _a1) } else { @@ -100,8 +111,8 @@ type GrantService_Prepare_Call struct { } // Prepare is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.Appeal +// - _a0 context.Context +// - _a1 domain.Appeal func (_e *GrantService_Expecter) Prepare(_a0 interface{}, _a1 interface{}) *GrantService_Prepare_Call { return &GrantService_Prepare_Call{Call: _e.mock.On("Prepare", _a0, _a1)} } @@ -118,6 +129,11 @@ func (_c *GrantService_Prepare_Call) Return(_a0 *domain.Grant, _a1 error) *Grant return _c } +func (_c *GrantService_Prepare_Call) RunAndReturn(run func(context.Context, domain.Appeal) (*domain.Grant, error)) *GrantService_Prepare_Call { + _c.Call.Return(run) + return _c +} + // Revoke provides a mock function with given fields: ctx, id, actor, reason, opts func (_m *GrantService) Revoke(ctx context.Context, id string, actor string, reason string, opts ...grant.Option) (*domain.Grant, error) { _va := make([]interface{}, len(opts)) @@ -130,6 +146,10 @@ func (_m *GrantService) Revoke(ctx context.Context, id string, actor string, rea ret := _m.Called(_ca...) var r0 *domain.Grant + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, string, string, ...grant.Option) (*domain.Grant, error)); ok { + return rf(ctx, id, actor, reason, opts...) + } if rf, ok := ret.Get(0).(func(context.Context, string, string, string, ...grant.Option) *domain.Grant); ok { r0 = rf(ctx, id, actor, reason, opts...) } else { @@ -138,7 +158,6 @@ func (_m *GrantService) Revoke(ctx context.Context, id string, actor string, rea } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, string, string, ...grant.Option) error); ok { r1 = rf(ctx, id, actor, reason, opts...) } else { @@ -154,11 +173,11 @@ type GrantService_Revoke_Call struct { } // Revoke is a helper method to define mock.On call -// - ctx context.Context -// - id string -// - actor string -// - reason string -// - opts ...grant.Option +// - ctx context.Context +// - id string +// - actor string +// - reason string +// - opts ...grant.Option func (_e *GrantService_Expecter) Revoke(ctx interface{}, id interface{}, actor interface{}, reason interface{}, opts ...interface{}) *GrantService_Revoke_Call { return &GrantService_Revoke_Call{Call: _e.mock.On("Revoke", append([]interface{}{ctx, id, actor, reason}, opts...)...)} @@ -181,3 +200,23 @@ func (_c *GrantService_Revoke_Call) Return(_a0 *domain.Grant, _a1 error) *GrantS _c.Call.Return(_a0, _a1) return _c } + +func (_c *GrantService_Revoke_Call) RunAndReturn(run func(context.Context, string, string, string, ...grant.Option) (*domain.Grant, error)) *GrantService_Revoke_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewGrantService interface { + mock.TestingT + Cleanup(func()) +} + +// NewGrantService creates a new instance of GrantService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewGrantService(t mockConstructorTestingTNewGrantService) *GrantService { + mock := &GrantService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/appeal/mocks/iamManager.go b/core/appeal/mocks/iamManager.go index bd6a3469c..c7d6b3f40 100644 --- a/core/appeal/mocks/iamManager.go +++ b/core/appeal/mocks/iamManager.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -25,6 +25,10 @@ func (_m *IamManager) GetClient(_a0 domain.SensitiveConfig) (domain.IAMClient, e ret := _m.Called(_a0) var r0 domain.IAMClient + var r1 error + if rf, ok := ret.Get(0).(func(domain.SensitiveConfig) (domain.IAMClient, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(domain.SensitiveConfig) domain.IAMClient); ok { r0 = rf(_a0) } else { @@ -33,7 +37,6 @@ func (_m *IamManager) GetClient(_a0 domain.SensitiveConfig) (domain.IAMClient, e } } - var r1 error if rf, ok := ret.Get(1).(func(domain.SensitiveConfig) error); ok { r1 = rf(_a0) } else { @@ -49,7 +52,7 @@ type IamManager_GetClient_Call struct { } // GetClient is a helper method to define mock.On call -// - _a0 domain.SensitiveConfig +// - _a0 domain.SensitiveConfig func (_e *IamManager_Expecter) GetClient(_a0 interface{}) *IamManager_GetClient_Call { return &IamManager_GetClient_Call{Call: _e.mock.On("GetClient", _a0)} } @@ -66,11 +69,20 @@ func (_c *IamManager_GetClient_Call) Return(_a0 domain.IAMClient, _a1 error) *Ia return _c } +func (_c *IamManager_GetClient_Call) RunAndReturn(run func(domain.SensitiveConfig) (domain.IAMClient, error)) *IamManager_GetClient_Call { + _c.Call.Return(run) + return _c +} + // ParseConfig provides a mock function with given fields: _a0 func (_m *IamManager) ParseConfig(_a0 *domain.IAMConfig) (domain.SensitiveConfig, error) { ret := _m.Called(_a0) var r0 domain.SensitiveConfig + var r1 error + if rf, ok := ret.Get(0).(func(*domain.IAMConfig) (domain.SensitiveConfig, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(*domain.IAMConfig) domain.SensitiveConfig); ok { r0 = rf(_a0) } else { @@ -79,7 +91,6 @@ func (_m *IamManager) ParseConfig(_a0 *domain.IAMConfig) (domain.SensitiveConfig } } - var r1 error if rf, ok := ret.Get(1).(func(*domain.IAMConfig) error); ok { r1 = rf(_a0) } else { @@ -95,7 +106,7 @@ type IamManager_ParseConfig_Call struct { } // ParseConfig is a helper method to define mock.On call -// - _a0 *domain.IAMConfig +// - _a0 *domain.IAMConfig func (_e *IamManager_Expecter) ParseConfig(_a0 interface{}) *IamManager_ParseConfig_Call { return &IamManager_ParseConfig_Call{Call: _e.mock.On("ParseConfig", _a0)} } @@ -111,3 +122,23 @@ func (_c *IamManager_ParseConfig_Call) Return(_a0 domain.SensitiveConfig, _a1 er _c.Call.Return(_a0, _a1) return _c } + +func (_c *IamManager_ParseConfig_Call) RunAndReturn(run func(*domain.IAMConfig) (domain.SensitiveConfig, error)) *IamManager_ParseConfig_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewIamManager interface { + mock.TestingT + Cleanup(func()) +} + +// NewIamManager creates a new instance of IamManager. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewIamManager(t mockConstructorTestingTNewIamManager) *IamManager { + mock := &IamManager{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/appeal/mocks/notifier.go b/core/appeal/mocks/notifier.go index 33993fa1e..b86eb5b9d 100644 --- a/core/appeal/mocks/notifier.go +++ b/core/appeal/mocks/notifier.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,7 +42,7 @@ type Notifier_Notify_Call struct { } // Notify is a helper method to define mock.On call -// - _a0 []domain.Notification +// - _a0 []domain.Notification func (_e *Notifier_Expecter) Notify(_a0 interface{}) *Notifier_Notify_Call { return &Notifier_Notify_Call{Call: _e.mock.On("Notify", _a0)} } @@ -58,3 +58,23 @@ func (_c *Notifier_Notify_Call) Return(_a0 []error) *Notifier_Notify_Call { _c.Call.Return(_a0) return _c } + +func (_c *Notifier_Notify_Call) RunAndReturn(run func([]domain.Notification) []error) *Notifier_Notify_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewNotifier interface { + mock.TestingT + Cleanup(func()) +} + +// NewNotifier creates a new instance of Notifier. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewNotifier(t mockConstructorTestingTNewNotifier) *Notifier { + mock := &Notifier{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/appeal/mocks/policyService.go b/core/appeal/mocks/policyService.go index 6114b39e9..7fa47dd04 100644 --- a/core/appeal/mocks/policyService.go +++ b/core/appeal/mocks/policyService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *PolicyService) Find(_a0 context.Context) ([]*domain.Policy, error) { ret := _m.Called(_a0) var r0 []*domain.Policy + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]*domain.Policy, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []*domain.Policy); ok { r0 = rf(_a0) } else { @@ -35,7 +39,6 @@ func (_m *PolicyService) Find(_a0 context.Context) ([]*domain.Policy, error) { } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -51,7 +54,7 @@ type PolicyService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *PolicyService_Expecter) Find(_a0 interface{}) *PolicyService_Find_Call { return &PolicyService_Find_Call{Call: _e.mock.On("Find", _a0)} } @@ -68,11 +71,20 @@ func (_c *PolicyService_Find_Call) Return(_a0 []*domain.Policy, _a1 error) *Poli return _c } +func (_c *PolicyService_Find_Call) RunAndReturn(run func(context.Context) ([]*domain.Policy, error)) *PolicyService_Find_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: _a0, _a1, _a2 func (_m *PolicyService) GetOne(_a0 context.Context, _a1 string, _a2 uint) (*domain.Policy, error) { ret := _m.Called(_a0, _a1, _a2) var r0 *domain.Policy + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, uint) (*domain.Policy, error)); ok { + return rf(_a0, _a1, _a2) + } if rf, ok := ret.Get(0).(func(context.Context, string, uint) *domain.Policy); ok { r0 = rf(_a0, _a1, _a2) } else { @@ -81,7 +93,6 @@ func (_m *PolicyService) GetOne(_a0 context.Context, _a1 string, _a2 uint) (*dom } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, uint) error); ok { r1 = rf(_a0, _a1, _a2) } else { @@ -97,9 +108,9 @@ type PolicyService_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string -// - _a2 uint +// - _a0 context.Context +// - _a1 string +// - _a2 uint func (_e *PolicyService_Expecter) GetOne(_a0 interface{}, _a1 interface{}, _a2 interface{}) *PolicyService_GetOne_Call { return &PolicyService_GetOne_Call{Call: _e.mock.On("GetOne", _a0, _a1, _a2)} } @@ -115,3 +126,23 @@ func (_c *PolicyService_GetOne_Call) Return(_a0 *domain.Policy, _a1 error) *Poli _c.Call.Return(_a0, _a1) return _c } + +func (_c *PolicyService_GetOne_Call) RunAndReturn(run func(context.Context, string, uint) (*domain.Policy, error)) *PolicyService_GetOne_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewPolicyService interface { + mock.TestingT + Cleanup(func()) +} + +// NewPolicyService creates a new instance of PolicyService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewPolicyService(t mockConstructorTestingTNewPolicyService) *PolicyService { + mock := &PolicyService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/appeal/mocks/providerService.go b/core/appeal/mocks/providerService.go index 36de59793..060dda19f 100644 --- a/core/appeal/mocks/providerService.go +++ b/core/appeal/mocks/providerService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *ProviderService) Find(_a0 context.Context) ([]*domain.Provider, error) ret := _m.Called(_a0) var r0 []*domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]*domain.Provider, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []*domain.Provider); ok { r0 = rf(_a0) } else { @@ -35,7 +39,6 @@ func (_m *ProviderService) Find(_a0 context.Context) ([]*domain.Provider, error) } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -51,7 +54,7 @@ type ProviderService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *ProviderService_Expecter) Find(_a0 interface{}) *ProviderService_Find_Call { return &ProviderService_Find_Call{Call: _e.mock.On("Find", _a0)} } @@ -68,11 +71,20 @@ func (_c *ProviderService_Find_Call) Return(_a0 []*domain.Provider, _a1 error) * return _c } +func (_c *ProviderService_Find_Call) RunAndReturn(run func(context.Context) ([]*domain.Provider, error)) *ProviderService_Find_Call { + _c.Call.Return(run) + return _c +} + // GetPermissions provides a mock function with given fields: _a0, _a1, _a2, _a3 func (_m *ProviderService) GetPermissions(_a0 context.Context, _a1 *domain.ProviderConfig, _a2 string, _a3 string) ([]interface{}, error) { ret := _m.Called(_a0, _a1, _a2, _a3) var r0 []interface{} + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *domain.ProviderConfig, string, string) ([]interface{}, error)); ok { + return rf(_a0, _a1, _a2, _a3) + } if rf, ok := ret.Get(0).(func(context.Context, *domain.ProviderConfig, string, string) []interface{}); ok { r0 = rf(_a0, _a1, _a2, _a3) } else { @@ -81,7 +93,6 @@ func (_m *ProviderService) GetPermissions(_a0 context.Context, _a1 *domain.Provi } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, *domain.ProviderConfig, string, string) error); ok { r1 = rf(_a0, _a1, _a2, _a3) } else { @@ -97,10 +108,10 @@ type ProviderService_GetPermissions_Call struct { } // GetPermissions is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.ProviderConfig -// - _a2 string -// - _a3 string +// - _a0 context.Context +// - _a1 *domain.ProviderConfig +// - _a2 string +// - _a3 string func (_e *ProviderService_Expecter) GetPermissions(_a0 interface{}, _a1 interface{}, _a2 interface{}, _a3 interface{}) *ProviderService_GetPermissions_Call { return &ProviderService_GetPermissions_Call{Call: _e.mock.On("GetPermissions", _a0, _a1, _a2, _a3)} } @@ -117,6 +128,11 @@ func (_c *ProviderService_GetPermissions_Call) Return(_a0 []interface{}, _a1 err return _c } +func (_c *ProviderService_GetPermissions_Call) RunAndReturn(run func(context.Context, *domain.ProviderConfig, string, string) ([]interface{}, error)) *ProviderService_GetPermissions_Call { + _c.Call.Return(run) + return _c +} + // GrantAccess provides a mock function with given fields: _a0, _a1 func (_m *ProviderService) GrantAccess(_a0 context.Context, _a1 domain.Grant) error { ret := _m.Called(_a0, _a1) @@ -137,8 +153,8 @@ type ProviderService_GrantAccess_Call struct { } // GrantAccess is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.Grant +// - _a0 context.Context +// - _a1 domain.Grant func (_e *ProviderService_Expecter) GrantAccess(_a0 interface{}, _a1 interface{}) *ProviderService_GrantAccess_Call { return &ProviderService_GrantAccess_Call{Call: _e.mock.On("GrantAccess", _a0, _a1)} } @@ -155,6 +171,11 @@ func (_c *ProviderService_GrantAccess_Call) Return(_a0 error) *ProviderService_G return _c } +func (_c *ProviderService_GrantAccess_Call) RunAndReturn(run func(context.Context, domain.Grant) error) *ProviderService_GrantAccess_Call { + _c.Call.Return(run) + return _c +} + // RevokeAccess provides a mock function with given fields: _a0, _a1 func (_m *ProviderService) RevokeAccess(_a0 context.Context, _a1 domain.Grant) error { ret := _m.Called(_a0, _a1) @@ -175,8 +196,8 @@ type ProviderService_RevokeAccess_Call struct { } // RevokeAccess is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.Grant +// - _a0 context.Context +// - _a1 domain.Grant func (_e *ProviderService_Expecter) RevokeAccess(_a0 interface{}, _a1 interface{}) *ProviderService_RevokeAccess_Call { return &ProviderService_RevokeAccess_Call{Call: _e.mock.On("RevokeAccess", _a0, _a1)} } @@ -193,6 +214,11 @@ func (_c *ProviderService_RevokeAccess_Call) Return(_a0 error) *ProviderService_ return _c } +func (_c *ProviderService_RevokeAccess_Call) RunAndReturn(run func(context.Context, domain.Grant) error) *ProviderService_RevokeAccess_Call { + _c.Call.Return(run) + return _c +} + // ValidateAppeal provides a mock function with given fields: _a0, _a1, _a2, _a3 func (_m *ProviderService) ValidateAppeal(_a0 context.Context, _a1 *domain.Appeal, _a2 *domain.Provider, _a3 *domain.Policy) error { ret := _m.Called(_a0, _a1, _a2, _a3) @@ -213,10 +239,10 @@ type ProviderService_ValidateAppeal_Call struct { } // ValidateAppeal is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Appeal -// - _a2 *domain.Provider -// - _a3 *domain.Policy +// - _a0 context.Context +// - _a1 *domain.Appeal +// - _a2 *domain.Provider +// - _a3 *domain.Policy func (_e *ProviderService_Expecter) ValidateAppeal(_a0 interface{}, _a1 interface{}, _a2 interface{}, _a3 interface{}) *ProviderService_ValidateAppeal_Call { return &ProviderService_ValidateAppeal_Call{Call: _e.mock.On("ValidateAppeal", _a0, _a1, _a2, _a3)} } @@ -232,3 +258,23 @@ func (_c *ProviderService_ValidateAppeal_Call) Return(_a0 error) *ProviderServic _c.Call.Return(_a0) return _c } + +func (_c *ProviderService_ValidateAppeal_Call) RunAndReturn(run func(context.Context, *domain.Appeal, *domain.Provider, *domain.Policy) error) *ProviderService_ValidateAppeal_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewProviderService interface { + mock.TestingT + Cleanup(func()) +} + +// NewProviderService creates a new instance of ProviderService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewProviderService(t mockConstructorTestingTNewProviderService) *ProviderService { + mock := &ProviderService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/appeal/mocks/repository.go b/core/appeal/mocks/repository.go index 5d110720f..e2a18c208 100644 --- a/core/appeal/mocks/repository.go +++ b/core/appeal/mocks/repository.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type Repository_BulkUpsert_Call struct { } // BulkUpsert is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Appeal +// - _a0 context.Context +// - _a1 []*domain.Appeal func (_e *Repository_Expecter) BulkUpsert(_a0 interface{}, _a1 interface{}) *Repository_BulkUpsert_Call { return &Repository_BulkUpsert_Call{Call: _e.mock.On("BulkUpsert", _a0, _a1)} } @@ -60,11 +60,20 @@ func (_c *Repository_BulkUpsert_Call) Return(_a0 error) *Repository_BulkUpsert_C return _c } +func (_c *Repository_BulkUpsert_Call) RunAndReturn(run func(context.Context, []*domain.Appeal) error) *Repository_BulkUpsert_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0, _a1 func (_m *Repository) Find(_a0 context.Context, _a1 *domain.ListAppealsFilter) ([]*domain.Appeal, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Appeal + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *domain.ListAppealsFilter) ([]*domain.Appeal, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, *domain.ListAppealsFilter) []*domain.Appeal); ok { r0 = rf(_a0, _a1) } else { @@ -73,7 +82,6 @@ func (_m *Repository) Find(_a0 context.Context, _a1 *domain.ListAppealsFilter) ( } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, *domain.ListAppealsFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -89,8 +97,8 @@ type Repository_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.ListAppealsFilter +// - _a0 context.Context +// - _a1 *domain.ListAppealsFilter func (_e *Repository_Expecter) Find(_a0 interface{}, _a1 interface{}) *Repository_Find_Call { return &Repository_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -107,11 +115,20 @@ func (_c *Repository_Find_Call) Return(_a0 []*domain.Appeal, _a1 error) *Reposit return _c } +func (_c *Repository_Find_Call) RunAndReturn(run func(context.Context, *domain.ListAppealsFilter) ([]*domain.Appeal, error)) *Repository_Find_Call { + _c.Call.Return(run) + return _c +} + // GetByID provides a mock function with given fields: ctx, id func (_m *Repository) GetByID(ctx context.Context, id string) (*domain.Appeal, error) { ret := _m.Called(ctx, id) var r0 *domain.Appeal + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Appeal, error)); ok { + return rf(ctx, id) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Appeal); ok { r0 = rf(ctx, id) } else { @@ -120,7 +137,6 @@ func (_m *Repository) GetByID(ctx context.Context, id string) (*domain.Appeal, e } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(ctx, id) } else { @@ -136,8 +152,8 @@ type Repository_GetByID_Call struct { } // GetByID is a helper method to define mock.On call -// - ctx context.Context -// - id string +// - ctx context.Context +// - id string func (_e *Repository_Expecter) GetByID(ctx interface{}, id interface{}) *Repository_GetByID_Call { return &Repository_GetByID_Call{Call: _e.mock.On("GetByID", ctx, id)} } @@ -154,6 +170,11 @@ func (_c *Repository_GetByID_Call) Return(_a0 *domain.Appeal, _a1 error) *Reposi return _c } +func (_c *Repository_GetByID_Call) RunAndReturn(run func(context.Context, string) (*domain.Appeal, error)) *Repository_GetByID_Call { + _c.Call.Return(run) + return _c +} + // Update provides a mock function with given fields: _a0, _a1 func (_m *Repository) Update(_a0 context.Context, _a1 *domain.Appeal) error { ret := _m.Called(_a0, _a1) @@ -174,8 +195,8 @@ type Repository_Update_Call struct { } // Update is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Appeal +// - _a0 context.Context +// - _a1 *domain.Appeal func (_e *Repository_Expecter) Update(_a0 interface{}, _a1 interface{}) *Repository_Update_Call { return &Repository_Update_Call{Call: _e.mock.On("Update", _a0, _a1)} } @@ -191,3 +212,23 @@ func (_c *Repository_Update_Call) Return(_a0 error) *Repository_Update_Call { _c.Call.Return(_a0) return _c } + +func (_c *Repository_Update_Call) RunAndReturn(run func(context.Context, *domain.Appeal) error) *Repository_Update_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewRepository interface { + mock.TestingT + Cleanup(func()) +} + +// NewRepository creates a new instance of Repository. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewRepository(t mockConstructorTestingTNewRepository) *Repository { + mock := &Repository{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/appeal/mocks/resourceService.go b/core/appeal/mocks/resourceService.go index 38713699b..5893d3273 100644 --- a/core/appeal/mocks/resourceService.go +++ b/core/appeal/mocks/resourceService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *ResourceService) Find(_a0 context.Context, _a1 domain.ListResourcesFil ret := _m.Called(_a0, _a1) var r0 []*domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) []*domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -35,7 +39,6 @@ func (_m *ResourceService) Find(_a0 context.Context, _a1 domain.ListResourcesFil } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListResourcesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -51,8 +54,8 @@ type ResourceService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListResourcesFilter +// - _a0 context.Context +// - _a1 domain.ListResourcesFilter func (_e *ResourceService_Expecter) Find(_a0 interface{}, _a1 interface{}) *ResourceService_Find_Call { return &ResourceService_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -69,11 +72,20 @@ func (_c *ResourceService_Find_Call) Return(_a0 []*domain.Resource, _a1 error) * return _c } +func (_c *ResourceService_Find_Call) RunAndReturn(run func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)) *ResourceService_Find_Call { + _c.Call.Return(run) + return _c +} + // Get provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) Get(_a0 context.Context, _a1 *domain.ResourceIdentifier) (*domain.Resource, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *domain.ResourceIdentifier) (*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, *domain.ResourceIdentifier) *domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -82,7 +94,6 @@ func (_m *ResourceService) Get(_a0 context.Context, _a1 *domain.ResourceIdentifi } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, *domain.ResourceIdentifier) error); ok { r1 = rf(_a0, _a1) } else { @@ -98,8 +109,8 @@ type ResourceService_Get_Call struct { } // Get is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.ResourceIdentifier +// - _a0 context.Context +// - _a1 *domain.ResourceIdentifier func (_e *ResourceService_Expecter) Get(_a0 interface{}, _a1 interface{}) *ResourceService_Get_Call { return &ResourceService_Get_Call{Call: _e.mock.On("Get", _a0, _a1)} } @@ -115,3 +126,23 @@ func (_c *ResourceService_Get_Call) Return(_a0 *domain.Resource, _a1 error) *Res _c.Call.Return(_a0, _a1) return _c } + +func (_c *ResourceService_Get_Call) RunAndReturn(run func(context.Context, *domain.ResourceIdentifier) (*domain.Resource, error)) *ResourceService_Get_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewResourceService interface { + mock.TestingT + Cleanup(func()) +} + +// NewResourceService creates a new instance of ResourceService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewResourceService(t mockConstructorTestingTNewResourceService) *ResourceService { + mock := &ResourceService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/approval/mocks/policyService.go b/core/approval/mocks/policyService.go index 2b17e555b..f2219e41f 100644 --- a/core/approval/mocks/policyService.go +++ b/core/approval/mocks/policyService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.14.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *PolicyService) GetOne(_a0 context.Context, _a1 string, _a2 uint) (*dom ret := _m.Called(_a0, _a1, _a2) var r0 *domain.Policy + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, uint) (*domain.Policy, error)); ok { + return rf(_a0, _a1, _a2) + } if rf, ok := ret.Get(0).(func(context.Context, string, uint) *domain.Policy); ok { r0 = rf(_a0, _a1, _a2) } else { @@ -35,7 +39,6 @@ func (_m *PolicyService) GetOne(_a0 context.Context, _a1 string, _a2 uint) (*dom } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, uint) error); ok { r1 = rf(_a0, _a1, _a2) } else { @@ -51,9 +54,9 @@ type PolicyService_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string -// - _a2 uint +// - _a0 context.Context +// - _a1 string +// - _a2 uint func (_e *PolicyService_Expecter) GetOne(_a0 interface{}, _a1 interface{}, _a2 interface{}) *PolicyService_GetOne_Call { return &PolicyService_GetOne_Call{Call: _e.mock.On("GetOne", _a0, _a1, _a2)} } @@ -70,6 +73,11 @@ func (_c *PolicyService_GetOne_Call) Return(_a0 *domain.Policy, _a1 error) *Poli return _c } +func (_c *PolicyService_GetOne_Call) RunAndReturn(run func(context.Context, string, uint) (*domain.Policy, error)) *PolicyService_GetOne_Call { + _c.Call.Return(run) + return _c +} + type mockConstructorTestingTNewPolicyService interface { mock.TestingT Cleanup(func()) diff --git a/core/approval/mocks/repository.go b/core/approval/mocks/repository.go index f0f5f3cee..f0201ea01 100644 --- a/core/approval/mocks/repository.go +++ b/core/approval/mocks/repository.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.14.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type Repository_AddApprover_Call struct { } // AddApprover is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Approver +// - _a0 context.Context +// - _a1 *domain.Approver func (_e *Repository_Expecter) AddApprover(_a0 interface{}, _a1 interface{}) *Repository_AddApprover_Call { return &Repository_AddApprover_Call{Call: _e.mock.On("AddApprover", _a0, _a1)} } @@ -60,6 +60,11 @@ func (_c *Repository_AddApprover_Call) Return(_a0 error) *Repository_AddApprover return _c } +func (_c *Repository_AddApprover_Call) RunAndReturn(run func(context.Context, *domain.Approver) error) *Repository_AddApprover_Call { + _c.Call.Return(run) + return _c +} + // BulkInsert provides a mock function with given fields: _a0, _a1 func (_m *Repository) BulkInsert(_a0 context.Context, _a1 []*domain.Approval) error { ret := _m.Called(_a0, _a1) @@ -80,8 +85,8 @@ type Repository_BulkInsert_Call struct { } // BulkInsert is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Approval +// - _a0 context.Context +// - _a1 []*domain.Approval func (_e *Repository_Expecter) BulkInsert(_a0 interface{}, _a1 interface{}) *Repository_BulkInsert_Call { return &Repository_BulkInsert_Call{Call: _e.mock.On("BulkInsert", _a0, _a1)} } @@ -98,6 +103,11 @@ func (_c *Repository_BulkInsert_Call) Return(_a0 error) *Repository_BulkInsert_C return _c } +func (_c *Repository_BulkInsert_Call) RunAndReturn(run func(context.Context, []*domain.Approval) error) *Repository_BulkInsert_Call { + _c.Call.Return(run) + return _c +} + // DeleteApprover provides a mock function with given fields: ctx, approvalID, email func (_m *Repository) DeleteApprover(ctx context.Context, approvalID string, email string) error { ret := _m.Called(ctx, approvalID, email) @@ -118,9 +128,9 @@ type Repository_DeleteApprover_Call struct { } // DeleteApprover is a helper method to define mock.On call -// - ctx context.Context -// - approvalID string -// - email string +// - ctx context.Context +// - approvalID string +// - email string func (_e *Repository_Expecter) DeleteApprover(ctx interface{}, approvalID interface{}, email interface{}) *Repository_DeleteApprover_Call { return &Repository_DeleteApprover_Call{Call: _e.mock.On("DeleteApprover", ctx, approvalID, email)} } @@ -137,11 +147,20 @@ func (_c *Repository_DeleteApprover_Call) Return(_a0 error) *Repository_DeleteAp return _c } +func (_c *Repository_DeleteApprover_Call) RunAndReturn(run func(context.Context, string, string) error) *Repository_DeleteApprover_Call { + _c.Call.Return(run) + return _c +} + // ListApprovals provides a mock function with given fields: _a0, _a1 func (_m *Repository) ListApprovals(_a0 context.Context, _a1 *domain.ListApprovalsFilter) ([]*domain.Approval, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Approval + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *domain.ListApprovalsFilter) ([]*domain.Approval, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, *domain.ListApprovalsFilter) []*domain.Approval); ok { r0 = rf(_a0, _a1) } else { @@ -150,7 +169,6 @@ func (_m *Repository) ListApprovals(_a0 context.Context, _a1 *domain.ListApprova } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, *domain.ListApprovalsFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -166,8 +184,8 @@ type Repository_ListApprovals_Call struct { } // ListApprovals is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.ListApprovalsFilter +// - _a0 context.Context +// - _a1 *domain.ListApprovalsFilter func (_e *Repository_Expecter) ListApprovals(_a0 interface{}, _a1 interface{}) *Repository_ListApprovals_Call { return &Repository_ListApprovals_Call{Call: _e.mock.On("ListApprovals", _a0, _a1)} } @@ -184,6 +202,11 @@ func (_c *Repository_ListApprovals_Call) Return(_a0 []*domain.Approval, _a1 erro return _c } +func (_c *Repository_ListApprovals_Call) RunAndReturn(run func(context.Context, *domain.ListApprovalsFilter) ([]*domain.Approval, error)) *Repository_ListApprovals_Call { + _c.Call.Return(run) + return _c +} + type mockConstructorTestingTNewRepository interface { mock.TestingT Cleanup(func()) diff --git a/core/grant/mocks/auditLogger.go b/core/grant/mocks/auditLogger.go index 421d831ee..5c791a405 100644 --- a/core/grant/mocks/auditLogger.go +++ b/core/grant/mocks/auditLogger.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -41,9 +41,9 @@ type AuditLogger_Log_Call struct { } // Log is a helper method to define mock.On call -// - ctx context.Context -// - action string -// - data interface{} +// - ctx context.Context +// - action string +// - data interface{} func (_e *AuditLogger_Expecter) Log(ctx interface{}, action interface{}, data interface{}) *AuditLogger_Log_Call { return &AuditLogger_Log_Call{Call: _e.mock.On("Log", ctx, action, data)} } @@ -59,3 +59,23 @@ func (_c *AuditLogger_Log_Call) Return(_a0 error) *AuditLogger_Log_Call { _c.Call.Return(_a0) return _c } + +func (_c *AuditLogger_Log_Call) RunAndReturn(run func(context.Context, string, interface{}) error) *AuditLogger_Log_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewAuditLogger interface { + mock.TestingT + Cleanup(func()) +} + +// NewAuditLogger creates a new instance of AuditLogger. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewAuditLogger(t mockConstructorTestingTNewAuditLogger) *AuditLogger { + mock := &AuditLogger{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/grant/mocks/notifier.go b/core/grant/mocks/notifier.go index 4d5e3ee59..a7975f6db 100644 --- a/core/grant/mocks/notifier.go +++ b/core/grant/mocks/notifier.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -43,7 +43,7 @@ type Notifier_Notify_Call struct { } // Notify is a helper method to define mock.On call -// - _a0 []domain.Notification +// - _a0 []domain.Notification func (_e *Notifier_Expecter) Notify(_a0 interface{}) *Notifier_Notify_Call { return &Notifier_Notify_Call{Call: _e.mock.On("Notify", _a0)} } @@ -59,3 +59,23 @@ func (_c *Notifier_Notify_Call) Return(_a0 []error) *Notifier_Notify_Call { _c.Call.Return(_a0) return _c } + +func (_c *Notifier_Notify_Call) RunAndReturn(run func([]domain.Notification) []error) *Notifier_Notify_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewNotifier interface { + mock.TestingT + Cleanup(func()) +} + +// NewNotifier creates a new instance of Notifier. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewNotifier(t mockConstructorTestingTNewNotifier) *Notifier { + mock := &Notifier{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/grant/mocks/providerService.go b/core/grant/mocks/providerService.go index 668b9bf60..219be591c 100644 --- a/core/grant/mocks/providerService.go +++ b/core/grant/mocks/providerService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -28,6 +28,10 @@ func (_m *ProviderService) GetByID(_a0 context.Context, _a1 string) (*domain.Pro ret := _m.Called(_a0, _a1) var r0 *domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Provider, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Provider); ok { r0 = rf(_a0, _a1) } else { @@ -36,7 +40,6 @@ func (_m *ProviderService) GetByID(_a0 context.Context, _a1 string) (*domain.Pro } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -52,8 +55,8 @@ type ProviderService_GetByID_Call struct { } // GetByID is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *ProviderService_Expecter) GetByID(_a0 interface{}, _a1 interface{}) *ProviderService_GetByID_Call { return &ProviderService_GetByID_Call{Call: _e.mock.On("GetByID", _a0, _a1)} } @@ -70,11 +73,20 @@ func (_c *ProviderService_GetByID_Call) Return(_a0 *domain.Provider, _a1 error) return _c } +func (_c *ProviderService_GetByID_Call) RunAndReturn(run func(context.Context, string) (*domain.Provider, error)) *ProviderService_GetByID_Call { + _c.Call.Return(run) + return _c +} + // ListAccess provides a mock function with given fields: _a0, _a1, _a2 func (_m *ProviderService) ListAccess(_a0 context.Context, _a1 domain.Provider, _a2 []*domain.Resource) (domain.MapResourceAccess, error) { ret := _m.Called(_a0, _a1, _a2) var r0 domain.MapResourceAccess + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.Provider, []*domain.Resource) (domain.MapResourceAccess, error)); ok { + return rf(_a0, _a1, _a2) + } if rf, ok := ret.Get(0).(func(context.Context, domain.Provider, []*domain.Resource) domain.MapResourceAccess); ok { r0 = rf(_a0, _a1, _a2) } else { @@ -83,7 +95,6 @@ func (_m *ProviderService) ListAccess(_a0 context.Context, _a1 domain.Provider, } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.Provider, []*domain.Resource) error); ok { r1 = rf(_a0, _a1, _a2) } else { @@ -99,9 +110,9 @@ type ProviderService_ListAccess_Call struct { } // ListAccess is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.Provider -// - _a2 []*domain.Resource +// - _a0 context.Context +// - _a1 domain.Provider +// - _a2 []*domain.Resource func (_e *ProviderService_Expecter) ListAccess(_a0 interface{}, _a1 interface{}, _a2 interface{}) *ProviderService_ListAccess_Call { return &ProviderService_ListAccess_Call{Call: _e.mock.On("ListAccess", _a0, _a1, _a2)} } @@ -118,6 +129,11 @@ func (_c *ProviderService_ListAccess_Call) Return(_a0 domain.MapResourceAccess, return _c } +func (_c *ProviderService_ListAccess_Call) RunAndReturn(run func(context.Context, domain.Provider, []*domain.Resource) (domain.MapResourceAccess, error)) *ProviderService_ListAccess_Call { + _c.Call.Return(run) + return _c +} + // RevokeAccess provides a mock function with given fields: _a0, _a1 func (_m *ProviderService) RevokeAccess(_a0 context.Context, _a1 domain.Grant) error { ret := _m.Called(_a0, _a1) @@ -138,8 +154,8 @@ type ProviderService_RevokeAccess_Call struct { } // RevokeAccess is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.Grant +// - _a0 context.Context +// - _a1 domain.Grant func (_e *ProviderService_Expecter) RevokeAccess(_a0 interface{}, _a1 interface{}) *ProviderService_RevokeAccess_Call { return &ProviderService_RevokeAccess_Call{Call: _e.mock.On("RevokeAccess", _a0, _a1)} } @@ -155,3 +171,23 @@ func (_c *ProviderService_RevokeAccess_Call) Return(_a0 error) *ProviderService_ _c.Call.Return(_a0) return _c } + +func (_c *ProviderService_RevokeAccess_Call) RunAndReturn(run func(context.Context, domain.Grant) error) *ProviderService_RevokeAccess_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewProviderService interface { + mock.TestingT + Cleanup(func()) +} + +// NewProviderService creates a new instance of ProviderService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewProviderService(t mockConstructorTestingTNewProviderService) *ProviderService { + mock := &ProviderService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/grant/mocks/repository.go b/core/grant/mocks/repository.go index 730fa8f6d..cd3973ff4 100644 --- a/core/grant/mocks/repository.go +++ b/core/grant/mocks/repository.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -43,8 +43,8 @@ type Repository_BulkUpsert_Call struct { } // BulkUpsert is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Grant +// - _a0 context.Context +// - _a1 []*domain.Grant func (_e *Repository_Expecter) BulkUpsert(_a0 interface{}, _a1 interface{}) *Repository_BulkUpsert_Call { return &Repository_BulkUpsert_Call{Call: _e.mock.On("BulkUpsert", _a0, _a1)} } @@ -61,11 +61,20 @@ func (_c *Repository_BulkUpsert_Call) Return(_a0 error) *Repository_BulkUpsert_C return _c } +func (_c *Repository_BulkUpsert_Call) RunAndReturn(run func(context.Context, []*domain.Grant) error) *Repository_BulkUpsert_Call { + _c.Call.Return(run) + return _c +} + // GetByID provides a mock function with given fields: _a0, _a1 func (_m *Repository) GetByID(_a0 context.Context, _a1 string) (*domain.Grant, error) { ret := _m.Called(_a0, _a1) var r0 *domain.Grant + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Grant, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Grant); ok { r0 = rf(_a0, _a1) } else { @@ -74,7 +83,6 @@ func (_m *Repository) GetByID(_a0 context.Context, _a1 string) (*domain.Grant, e } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -90,8 +98,8 @@ type Repository_GetByID_Call struct { } // GetByID is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *Repository_Expecter) GetByID(_a0 interface{}, _a1 interface{}) *Repository_GetByID_Call { return &Repository_GetByID_Call{Call: _e.mock.On("GetByID", _a0, _a1)} } @@ -108,11 +116,20 @@ func (_c *Repository_GetByID_Call) Return(_a0 *domain.Grant, _a1 error) *Reposit return _c } +func (_c *Repository_GetByID_Call) RunAndReturn(run func(context.Context, string) (*domain.Grant, error)) *Repository_GetByID_Call { + _c.Call.Return(run) + return _c +} + // List provides a mock function with given fields: _a0, _a1 func (_m *Repository) List(_a0 context.Context, _a1 domain.ListGrantsFilter) ([]domain.Grant, error) { ret := _m.Called(_a0, _a1) var r0 []domain.Grant + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListGrantsFilter) ([]domain.Grant, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListGrantsFilter) []domain.Grant); ok { r0 = rf(_a0, _a1) } else { @@ -121,7 +138,6 @@ func (_m *Repository) List(_a0 context.Context, _a1 domain.ListGrantsFilter) ([] } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListGrantsFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -137,8 +153,8 @@ type Repository_List_Call struct { } // List is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListGrantsFilter +// - _a0 context.Context +// - _a1 domain.ListGrantsFilter func (_e *Repository_Expecter) List(_a0 interface{}, _a1 interface{}) *Repository_List_Call { return &Repository_List_Call{Call: _e.mock.On("List", _a0, _a1)} } @@ -155,6 +171,11 @@ func (_c *Repository_List_Call) Return(_a0 []domain.Grant, _a1 error) *Repositor return _c } +func (_c *Repository_List_Call) RunAndReturn(run func(context.Context, domain.ListGrantsFilter) ([]domain.Grant, error)) *Repository_List_Call { + _c.Call.Return(run) + return _c +} + // Update provides a mock function with given fields: _a0, _a1 func (_m *Repository) Update(_a0 context.Context, _a1 *domain.Grant) error { ret := _m.Called(_a0, _a1) @@ -175,8 +196,8 @@ type Repository_Update_Call struct { } // Update is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Grant +// - _a0 context.Context +// - _a1 *domain.Grant func (_e *Repository_Expecter) Update(_a0 interface{}, _a1 interface{}) *Repository_Update_Call { return &Repository_Update_Call{Call: _e.mock.On("Update", _a0, _a1)} } @@ -192,3 +213,23 @@ func (_c *Repository_Update_Call) Return(_a0 error) *Repository_Update_Call { _c.Call.Return(_a0) return _c } + +func (_c *Repository_Update_Call) RunAndReturn(run func(context.Context, *domain.Grant) error) *Repository_Update_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewRepository interface { + mock.TestingT + Cleanup(func()) +} + +// NewRepository creates a new instance of Repository. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewRepository(t mockConstructorTestingTNewRepository) *Repository { + mock := &Repository{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/grant/mocks/resourceService.go b/core/grant/mocks/resourceService.go index dfb8264a5..bd58b8af8 100644 --- a/core/grant/mocks/resourceService.go +++ b/core/grant/mocks/resourceService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -28,6 +28,10 @@ func (_m *ResourceService) Find(_a0 context.Context, _a1 domain.ListResourcesFil ret := _m.Called(_a0, _a1) var r0 []*domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) []*domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -36,7 +40,6 @@ func (_m *ResourceService) Find(_a0 context.Context, _a1 domain.ListResourcesFil } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListResourcesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -52,8 +55,8 @@ type ResourceService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListResourcesFilter +// - _a0 context.Context +// - _a1 domain.ListResourcesFilter func (_e *ResourceService_Expecter) Find(_a0 interface{}, _a1 interface{}) *ResourceService_Find_Call { return &ResourceService_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -69,3 +72,23 @@ func (_c *ResourceService_Find_Call) Return(_a0 []*domain.Resource, _a1 error) * _c.Call.Return(_a0, _a1) return _c } + +func (_c *ResourceService_Find_Call) RunAndReturn(run func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)) *ResourceService_Find_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewResourceService interface { + mock.TestingT + Cleanup(func()) +} + +// NewResourceService creates a new instance of ResourceService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewResourceService(t mockConstructorTestingTNewResourceService) *ResourceService { + mock := &ResourceService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/policy/mocks/auditLogger.go b/core/policy/mocks/auditLogger.go index 421d831ee..5c791a405 100644 --- a/core/policy/mocks/auditLogger.go +++ b/core/policy/mocks/auditLogger.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -41,9 +41,9 @@ type AuditLogger_Log_Call struct { } // Log is a helper method to define mock.On call -// - ctx context.Context -// - action string -// - data interface{} +// - ctx context.Context +// - action string +// - data interface{} func (_e *AuditLogger_Expecter) Log(ctx interface{}, action interface{}, data interface{}) *AuditLogger_Log_Call { return &AuditLogger_Log_Call{Call: _e.mock.On("Log", ctx, action, data)} } @@ -59,3 +59,23 @@ func (_c *AuditLogger_Log_Call) Return(_a0 error) *AuditLogger_Log_Call { _c.Call.Return(_a0) return _c } + +func (_c *AuditLogger_Log_Call) RunAndReturn(run func(context.Context, string, interface{}) error) *AuditLogger_Log_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewAuditLogger interface { + mock.TestingT + Cleanup(func()) +} + +// NewAuditLogger creates a new instance of AuditLogger. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewAuditLogger(t mockConstructorTestingTNewAuditLogger) *AuditLogger { + mock := &AuditLogger{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/policy/mocks/providerService.go b/core/policy/mocks/providerService.go index 99b9be46f..1b6145639 100644 --- a/core/policy/mocks/providerService.go +++ b/core/policy/mocks/providerService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *ProviderService) GetOne(ctx context.Context, pType string, urn string) ret := _m.Called(ctx, pType, urn) var r0 *domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, string) (*domain.Provider, error)); ok { + return rf(ctx, pType, urn) + } if rf, ok := ret.Get(0).(func(context.Context, string, string) *domain.Provider); ok { r0 = rf(ctx, pType, urn) } else { @@ -35,7 +39,6 @@ func (_m *ProviderService) GetOne(ctx context.Context, pType string, urn string) } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, string) error); ok { r1 = rf(ctx, pType, urn) } else { @@ -51,9 +54,9 @@ type ProviderService_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - ctx context.Context -// - pType string -// - urn string +// - ctx context.Context +// - pType string +// - urn string func (_e *ProviderService_Expecter) GetOne(ctx interface{}, pType interface{}, urn interface{}) *ProviderService_GetOne_Call { return &ProviderService_GetOne_Call{Call: _e.mock.On("GetOne", ctx, pType, urn)} } @@ -70,6 +73,11 @@ func (_c *ProviderService_GetOne_Call) Return(_a0 *domain.Provider, _a1 error) * return _c } +func (_c *ProviderService_GetOne_Call) RunAndReturn(run func(context.Context, string, string) (*domain.Provider, error)) *ProviderService_GetOne_Call { + _c.Call.Return(run) + return _c +} + // ValidateAppeal provides a mock function with given fields: _a0, _a1, _a2, _a3 func (_m *ProviderService) ValidateAppeal(_a0 context.Context, _a1 *domain.Appeal, _a2 *domain.Provider, _a3 *domain.Policy) error { ret := _m.Called(_a0, _a1, _a2, _a3) @@ -90,10 +98,10 @@ type ProviderService_ValidateAppeal_Call struct { } // ValidateAppeal is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Appeal -// - _a2 *domain.Provider -// - _a3 *domain.Policy +// - _a0 context.Context +// - _a1 *domain.Appeal +// - _a2 *domain.Provider +// - _a3 *domain.Policy func (_e *ProviderService_Expecter) ValidateAppeal(_a0 interface{}, _a1 interface{}, _a2 interface{}, _a3 interface{}) *ProviderService_ValidateAppeal_Call { return &ProviderService_ValidateAppeal_Call{Call: _e.mock.On("ValidateAppeal", _a0, _a1, _a2, _a3)} } @@ -109,3 +117,23 @@ func (_c *ProviderService_ValidateAppeal_Call) Return(_a0 error) *ProviderServic _c.Call.Return(_a0) return _c } + +func (_c *ProviderService_ValidateAppeal_Call) RunAndReturn(run func(context.Context, *domain.Appeal, *domain.Provider, *domain.Policy) error) *ProviderService_ValidateAppeal_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewProviderService interface { + mock.TestingT + Cleanup(func()) +} + +// NewProviderService creates a new instance of ProviderService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewProviderService(t mockConstructorTestingTNewProviderService) *ProviderService { + mock := &ProviderService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/policy/mocks/repository.go b/core/policy/mocks/repository.go index c8b91568d..2503e66e0 100644 --- a/core/policy/mocks/repository.go +++ b/core/policy/mocks/repository.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type Repository_Create_Call struct { } // Create is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Policy +// - _a0 context.Context +// - _a1 *domain.Policy func (_e *Repository_Expecter) Create(_a0 interface{}, _a1 interface{}) *Repository_Create_Call { return &Repository_Create_Call{Call: _e.mock.On("Create", _a0, _a1)} } @@ -60,11 +60,20 @@ func (_c *Repository_Create_Call) Return(_a0 error) *Repository_Create_Call { return _c } +func (_c *Repository_Create_Call) RunAndReturn(run func(context.Context, *domain.Policy) error) *Repository_Create_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0 func (_m *Repository) Find(_a0 context.Context) ([]*domain.Policy, error) { ret := _m.Called(_a0) var r0 []*domain.Policy + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]*domain.Policy, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []*domain.Policy); ok { r0 = rf(_a0) } else { @@ -73,7 +82,6 @@ func (_m *Repository) Find(_a0 context.Context) ([]*domain.Policy, error) { } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -89,7 +97,7 @@ type Repository_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *Repository_Expecter) Find(_a0 interface{}) *Repository_Find_Call { return &Repository_Find_Call{Call: _e.mock.On("Find", _a0)} } @@ -106,11 +114,20 @@ func (_c *Repository_Find_Call) Return(_a0 []*domain.Policy, _a1 error) *Reposit return _c } +func (_c *Repository_Find_Call) RunAndReturn(run func(context.Context) ([]*domain.Policy, error)) *Repository_Find_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: ctx, id, version func (_m *Repository) GetOne(ctx context.Context, id string, version uint) (*domain.Policy, error) { ret := _m.Called(ctx, id, version) var r0 *domain.Policy + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, uint) (*domain.Policy, error)); ok { + return rf(ctx, id, version) + } if rf, ok := ret.Get(0).(func(context.Context, string, uint) *domain.Policy); ok { r0 = rf(ctx, id, version) } else { @@ -119,7 +136,6 @@ func (_m *Repository) GetOne(ctx context.Context, id string, version uint) (*dom } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, uint) error); ok { r1 = rf(ctx, id, version) } else { @@ -135,9 +151,9 @@ type Repository_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - ctx context.Context -// - id string -// - version uint +// - ctx context.Context +// - id string +// - version uint func (_e *Repository_Expecter) GetOne(ctx interface{}, id interface{}, version interface{}) *Repository_GetOne_Call { return &Repository_GetOne_Call{Call: _e.mock.On("GetOne", ctx, id, version)} } @@ -153,3 +169,23 @@ func (_c *Repository_GetOne_Call) Return(_a0 *domain.Policy, _a1 error) *Reposit _c.Call.Return(_a0, _a1) return _c } + +func (_c *Repository_GetOne_Call) RunAndReturn(run func(context.Context, string, uint) (*domain.Policy, error)) *Repository_GetOne_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewRepository interface { + mock.TestingT + Cleanup(func()) +} + +// NewRepository creates a new instance of Repository. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewRepository(t mockConstructorTestingTNewRepository) *Repository { + mock := &Repository{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/policy/mocks/resourceService.go b/core/policy/mocks/resourceService.go index 511247ad0..750f526e6 100644 --- a/core/policy/mocks/resourceService.go +++ b/core/policy/mocks/resourceService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *ResourceService) Get(_a0 context.Context, _a1 *domain.ResourceIdentifi ret := _m.Called(_a0, _a1) var r0 *domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *domain.ResourceIdentifier) (*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, *domain.ResourceIdentifier) *domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -35,7 +39,6 @@ func (_m *ResourceService) Get(_a0 context.Context, _a1 *domain.ResourceIdentifi } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, *domain.ResourceIdentifier) error); ok { r1 = rf(_a0, _a1) } else { @@ -51,8 +54,8 @@ type ResourceService_Get_Call struct { } // Get is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.ResourceIdentifier +// - _a0 context.Context +// - _a1 *domain.ResourceIdentifier func (_e *ResourceService_Expecter) Get(_a0 interface{}, _a1 interface{}) *ResourceService_Get_Call { return &ResourceService_Get_Call{Call: _e.mock.On("Get", _a0, _a1)} } @@ -68,3 +71,23 @@ func (_c *ResourceService_Get_Call) Return(_a0 *domain.Resource, _a1 error) *Res _c.Call.Return(_a0, _a1) return _c } + +func (_c *ResourceService_Get_Call) RunAndReturn(run func(context.Context, *domain.ResourceIdentifier) (*domain.Resource, error)) *ResourceService_Get_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewResourceService interface { + mock.TestingT + Cleanup(func()) +} + +// NewResourceService creates a new instance of ResourceService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewResourceService(t mockConstructorTestingTNewResourceService) *ResourceService { + mock := &ResourceService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/provider/mocks/activityManager.go b/core/provider/mocks/activityManager.go index 326b8008d..f117bc48d 100644 --- a/core/provider/mocks/activityManager.go +++ b/core/provider/mocks/activityManager.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -27,6 +27,10 @@ func (_m *ActivityManager) GetActivities(_a0 context.Context, _a1 domain.Provide ret := _m.Called(_a0, _a1, _a2) var r0 []*domain.Activity + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.Provider, domain.ImportActivitiesFilter) ([]*domain.Activity, error)); ok { + return rf(_a0, _a1, _a2) + } if rf, ok := ret.Get(0).(func(context.Context, domain.Provider, domain.ImportActivitiesFilter) []*domain.Activity); ok { r0 = rf(_a0, _a1, _a2) } else { @@ -35,7 +39,6 @@ func (_m *ActivityManager) GetActivities(_a0 context.Context, _a1 domain.Provide } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.Provider, domain.ImportActivitiesFilter) error); ok { r1 = rf(_a0, _a1, _a2) } else { @@ -51,9 +54,9 @@ type ActivityManager_GetActivities_Call struct { } // GetActivities is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.Provider -// - _a2 domain.ImportActivitiesFilter +// - _a0 context.Context +// - _a1 domain.Provider +// - _a2 domain.ImportActivitiesFilter func (_e *ActivityManager_Expecter) GetActivities(_a0 interface{}, _a1 interface{}, _a2 interface{}) *ActivityManager_GetActivities_Call { return &ActivityManager_GetActivities_Call{Call: _e.mock.On("GetActivities", _a0, _a1, _a2)} } @@ -69,3 +72,23 @@ func (_c *ActivityManager_GetActivities_Call) Return(_a0 []*domain.Activity, _a1 _c.Call.Return(_a0, _a1) return _c } + +func (_c *ActivityManager_GetActivities_Call) RunAndReturn(run func(context.Context, domain.Provider, domain.ImportActivitiesFilter) ([]*domain.Activity, error)) *ActivityManager_GetActivities_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewActivityManager interface { + mock.TestingT + Cleanup(func()) +} + +// NewActivityManager creates a new instance of ActivityManager. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewActivityManager(t mockConstructorTestingTNewActivityManager) *ActivityManager { + mock := &ActivityManager{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/provider/mocks/auditLogger.go b/core/provider/mocks/auditLogger.go index 421d831ee..5c791a405 100644 --- a/core/provider/mocks/auditLogger.go +++ b/core/provider/mocks/auditLogger.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -41,9 +41,9 @@ type AuditLogger_Log_Call struct { } // Log is a helper method to define mock.On call -// - ctx context.Context -// - action string -// - data interface{} +// - ctx context.Context +// - action string +// - data interface{} func (_e *AuditLogger_Expecter) Log(ctx interface{}, action interface{}, data interface{}) *AuditLogger_Log_Call { return &AuditLogger_Log_Call{Call: _e.mock.On("Log", ctx, action, data)} } @@ -59,3 +59,23 @@ func (_c *AuditLogger_Log_Call) Return(_a0 error) *AuditLogger_Log_Call { _c.Call.Return(_a0) return _c } + +func (_c *AuditLogger_Log_Call) RunAndReturn(run func(context.Context, string, interface{}) error) *AuditLogger_Log_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewAuditLogger interface { + mock.TestingT + Cleanup(func()) +} + +// NewAuditLogger creates a new instance of AuditLogger. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewAuditLogger(t mockConstructorTestingTNewAuditLogger) *AuditLogger { + mock := &AuditLogger{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/provider/mocks/client.go b/core/provider/mocks/client.go index afbc59985..a1672fa1f 100644 --- a/core/provider/mocks/client.go +++ b/core/provider/mocks/client.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,7 +42,7 @@ type Client_CreateConfig_Call struct { } // CreateConfig is a helper method to define mock.On call -// - _a0 *domain.ProviderConfig +// - _a0 *domain.ProviderConfig func (_e *Client_Expecter) CreateConfig(_a0 interface{}) *Client_CreateConfig_Call { return &Client_CreateConfig_Call{Call: _e.mock.On("CreateConfig", _a0)} } @@ -59,6 +59,11 @@ func (_c *Client_CreateConfig_Call) Return(_a0 error) *Client_CreateConfig_Call return _c } +func (_c *Client_CreateConfig_Call) RunAndReturn(run func(*domain.ProviderConfig) error) *Client_CreateConfig_Call { + _c.Call.Return(run) + return _c +} + // GetAccountTypes provides a mock function with given fields: func (_m *Client) GetAccountTypes() []string { ret := _m.Called() @@ -97,11 +102,20 @@ func (_c *Client_GetAccountTypes_Call) Return(_a0 []string) *Client_GetAccountTy return _c } +func (_c *Client_GetAccountTypes_Call) RunAndReturn(run func() []string) *Client_GetAccountTypes_Call { + _c.Call.Return(run) + return _c +} + // GetPermissions provides a mock function with given fields: p, resourceType, role func (_m *Client) GetPermissions(p *domain.ProviderConfig, resourceType string, role string) ([]interface{}, error) { ret := _m.Called(p, resourceType, role) var r0 []interface{} + var r1 error + if rf, ok := ret.Get(0).(func(*domain.ProviderConfig, string, string) ([]interface{}, error)); ok { + return rf(p, resourceType, role) + } if rf, ok := ret.Get(0).(func(*domain.ProviderConfig, string, string) []interface{}); ok { r0 = rf(p, resourceType, role) } else { @@ -110,7 +124,6 @@ func (_m *Client) GetPermissions(p *domain.ProviderConfig, resourceType string, } } - var r1 error if rf, ok := ret.Get(1).(func(*domain.ProviderConfig, string, string) error); ok { r1 = rf(p, resourceType, role) } else { @@ -126,9 +139,9 @@ type Client_GetPermissions_Call struct { } // GetPermissions is a helper method to define mock.On call -// - p *domain.ProviderConfig -// - resourceType string -// - role string +// - p *domain.ProviderConfig +// - resourceType string +// - role string func (_e *Client_Expecter) GetPermissions(p interface{}, resourceType interface{}, role interface{}) *Client_GetPermissions_Call { return &Client_GetPermissions_Call{Call: _e.mock.On("GetPermissions", p, resourceType, role)} } @@ -145,11 +158,20 @@ func (_c *Client_GetPermissions_Call) Return(_a0 []interface{}, _a1 error) *Clie return _c } +func (_c *Client_GetPermissions_Call) RunAndReturn(run func(*domain.ProviderConfig, string, string) ([]interface{}, error)) *Client_GetPermissions_Call { + _c.Call.Return(run) + return _c +} + // GetResources provides a mock function with given fields: pc func (_m *Client) GetResources(pc *domain.ProviderConfig) ([]*domain.Resource, error) { ret := _m.Called(pc) var r0 []*domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(*domain.ProviderConfig) ([]*domain.Resource, error)); ok { + return rf(pc) + } if rf, ok := ret.Get(0).(func(*domain.ProviderConfig) []*domain.Resource); ok { r0 = rf(pc) } else { @@ -158,7 +180,6 @@ func (_m *Client) GetResources(pc *domain.ProviderConfig) ([]*domain.Resource, e } } - var r1 error if rf, ok := ret.Get(1).(func(*domain.ProviderConfig) error); ok { r1 = rf(pc) } else { @@ -174,7 +195,7 @@ type Client_GetResources_Call struct { } // GetResources is a helper method to define mock.On call -// - pc *domain.ProviderConfig +// - pc *domain.ProviderConfig func (_e *Client_Expecter) GetResources(pc interface{}) *Client_GetResources_Call { return &Client_GetResources_Call{Call: _e.mock.On("GetResources", pc)} } @@ -191,11 +212,20 @@ func (_c *Client_GetResources_Call) Return(_a0 []*domain.Resource, _a1 error) *C return _c } +func (_c *Client_GetResources_Call) RunAndReturn(run func(*domain.ProviderConfig) ([]*domain.Resource, error)) *Client_GetResources_Call { + _c.Call.Return(run) + return _c +} + // GetRoles provides a mock function with given fields: pc, resourceType func (_m *Client) GetRoles(pc *domain.ProviderConfig, resourceType string) ([]*domain.Role, error) { ret := _m.Called(pc, resourceType) var r0 []*domain.Role + var r1 error + if rf, ok := ret.Get(0).(func(*domain.ProviderConfig, string) ([]*domain.Role, error)); ok { + return rf(pc, resourceType) + } if rf, ok := ret.Get(0).(func(*domain.ProviderConfig, string) []*domain.Role); ok { r0 = rf(pc, resourceType) } else { @@ -204,7 +234,6 @@ func (_m *Client) GetRoles(pc *domain.ProviderConfig, resourceType string) ([]*d } } - var r1 error if rf, ok := ret.Get(1).(func(*domain.ProviderConfig, string) error); ok { r1 = rf(pc, resourceType) } else { @@ -220,8 +249,8 @@ type Client_GetRoles_Call struct { } // GetRoles is a helper method to define mock.On call -// - pc *domain.ProviderConfig -// - resourceType string +// - pc *domain.ProviderConfig +// - resourceType string func (_e *Client_Expecter) GetRoles(pc interface{}, resourceType interface{}) *Client_GetRoles_Call { return &Client_GetRoles_Call{Call: _e.mock.On("GetRoles", pc, resourceType)} } @@ -238,6 +267,11 @@ func (_c *Client_GetRoles_Call) Return(_a0 []*domain.Role, _a1 error) *Client_Ge return _c } +func (_c *Client_GetRoles_Call) RunAndReturn(run func(*domain.ProviderConfig, string) ([]*domain.Role, error)) *Client_GetRoles_Call { + _c.Call.Return(run) + return _c +} + // GetType provides a mock function with given fields: func (_m *Client) GetType() string { ret := _m.Called() @@ -274,6 +308,11 @@ func (_c *Client_GetType_Call) Return(_a0 string) *Client_GetType_Call { return _c } +func (_c *Client_GetType_Call) RunAndReturn(run func() string) *Client_GetType_Call { + _c.Call.Return(run) + return _c +} + // GrantAccess provides a mock function with given fields: _a0, _a1 func (_m *Client) GrantAccess(_a0 *domain.ProviderConfig, _a1 domain.Grant) error { ret := _m.Called(_a0, _a1) @@ -294,8 +333,8 @@ type Client_GrantAccess_Call struct { } // GrantAccess is a helper method to define mock.On call -// - _a0 *domain.ProviderConfig -// - _a1 domain.Grant +// - _a0 *domain.ProviderConfig +// - _a1 domain.Grant func (_e *Client_Expecter) GrantAccess(_a0 interface{}, _a1 interface{}) *Client_GrantAccess_Call { return &Client_GrantAccess_Call{Call: _e.mock.On("GrantAccess", _a0, _a1)} } @@ -312,11 +351,20 @@ func (_c *Client_GrantAccess_Call) Return(_a0 error) *Client_GrantAccess_Call { return _c } +func (_c *Client_GrantAccess_Call) RunAndReturn(run func(*domain.ProviderConfig, domain.Grant) error) *Client_GrantAccess_Call { + _c.Call.Return(run) + return _c +} + // ListAccess provides a mock function with given fields: _a0, _a1, _a2 func (_m *Client) ListAccess(_a0 context.Context, _a1 domain.ProviderConfig, _a2 []*domain.Resource) (domain.MapResourceAccess, error) { ret := _m.Called(_a0, _a1, _a2) var r0 domain.MapResourceAccess + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ProviderConfig, []*domain.Resource) (domain.MapResourceAccess, error)); ok { + return rf(_a0, _a1, _a2) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ProviderConfig, []*domain.Resource) domain.MapResourceAccess); ok { r0 = rf(_a0, _a1, _a2) } else { @@ -325,7 +373,6 @@ func (_m *Client) ListAccess(_a0 context.Context, _a1 domain.ProviderConfig, _a2 } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ProviderConfig, []*domain.Resource) error); ok { r1 = rf(_a0, _a1, _a2) } else { @@ -341,9 +388,9 @@ type Client_ListAccess_Call struct { } // ListAccess is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ProviderConfig -// - _a2 []*domain.Resource +// - _a0 context.Context +// - _a1 domain.ProviderConfig +// - _a2 []*domain.Resource func (_e *Client_Expecter) ListAccess(_a0 interface{}, _a1 interface{}, _a2 interface{}) *Client_ListAccess_Call { return &Client_ListAccess_Call{Call: _e.mock.On("ListAccess", _a0, _a1, _a2)} } @@ -360,6 +407,11 @@ func (_c *Client_ListAccess_Call) Return(_a0 domain.MapResourceAccess, _a1 error return _c } +func (_c *Client_ListAccess_Call) RunAndReturn(run func(context.Context, domain.ProviderConfig, []*domain.Resource) (domain.MapResourceAccess, error)) *Client_ListAccess_Call { + _c.Call.Return(run) + return _c +} + // RevokeAccess provides a mock function with given fields: _a0, _a1 func (_m *Client) RevokeAccess(_a0 *domain.ProviderConfig, _a1 domain.Grant) error { ret := _m.Called(_a0, _a1) @@ -380,8 +432,8 @@ type Client_RevokeAccess_Call struct { } // RevokeAccess is a helper method to define mock.On call -// - _a0 *domain.ProviderConfig -// - _a1 domain.Grant +// - _a0 *domain.ProviderConfig +// - _a1 domain.Grant func (_e *Client_Expecter) RevokeAccess(_a0 interface{}, _a1 interface{}) *Client_RevokeAccess_Call { return &Client_RevokeAccess_Call{Call: _e.mock.On("RevokeAccess", _a0, _a1)} } @@ -397,3 +449,23 @@ func (_c *Client_RevokeAccess_Call) Return(_a0 error) *Client_RevokeAccess_Call _c.Call.Return(_a0) return _c } + +func (_c *Client_RevokeAccess_Call) RunAndReturn(run func(*domain.ProviderConfig, domain.Grant) error) *Client_RevokeAccess_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewClient interface { + mock.TestingT + Cleanup(func()) +} + +// NewClient creates a new instance of Client. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewClient(t mockConstructorTestingTNewClient) *Client { + mock := &Client{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/plugins/providers/bigquery/mocks/encryptor.go b/core/provider/mocks/encryptor.go similarity index 71% rename from plugins/providers/bigquery/mocks/encryptor.go rename to core/provider/mocks/encryptor.go index 2c9fd72dc..17022f262 100644 --- a/plugins/providers/bigquery/mocks/encryptor.go +++ b/core/provider/mocks/encryptor.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -22,13 +22,16 @@ func (_m *Encryptor) Decrypt(_a0 string) (string, error) { ret := _m.Called(_a0) var r0 string + var r1 error + if rf, ok := ret.Get(0).(func(string) (string, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(string) string); ok { r0 = rf(_a0) } else { r0 = ret.Get(0).(string) } - var r1 error if rf, ok := ret.Get(1).(func(string) error); ok { r1 = rf(_a0) } else { @@ -44,7 +47,7 @@ type Encryptor_Decrypt_Call struct { } // Decrypt is a helper method to define mock.On call -// - _a0 string +// - _a0 string func (_e *Encryptor_Expecter) Decrypt(_a0 interface{}) *Encryptor_Decrypt_Call { return &Encryptor_Decrypt_Call{Call: _e.mock.On("Decrypt", _a0)} } @@ -61,18 +64,26 @@ func (_c *Encryptor_Decrypt_Call) Return(_a0 string, _a1 error) *Encryptor_Decry return _c } +func (_c *Encryptor_Decrypt_Call) RunAndReturn(run func(string) (string, error)) *Encryptor_Decrypt_Call { + _c.Call.Return(run) + return _c +} + // Encrypt provides a mock function with given fields: _a0 func (_m *Encryptor) Encrypt(_a0 string) (string, error) { ret := _m.Called(_a0) var r0 string + var r1 error + if rf, ok := ret.Get(0).(func(string) (string, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(string) string); ok { r0 = rf(_a0) } else { r0 = ret.Get(0).(string) } - var r1 error if rf, ok := ret.Get(1).(func(string) error); ok { r1 = rf(_a0) } else { @@ -88,7 +99,7 @@ type Encryptor_Encrypt_Call struct { } // Encrypt is a helper method to define mock.On call -// - _a0 string +// - _a0 string func (_e *Encryptor_Expecter) Encrypt(_a0 interface{}) *Encryptor_Encrypt_Call { return &Encryptor_Encrypt_Call{Call: _e.mock.On("Encrypt", _a0)} } @@ -104,3 +115,23 @@ func (_c *Encryptor_Encrypt_Call) Return(_a0 string, _a1 error) *Encryptor_Encry _c.Call.Return(_a0, _a1) return _c } + +func (_c *Encryptor_Encrypt_Call) RunAndReturn(run func(string) (string, error)) *Encryptor_Encrypt_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewEncryptor interface { + mock.TestingT + Cleanup(func()) +} + +// NewEncryptor creates a new instance of Encryptor. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewEncryptor(t mockConstructorTestingTNewEncryptor) *Encryptor { + mock := &Encryptor{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/provider/mocks/repository.go b/core/provider/mocks/repository.go index a5cc0df2a..d8243eef6 100644 --- a/core/provider/mocks/repository.go +++ b/core/provider/mocks/repository.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type Repository_Create_Call struct { } // Create is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Provider +// - _a0 context.Context +// - _a1 *domain.Provider func (_e *Repository_Expecter) Create(_a0 interface{}, _a1 interface{}) *Repository_Create_Call { return &Repository_Create_Call{Call: _e.mock.On("Create", _a0, _a1)} } @@ -60,6 +60,11 @@ func (_c *Repository_Create_Call) Return(_a0 error) *Repository_Create_Call { return _c } +func (_c *Repository_Create_Call) RunAndReturn(run func(context.Context, *domain.Provider) error) *Repository_Create_Call { + _c.Call.Return(run) + return _c +} + // Delete provides a mock function with given fields: ctx, id func (_m *Repository) Delete(ctx context.Context, id string) error { ret := _m.Called(ctx, id) @@ -80,8 +85,8 @@ type Repository_Delete_Call struct { } // Delete is a helper method to define mock.On call -// - ctx context.Context -// - id string +// - ctx context.Context +// - id string func (_e *Repository_Expecter) Delete(ctx interface{}, id interface{}) *Repository_Delete_Call { return &Repository_Delete_Call{Call: _e.mock.On("Delete", ctx, id)} } @@ -98,11 +103,20 @@ func (_c *Repository_Delete_Call) Return(_a0 error) *Repository_Delete_Call { return _c } +func (_c *Repository_Delete_Call) RunAndReturn(run func(context.Context, string) error) *Repository_Delete_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0 func (_m *Repository) Find(_a0 context.Context) ([]*domain.Provider, error) { ret := _m.Called(_a0) var r0 []*domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]*domain.Provider, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []*domain.Provider); ok { r0 = rf(_a0) } else { @@ -111,7 +125,6 @@ func (_m *Repository) Find(_a0 context.Context) ([]*domain.Provider, error) { } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -127,7 +140,7 @@ type Repository_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *Repository_Expecter) Find(_a0 interface{}) *Repository_Find_Call { return &Repository_Find_Call{Call: _e.mock.On("Find", _a0)} } @@ -144,11 +157,20 @@ func (_c *Repository_Find_Call) Return(_a0 []*domain.Provider, _a1 error) *Repos return _c } +func (_c *Repository_Find_Call) RunAndReturn(run func(context.Context) ([]*domain.Provider, error)) *Repository_Find_Call { + _c.Call.Return(run) + return _c +} + // GetByID provides a mock function with given fields: ctx, id func (_m *Repository) GetByID(ctx context.Context, id string) (*domain.Provider, error) { ret := _m.Called(ctx, id) var r0 *domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Provider, error)); ok { + return rf(ctx, id) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Provider); ok { r0 = rf(ctx, id) } else { @@ -157,7 +179,6 @@ func (_m *Repository) GetByID(ctx context.Context, id string) (*domain.Provider, } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(ctx, id) } else { @@ -173,8 +194,8 @@ type Repository_GetByID_Call struct { } // GetByID is a helper method to define mock.On call -// - ctx context.Context -// - id string +// - ctx context.Context +// - id string func (_e *Repository_Expecter) GetByID(ctx interface{}, id interface{}) *Repository_GetByID_Call { return &Repository_GetByID_Call{Call: _e.mock.On("GetByID", ctx, id)} } @@ -191,11 +212,20 @@ func (_c *Repository_GetByID_Call) Return(_a0 *domain.Provider, _a1 error) *Repo return _c } +func (_c *Repository_GetByID_Call) RunAndReturn(run func(context.Context, string) (*domain.Provider, error)) *Repository_GetByID_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: ctx, pType, urn func (_m *Repository) GetOne(ctx context.Context, pType string, urn string) (*domain.Provider, error) { ret := _m.Called(ctx, pType, urn) var r0 *domain.Provider + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, string) (*domain.Provider, error)); ok { + return rf(ctx, pType, urn) + } if rf, ok := ret.Get(0).(func(context.Context, string, string) *domain.Provider); ok { r0 = rf(ctx, pType, urn) } else { @@ -204,7 +234,6 @@ func (_m *Repository) GetOne(ctx context.Context, pType string, urn string) (*do } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, string) error); ok { r1 = rf(ctx, pType, urn) } else { @@ -220,9 +249,9 @@ type Repository_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - ctx context.Context -// - pType string -// - urn string +// - ctx context.Context +// - pType string +// - urn string func (_e *Repository_Expecter) GetOne(ctx interface{}, pType interface{}, urn interface{}) *Repository_GetOne_Call { return &Repository_GetOne_Call{Call: _e.mock.On("GetOne", ctx, pType, urn)} } @@ -239,11 +268,20 @@ func (_c *Repository_GetOne_Call) Return(_a0 *domain.Provider, _a1 error) *Repos return _c } +func (_c *Repository_GetOne_Call) RunAndReturn(run func(context.Context, string, string) (*domain.Provider, error)) *Repository_GetOne_Call { + _c.Call.Return(run) + return _c +} + // GetTypes provides a mock function with given fields: _a0 func (_m *Repository) GetTypes(_a0 context.Context) ([]domain.ProviderType, error) { ret := _m.Called(_a0) var r0 []domain.ProviderType + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]domain.ProviderType, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []domain.ProviderType); ok { r0 = rf(_a0) } else { @@ -252,7 +290,6 @@ func (_m *Repository) GetTypes(_a0 context.Context) ([]domain.ProviderType, erro } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -268,7 +305,7 @@ type Repository_GetTypes_Call struct { } // GetTypes is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *Repository_Expecter) GetTypes(_a0 interface{}) *Repository_GetTypes_Call { return &Repository_GetTypes_Call{Call: _e.mock.On("GetTypes", _a0)} } @@ -285,6 +322,11 @@ func (_c *Repository_GetTypes_Call) Return(_a0 []domain.ProviderType, _a1 error) return _c } +func (_c *Repository_GetTypes_Call) RunAndReturn(run func(context.Context) ([]domain.ProviderType, error)) *Repository_GetTypes_Call { + _c.Call.Return(run) + return _c +} + // Update provides a mock function with given fields: _a0, _a1 func (_m *Repository) Update(_a0 context.Context, _a1 *domain.Provider) error { ret := _m.Called(_a0, _a1) @@ -305,8 +347,8 @@ type Repository_Update_Call struct { } // Update is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Provider +// - _a0 context.Context +// - _a1 *domain.Provider func (_e *Repository_Expecter) Update(_a0 interface{}, _a1 interface{}) *Repository_Update_Call { return &Repository_Update_Call{Call: _e.mock.On("Update", _a0, _a1)} } @@ -322,3 +364,23 @@ func (_c *Repository_Update_Call) Return(_a0 error) *Repository_Update_Call { _c.Call.Return(_a0) return _c } + +func (_c *Repository_Update_Call) RunAndReturn(run func(context.Context, *domain.Provider) error) *Repository_Update_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewRepository interface { + mock.TestingT + Cleanup(func()) +} + +// NewRepository creates a new instance of Repository. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewRepository(t mockConstructorTestingTNewRepository) *Repository { + mock := &Repository{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/provider/mocks/resourceService.go b/core/provider/mocks/resourceService.go index 162fe14c3..c4c76ae0a 100644 --- a/core/provider/mocks/resourceService.go +++ b/core/provider/mocks/resourceService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type ResourceService_BatchDelete_Call struct { } // BatchDelete is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []string +// - _a0 context.Context +// - _a1 []string func (_e *ResourceService_Expecter) BatchDelete(_a0 interface{}, _a1 interface{}) *ResourceService_BatchDelete_Call { return &ResourceService_BatchDelete_Call{Call: _e.mock.On("BatchDelete", _a0, _a1)} } @@ -60,6 +60,11 @@ func (_c *ResourceService_BatchDelete_Call) Return(_a0 error) *ResourceService_B return _c } +func (_c *ResourceService_BatchDelete_Call) RunAndReturn(run func(context.Context, []string) error) *ResourceService_BatchDelete_Call { + _c.Call.Return(run) + return _c +} + // BulkUpsert provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) BulkUpsert(_a0 context.Context, _a1 []*domain.Resource) error { ret := _m.Called(_a0, _a1) @@ -80,8 +85,8 @@ type ResourceService_BulkUpsert_Call struct { } // BulkUpsert is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Resource +// - _a0 context.Context +// - _a1 []*domain.Resource func (_e *ResourceService_Expecter) BulkUpsert(_a0 interface{}, _a1 interface{}) *ResourceService_BulkUpsert_Call { return &ResourceService_BulkUpsert_Call{Call: _e.mock.On("BulkUpsert", _a0, _a1)} } @@ -98,11 +103,20 @@ func (_c *ResourceService_BulkUpsert_Call) Return(_a0 error) *ResourceService_Bu return _c } +func (_c *ResourceService_BulkUpsert_Call) RunAndReturn(run func(context.Context, []*domain.Resource) error) *ResourceService_BulkUpsert_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0, _a1 func (_m *ResourceService) Find(_a0 context.Context, _a1 domain.ListResourcesFilter) ([]*domain.Resource, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) []*domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -111,7 +125,6 @@ func (_m *ResourceService) Find(_a0 context.Context, _a1 domain.ListResourcesFil } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListResourcesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -127,8 +140,8 @@ type ResourceService_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListResourcesFilter +// - _a0 context.Context +// - _a1 domain.ListResourcesFilter func (_e *ResourceService_Expecter) Find(_a0 interface{}, _a1 interface{}) *ResourceService_Find_Call { return &ResourceService_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -144,3 +157,23 @@ func (_c *ResourceService_Find_Call) Return(_a0 []*domain.Resource, _a1 error) * _c.Call.Return(_a0, _a1) return _c } + +func (_c *ResourceService_Find_Call) RunAndReturn(run func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)) *ResourceService_Find_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewResourceService interface { + mock.TestingT + Cleanup(func()) +} + +// NewResourceService creates a new instance of ResourceService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewResourceService(t mockConstructorTestingTNewResourceService) *ResourceService { + mock := &ResourceService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/provider/service.go b/core/provider/service.go index 0fc5f2a99..5ef193c45 100644 --- a/core/provider/service.go +++ b/core/provider/service.go @@ -60,6 +60,11 @@ type auditLogger interface { Log(ctx context.Context, action string, data interface{}) error } +//go:generate mockery --name=encryptor --exported --with-expecter +type encryptor interface { + domain.Crypto +} + // Service handling the business logics type Service struct { repository repository @@ -67,6 +72,7 @@ type Service struct { clients map[string]Client validator *validator.Validate + encryptor encryptor logger log.Logger auditLogger auditLogger } @@ -77,6 +83,7 @@ type ServiceDeps struct { Clients []Client Validator *validator.Validate + Encryptor encryptor Logger log.Logger AuditLogger auditLogger } @@ -94,6 +101,7 @@ func NewService(deps ServiceDeps) *Service { mapProviderClients, deps.Validator, + deps.Encryptor, deps.Logger, deps.AuditLogger, } @@ -120,9 +128,11 @@ func (s *Service) Create(ctx context.Context, p *domain.Provider) error { if err := c.CreateConfig(p.Config); err != nil { return err } + if err := p.Config.EncryptCredentials(s.encryptor); err != nil { + return fmt.Errorf("encrypting credentials: %w", err) + } dryRun := isDryRun(ctx) - if !dryRun { if err := s.repository.Create(ctx, p); err != nil { return err @@ -136,6 +146,10 @@ func (s *Service) Create(ctx context.Context, p *domain.Provider) error { go func() { s.logger.Info("provider create fetching resources", "provider_urn", p.URN) ctx := audit.WithActor(context.Background(), domain.SystemActorName) + if err := p.Config.DecryptCredentials(s.encryptor); err != nil { + s.logger.Error("failed to decrypt credentials", "error", err) + return + } resources, err := s.getResources(ctx, p) if err != nil { s.logger.Error("failed to fetch resources", "error", err) @@ -198,9 +212,11 @@ func (s *Service) Update(ctx context.Context, p *domain.Provider) error { if err := c.CreateConfig(p.Config); err != nil { return err } + if err := p.Config.EncryptCredentials(s.encryptor); err != nil { + return fmt.Errorf("encrypting credentials: %w", err) + } dryRun := isDryRun(ctx) - if !dryRun { if err := s.repository.Update(ctx, p); err != nil { return err @@ -214,6 +230,10 @@ func (s *Service) Update(ctx context.Context, p *domain.Provider) error { go func() { s.logger.Info("provider update fetching resources", "provider_urn", p.URN) ctx := audit.WithActor(context.Background(), domain.SystemActorName) + if err := p.Config.DecryptCredentials(s.encryptor); err != nil { + s.logger.Error("failed to decrypt credentials", "error", err) + return + } resources, err := s.getResources(ctx, p) if err != nil { s.logger.Error("failed to fetch resources", "error", err) @@ -241,6 +261,7 @@ func (s *Service) FetchResources(ctx context.Context) error { failedProviders := make([]string, 0) for _, p := range providers { s.logger.Info("fetching resources", "provider_urn", p.URN) + // TODO: decrypt credentials resources, err := s.getResources(ctx, p) if err != nil { s.logger.Error("failed to get resources", "error", err) @@ -393,6 +414,9 @@ func (s *Service) GrantAccess(ctx context.Context, a domain.Grant) error { if err != nil { return err } + if err := p.Config.DecryptCredentials(s.encryptor); err != nil { + return fmt.Errorf("decrypting credentials: %w", err) + } return c.GrantAccess(p.Config, a) } @@ -411,6 +435,9 @@ func (s *Service) RevokeAccess(ctx context.Context, a domain.Grant) error { if err != nil { return err } + if err := p.Config.DecryptCredentials(s.encryptor); err != nil { + return fmt.Errorf("decrypting credentials: %w", err) + } return c.RevokeAccess(p.Config, a) } @@ -450,6 +477,9 @@ func (s *Service) Delete(ctx context.Context, id string) error { func (s *Service) ListAccess(ctx context.Context, p domain.Provider, resources []*domain.Resource) (domain.MapResourceAccess, error) { c := s.getClient(p.Type) + if err := p.Config.DecryptCredentials(s.encryptor); err != nil { + return nil, fmt.Errorf("decrypting credentials: %w", err) + } providerAccesses, err := c.ListAccess(ctx, *p.Config, resources) if err != nil { return nil, err @@ -490,6 +520,9 @@ func (s *Service) ImportActivities(ctx context.Context, filter domain.ImportActi return nil, fmt.Errorf("populating resources: %w", err) } + if err := p.Config.DecryptCredentials(s.encryptor); err != nil { + return nil, fmt.Errorf("decrypting credentials: %w", err) + } activities, err := activityClient.GetActivities(ctx, *p, filter) if err != nil { return nil, fmt.Errorf("getting activities: %w", err) diff --git a/core/provider/service_test.go b/core/provider/service_test.go index 6be24ba5b..ca8e20686 100644 --- a/core/provider/service_test.go +++ b/core/provider/service_test.go @@ -29,6 +29,7 @@ type ServiceTestSuite struct { mockResourceService *providermocks.ResourceService mockProvider *providermocks.Client mockAuditLogger *providermocks.AuditLogger + mockEncryptor *providermocks.Encryptor service *provider.Service } @@ -39,6 +40,7 @@ func (s *ServiceTestSuite) SetupTest() { s.mockResourceService = new(providermocks.ResourceService) s.mockProvider = new(providermocks.Client) s.mockAuditLogger = new(providermocks.AuditLogger) + s.mockEncryptor = new(providermocks.Encryptor) s.mockProvider.On("GetType").Return(mockProviderType).Once() s.service = provider.NewService(provider.ServiceDeps{ @@ -48,6 +50,7 @@ func (s *ServiceTestSuite) SetupTest() { Validator: validator, Logger: logger, AuditLogger: s.mockAuditLogger, + Encryptor: s.mockEncryptor, }) } @@ -113,6 +116,7 @@ func (s *ServiceTestSuite) TestCreate() { s.Run("should return error if got error from the provider repository", func() { expectedError := errors.New("error from repository") s.mockProvider.On("GetAccountTypes").Return([]string{"user"}).Once() + s.mockEncryptor.EXPECT().Encrypt(mock.Anything).Return("encrypted-creds", nil).Once() s.mockProvider.On("CreateConfig", mock.Anything).Return(nil).Once() s.mockProviderRepository.EXPECT().Create(mock.AnythingOfType("*context.emptyCtx"), mock.Anything).Return(expectedError).Once() @@ -123,6 +127,7 @@ func (s *ServiceTestSuite) TestCreate() { s.Run("should pass the model from the param and trigger fetch resources on success", func() { s.mockProvider.On("GetAccountTypes").Return([]string{"user"}).Once() + s.mockEncryptor.EXPECT().Encrypt(mock.Anything).Return("encrypted-creds", nil).Once() s.mockProvider.On("CreateConfig", mock.Anything).Return(nil).Once() s.mockProviderRepository.EXPECT().Create(mock.AnythingOfType("*context.emptyCtx"), p).Return(nil).Once() s.mockAuditLogger.On("Log", mock.Anything, provider.AuditKeyCreate, mock.Anything).Return(nil).Once() @@ -132,6 +137,7 @@ func (s *ServiceTestSuite) TestCreate() { ProviderType: p.Type, ProviderURN: p.URN, }).Return([]*domain.Resource{}, nil).Once() + s.mockEncryptor.EXPECT().Decrypt(mock.Anything).Return("{}", nil).Once() s.mockProvider.On("GetResources", p.Config).Return(expectedResources, nil).Once() s.mockResourceService.On("BulkUpsert", mock.Anything, expectedResources).Return(nil).Once() @@ -235,7 +241,6 @@ func (s *ServiceTestSuite) TestUpdate() { s.Run("should update record on success", func() { testCases := []struct { updatePayload *domain.Provider - existingProvider *domain.Provider expectedNewProvider *domain.Provider }{ { @@ -253,6 +258,9 @@ func (s *ServiceTestSuite) TestUpdate() { }, Type: mockProviderType, URN: "urn", + Credentials: map[string]interface{}{ + "foo": "bar", + }, }, }, expectedNewProvider: &domain.Provider{ @@ -267,8 +275,9 @@ func (s *ServiceTestSuite) TestUpdate() { Labels: map[string]string{ "foo": "bar", }, - Type: mockProviderType, - URN: "urn", + Type: mockProviderType, + URN: "urn", + Credentials: "encrypted-creds", }, }, }, @@ -276,6 +285,7 @@ func (s *ServiceTestSuite) TestUpdate() { for _, tc := range testCases { s.mockProvider.On("GetAccountTypes").Return([]string{"user"}).Once() + s.mockEncryptor.EXPECT().Encrypt(`{"foo":"bar"}`).Return("encrypted-creds", nil).Once() s.mockProvider.On("CreateConfig", mock.Anything).Return(nil).Once() s.mockProviderRepository.EXPECT().Update(mock.AnythingOfType("*context.emptyCtx"), tc.expectedNewProvider).Return(nil) s.mockAuditLogger.On("Log", mock.Anything, provider.AuditKeyUpdate, mock.Anything).Return(nil).Once() @@ -285,6 +295,7 @@ func (s *ServiceTestSuite) TestUpdate() { ProviderType: tc.updatePayload.Type, ProviderURN: tc.updatePayload.URN, }).Return([]*domain.Resource{}, nil).Once() + s.mockEncryptor.EXPECT().Decrypt("encrypted-creds").Return(`{"foo":"bar"}`, nil).Once() s.mockProvider.On("GetResources", tc.updatePayload.Config).Return(expectedResources, nil).Once() s.mockResourceService.On("BulkUpsert", mock.Anything, expectedResources).Return(nil).Once() @@ -596,12 +607,15 @@ func (s *ServiceTestSuite) TestGrantAccess() { s.Run("should grant access to the provider on success", func() { provider := &domain.Provider{ - Config: &domain.ProviderConfig{}, + Config: &domain.ProviderConfig{ + Credentials: "encrypted-credentials", + }, } s.mockProviderRepository. EXPECT().GetOne(mock.AnythingOfType("*context.emptyCtx"), validAppeal.Resource.ProviderType, validAppeal.Resource.ProviderURN). Return(provider, nil). Once() + s.mockEncryptor.EXPECT().Decrypt("encrypted-credentials").Return("{}", nil).Once() s.mockProvider. On("GrantAccess", provider.Config, validAppeal). Return(nil). @@ -690,12 +704,15 @@ func (s *ServiceTestSuite) TestRevokeAccess() { s.Run("should grant access to the provider on success", func() { provider := &domain.Provider{ - Config: &domain.ProviderConfig{}, + Config: &domain.ProviderConfig{ + Credentials: "encrypted-credentials", + }, } s.mockProviderRepository. EXPECT().GetOne(mock.AnythingOfType("*context.emptyCtx"), validAppeal.Resource.ProviderType, validAppeal.Resource.ProviderURN). Return(provider, nil). Once() + s.mockEncryptor.EXPECT().Decrypt("encrypted-credentials").Return("{}", nil).Once() s.mockProvider. On("RevokeAccess", provider.Config, validAppeal). Return(nil). diff --git a/core/resource/mocks/auditLogger.go b/core/resource/mocks/auditLogger.go index 421d831ee..5c791a405 100644 --- a/core/resource/mocks/auditLogger.go +++ b/core/resource/mocks/auditLogger.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -41,9 +41,9 @@ type AuditLogger_Log_Call struct { } // Log is a helper method to define mock.On call -// - ctx context.Context -// - action string -// - data interface{} +// - ctx context.Context +// - action string +// - data interface{} func (_e *AuditLogger_Expecter) Log(ctx interface{}, action interface{}, data interface{}) *AuditLogger_Log_Call { return &AuditLogger_Log_Call{Call: _e.mock.On("Log", ctx, action, data)} } @@ -59,3 +59,23 @@ func (_c *AuditLogger_Log_Call) Return(_a0 error) *AuditLogger_Log_Call { _c.Call.Return(_a0) return _c } + +func (_c *AuditLogger_Log_Call) RunAndReturn(run func(context.Context, string, interface{}) error) *AuditLogger_Log_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewAuditLogger interface { + mock.TestingT + Cleanup(func()) +} + +// NewAuditLogger creates a new instance of AuditLogger. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewAuditLogger(t mockConstructorTestingTNewAuditLogger) *AuditLogger { + mock := &AuditLogger{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/core/resource/mocks/repository.go b/core/resource/mocks/repository.go index 42f5c8ecd..eb85d962f 100644 --- a/core/resource/mocks/repository.go +++ b/core/resource/mocks/repository.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -42,8 +42,8 @@ type Repository_BatchDelete_Call struct { } // BatchDelete is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []string +// - _a0 context.Context +// - _a1 []string func (_e *Repository_Expecter) BatchDelete(_a0 interface{}, _a1 interface{}) *Repository_BatchDelete_Call { return &Repository_BatchDelete_Call{Call: _e.mock.On("BatchDelete", _a0, _a1)} } @@ -60,6 +60,11 @@ func (_c *Repository_BatchDelete_Call) Return(_a0 error) *Repository_BatchDelete return _c } +func (_c *Repository_BatchDelete_Call) RunAndReturn(run func(context.Context, []string) error) *Repository_BatchDelete_Call { + _c.Call.Return(run) + return _c +} + // BulkUpsert provides a mock function with given fields: _a0, _a1 func (_m *Repository) BulkUpsert(_a0 context.Context, _a1 []*domain.Resource) error { ret := _m.Called(_a0, _a1) @@ -80,8 +85,8 @@ type Repository_BulkUpsert_Call struct { } // BulkUpsert is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 []*domain.Resource +// - _a0 context.Context +// - _a1 []*domain.Resource func (_e *Repository_Expecter) BulkUpsert(_a0 interface{}, _a1 interface{}) *Repository_BulkUpsert_Call { return &Repository_BulkUpsert_Call{Call: _e.mock.On("BulkUpsert", _a0, _a1)} } @@ -98,6 +103,11 @@ func (_c *Repository_BulkUpsert_Call) Return(_a0 error) *Repository_BulkUpsert_C return _c } +func (_c *Repository_BulkUpsert_Call) RunAndReturn(run func(context.Context, []*domain.Resource) error) *Repository_BulkUpsert_Call { + _c.Call.Return(run) + return _c +} + // Delete provides a mock function with given fields: ctx, id func (_m *Repository) Delete(ctx context.Context, id string) error { ret := _m.Called(ctx, id) @@ -118,8 +128,8 @@ type Repository_Delete_Call struct { } // Delete is a helper method to define mock.On call -// - ctx context.Context -// - id string +// - ctx context.Context +// - id string func (_e *Repository_Expecter) Delete(ctx interface{}, id interface{}) *Repository_Delete_Call { return &Repository_Delete_Call{Call: _e.mock.On("Delete", ctx, id)} } @@ -136,11 +146,20 @@ func (_c *Repository_Delete_Call) Return(_a0 error) *Repository_Delete_Call { return _c } +func (_c *Repository_Delete_Call) RunAndReturn(run func(context.Context, string) error) *Repository_Delete_Call { + _c.Call.Return(run) + return _c +} + // Find provides a mock function with given fields: _a0, _a1 func (_m *Repository) Find(_a0 context.Context, _a1 domain.ListResourcesFilter) ([]*domain.Resource, error) { ret := _m.Called(_a0, _a1) var r0 []*domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListResourcesFilter) []*domain.Resource); ok { r0 = rf(_a0, _a1) } else { @@ -149,7 +168,6 @@ func (_m *Repository) Find(_a0 context.Context, _a1 domain.ListResourcesFilter) } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListResourcesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -165,8 +183,8 @@ type Repository_Find_Call struct { } // Find is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 domain.ListResourcesFilter +// - _a0 context.Context +// - _a1 domain.ListResourcesFilter func (_e *Repository_Expecter) Find(_a0 interface{}, _a1 interface{}) *Repository_Find_Call { return &Repository_Find_Call{Call: _e.mock.On("Find", _a0, _a1)} } @@ -183,11 +201,20 @@ func (_c *Repository_Find_Call) Return(_a0 []*domain.Resource, _a1 error) *Repos return _c } +func (_c *Repository_Find_Call) RunAndReturn(run func(context.Context, domain.ListResourcesFilter) ([]*domain.Resource, error)) *Repository_Find_Call { + _c.Call.Return(run) + return _c +} + // GetOne provides a mock function with given fields: ctx, id func (_m *Repository) GetOne(ctx context.Context, id string) (*domain.Resource, error) { ret := _m.Called(ctx, id) var r0 *domain.Resource + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) (*domain.Resource, error)); ok { + return rf(ctx, id) + } if rf, ok := ret.Get(0).(func(context.Context, string) *domain.Resource); ok { r0 = rf(ctx, id) } else { @@ -196,7 +223,6 @@ func (_m *Repository) GetOne(ctx context.Context, id string) (*domain.Resource, } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(ctx, id) } else { @@ -212,8 +238,8 @@ type Repository_GetOne_Call struct { } // GetOne is a helper method to define mock.On call -// - ctx context.Context -// - id string +// - ctx context.Context +// - id string func (_e *Repository_Expecter) GetOne(ctx interface{}, id interface{}) *Repository_GetOne_Call { return &Repository_GetOne_Call{Call: _e.mock.On("GetOne", ctx, id)} } @@ -230,6 +256,11 @@ func (_c *Repository_GetOne_Call) Return(_a0 *domain.Resource, _a1 error) *Repos return _c } +func (_c *Repository_GetOne_Call) RunAndReturn(run func(context.Context, string) (*domain.Resource, error)) *Repository_GetOne_Call { + _c.Call.Return(run) + return _c +} + // Update provides a mock function with given fields: _a0, _a1 func (_m *Repository) Update(_a0 context.Context, _a1 *domain.Resource) error { ret := _m.Called(_a0, _a1) @@ -250,8 +281,8 @@ type Repository_Update_Call struct { } // Update is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 *domain.Resource +// - _a0 context.Context +// - _a1 *domain.Resource func (_e *Repository_Expecter) Update(_a0 interface{}, _a1 interface{}) *Repository_Update_Call { return &Repository_Update_Call{Call: _e.mock.On("Update", _a0, _a1)} } @@ -267,3 +298,23 @@ func (_c *Repository_Update_Call) Return(_a0 error) *Repository_Update_Call { _c.Call.Return(_a0) return _c } + +func (_c *Repository_Update_Call) RunAndReturn(run func(context.Context, *domain.Resource) error) *Repository_Update_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewRepository interface { + mock.TestingT + Cleanup(func()) +} + +// NewRepository creates a new instance of Repository. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewRepository(t mockConstructorTestingTNewRepository) *Repository { + mock := &Repository{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/domain/encryption.go b/domain/encryption.go index 0bc66e14f..0e9b3ef9b 100644 --- a/domain/encryption.go +++ b/domain/encryption.go @@ -1,11 +1,15 @@ package domain // Encryptor does encrypt a plain text into an encrypted text +// +//go:generate mockery --name=Encryptor --exported --with-expecter type Encryptor interface { Encrypt(string) (string, error) } // Decryptor does decrypt an encrypted text into a plain text +// +//go:generate mockery --name=Decryptor --exported --with-expecter type Decryptor interface { Decrypt(string) (string, error) } diff --git a/domain/mocks/Decryptor.go b/domain/mocks/Decryptor.go new file mode 100644 index 000000000..665721e8f --- /dev/null +++ b/domain/mocks/Decryptor.go @@ -0,0 +1,85 @@ +// Code generated by mockery v2.20.0. DO NOT EDIT. + +package mocks + +import mock "github.com/stretchr/testify/mock" + +// Decryptor is an autogenerated mock type for the Decryptor type +type Decryptor struct { + mock.Mock +} + +type Decryptor_Expecter struct { + mock *mock.Mock +} + +func (_m *Decryptor) EXPECT() *Decryptor_Expecter { + return &Decryptor_Expecter{mock: &_m.Mock} +} + +// Decrypt provides a mock function with given fields: _a0 +func (_m *Decryptor) Decrypt(_a0 string) (string, error) { + ret := _m.Called(_a0) + + var r0 string + var r1 error + if rf, ok := ret.Get(0).(func(string) (string, error)); ok { + return rf(_a0) + } + if rf, ok := ret.Get(0).(func(string) string); ok { + r0 = rf(_a0) + } else { + r0 = ret.Get(0).(string) + } + + if rf, ok := ret.Get(1).(func(string) error); ok { + r1 = rf(_a0) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + +// Decryptor_Decrypt_Call is a *mock.Call that shadows Run/Return methods with type explicit version for method 'Decrypt' +type Decryptor_Decrypt_Call struct { + *mock.Call +} + +// Decrypt is a helper method to define mock.On call +// - _a0 string +func (_e *Decryptor_Expecter) Decrypt(_a0 interface{}) *Decryptor_Decrypt_Call { + return &Decryptor_Decrypt_Call{Call: _e.mock.On("Decrypt", _a0)} +} + +func (_c *Decryptor_Decrypt_Call) Run(run func(_a0 string)) *Decryptor_Decrypt_Call { + _c.Call.Run(func(args mock.Arguments) { + run(args[0].(string)) + }) + return _c +} + +func (_c *Decryptor_Decrypt_Call) Return(_a0 string, _a1 error) *Decryptor_Decrypt_Call { + _c.Call.Return(_a0, _a1) + return _c +} + +func (_c *Decryptor_Decrypt_Call) RunAndReturn(run func(string) (string, error)) *Decryptor_Decrypt_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewDecryptor interface { + mock.TestingT + Cleanup(func()) +} + +// NewDecryptor creates a new instance of Decryptor. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewDecryptor(t mockConstructorTestingTNewDecryptor) *Decryptor { + mock := &Decryptor{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/plugins/providers/dataplex/mocks/encryptor.go b/domain/mocks/Encryptor.go similarity index 53% rename from plugins/providers/dataplex/mocks/encryptor.go rename to domain/mocks/Encryptor.go index d2f02f428..9211ab9a7 100644 --- a/plugins/providers/dataplex/mocks/encryptor.go +++ b/domain/mocks/Encryptor.go @@ -1,10 +1,10 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks import mock "github.com/stretchr/testify/mock" -// Encryptor is an autogenerated mock type for the encryptor type +// Encryptor is an autogenerated mock type for the Encryptor type type Encryptor struct { mock.Mock } @@ -17,62 +17,21 @@ func (_m *Encryptor) EXPECT() *Encryptor_Expecter { return &Encryptor_Expecter{mock: &_m.Mock} } -// Decrypt provides a mock function with given fields: _a0 -func (_m *Encryptor) Decrypt(_a0 string) (string, error) { - ret := _m.Called(_a0) - - var r0 string - if rf, ok := ret.Get(0).(func(string) string); ok { - r0 = rf(_a0) - } else { - r0 = ret.Get(0).(string) - } - - var r1 error - if rf, ok := ret.Get(1).(func(string) error); ok { - r1 = rf(_a0) - } else { - r1 = ret.Error(1) - } - - return r0, r1 -} - -// Encryptor_Decrypt_Call is a *mock.Call that shadows Run/Return methods with type explicit version for method 'Decrypt' -type Encryptor_Decrypt_Call struct { - *mock.Call -} - -// Decrypt is a helper method to define mock.On call -// - _a0 string -func (_e *Encryptor_Expecter) Decrypt(_a0 interface{}) *Encryptor_Decrypt_Call { - return &Encryptor_Decrypt_Call{Call: _e.mock.On("Decrypt", _a0)} -} - -func (_c *Encryptor_Decrypt_Call) Run(run func(_a0 string)) *Encryptor_Decrypt_Call { - _c.Call.Run(func(args mock.Arguments) { - run(args[0].(string)) - }) - return _c -} - -func (_c *Encryptor_Decrypt_Call) Return(_a0 string, _a1 error) *Encryptor_Decrypt_Call { - _c.Call.Return(_a0, _a1) - return _c -} - // Encrypt provides a mock function with given fields: _a0 func (_m *Encryptor) Encrypt(_a0 string) (string, error) { ret := _m.Called(_a0) var r0 string + var r1 error + if rf, ok := ret.Get(0).(func(string) (string, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(string) string); ok { r0 = rf(_a0) } else { r0 = ret.Get(0).(string) } - var r1 error if rf, ok := ret.Get(1).(func(string) error); ok { r1 = rf(_a0) } else { @@ -88,7 +47,7 @@ type Encryptor_Encrypt_Call struct { } // Encrypt is a helper method to define mock.On call -// - _a0 string +// - _a0 string func (_e *Encryptor_Expecter) Encrypt(_a0 interface{}) *Encryptor_Encrypt_Call { return &Encryptor_Encrypt_Call{Call: _e.mock.On("Encrypt", _a0)} } @@ -103,4 +62,24 @@ func (_c *Encryptor_Encrypt_Call) Run(run func(_a0 string)) *Encryptor_Encrypt_C func (_c *Encryptor_Encrypt_Call) Return(_a0 string, _a1 error) *Encryptor_Encrypt_Call { _c.Call.Return(_a0, _a1) return _c -} \ No newline at end of file +} + +func (_c *Encryptor_Encrypt_Call) RunAndReturn(run func(string) (string, error)) *Encryptor_Encrypt_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewEncryptor interface { + mock.TestingT + Cleanup(func()) +} + +// NewEncryptor creates a new instance of Encryptor. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewEncryptor(t mockConstructorTestingTNewEncryptor) *Encryptor { + mock := &Encryptor{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/domain/provider.go b/domain/provider.go index 1890800e4..0d596f4e3 100644 --- a/domain/provider.go +++ b/domain/provider.go @@ -1,6 +1,7 @@ package domain import ( + "encoding/json" "fmt" "sort" "time" @@ -71,12 +72,52 @@ type ProviderConfig struct { URN string `json:"urn" yaml:"urn" validate:"required"` AllowedAccountTypes []string `json:"allowed_account_types" yaml:"allowed_account_types" validate:"omitempty,min=1"` Labels map[string]string `json:"labels,omitempty" yaml:"labels,omitempty"` - Credentials interface{} `json:"credentials,omitempty" yaml:"credentials" validate:"required"` + Credentials interface{} `json:"credentials,omitempty" yaml:"credentials,omitempty" validate:"required"` Appeal *AppealConfig `json:"appeal,omitempty" yaml:"appeal,omitempty" validate:"required"` Resources []*ResourceConfig `json:"resources" yaml:"resources" validate:"required"` Parameters []*ProviderParameter `json:"parameters,omitempty" yaml:"parameters,omitempty"` } +func (pc *ProviderConfig) EncryptCredentials(encryptor Encryptor) error { + if pc.Credentials == nil { + return nil + } + + serializedCreds, err := json.Marshal(pc.Credentials) + if err != nil { + return fmt.Errorf("serializing credentials: %w", err) + } + + encryptedCreds, err := encryptor.Encrypt(string(serializedCreds)) + if err != nil { + return err + } + pc.Credentials = encryptedCreds + return nil +} + +func (pc *ProviderConfig) DecryptCredentials(decryptor Decryptor) error { + if pc.Credentials == nil { + return nil + } + encryptedCreds, ok := pc.Credentials.(string) + if !ok { + return fmt.Errorf("invalid credentials type: %T", pc.Credentials) + } + + decryptedCreds, err := decryptor.Decrypt(encryptedCreds) + if err != nil { + return err + } + + var creds interface{} + if err := json.Unmarshal([]byte(decryptedCreds), &creds); err != nil { + return fmt.Errorf("unmarshalling credentials: %w", err) + } + pc.Credentials = creds + return nil +} + type ProviderParameter struct { Key string `json:"key" yaml:"key" validate:"required"` Label string `json:"label" yaml:"label" validate:"required"` diff --git a/domain/provider_test.go b/domain/provider_test.go new file mode 100644 index 000000000..3b7cc30eb --- /dev/null +++ b/domain/provider_test.go @@ -0,0 +1,112 @@ +package domain + +import ( + "testing" + + "github.com/goto/guardian/domain/mocks" + "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/mock" +) + +func TestEncryptCredentials(t *testing.T) { + t.Run("should encrypt credentials", func(t *testing.T) { + mockEncryptor := new(mocks.Encryptor) + mockEncryptor.EXPECT().Encrypt(`{"foo":"bar"}`).Return("encrypted", nil).Times(1) + + pc := &ProviderConfig{ + Credentials: map[string]interface{}{"foo": "bar"}, + } + err := pc.EncryptCredentials(mockEncryptor) + + assert.NoError(t, err) + assert.Equal(t, "encrypted", pc.Credentials) + }) + + t.Run("should return nil if credentials is nil", func(t *testing.T) { + pc := &ProviderConfig{} + err := pc.EncryptCredentials(nil) + + assert.NoError(t, err) + assert.Nil(t, pc.Credentials) + }) + + t.Run("should return error if credentials are not serializable", func(t *testing.T) { + pc := &ProviderConfig{ + Credentials: make(chan int), + } + err := pc.EncryptCredentials(nil) + + assert.Error(t, err) + }) + + t.Run("should return error if encryptor fails", func(t *testing.T) { + mockEncryptor := new(mocks.Encryptor) + mockEncryptor.EXPECT().Encrypt(mock.AnythingOfType("string")).Return("", assert.AnError).Times(1) + + creds := map[string]interface{}{"foo": "bar"} + pc := &ProviderConfig{ + Credentials: creds, + } + err := pc.EncryptCredentials(mockEncryptor) + + assert.Error(t, err) + assert.Equal(t, creds, pc.Credentials) + }) +} + +func TestDecryptCredentials(t *testing.T) { + t.Run("should decrypt credentials", func(t *testing.T) { + mockDecryptor := new(mocks.Decryptor) + mockDecryptor.EXPECT().Decrypt("encrypted").Return(`{"foo":"bar"}`, nil).Times(1) + + pc := &ProviderConfig{ + Credentials: "encrypted", + } + err := pc.DecryptCredentials(mockDecryptor) + + assert.NoError(t, err) + assert.Equal(t, map[string]interface{}{"foo": "bar"}, pc.Credentials) + }) + + t.Run("should return nil if credentials is nil", func(t *testing.T) { + pc := &ProviderConfig{} + err := pc.DecryptCredentials(nil) + + assert.NoError(t, err) + assert.Nil(t, pc.Credentials) + }) + + t.Run("should return error if credentials is not a string", func(t *testing.T) { + pc := &ProviderConfig{ + Credentials: 1, + } + err := pc.DecryptCredentials(nil) + + assert.Error(t, err) + }) + + t.Run("should return error if decryptor fails", func(t *testing.T) { + mockDecryptor := new(mocks.Decryptor) + mockDecryptor.EXPECT().Decrypt(mock.AnythingOfType("string")).Return("", assert.AnError).Times(1) + + pc := &ProviderConfig{ + Credentials: "encrypted", + } + err := pc.DecryptCredentials(mockDecryptor) + + assert.Error(t, err) + assert.Equal(t, "encrypted", pc.Credentials) + }) + + t.Run("should return error if credentials are not deserializable", func(t *testing.T) { + mockDecryptor := new(mocks.Decryptor) + mockDecryptor.EXPECT().Decrypt(mock.AnythingOfType("string")).Return(`invalid json`, nil).Times(1) + + pc := &ProviderConfig{ + Credentials: "encrypted", + } + err := pc.DecryptCredentials(mockDecryptor) + + assert.Error(t, err) + }) +} diff --git a/internal/server/services.go b/internal/server/services.go index 2ee12be3b..761d65145 100644 --- a/internal/server/services.go +++ b/internal/server/services.go @@ -103,14 +103,14 @@ func InitServices(deps ServiceDeps) (*Services, error) { grantRepository := postgres.NewGrantRepository(store.DB()) providerClients := []provider.Client{ - bigquery.NewProvider(domain.ProviderTypeBigQuery, deps.Crypto, deps.Logger), - metabase.NewProvider(domain.ProviderTypeMetabase, deps.Crypto, deps.Logger), - grafana.NewProvider(domain.ProviderTypeGrafana, deps.Crypto), + bigquery.NewProvider(domain.ProviderTypeBigQuery, deps.Logger), + metabase.NewProvider(domain.ProviderTypeMetabase, deps.Logger), + grafana.NewProvider(domain.ProviderTypeGrafana), tableau.NewProvider(domain.ProviderTypeTableau, deps.Crypto), - gcloudiam.NewProvider(domain.ProviderTypeGCloudIAM, deps.Crypto), + gcloudiam.NewProvider(domain.ProviderTypeGCloudIAM), noop.NewProvider(domain.ProviderTypeNoOp, deps.Logger), - gcs.NewProvider(domain.ProviderTypeGCS, deps.Crypto), - dataplex.NewProvider(domain.ProviderTypePolicyTag, deps.Crypto), + gcs.NewProvider(domain.ProviderTypeGCS), + dataplex.NewProvider(domain.ProviderTypePolicyTag), shield.NewProvider(domain.ProviderTypeShield, deps.Logger), } @@ -126,6 +126,7 @@ func InitServices(deps ServiceDeps) (*Services, error) { ResourceService: resourceService, Clients: providerClients, Validator: deps.Validator, + Encryptor: deps.Crypto, Logger: deps.Logger, AuditLogger: auditLogger, }) diff --git a/internal/store/postgres/migrations/000015_migrate_provider_credentials.down.sql b/internal/store/postgres/migrations/000015_migrate_provider_credentials.down.sql new file mode 100644 index 000000000..e69de29bb diff --git a/internal/store/postgres/migrations/000015_migrate_provider_credentials.up.sql b/internal/store/postgres/migrations/000015_migrate_provider_credentials.up.sql new file mode 100644 index 000000000..e69de29bb diff --git a/jobs/mocks/grantService.go b/jobs/mocks/grantService.go index 37bbef29b..7d933be09 100644 --- a/jobs/mocks/grantService.go +++ b/jobs/mocks/grantService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -21,6 +21,10 @@ func (_m *GrantService) List(_a0 context.Context, _a1 domain.ListGrantsFilter) ( ret := _m.Called(_a0, _a1) var r0 []domain.Grant + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, domain.ListGrantsFilter) ([]domain.Grant, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, domain.ListGrantsFilter) []domain.Grant); ok { r0 = rf(_a0, _a1) } else { @@ -29,7 +33,6 @@ func (_m *GrantService) List(_a0 context.Context, _a1 domain.ListGrantsFilter) ( } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, domain.ListGrantsFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -51,6 +54,10 @@ func (_m *GrantService) Revoke(ctx context.Context, id string, actor string, rea ret := _m.Called(_ca...) var r0 *domain.Grant + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string, string, string, ...grant.Option) (*domain.Grant, error)); ok { + return rf(ctx, id, actor, reason, opts...) + } if rf, ok := ret.Get(0).(func(context.Context, string, string, string, ...grant.Option) *domain.Grant); ok { r0 = rf(ctx, id, actor, reason, opts...) } else { @@ -59,7 +66,6 @@ func (_m *GrantService) Revoke(ctx context.Context, id string, actor string, rea } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string, string, string, ...grant.Option) error); ok { r1 = rf(ctx, id, actor, reason, opts...) } else { @@ -68,3 +74,18 @@ func (_m *GrantService) Revoke(ctx context.Context, id string, actor string, rea return r0, r1 } + +type mockConstructorTestingTNewGrantService interface { + mock.TestingT + Cleanup(func()) +} + +// NewGrantService creates a new instance of GrantService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewGrantService(t mockConstructorTestingTNewGrantService) *GrantService { + mock := &GrantService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/jobs/mocks/providerService.go b/jobs/mocks/providerService.go index 422af48ee..91af7289c 100644 --- a/jobs/mocks/providerService.go +++ b/jobs/mocks/providerService.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -26,3 +26,18 @@ func (_m *ProviderService) FetchResources(_a0 context.Context) error { return r0 } + +type mockConstructorTestingTNewProviderService interface { + mock.TestingT + Cleanup(func()) +} + +// NewProviderService creates a new instance of ProviderService. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewProviderService(t mockConstructorTestingTNewProviderService) *ProviderService { + mock := &ProviderService{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/plugins/providers/bigquery/config.go b/plugins/providers/bigquery/config.go index de546b3c3..53d16a87b 100644 --- a/plugins/providers/bigquery/config.go +++ b/plugins/providers/bigquery/config.go @@ -28,50 +28,16 @@ type Credentials struct { ResourceName string `mapstructure:"resource_name" json:"resource_name" validate:"startswith=projects/"` } -// Encrypt encrypts BigQuery credentials -func (c *Credentials) Encrypt(encryptor domain.Encryptor) error { - if c == nil { - return ErrUnableToEncryptNilCredentials - } - - encryptedCredentials, err := encryptor.Encrypt(c.ServiceAccountKey) - if err != nil { - return err - } - - c.ServiceAccountKey = encryptedCredentials - return nil -} - -// Decrypt decrypts BigQuery credentials -func (c *Credentials) Decrypt(decryptor domain.Decryptor) error { - if c == nil { - return ErrUnableToDecryptNilCredentials - } - - decryptedCredentials, err := decryptor.Decrypt(c.ServiceAccountKey) - if err != nil { - return err - } - - c.ServiceAccountKey = decryptedCredentials - return nil -} - func (c Credentials) ProjectID() string { return strings.Replace(c.ResourceName, "projects/", "", 1) } -func ParseCredentials(v interface{}, decryptor domain.Decryptor) (*Credentials, error) { +func ParseCredentials(v interface{}) (*Credentials, error) { var credentials Credentials if err := mapstructure.Decode(v, &credentials); err != nil { return nil, err } - if err := credentials.Decrypt(decryptor); err != nil { - return nil, fmt.Errorf("decrypting credentials: %w", err) - } - return &credentials, nil } @@ -83,16 +49,14 @@ type Config struct { ProviderConfig *domain.ProviderConfig valid bool - crypto domain.Crypto validator *validator.Validate } // NewConfig returns bigquery config struct -func NewConfig(pc *domain.ProviderConfig, crypto domain.Crypto) *Config { +func NewConfig(pc *domain.ProviderConfig) *Config { return &Config{ ProviderConfig: pc, validator: validator.New(), - crypto: crypto, } } @@ -101,25 +65,6 @@ func (c *Config) ParseAndValidate() error { return c.parseAndValidate() } -// EncryptCredentials encrypts the bigquery credentials config -func (c *Config) EncryptCredentials() error { - if err := c.parseAndValidate(); err != nil { - return err - } - - credentials, ok := c.ProviderConfig.Credentials.(*Credentials) - if !ok { - return ErrInvalidCredentialsType - } - - if err := credentials.Encrypt(c.crypto); err != nil { - return err - } - - c.ProviderConfig.Credentials = credentials - return nil -} - func (c *Config) parseAndValidate() error { if c.valid { return nil diff --git a/plugins/providers/bigquery/config_test.go b/plugins/providers/bigquery/config_test.go index 840cfbd8f..25d12ab88 100644 --- a/plugins/providers/bigquery/config_test.go +++ b/plugins/providers/bigquery/config_test.go @@ -2,106 +2,19 @@ package bigquery_test import ( "encoding/base64" - "errors" "testing" "github.com/goto/guardian/domain" - "github.com/goto/guardian/mocks" "github.com/goto/guardian/plugins/providers/bigquery" "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/mock" ) -func TestCredentials(t *testing.T) { - encryptor := new(mocks.Encryptor) - decryptor := new(mocks.Decryptor) - - t.Run("encrypt", func(t *testing.T) { - t.Run("should return error if creds is nil", func(t *testing.T) { - var creds *bigquery.Credentials - expectedError := bigquery.ErrUnableToEncryptNilCredentials - - actualError := creds.Encrypt(encryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return error if encryptor failed to encrypt the creds", func(t *testing.T) { - creds := bigquery.Credentials{} - expectedError := errors.New("encryptor error") - encryptor.On("Encrypt", mock.Anything).Return("", expectedError).Once() - - actualError := creds.Encrypt(encryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return encrypted password inside Credentials on success", func(t *testing.T) { - service_account_key := base64.StdEncoding.EncodeToString([]byte("service-account-key-json")) - resourceName := "resource_name" - creds := bigquery.Credentials{ - ServiceAccountKey: service_account_key, - ResourceName: resourceName, - } - - expectedEncryptedServiceAccountKey := "encrypted_service_account_key" - encryptor.On("Encrypt", service_account_key).Return(expectedEncryptedServiceAccountKey, nil).Once() - - actualError := creds.Encrypt(encryptor) - - assert.Nil(t, actualError) - assert.Equal(t, expectedEncryptedServiceAccountKey, creds.ServiceAccountKey) - encryptor.AssertExpectations(t) - }) - }) - - t.Run("decrypt", func(t *testing.T) { - t.Run("should return error if creds is nil", func(t *testing.T) { - var creds *bigquery.Credentials - - expectedError := bigquery.ErrUnableToDecryptNilCredentials - - actualError := creds.Decrypt(decryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return error if decryptor failed to decrypt the creds", func(t *testing.T) { - creds := bigquery.Credentials{} - expectedError := errors.New("decryptor error") - decryptor.On("Decrypt", mock.Anything).Return("", expectedError).Once() - - actualError := creds.Decrypt(decryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return decrypted service account key on success", func(t *testing.T) { - service_account_key := base64.StdEncoding.EncodeToString([]byte("service-account-key-json")) - resourceName := "resource_name" - creds := bigquery.Credentials{ - ServiceAccountKey: service_account_key, - ResourceName: resourceName, - } - expectedDecryptedServiceAccountKey := "decrypted_service_account_key" - decryptor.On("Decrypt", service_account_key).Return(expectedDecryptedServiceAccountKey, nil).Once() - - actualError := creds.Decrypt(decryptor) - - assert.Nil(t, actualError) - assert.Equal(t, expectedDecryptedServiceAccountKey, creds.ServiceAccountKey) - decryptor.AssertExpectations(t) - }) - }) -} - func TestNewConfig(t *testing.T) { t.Run("should return bigquery config containing the same provider config", func(t *testing.T) { - mockCrypto := new(mocks.Crypto) pc := &domain.ProviderConfig{} expectedProviderConfig := pc - c := bigquery.NewConfig(pc, mockCrypto) + c := bigquery.NewConfig(pc) actualProviderConfig := c.ProviderConfig assert.NotNil(t, c) @@ -110,7 +23,6 @@ func TestNewConfig(t *testing.T) { } func TestValidate(t *testing.T) { - mockCrypto := new(mocks.Crypto) validCredentials := bigquery.Credentials{ ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte("service-account-key-json")), ResourceName: "projects/resource-name", @@ -161,9 +73,8 @@ func TestValidate(t *testing.T) { }, }, } - mockCrypto.On("Encrypt", mock.Anything).Return("", nil).Once() - err := bigquery.NewConfig(pc, mockCrypto).ParseAndValidate() + err := bigquery.NewConfig(pc).ParseAndValidate() assert.Error(t, err) }) } diff --git a/plugins/providers/bigquery/mocks/BigQueryClient.go b/plugins/providers/bigquery/mocks/BigQueryClient.go index cd5f2718a..bffd1a19a 100644 --- a/plugins/providers/bigquery/mocks/BigQueryClient.go +++ b/plugins/providers/bigquery/mocks/BigQueryClient.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -32,6 +32,10 @@ func (_m *BigQueryClient) GetDatasets(_a0 context.Context) ([]*bigquery.Dataset, ret := _m.Called(_a0) var r0 []*bigquery.Dataset + var r1 error + if rf, ok := ret.Get(0).(func(context.Context) ([]*bigquery.Dataset, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(context.Context) []*bigquery.Dataset); ok { r0 = rf(_a0) } else { @@ -40,7 +44,6 @@ func (_m *BigQueryClient) GetDatasets(_a0 context.Context) ([]*bigquery.Dataset, } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context) error); ok { r1 = rf(_a0) } else { @@ -56,7 +59,7 @@ type BigQueryClient_GetDatasets_Call struct { } // GetDatasets is a helper method to define mock.On call -// - _a0 context.Context +// - _a0 context.Context func (_e *BigQueryClient_Expecter) GetDatasets(_a0 interface{}) *BigQueryClient_GetDatasets_Call { return &BigQueryClient_GetDatasets_Call{Call: _e.mock.On("GetDatasets", _a0)} } @@ -73,11 +76,20 @@ func (_c *BigQueryClient_GetDatasets_Call) Return(_a0 []*bigquery.Dataset, _a1 e return _c } +func (_c *BigQueryClient_GetDatasets_Call) RunAndReturn(run func(context.Context) ([]*bigquery.Dataset, error)) *BigQueryClient_GetDatasets_Call { + _c.Call.Return(run) + return _c +} + // GetRolePermissions provides a mock function with given fields: _a0, _a1 func (_m *BigQueryClient) GetRolePermissions(_a0 context.Context, _a1 string) ([]string, error) { ret := _m.Called(_a0, _a1) var r0 []string + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) ([]string, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, string) []string); ok { r0 = rf(_a0, _a1) } else { @@ -86,7 +98,6 @@ func (_m *BigQueryClient) GetRolePermissions(_a0 context.Context, _a1 string) ([ } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(_a0, _a1) } else { @@ -102,8 +113,8 @@ type BigQueryClient_GetRolePermissions_Call struct { } // GetRolePermissions is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 string +// - _a0 context.Context +// - _a1 string func (_e *BigQueryClient_Expecter) GetRolePermissions(_a0 interface{}, _a1 interface{}) *BigQueryClient_GetRolePermissions_Call { return &BigQueryClient_GetRolePermissions_Call{Call: _e.mock.On("GetRolePermissions", _a0, _a1)} } @@ -120,11 +131,20 @@ func (_c *BigQueryClient_GetRolePermissions_Call) Return(_a0 []string, _a1 error return _c } +func (_c *BigQueryClient_GetRolePermissions_Call) RunAndReturn(run func(context.Context, string) ([]string, error)) *BigQueryClient_GetRolePermissions_Call { + _c.Call.Return(run) + return _c +} + // GetTables provides a mock function with given fields: ctx, datasetID func (_m *BigQueryClient) GetTables(ctx context.Context, datasetID string) ([]*bigquery.Table, error) { ret := _m.Called(ctx, datasetID) var r0 []*bigquery.Table + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, string) ([]*bigquery.Table, error)); ok { + return rf(ctx, datasetID) + } if rf, ok := ret.Get(0).(func(context.Context, string) []*bigquery.Table); ok { r0 = rf(ctx, datasetID) } else { @@ -133,7 +153,6 @@ func (_m *BigQueryClient) GetTables(ctx context.Context, datasetID string) ([]*b } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, string) error); ok { r1 = rf(ctx, datasetID) } else { @@ -149,8 +168,8 @@ type BigQueryClient_GetTables_Call struct { } // GetTables is a helper method to define mock.On call -// - ctx context.Context -// - datasetID string +// - ctx context.Context +// - datasetID string func (_e *BigQueryClient_Expecter) GetTables(ctx interface{}, datasetID interface{}) *BigQueryClient_GetTables_Call { return &BigQueryClient_GetTables_Call{Call: _e.mock.On("GetTables", ctx, datasetID)} } @@ -167,6 +186,11 @@ func (_c *BigQueryClient_GetTables_Call) Return(_a0 []*bigquery.Table, _a1 error return _c } +func (_c *BigQueryClient_GetTables_Call) RunAndReturn(run func(context.Context, string) ([]*bigquery.Table, error)) *BigQueryClient_GetTables_Call { + _c.Call.Return(run) + return _c +} + // GrantDatasetAccess provides a mock function with given fields: ctx, d, user, role func (_m *BigQueryClient) GrantDatasetAccess(ctx context.Context, d *bigquery.Dataset, user string, role string) error { ret := _m.Called(ctx, d, user, role) @@ -187,10 +211,10 @@ type BigQueryClient_GrantDatasetAccess_Call struct { } // GrantDatasetAccess is a helper method to define mock.On call -// - ctx context.Context -// - d *bigquery.Dataset -// - user string -// - role string +// - ctx context.Context +// - d *bigquery.Dataset +// - user string +// - role string func (_e *BigQueryClient_Expecter) GrantDatasetAccess(ctx interface{}, d interface{}, user interface{}, role interface{}) *BigQueryClient_GrantDatasetAccess_Call { return &BigQueryClient_GrantDatasetAccess_Call{Call: _e.mock.On("GrantDatasetAccess", ctx, d, user, role)} } @@ -207,6 +231,11 @@ func (_c *BigQueryClient_GrantDatasetAccess_Call) Return(_a0 error) *BigQueryCli return _c } +func (_c *BigQueryClient_GrantDatasetAccess_Call) RunAndReturn(run func(context.Context, *bigquery.Dataset, string, string) error) *BigQueryClient_GrantDatasetAccess_Call { + _c.Call.Return(run) + return _c +} + // GrantTableAccess provides a mock function with given fields: ctx, t, accountType, accountID, role func (_m *BigQueryClient) GrantTableAccess(ctx context.Context, t *bigquery.Table, accountType string, accountID string, role string) error { ret := _m.Called(ctx, t, accountType, accountID, role) @@ -227,11 +256,11 @@ type BigQueryClient_GrantTableAccess_Call struct { } // GrantTableAccess is a helper method to define mock.On call -// - ctx context.Context -// - t *bigquery.Table -// - accountType string -// - accountID string -// - role string +// - ctx context.Context +// - t *bigquery.Table +// - accountType string +// - accountID string +// - role string func (_e *BigQueryClient_Expecter) GrantTableAccess(ctx interface{}, t interface{}, accountType interface{}, accountID interface{}, role interface{}) *BigQueryClient_GrantTableAccess_Call { return &BigQueryClient_GrantTableAccess_Call{Call: _e.mock.On("GrantTableAccess", ctx, t, accountType, accountID, role)} } @@ -248,11 +277,20 @@ func (_c *BigQueryClient_GrantTableAccess_Call) Return(_a0 error) *BigQueryClien return _c } +func (_c *BigQueryClient_GrantTableAccess_Call) RunAndReturn(run func(context.Context, *bigquery.Table, string, string, string) error) *BigQueryClient_GrantTableAccess_Call { + _c.Call.Return(run) + return _c +} + // ListAccess provides a mock function with given fields: ctx, resources func (_m *BigQueryClient) ListAccess(ctx context.Context, resources []*domain.Resource) (domain.MapResourceAccess, error) { ret := _m.Called(ctx, resources) var r0 domain.MapResourceAccess + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, []*domain.Resource) (domain.MapResourceAccess, error)); ok { + return rf(ctx, resources) + } if rf, ok := ret.Get(0).(func(context.Context, []*domain.Resource) domain.MapResourceAccess); ok { r0 = rf(ctx, resources) } else { @@ -261,7 +299,6 @@ func (_m *BigQueryClient) ListAccess(ctx context.Context, resources []*domain.Re } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, []*domain.Resource) error); ok { r1 = rf(ctx, resources) } else { @@ -277,8 +314,8 @@ type BigQueryClient_ListAccess_Call struct { } // ListAccess is a helper method to define mock.On call -// - ctx context.Context -// - resources []*domain.Resource +// - ctx context.Context +// - resources []*domain.Resource func (_e *BigQueryClient_Expecter) ListAccess(ctx interface{}, resources interface{}) *BigQueryClient_ListAccess_Call { return &BigQueryClient_ListAccess_Call{Call: _e.mock.On("ListAccess", ctx, resources)} } @@ -295,18 +332,26 @@ func (_c *BigQueryClient_ListAccess_Call) Return(_a0 domain.MapResourceAccess, _ return _c } +func (_c *BigQueryClient_ListAccess_Call) RunAndReturn(run func(context.Context, []*domain.Resource) (domain.MapResourceAccess, error)) *BigQueryClient_ListAccess_Call { + _c.Call.Return(run) + return _c +} + // ResolveDatasetRole provides a mock function with given fields: role func (_m *BigQueryClient) ResolveDatasetRole(role string) (gobigquery.AccessRole, error) { ret := _m.Called(role) var r0 gobigquery.AccessRole + var r1 error + if rf, ok := ret.Get(0).(func(string) (gobigquery.AccessRole, error)); ok { + return rf(role) + } if rf, ok := ret.Get(0).(func(string) gobigquery.AccessRole); ok { r0 = rf(role) } else { r0 = ret.Get(0).(gobigquery.AccessRole) } - var r1 error if rf, ok := ret.Get(1).(func(string) error); ok { r1 = rf(role) } else { @@ -322,7 +367,7 @@ type BigQueryClient_ResolveDatasetRole_Call struct { } // ResolveDatasetRole is a helper method to define mock.On call -// - role string +// - role string func (_e *BigQueryClient_Expecter) ResolveDatasetRole(role interface{}) *BigQueryClient_ResolveDatasetRole_Call { return &BigQueryClient_ResolveDatasetRole_Call{Call: _e.mock.On("ResolveDatasetRole", role)} } @@ -339,6 +384,11 @@ func (_c *BigQueryClient_ResolveDatasetRole_Call) Return(_a0 gobigquery.AccessRo return _c } +func (_c *BigQueryClient_ResolveDatasetRole_Call) RunAndReturn(run func(string) (gobigquery.AccessRole, error)) *BigQueryClient_ResolveDatasetRole_Call { + _c.Call.Return(run) + return _c +} + // RevokeDatasetAccess provides a mock function with given fields: ctx, d, user, role func (_m *BigQueryClient) RevokeDatasetAccess(ctx context.Context, d *bigquery.Dataset, user string, role string) error { ret := _m.Called(ctx, d, user, role) @@ -359,10 +409,10 @@ type BigQueryClient_RevokeDatasetAccess_Call struct { } // RevokeDatasetAccess is a helper method to define mock.On call -// - ctx context.Context -// - d *bigquery.Dataset -// - user string -// - role string +// - ctx context.Context +// - d *bigquery.Dataset +// - user string +// - role string func (_e *BigQueryClient_Expecter) RevokeDatasetAccess(ctx interface{}, d interface{}, user interface{}, role interface{}) *BigQueryClient_RevokeDatasetAccess_Call { return &BigQueryClient_RevokeDatasetAccess_Call{Call: _e.mock.On("RevokeDatasetAccess", ctx, d, user, role)} } @@ -379,6 +429,11 @@ func (_c *BigQueryClient_RevokeDatasetAccess_Call) Return(_a0 error) *BigQueryCl return _c } +func (_c *BigQueryClient_RevokeDatasetAccess_Call) RunAndReturn(run func(context.Context, *bigquery.Dataset, string, string) error) *BigQueryClient_RevokeDatasetAccess_Call { + _c.Call.Return(run) + return _c +} + // RevokeTableAccess provides a mock function with given fields: ctx, t, accountType, accountID, role func (_m *BigQueryClient) RevokeTableAccess(ctx context.Context, t *bigquery.Table, accountType string, accountID string, role string) error { ret := _m.Called(ctx, t, accountType, accountID, role) @@ -399,11 +454,11 @@ type BigQueryClient_RevokeTableAccess_Call struct { } // RevokeTableAccess is a helper method to define mock.On call -// - ctx context.Context -// - t *bigquery.Table -// - accountType string -// - accountID string -// - role string +// - ctx context.Context +// - t *bigquery.Table +// - accountType string +// - accountID string +// - role string func (_e *BigQueryClient_Expecter) RevokeTableAccess(ctx interface{}, t interface{}, accountType interface{}, accountID interface{}, role interface{}) *BigQueryClient_RevokeTableAccess_Call { return &BigQueryClient_RevokeTableAccess_Call{Call: _e.mock.On("RevokeTableAccess", ctx, t, accountType, accountID, role)} } @@ -419,3 +474,23 @@ func (_c *BigQueryClient_RevokeTableAccess_Call) Return(_a0 error) *BigQueryClie _c.Call.Return(_a0) return _c } + +func (_c *BigQueryClient_RevokeTableAccess_Call) RunAndReturn(run func(context.Context, *bigquery.Table, string, string, string) error) *BigQueryClient_RevokeTableAccess_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewBigQueryClient interface { + mock.TestingT + Cleanup(func()) +} + +// NewBigQueryClient creates a new instance of BigQueryClient. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewBigQueryClient(t mockConstructorTestingTNewBigQueryClient) *BigQueryClient { + mock := &BigQueryClient{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/plugins/providers/bigquery/mocks/cloudLoggingClientI.go b/plugins/providers/bigquery/mocks/cloudLoggingClientI.go index c65694450..3a9d9974c 100644 --- a/plugins/providers/bigquery/mocks/cloudLoggingClientI.go +++ b/plugins/providers/bigquery/mocks/cloudLoggingClientI.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -59,11 +59,20 @@ func (_c *CloudLoggingClientI_Close_Call) Return(_a0 error) *CloudLoggingClientI return _c } +func (_c *CloudLoggingClientI_Close_Call) RunAndReturn(run func() error) *CloudLoggingClientI_Close_Call { + _c.Call.Return(run) + return _c +} + // ListLogEntries provides a mock function with given fields: _a0, _a1 func (_m *CloudLoggingClientI) ListLogEntries(_a0 context.Context, _a1 bigquery.ImportActivitiesFilter) ([]*bigquery.Activity, error) { ret := _m.Called(_a0, _a1) var r0 []*bigquery.Activity + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, bigquery.ImportActivitiesFilter) ([]*bigquery.Activity, error)); ok { + return rf(_a0, _a1) + } if rf, ok := ret.Get(0).(func(context.Context, bigquery.ImportActivitiesFilter) []*bigquery.Activity); ok { r0 = rf(_a0, _a1) } else { @@ -72,7 +81,6 @@ func (_m *CloudLoggingClientI) ListLogEntries(_a0 context.Context, _a1 bigquery. } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, bigquery.ImportActivitiesFilter) error); ok { r1 = rf(_a0, _a1) } else { @@ -88,8 +96,8 @@ type CloudLoggingClientI_ListLogEntries_Call struct { } // ListLogEntries is a helper method to define mock.On call -// - _a0 context.Context -// - _a1 bigquery.ImportActivitiesFilter +// - _a0 context.Context +// - _a1 bigquery.ImportActivitiesFilter func (_e *CloudLoggingClientI_Expecter) ListLogEntries(_a0 interface{}, _a1 interface{}) *CloudLoggingClientI_ListLogEntries_Call { return &CloudLoggingClientI_ListLogEntries_Call{Call: _e.mock.On("ListLogEntries", _a0, _a1)} } @@ -105,3 +113,23 @@ func (_c *CloudLoggingClientI_ListLogEntries_Call) Return(_a0 []*bigquery.Activi _c.Call.Return(_a0, _a1) return _c } + +func (_c *CloudLoggingClientI_ListLogEntries_Call) RunAndReturn(run func(context.Context, bigquery.ImportActivitiesFilter) ([]*bigquery.Activity, error)) *CloudLoggingClientI_ListLogEntries_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewCloudLoggingClientI interface { + mock.TestingT + Cleanup(func()) +} + +// NewCloudLoggingClientI creates a new instance of CloudLoggingClientI. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewCloudLoggingClientI(t mockConstructorTestingTNewCloudLoggingClientI) *CloudLoggingClientI { + mock := &CloudLoggingClientI{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/plugins/providers/bigquery/provider.go b/plugins/providers/bigquery/provider.go index 3cf127709..a3036a056 100644 --- a/plugins/providers/bigquery/provider.go +++ b/plugins/providers/bigquery/provider.go @@ -58,11 +58,6 @@ type cloudLoggingClientI interface { ListLogEntries(context.Context, ImportActivitiesFilter) ([]*Activity, error) } -//go:generate mockery --name=encryptor --exported --with-expecter -type encryptor interface { - domain.Crypto -} - // Provider for bigquery type Provider struct { provider.PermissionManager @@ -70,7 +65,6 @@ type Provider struct { typeName string Clients map[string]BigQueryClient LogClients map[string]cloudLoggingClientI - encryptor encryptor logger log.Logger mu sync.Mutex @@ -78,12 +72,11 @@ type Provider struct { } // NewProvider returns bigquery provider -func NewProvider(typeName string, c encryptor, logger log.Logger) *Provider { +func NewProvider(typeName string, logger log.Logger) *Provider { return &Provider{ typeName: typeName, Clients: map[string]BigQueryClient{}, LogClients: map[string]cloudLoggingClientI{}, - encryptor: c, logger: logger, mu: sync.Mutex{}, @@ -98,13 +91,8 @@ func (p *Provider) GetType() string { // CreateConfig validates provider config func (p *Provider) CreateConfig(pc *domain.ProviderConfig) error { - c := NewConfig(pc, p.encryptor) - - if err := c.ParseAndValidate(); err != nil { - return err - } - - return c.EncryptCredentials() + c := NewConfig(pc) + return c.ParseAndValidate() } // GetResources returns BigQuery dataset and table resources @@ -346,7 +334,6 @@ func (p *Provider) getBigQueryClient(credentials Credentials) (BigQueryClient, e return p.Clients[projectID], nil } - credentials.Decrypt(p.encryptor) client, err := NewBigQueryClient(projectID, option.WithCredentialsJSON([]byte(credentials.ServiceAccountKey))) if err != nil { return nil, err @@ -357,7 +344,7 @@ func (p *Provider) getBigQueryClient(credentials Credentials) (BigQueryClient, e } func (p *Provider) getCloudLoggingClient(ctx context.Context, pd domain.ProviderConfig) (cloudLoggingClientI, error) { - decryptedCreds, err := ParseCredentials(pd.Credentials, p.encryptor) + decryptedCreds, err := ParseCredentials(pd.Credentials) if err != nil { return nil, fmt.Errorf("parsing credentials: %w", err) } @@ -442,7 +429,7 @@ func (p *Provider) getGcloudPermissions(ctx context.Context, pd domain.Provider, } p.logger.Debug("getting permissions from gcloud", "role", roleID) - creds, err := ParseCredentials(pd.Config.Credentials, p.encryptor) + creds, err := ParseCredentials(pd.Config.Credentials) if err != nil { return nil, fmt.Errorf("parsing credentials: %w", err) } diff --git a/plugins/providers/bigquery/provider_test.go b/plugins/providers/bigquery/provider_test.go index 4f22c3dea..1a808c162 100644 --- a/plugins/providers/bigquery/provider_test.go +++ b/plugins/providers/bigquery/provider_test.go @@ -35,10 +35,9 @@ func TestGetType(t *testing.T) { func TestCreateConfig(t *testing.T) { t.Run("should return error if error in credentials are invalid/mandatory fields are missing", func(t *testing.T) { - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("", encryptor, l) + p := bigquery.NewProvider("", l) p.Clients = map[string]bigquery.BigQueryClient{ "resource-name": client, } @@ -83,10 +82,9 @@ func TestCreateConfig(t *testing.T) { }) t.Run("should return error if error in parse and validate configurations", func(t *testing.T) { - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("", encryptor, l) + p := bigquery.NewProvider("", l) p.Clients = map[string]bigquery.BigQueryClient{ "test-resource-name": client, } @@ -156,7 +154,6 @@ func TestCreateConfig(t *testing.T) { }, }, } - encryptor.On("Encrypt", `{"type":"service_account"}`).Return(`{"type":"service_account"}`, nil) for _, tc := range testcases { t.Run(tc.name, func(t *testing.T) { @@ -168,10 +165,9 @@ func TestCreateConfig(t *testing.T) { t.Run("should return error if error in parsing or validaing permissions", func(t *testing.T) { providerURN := "test-URN" - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("", encryptor, l) + p := bigquery.NewProvider("", l) p.Clients = map[string]bigquery.BigQueryClient{ "test-resource-name": client, } @@ -200,41 +196,11 @@ func TestCreateConfig(t *testing.T) { assert.Error(t, actualError) }) - t.Run("should return error if error in encrypting the credentials", func(t *testing.T) { - providerURN := "test-URN" - encryptor := new(mocks.Encryptor) - client := new(mocks.BigQueryClient) - l := log.NewNoop() - p := bigquery.NewProvider("", encryptor, l) - p.Clients = map[string]bigquery.BigQueryClient{ - "test-resource-name": client, - } - pc := &domain.ProviderConfig{ - Resources: []*domain.ResourceConfig{ - { - Type: bigquery.ResourceTypeDataset, - Roles: []*domain.Role{}, - }, - }, - Credentials: bigquery.Credentials{ - ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte(`{"type":"service_account"}`)), - ResourceName: "projects/test-resource-name", - }, - URN: providerURN, - } - expectedError := errors.New("error in encrypting SAK") - encryptor.On("Encrypt", `{"type":"service_account"}`).Return("", expectedError) - actualError := p.CreateConfig(pc) - - assert.Equal(t, expectedError, actualError) - }) - t.Run("should return nil error and create the config on success", func(t *testing.T) { providerURN := "test-URN" - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("", encryptor, l) + p := bigquery.NewProvider("", l) p.Clients = map[string]bigquery.BigQueryClient{ "test-resource-name": client, } @@ -257,20 +223,17 @@ func TestCreateConfig(t *testing.T) { }, URN: providerURN, } - encryptor.On("Encrypt", `{"type":"service_account"}`).Return(`{"type":"service_account"}`, nil) actualError := p.CreateConfig(pc) assert.NoError(t, actualError) - encryptor.AssertExpectations(t) }) } func TestGetResources(t *testing.T) { t.Run("should error when credentials are invalid", func(t *testing.T) { - encryptor := new(mocks.Encryptor) l := log.NewNoop() - p := bigquery.NewProvider("", encryptor, l) + p := bigquery.NewProvider("", l) pc := &domain.ProviderConfig{ Type: domain.ProviderTypeBigQuery, URN: "test-project-id", @@ -284,10 +247,9 @@ func TestGetResources(t *testing.T) { }) t.Run("should return dataset resource object", func(t *testing.T) { - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("", encryptor, l) + p := bigquery.NewProvider("", l) p.Clients = map[string]bigquery.BigQueryClient{ "resource-name": client, } @@ -464,10 +426,9 @@ func TestGrantAccess(t *testing.T) { expectedError := errors.New("Test-Error") expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("bigquery", encryptor, l) + p := bigquery.NewProvider("bigquery", l) p.Clients = map[string]bigquery.BigQueryClient{ "resource-name": client, } @@ -516,10 +477,9 @@ func TestGrantAccess(t *testing.T) { t.Run("should grant access to dataset resource and return no error on success", func(t *testing.T) { expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("bigquery", encryptor, l) + p := bigquery.NewProvider("bigquery", l) p.Clients = map[string]bigquery.BigQueryClient{ "resource-name": client, } @@ -570,10 +530,9 @@ func TestGrantAccess(t *testing.T) { providerURN := "test-URN" expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("bigquery", encryptor, l) + p := bigquery.NewProvider("bigquery", l) p.Clients = map[string]bigquery.BigQueryClient{ "resource-name": client, } @@ -723,10 +682,9 @@ func TestRevokeAccess(t *testing.T) { expectedError := errors.New("Test-Error") expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("bigquery", encryptor, l) + p := bigquery.NewProvider("bigquery", l) p.Clients = map[string]bigquery.BigQueryClient{ "resource-name": client, } @@ -775,10 +733,9 @@ func TestRevokeAccess(t *testing.T) { t.Run("should Revoke access to dataset resource and return no error on success", func(t *testing.T) { expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("bigquery", encryptor, l) + p := bigquery.NewProvider("bigquery", l) p.Clients = map[string]bigquery.BigQueryClient{ "resource-name": client, } @@ -828,10 +785,9 @@ func TestRevokeAccess(t *testing.T) { providerURN := "test-URN" expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.BigQueryClient) l := log.NewNoop() - p := bigquery.NewProvider("bigquery", encryptor, l) + p := bigquery.NewProvider("bigquery", l) p.Clients = map[string]bigquery.BigQueryClient{ "resource-name": client, } @@ -963,7 +919,6 @@ type BigQueryProviderTestSuite struct { mockBigQueryClient *mocks.BigQueryClient mockCloudLoggingClient *mocks.CloudLoggingClientI - mockEncryptor *mocks.Encryptor dummyProjectID string provider *bigquery.Provider @@ -977,8 +932,7 @@ func TestBigQueryProvider(t *testing.T) { func (s *BigQueryProviderTestSuite) SetupTest() { s.mockBigQueryClient = new(mocks.BigQueryClient) s.mockCloudLoggingClient = new(mocks.CloudLoggingClientI) - s.mockEncryptor = new(mocks.Encryptor) - s.provider = bigquery.NewProvider("bigquery", s.mockEncryptor, log.NewNoop()) + s.provider = bigquery.NewProvider("bigquery", log.NewNoop()) s.dummyProjectID = "test-project-id" s.provider.Clients[s.dummyProjectID] = s.mockBigQueryClient s.provider.LogClients[s.dummyProjectID] = s.mockCloudLoggingClient @@ -1017,24 +971,20 @@ func (s *BigQueryProviderTestSuite) SetupTest() { }, }, } - - s.mockEncryptor.EXPECT().Decrypt("dummy-credentials").Return("dummy-credentials", nil) } func (s *BigQueryProviderTestSuite) TestListAccess() { s.Run("return error if initializing client fails", func() { - s.mockEncryptor.EXPECT().Decrypt("invalid-key").Return("", errors.New("invalid-key")) - ctx := context.Background() _, err := s.provider.ListAccess(ctx, domain.ProviderConfig{ Type: "bigquery", URN: "new-urn", Credentials: map[string]interface{}{ - "service_account_key": "invalid-key", + "service_account_key": make(chan int), // invalid type to trigger error }, }, []*domain.Resource{}) - s.EqualError(err, "initializing bigquery client: bigquery: constructing client: invalid character 'i' looking for beginning of value") + s.ErrorContains(err, "parsing credentials: 1 error(s) decoding:\n\n* 'service_account_key' expected type 'string', got unconvertible type 'chan int'") }) s.Run("return nil error on success", func() { @@ -1153,24 +1103,18 @@ func (s *BigQueryProviderTestSuite) TestGetActivities_Success() { }) s.Run("should return error if there is an error on initializing logging client", func() { - expectedError := errors.New("error") - - s.mockEncryptor.EXPECT(). - Decrypt("invalid-key").Return("", expectedError).Once() - invalidProvider := &domain.Provider{ Config: &domain.ProviderConfig{ Type: "bigquery", URN: "new-urn", Credentials: map[string]interface{}{ - "service_account_key": "invalid-key", + "service_account_key": make(chan int), }, }, } _, err := s.provider.GetActivities(context.Background(), *invalidProvider, domain.ImportActivitiesFilter{}) - s.mockEncryptor.AssertExpectations(s.T()) - s.ErrorIs(err, expectedError) + s.ErrorContains(err, "parsing credentials: 1 error(s) decoding:\n\n* 'service_account_key' expected type 'string', got unconvertible type 'chan int'") }) s.Run("should return error if there is an error on listing log entries", func() { @@ -1186,7 +1130,6 @@ func (s *BigQueryProviderTestSuite) TestGetActivities_Success() { } func initProvider() *bigquery.Provider { - crypto := new(mocks.Encryptor) l := log.NewNoop() - return bigquery.NewProvider("bigquery", crypto, l) + return bigquery.NewProvider("bigquery", l) } diff --git a/plugins/providers/dataplex/config.go b/plugins/providers/dataplex/config.go index 4b25a7058..f8f0233d9 100644 --- a/plugins/providers/dataplex/config.go +++ b/plugins/providers/dataplex/config.go @@ -23,36 +23,6 @@ type Credentials struct { ResourceName string `mapstructure:"resource_name" json:"resource_name" validate:"startswith=projects/"` } -// Encrypt encrypts GCP credentials -func (c *Credentials) Encrypt(encryptor domain.Encryptor) error { - if c == nil { - return ErrUnableToEncryptNilCredentials - } - - encryptedCredentials, err := encryptor.Encrypt(c.ServiceAccountKey) - if err != nil { - return err - } - - c.ServiceAccountKey = encryptedCredentials - return nil -} - -// Decrypt decrypts GCP credentials -func (c *Credentials) Decrypt(decryptor domain.Decryptor) error { - if c == nil { - return ErrUnableToDecryptNilCredentials - } - - decryptedCredentials, err := decryptor.Decrypt(c.ServiceAccountKey) - if err != nil { - return err - } - - c.ServiceAccountKey = decryptedCredentials - return nil -} - // Permission is for mapping role into policy tag fine-grained-reader permissions type Permission string @@ -61,36 +31,15 @@ type Config struct { ProviderConfig *domain.ProviderConfig valid bool - crypto domain.Crypto validator *validator.Validate } // NewConfig returns policy_tag config struct -func NewConfig(pc *domain.ProviderConfig, crypto domain.Crypto) *Config { +func NewConfig(pc *domain.ProviderConfig) *Config { return &Config{ ProviderConfig: pc, validator: validator.New(), - crypto: crypto, - } -} - -// EncryptCredentials encrypts the policy_tag credentials config -func (c *Config) EncryptCredentials() error { - if err := c.parseAndValidate(); err != nil { - return err } - - credentials, ok := c.ProviderConfig.Credentials.(*Credentials) - if !ok { - return ErrInvalidCredentialsType - } - - if err := credentials.Encrypt(c.crypto); err != nil { - return err - } - - c.ProviderConfig.Credentials = credentials - return nil } // ParseAndValidate validates policy_tag config within provider config and make the interface{} config value castable into the expected policy_tag config value diff --git a/plugins/providers/dataplex/config_test.go b/plugins/providers/dataplex/config_test.go index 080e940e0..da273bb3b 100644 --- a/plugins/providers/dataplex/config_test.go +++ b/plugins/providers/dataplex/config_test.go @@ -2,108 +2,19 @@ package dataplex_test import ( "encoding/base64" - "errors" "testing" - "github.com/goto/guardian/plugins/providers/bigquery" - "github.com/goto/guardian/domain" - "github.com/goto/guardian/mocks" "github.com/goto/guardian/plugins/providers/dataplex" "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/mock" ) -func TestCredentials(t *testing.T) { - encryptor := new(mocks.Encryptor) - decryptor := new(mocks.Decryptor) - - t.Run("encrypt", func(t *testing.T) { - t.Run("should return error if creds is nil", func(t *testing.T) { - var creds *dataplex.Credentials - expectedError := dataplex.ErrUnableToEncryptNilCredentials - - actualError := creds.Encrypt(encryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return error if encryptor failed to encrypt the creds", func(t *testing.T) { - creds := dataplex.Credentials{} - expectedError := errors.New("encryptor error") - encryptor.On("Encrypt", mock.Anything).Return("", expectedError).Once() - - actualError := creds.Encrypt(encryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return encrypted password inside Credentials on success", func(t *testing.T) { - service_account_key := base64.StdEncoding.EncodeToString([]byte("service-account-key-json")) - resourceName := "resource_name" - creds := bigquery.Credentials{ - ServiceAccountKey: service_account_key, - ResourceName: resourceName, - } - - expectedEncryptedServiceAccountKey := "encrypted_service_account_key" - encryptor.On("Encrypt", service_account_key).Return(expectedEncryptedServiceAccountKey, nil).Once() - - actualError := creds.Encrypt(encryptor) - - assert.Nil(t, actualError) - assert.Equal(t, expectedEncryptedServiceAccountKey, creds.ServiceAccountKey) - encryptor.AssertExpectations(t) - }) - }) - - t.Run("decrypt", func(t *testing.T) { - t.Run("should return error if creds is nil", func(t *testing.T) { - var creds *dataplex.Credentials - - expectedError := dataplex.ErrUnableToDecryptNilCredentials - - actualError := creds.Decrypt(decryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return error if decryptor failed to decrypt the creds", func(t *testing.T) { - creds := dataplex.Credentials{} - expectedError := errors.New("decryptor error") - decryptor.On("Decrypt", mock.Anything).Return("", expectedError).Once() - - actualError := creds.Decrypt(decryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return decrypted service account key on success", func(t *testing.T) { - service_account_key := base64.StdEncoding.EncodeToString([]byte("service-account-key-json")) - resourceName := "resource_name" - creds := bigquery.Credentials{ - ServiceAccountKey: service_account_key, - ResourceName: resourceName, - } - expectedDecryptedServiceAccountKey := "decrypted_service_account_key" - decryptor.On("Decrypt", service_account_key).Return(expectedDecryptedServiceAccountKey, nil).Once() - - actualError := creds.Decrypt(decryptor) - - assert.Nil(t, actualError) - assert.Equal(t, expectedDecryptedServiceAccountKey, creds.ServiceAccountKey) - decryptor.AssertExpectations(t) - }) - }) -} - func TestNewConfig(t *testing.T) { t.Run("should return dataplex config containing the same provider config", func(t *testing.T) { - mockCrypto := new(mocks.Crypto) pc := &domain.ProviderConfig{} expectedProviderConfig := pc - c := dataplex.NewConfig(pc, mockCrypto) + c := dataplex.NewConfig(pc) actualProviderConfig := c.ProviderConfig assert.NotNil(t, c) @@ -112,7 +23,6 @@ func TestNewConfig(t *testing.T) { } func TestValidate(t *testing.T) { - mockCrypto := new(mocks.Crypto) validCredentials := dataplex.Credentials{ ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte("service-account-key-json")), ResourceName: "projects/project-name/location/us", @@ -163,9 +73,8 @@ func TestValidate(t *testing.T) { }, }, } - mockCrypto.On("Encrypt", mock.Anything).Return("", nil).Once() - err := bigquery.NewConfig(pc, mockCrypto).ParseAndValidate() + err := dataplex.NewConfig(pc).ParseAndValidate() assert.Error(t, err) }) } diff --git a/plugins/providers/dataplex/provider.go b/plugins/providers/dataplex/provider.go index 29ec97005..1d2cc737e 100644 --- a/plugins/providers/dataplex/provider.go +++ b/plugins/providers/dataplex/provider.go @@ -18,23 +18,17 @@ type PolicyTagClient interface { ListAccess(ctx context.Context, resources []*domain.Resource) (domain.MapResourceAccess, error) } -type encryptor interface { - domain.Crypto -} - // Provider for policy tag type Provider struct { - Clients map[string]PolicyTagClient - typeName string - encryptor encryptor + Clients map[string]PolicyTagClient + typeName string } // NewProvider returns policy tag provider -func NewProvider(typeName string, c encryptor) *Provider { +func NewProvider(typeName string) *Provider { return &Provider{ - typeName: typeName, - Clients: map[string]PolicyTagClient{}, - encryptor: c, + typeName: typeName, + Clients: map[string]PolicyTagClient{}, } } @@ -45,13 +39,9 @@ func (p *Provider) GetType() string { // CreateConfig validates provider config func (p *Provider) CreateConfig(pc *domain.ProviderConfig) error { - c := NewConfig(pc, p.encryptor) + c := NewConfig(pc) - if err := c.ParseAndValidate(); err != nil { - return err - } - - return c.EncryptCredentials() + return c.ParseAndValidate() } func (p *Provider) GetResources(pc *domain.ProviderConfig) ([]*domain.Resource, error) { @@ -197,10 +187,6 @@ func (p *Provider) getPolicyTagClient(credentials Credentials) (PolicyTagClient, return p.Clients[projectID], nil } - err = credentials.Decrypt(p.encryptor) - if err != nil { - return nil, ErrUnableToDecryptCredentials - } client, err := newPolicyTagClient(projectID, taxonomyLocation, []byte(credentials.ServiceAccountKey)) if err != nil { return nil, err diff --git a/plugins/providers/dataplex/provider_test.go b/plugins/providers/dataplex/provider_test.go index 4afa08fcb..5adfda1b0 100644 --- a/plugins/providers/dataplex/provider_test.go +++ b/plugins/providers/dataplex/provider_test.go @@ -29,9 +29,8 @@ func TestGetType(t *testing.T) { func TestCreateConfig(t *testing.T) { t.Run("should return error if error in credentials are invalid/mandatory fields are missing", func(t *testing.T) { - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("", encryptor) + p := dataplex.NewProvider("") p.Clients = map[string]dataplex.PolicyTagClient{ "resource-name": client, } @@ -76,9 +75,8 @@ func TestCreateConfig(t *testing.T) { }) t.Run("should return error if error in parse and validate configurations", func(t *testing.T) { - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("", encryptor) + p := dataplex.NewProvider("") p.Clients = map[string]dataplex.PolicyTagClient{ "test-resource-name": client, } @@ -128,7 +126,6 @@ func TestCreateConfig(t *testing.T) { }, }, } - encryptor.On("Encrypt", `{"type":"service_account"}`).Return(`{"type":"service_account"}`, nil) for _, tc := range testcases { t.Run(tc.name, func(t *testing.T) { @@ -140,9 +137,8 @@ func TestCreateConfig(t *testing.T) { t.Run("should return error if error in parsing or validaing permissions", func(t *testing.T) { providerURN := "test-URN" - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("", encryptor) + p := dataplex.NewProvider("") p.Clients = map[string]dataplex.PolicyTagClient{ "test-resource-name": client, } @@ -171,39 +167,10 @@ func TestCreateConfig(t *testing.T) { assert.Error(t, actualError) }) - t.Run("should return error if error in encrypting the credentials", func(t *testing.T) { - providerURN := "test-URN" - encryptor := new(mocks.Encryptor) - client := new(mocks.DataplexClient) - p := dataplex.NewProvider("", encryptor) - p.Clients = map[string]dataplex.PolicyTagClient{ - "test-resource-name": client, - } - pc := &domain.ProviderConfig{ - Resources: []*domain.ResourceConfig{ - { - Type: dataplex.ResourceTypeTag, - Roles: []*domain.Role{}, - }, - }, - Credentials: dataplex.Credentials{ - ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte(`{"type":"service_account"}`)), - ResourceName: "projects/project-name/location/us", - }, - URN: providerURN, - } - expectedError := errors.New("error in encrypting SAK") - encryptor.On("Encrypt", `{"type":"service_account"}`).Return("", expectedError) - actualError := p.CreateConfig(pc) - - assert.Equal(t, expectedError, actualError) - }) - t.Run("should return nil error and create the config on success", func(t *testing.T) { providerURN := "test-URN" - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("", encryptor) + p := dataplex.NewProvider("") p.Clients = map[string]dataplex.PolicyTagClient{ "test-resource-name": client, } @@ -226,19 +193,16 @@ func TestCreateConfig(t *testing.T) { }, URN: providerURN, } - encryptor.On("Encrypt", `{"type":"service_account"}`).Return(`{"type":"service_account"}`, nil) actualError := p.CreateConfig(pc) assert.NoError(t, actualError) - encryptor.AssertExpectations(t) }) } func TestGetResources(t *testing.T) { t.Run("should error when credentials are invalid", func(t *testing.T) { - encryptor := new(mocks.Encryptor) - p := dataplex.NewProvider("", encryptor) + p := dataplex.NewProvider("") pc := &domain.ProviderConfig{ Type: domain.ProviderTypePolicyTag, URN: "test-project-id", @@ -253,9 +217,8 @@ func TestGetResources(t *testing.T) { t.Run("should return policy resource object", func(t *testing.T) { providerUrn := "policy-tag-urn" - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("", encryptor) + p := dataplex.NewProvider("") p.Clients = map[string]dataplex.PolicyTagClient{ "project-name": client, } @@ -410,9 +373,8 @@ func TestGrantAccess(t *testing.T) { expectedError := errors.New("Test-Error") expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("dataplex", encryptor) + p := dataplex.NewProvider("dataplex") p.Clients = map[string]dataplex.PolicyTagClient{ "resource-name": client, } @@ -463,9 +425,8 @@ func TestGrantAccess(t *testing.T) { providerURN := "test-URN" expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("dataplex", encryptor) + p := dataplex.NewProvider("dataplex") p.Clients = map[string]dataplex.PolicyTagClient{ "resource-name": client, } @@ -620,9 +581,8 @@ func TestRevokeAccess(t *testing.T) { expectedError := errors.New("Test-Error") expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("dataplex", encryptor) + p := dataplex.NewProvider("dataplex") p.Clients = map[string]dataplex.PolicyTagClient{ "resource-name": client, } @@ -674,9 +634,8 @@ func TestRevokeAccess(t *testing.T) { t.Run("should Revoke access to policy resource and return no error on success", func(t *testing.T) { expectedAccountType := "user" expectedAccountID := "test@email.com" - encryptor := new(mocks.Encryptor) client := new(mocks.DataplexClient) - p := dataplex.NewProvider("dataplex", encryptor) + p := dataplex.NewProvider("dataplex") p.Clients = map[string]dataplex.PolicyTagClient{ "resource-name": client, } @@ -800,7 +759,6 @@ type DataplexProviderTestSuite struct { mockDataplexClient *mocks.DataplexClient //mockCloudLoggingClient *mocks.CloudLoggingClientI - mockEncryptor *mocks.Encryptor dummyProjectID string provider *dataplex.Provider @@ -813,8 +771,7 @@ func TestDataplexProvider(t *testing.T) { func (s *DataplexProviderTestSuite) SetupTest() { s.mockDataplexClient = new(mocks.DataplexClient) - s.mockEncryptor = new(mocks.Encryptor) - s.provider = dataplex.NewProvider(domain.ProviderTypePolicyTag, s.mockEncryptor) + s.provider = dataplex.NewProvider(domain.ProviderTypePolicyTag) s.dummyProjectID = "test-project-id" s.provider.Clients[s.dummyProjectID] = s.mockDataplexClient @@ -847,29 +804,23 @@ func (s *DataplexProviderTestSuite) SetupTest() { }, }, } - - s.mockEncryptor.On("Decrypt", "12345").Return(`{"type":"service_account"}`, nil) // tests the newIamClient when p.Clients is not initialised in the provider config } func (s *DataplexProviderTestSuite) TestListAccess() { s.Run("return error if initializing client fails", func() { - s.mockEncryptor.EXPECT().Decrypt("invalid-key").Return("", errors.New("invalid-key")).Once() - ctx := context.Background() _, err := s.provider.ListAccess(ctx, domain.ProviderConfig{ Type: "dataplex", URN: "new-urn", Credentials: map[string]interface{}{ - "service_account_key": "invalid-key", - "resource_name": "projects/project-name/locations/u", + "service_account_key": make(chan int), }, }, []*domain.Resource{}) - s.EqualError(err, "initializing dataplex client: unable to decrypt credentials") + s.ErrorContains(err, "parsing credentials: 1 error(s) decoding:\n\n* 'service_account_key' expected type 'string', got unconvertible type 'chan int'") }) } func initProvider() *dataplex.Provider { - crypto := new(mocks.Encryptor) - return dataplex.NewProvider(domain.ProviderTypePolicyTag, crypto) + return dataplex.NewProvider(domain.ProviderTypePolicyTag) } diff --git a/plugins/providers/gcloudiam/config.go b/plugins/providers/gcloudiam/config.go index ca6942cca..5d4fe32ae 100644 --- a/plugins/providers/gcloudiam/config.go +++ b/plugins/providers/gcloudiam/config.go @@ -22,47 +22,17 @@ type Credentials struct { ResourceName string `mapstructure:"resource_name" json:"resource_name" validate:"startswith=projects/|startswith=organizations/"` } -func (c *Credentials) Encrypt(encryptor domain.Encryptor) error { - if c == nil { - return ErrUnableToEncryptNilCredentials - } - - encryptedSAKey, err := encryptor.Encrypt(c.ServiceAccountKey) - if err != nil { - return err - } - - c.ServiceAccountKey = encryptedSAKey - return nil -} - -func (c *Credentials) Decrypt(decryptor domain.Decryptor) error { - if c == nil { - return ErrUnableToDecryptNilCredentials - } - - decryptedSAKey, err := decryptor.Decrypt(c.ServiceAccountKey) - if err != nil { - return err - } - - c.ServiceAccountKey = decryptedSAKey - return nil -} - type Config struct { ProviderConfig *domain.ProviderConfig valid bool - crypto domain.Crypto validator *validator.Validate } -func NewConfig(pc *domain.ProviderConfig, crypto domain.Crypto) *Config { +func NewConfig(pc *domain.ProviderConfig) *Config { return &Config{ ProviderConfig: pc, validator: validator.New(), - crypto: crypto, } } @@ -70,24 +40,6 @@ func (c *Config) ParseAndValidate() error { return c.parseAndValidate() } -func (c *Config) EncryptCredentials() error { - if err := c.parseAndValidate(); err != nil { - return err - } - - credentials, ok := c.ProviderConfig.Credentials.(*Credentials) - if !ok { - return ErrInvalidCredentials - } - - if err := credentials.Encrypt(c.crypto); err != nil { - return err - } - - c.ProviderConfig.Credentials = credentials - return nil -} - func (c *Config) parseAndValidate() error { if c.valid { return nil diff --git a/plugins/providers/gcloudiam/config_test.go b/plugins/providers/gcloudiam/config_test.go index faefc401d..e9348d444 100644 --- a/plugins/providers/gcloudiam/config_test.go +++ b/plugins/providers/gcloudiam/config_test.go @@ -1,95 +1 @@ package gcloudiam_test - -import ( - "encoding/base64" - "errors" - "testing" - - "github.com/goto/guardian/mocks" - "github.com/goto/guardian/plugins/providers/gcloudiam" - "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/mock" -) - -func TestCredentials(t *testing.T) { - encryptor := new(mocks.Encryptor) - decryptor := new(mocks.Decryptor) - - t.Run("encrypt", func(t *testing.T) { - t.Run("should return error if creds is nil", func(t *testing.T) { - var creds *gcloudiam.Credentials - expectedError := gcloudiam.ErrUnableToEncryptNilCredentials - - actualError := creds.Encrypt(encryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return error if encryptor failed to encrypt the creds", func(t *testing.T) { - creds := gcloudiam.Credentials{} - expectedError := errors.New("encryptor error") - encryptor.On("Encrypt", mock.Anything).Return("", expectedError).Once() - - actualError := creds.Encrypt(encryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return encrypted password inside Credentials on success", func(t *testing.T) { - service_account_key := base64.StdEncoding.EncodeToString([]byte("service-account-key-json")) - resourceName := "resource_name" - creds := gcloudiam.Credentials{ - ServiceAccountKey: service_account_key, - ResourceName: resourceName, - } - - expectedEncryptedServiceAccountKey := "encrypted_service_account_key" - encryptor.On("Encrypt", service_account_key).Return(expectedEncryptedServiceAccountKey, nil).Once() - - actualError := creds.Encrypt(encryptor) - - assert.Nil(t, actualError) - assert.Equal(t, expectedEncryptedServiceAccountKey, creds.ServiceAccountKey) - encryptor.AssertExpectations(t) - }) - }) - - t.Run("decrypt", func(t *testing.T) { - t.Run("should return error if creds is nil", func(t *testing.T) { - var creds *gcloudiam.Credentials - - expectedError := gcloudiam.ErrUnableToDecryptNilCredentials - - actualError := creds.Decrypt(decryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return error if decryptor failed to decrypt the creds", func(t *testing.T) { - creds := gcloudiam.Credentials{} - expectedError := errors.New("decryptor error") - decryptor.On("Decrypt", mock.Anything).Return("", expectedError).Once() - - actualError := creds.Decrypt(decryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return decrypted service account key on success", func(t *testing.T) { - service_account_key := base64.StdEncoding.EncodeToString([]byte("service-account-key-json")) - resourceName := "resource_name" - creds := gcloudiam.Credentials{ - ServiceAccountKey: service_account_key, - ResourceName: resourceName, - } - expectedDecryptedServiceAccountKey := "decrypted_service_account_key" - decryptor.On("Decrypt", service_account_key).Return(expectedDecryptedServiceAccountKey, nil).Once() - - actualError := creds.Decrypt(decryptor) - - assert.Nil(t, actualError) - assert.Equal(t, expectedDecryptedServiceAccountKey, creds.ServiceAccountKey) - decryptor.AssertExpectations(t) - }) - }) -} diff --git a/plugins/providers/gcloudiam/mocks/GcloudIamClient.go b/plugins/providers/gcloudiam/mocks/GcloudIamClient.go index ec9e0b1ee..1417be61c 100644 --- a/plugins/providers/gcloudiam/mocks/GcloudIamClient.go +++ b/plugins/providers/gcloudiam/mocks/GcloudIamClient.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -29,6 +29,10 @@ func (_m *GcloudIamClient) GetRoles() ([]*gcloudiam.Role, error) { ret := _m.Called() var r0 []*gcloudiam.Role + var r1 error + if rf, ok := ret.Get(0).(func() ([]*gcloudiam.Role, error)); ok { + return rf() + } if rf, ok := ret.Get(0).(func() []*gcloudiam.Role); ok { r0 = rf() } else { @@ -37,7 +41,6 @@ func (_m *GcloudIamClient) GetRoles() ([]*gcloudiam.Role, error) { } } - var r1 error if rf, ok := ret.Get(1).(func() error); ok { r1 = rf() } else { @@ -69,6 +72,11 @@ func (_c *GcloudIamClient_GetRoles_Call) Return(_a0 []*gcloudiam.Role, _a1 error return _c } +func (_c *GcloudIamClient_GetRoles_Call) RunAndReturn(run func() ([]*gcloudiam.Role, error)) *GcloudIamClient_GetRoles_Call { + _c.Call.Return(run) + return _c +} + // GrantAccess provides a mock function with given fields: accountType, accountID, role func (_m *GcloudIamClient) GrantAccess(accountType string, accountID string, role string) error { ret := _m.Called(accountType, accountID, role) @@ -89,9 +97,9 @@ type GcloudIamClient_GrantAccess_Call struct { } // GrantAccess is a helper method to define mock.On call -// - accountType string -// - accountID string -// - role string +// - accountType string +// - accountID string +// - role string func (_e *GcloudIamClient_Expecter) GrantAccess(accountType interface{}, accountID interface{}, role interface{}) *GcloudIamClient_GrantAccess_Call { return &GcloudIamClient_GrantAccess_Call{Call: _e.mock.On("GrantAccess", accountType, accountID, role)} } @@ -108,11 +116,20 @@ func (_c *GcloudIamClient_GrantAccess_Call) Return(_a0 error) *GcloudIamClient_G return _c } +func (_c *GcloudIamClient_GrantAccess_Call) RunAndReturn(run func(string, string, string) error) *GcloudIamClient_GrantAccess_Call { + _c.Call.Return(run) + return _c +} + // ListAccess provides a mock function with given fields: ctx, resources func (_m *GcloudIamClient) ListAccess(ctx context.Context, resources []*domain.Resource) (domain.MapResourceAccess, error) { ret := _m.Called(ctx, resources) var r0 domain.MapResourceAccess + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, []*domain.Resource) (domain.MapResourceAccess, error)); ok { + return rf(ctx, resources) + } if rf, ok := ret.Get(0).(func(context.Context, []*domain.Resource) domain.MapResourceAccess); ok { r0 = rf(ctx, resources) } else { @@ -121,7 +138,6 @@ func (_m *GcloudIamClient) ListAccess(ctx context.Context, resources []*domain.R } } - var r1 error if rf, ok := ret.Get(1).(func(context.Context, []*domain.Resource) error); ok { r1 = rf(ctx, resources) } else { @@ -137,8 +153,8 @@ type GcloudIamClient_ListAccess_Call struct { } // ListAccess is a helper method to define mock.On call -// - ctx context.Context -// - resources []*domain.Resource +// - ctx context.Context +// - resources []*domain.Resource func (_e *GcloudIamClient_Expecter) ListAccess(ctx interface{}, resources interface{}) *GcloudIamClient_ListAccess_Call { return &GcloudIamClient_ListAccess_Call{Call: _e.mock.On("ListAccess", ctx, resources)} } @@ -155,6 +171,11 @@ func (_c *GcloudIamClient_ListAccess_Call) Return(_a0 domain.MapResourceAccess, return _c } +func (_c *GcloudIamClient_ListAccess_Call) RunAndReturn(run func(context.Context, []*domain.Resource) (domain.MapResourceAccess, error)) *GcloudIamClient_ListAccess_Call { + _c.Call.Return(run) + return _c +} + // RevokeAccess provides a mock function with given fields: accountType, accountID, role func (_m *GcloudIamClient) RevokeAccess(accountType string, accountID string, role string) error { ret := _m.Called(accountType, accountID, role) @@ -175,9 +196,9 @@ type GcloudIamClient_RevokeAccess_Call struct { } // RevokeAccess is a helper method to define mock.On call -// - accountType string -// - accountID string -// - role string +// - accountType string +// - accountID string +// - role string func (_e *GcloudIamClient_Expecter) RevokeAccess(accountType interface{}, accountID interface{}, role interface{}) *GcloudIamClient_RevokeAccess_Call { return &GcloudIamClient_RevokeAccess_Call{Call: _e.mock.On("RevokeAccess", accountType, accountID, role)} } @@ -193,3 +214,23 @@ func (_c *GcloudIamClient_RevokeAccess_Call) Return(_a0 error) *GcloudIamClient_ _c.Call.Return(_a0) return _c } + +func (_c *GcloudIamClient_RevokeAccess_Call) RunAndReturn(run func(string, string, string) error) *GcloudIamClient_RevokeAccess_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewGcloudIamClient interface { + mock.TestingT + Cleanup(func()) +} + +// NewGcloudIamClient creates a new instance of GcloudIamClient. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewGcloudIamClient(t mockConstructorTestingTNewGcloudIamClient) *GcloudIamClient { + mock := &GcloudIamClient{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/plugins/providers/gcloudiam/mocks/encryptor.go b/plugins/providers/gcloudiam/mocks/encryptor.go index 2c9fd72dc..17022f262 100644 --- a/plugins/providers/gcloudiam/mocks/encryptor.go +++ b/plugins/providers/gcloudiam/mocks/encryptor.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.10.0. DO NOT EDIT. +// Code generated by mockery v2.20.0. DO NOT EDIT. package mocks @@ -22,13 +22,16 @@ func (_m *Encryptor) Decrypt(_a0 string) (string, error) { ret := _m.Called(_a0) var r0 string + var r1 error + if rf, ok := ret.Get(0).(func(string) (string, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(string) string); ok { r0 = rf(_a0) } else { r0 = ret.Get(0).(string) } - var r1 error if rf, ok := ret.Get(1).(func(string) error); ok { r1 = rf(_a0) } else { @@ -44,7 +47,7 @@ type Encryptor_Decrypt_Call struct { } // Decrypt is a helper method to define mock.On call -// - _a0 string +// - _a0 string func (_e *Encryptor_Expecter) Decrypt(_a0 interface{}) *Encryptor_Decrypt_Call { return &Encryptor_Decrypt_Call{Call: _e.mock.On("Decrypt", _a0)} } @@ -61,18 +64,26 @@ func (_c *Encryptor_Decrypt_Call) Return(_a0 string, _a1 error) *Encryptor_Decry return _c } +func (_c *Encryptor_Decrypt_Call) RunAndReturn(run func(string) (string, error)) *Encryptor_Decrypt_Call { + _c.Call.Return(run) + return _c +} + // Encrypt provides a mock function with given fields: _a0 func (_m *Encryptor) Encrypt(_a0 string) (string, error) { ret := _m.Called(_a0) var r0 string + var r1 error + if rf, ok := ret.Get(0).(func(string) (string, error)); ok { + return rf(_a0) + } if rf, ok := ret.Get(0).(func(string) string); ok { r0 = rf(_a0) } else { r0 = ret.Get(0).(string) } - var r1 error if rf, ok := ret.Get(1).(func(string) error); ok { r1 = rf(_a0) } else { @@ -88,7 +99,7 @@ type Encryptor_Encrypt_Call struct { } // Encrypt is a helper method to define mock.On call -// - _a0 string +// - _a0 string func (_e *Encryptor_Expecter) Encrypt(_a0 interface{}) *Encryptor_Encrypt_Call { return &Encryptor_Encrypt_Call{Call: _e.mock.On("Encrypt", _a0)} } @@ -104,3 +115,23 @@ func (_c *Encryptor_Encrypt_Call) Return(_a0 string, _a1 error) *Encryptor_Encry _c.Call.Return(_a0, _a1) return _c } + +func (_c *Encryptor_Encrypt_Call) RunAndReturn(run func(string) (string, error)) *Encryptor_Encrypt_Call { + _c.Call.Return(run) + return _c +} + +type mockConstructorTestingTNewEncryptor interface { + mock.TestingT + Cleanup(func()) +} + +// NewEncryptor creates a new instance of Encryptor. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. +func NewEncryptor(t mockConstructorTestingTNewEncryptor) *Encryptor { + mock := &Encryptor{} + mock.Mock.Test(t) + + t.Cleanup(func() { mock.AssertExpectations(t) }) + + return mock +} diff --git a/plugins/providers/gcloudiam/provider.go b/plugins/providers/gcloudiam/provider.go index 5539844b8..7bc7a37cc 100644 --- a/plugins/providers/gcloudiam/provider.go +++ b/plugins/providers/gcloudiam/provider.go @@ -19,25 +19,18 @@ type GcloudIamClient interface { ListAccess(ctx context.Context, resources []*domain.Resource) (domain.MapResourceAccess, error) } -//go:generate mockery --name=encryptor --exported --with-expecter -type encryptor interface { - domain.Crypto -} - type Provider struct { provider.PermissionManager provider.UnimplementedClient typeName string Clients map[string]GcloudIamClient - crypto encryptor } -func NewProvider(typeName string, crypto encryptor) *Provider { +func NewProvider(typeName string) *Provider { return &Provider{ typeName: typeName, Clients: map[string]GcloudIamClient{}, - crypto: crypto, } } @@ -46,7 +39,7 @@ func (p *Provider) GetType() string { } func (p *Provider) CreateConfig(pc *domain.ProviderConfig) error { - c := NewConfig(pc, p.crypto) + c := NewConfig(pc) if err := c.ParseAndValidate(); err != nil { return err @@ -63,7 +56,7 @@ func (p *Provider) CreateConfig(pc *domain.ProviderConfig) error { } } - return c.EncryptCredentials() + return nil } func (p *Provider) GetResources(pc *domain.ProviderConfig) ([]*domain.Resource, error) { @@ -192,7 +185,6 @@ func (p *Provider) getIamClient(pc *domain.ProviderConfig) (GcloudIamClient, err return p.Clients[providerURN], nil } - credentials.Decrypt(p.crypto) client, err := newIamClient([]byte(credentials.ServiceAccountKey), credentials.ResourceName) if err != nil { return nil, err diff --git a/plugins/providers/gcloudiam/provider_test.go b/plugins/providers/gcloudiam/provider_test.go index c37d38300..f21623577 100644 --- a/plugins/providers/gcloudiam/provider_test.go +++ b/plugins/providers/gcloudiam/provider_test.go @@ -15,9 +15,8 @@ import ( func TestCreateConfig(t *testing.T) { t.Run("should return error if error in credentials are invalid/mandatory fields are missing", func(t *testing.T) { providerURN := "test-URN" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -88,9 +87,8 @@ func TestCreateConfig(t *testing.T) { t.Run("should return error if there parse and valid config is invalid", func(t *testing.T) { providerURN := "test-URN" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -140,59 +138,10 @@ func TestCreateConfig(t *testing.T) { } }) - t.Run("should return error if error in encrypting the credentials", func(t *testing.T) { - providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) - client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) - p.Clients = map[string]gcloudiam.GcloudIamClient{ - providerURN: client, - } - expectedError := errors.New("error in encrypting SAK") - - crypto.On("Encrypt", `{"type":"service_account"}`).Return("", expectedError) - - gcloudRole1 := &gcloudiam.Role{ - Name: "roles/bigquery.admin", - Title: "BigQuery Admin", - Description: "Administer all BigQuery resources and data", - } - - gCloudRolesList := []*gcloudiam.Role{} - gCloudRolesList = append(gCloudRolesList, gcloudRole1) - - client.On("GetRoles").Return(gCloudRolesList, nil).Once() - - pc := &domain.ProviderConfig{ - Resources: []*domain.ResourceConfig{ - { - Type: gcloudiam.ResourceTypeProject, - Roles: []*domain.Role{ - { - ID: "role-1", - Name: "BigQuery", - Permissions: []interface{}{"roles/bigquery.admin"}, - }, - }, - }, - }, - Credentials: gcloudiam.Credentials{ - ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte(`{"type":"service_account"}`)), - ResourceName: "projects/test-resource-name", - }, - URN: providerURN, - } - - actualError := p.CreateConfig(pc) - - assert.Equal(t, expectedError, actualError) - }) - t.Run("should return nil error and create the config on success", func(t *testing.T) { providerURN := "test-URN" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -208,8 +157,6 @@ func TestCreateConfig(t *testing.T) { client.On("GetRoles").Return(gCloudRolesList, nil).Once() - crypto.On("Encrypt", `{"type":"service_account"}`).Return(`{"type":"service_account"}`, nil) - pc := &domain.ProviderConfig{ Resources: []*domain.ResourceConfig{ { @@ -233,15 +180,13 @@ func TestCreateConfig(t *testing.T) { actualError := p.CreateConfig(pc) assert.NoError(t, actualError) - crypto.AssertExpectations(t) }) } func TestGetType(t *testing.T) { t.Run("should return provider type name", func(t *testing.T) { expectedTypeName := domain.ProviderTypeMetabase - crypto := new(mocks.Encryptor) - p := gcloudiam.NewProvider(expectedTypeName, crypto) + p := gcloudiam.NewProvider(expectedTypeName) actualTypeName := p.GetType() @@ -251,8 +196,7 @@ func TestGetType(t *testing.T) { func TestGetResources(t *testing.T) { t.Run("should error when credentials are invalid", func(t *testing.T) { - crypto := new(mocks.Encryptor) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") pc := &domain.ProviderConfig{ Type: domain.ProviderTypeGCloudIAM, URN: "test-project-id", @@ -267,9 +211,8 @@ func TestGetResources(t *testing.T) { t.Run("should check for valid roles in provider config and return project resource object", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -334,9 +277,8 @@ func TestGetResources(t *testing.T) { t.Run("should return organization resource object", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -389,8 +331,7 @@ func TestGetResources(t *testing.T) { func TestGrantAccess(t *testing.T) { t.Run("should return error if credentials is invalid", func(t *testing.T) { - crypto := new(mocks.Encryptor) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") pc := &domain.ProviderConfig{ Credentials: "invalid-credentials", @@ -413,9 +354,7 @@ func TestGrantAccess(t *testing.T) { t.Run("should return error if resource type is unknown", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) - p := gcloudiam.NewProvider("", crypto) - crypto.On("Decrypt", "c2VydmljZS1hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, nil) // tests the newIamClient when p.Clients is not initialised in the provider config + p := gcloudiam.NewProvider("") expectedError := errors.New("invalid resource type") pc := &domain.ProviderConfig{ @@ -426,7 +365,7 @@ func TestGrantAccess(t *testing.T) { }, }, Credentials: gcloudiam.Credentials{ - ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte("service-account-key-json")), + ServiceAccountKey: `{"type":"service_account"}`, ResourceName: "projects/test-resource-name", }, } @@ -445,9 +384,8 @@ func TestGrantAccess(t *testing.T) { t.Run("should return error if there is an error in granting the access", func(t *testing.T) { providerURN := "test-provider-urn" expectedError := errors.New("client error") - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -490,13 +428,12 @@ func TestGrantAccess(t *testing.T) { t.Run("should return nil error if granting access is successful", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) expectedRole := "role-1" expectedAccountType := "user" expectedAccountID := "test@email.com" expectedPermission := "roles/bigquery.admin" - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -544,9 +481,8 @@ func TestGrantAccess(t *testing.T) { func TestRevokeAccess(t *testing.T) { t.Run("should return error if resource type is unknown", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -575,9 +511,8 @@ func TestRevokeAccess(t *testing.T) { t.Run("should return error if there is an error in revoking the access", func(t *testing.T) { providerURN := "test-provider-urn" expectedError := errors.New("client error") - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -620,13 +555,12 @@ func TestRevokeAccess(t *testing.T) { t.Run("should return nil error if revoking access is successful", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) expectedRole := "role-1" expectedPermission := "roles/bigquery.admin" expectedAccountType := "user" expectedAccountID := "test@email.com" - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -674,9 +608,8 @@ func TestGetRoles(t *testing.T) { t.Run("should return error if resource type is not project or organisation", func(t *testing.T) { expectedError := gcloudiam.ErrInvalidResourceType providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -697,7 +630,6 @@ func TestGetRoles(t *testing.T) { t.Run("should get the expected roles and no error", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) expectedRoles := []*domain.Role{ { @@ -707,7 +639,7 @@ func TestGetRoles(t *testing.T) { }, } - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -739,11 +671,10 @@ func TestGetRoles(t *testing.T) { func TestGetPermissions(t *testing.T) { t.Run("should get the expected permissions and no error", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Encryptor) client := new(mocks.GcloudIamClient) expectedPermissions := []interface{}{"roles/bigquery.admin"} - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") p.Clients = map[string]gcloudiam.GcloudIamClient{ providerURN: client, } @@ -775,8 +706,7 @@ func TestGetPermissions(t *testing.T) { func TestGetAccountTypes(t *testing.T) { t.Run("should return the supported account types: user, serviceAccount", func(t *testing.T) { expectedAccountTypes := []string{"user", "serviceAccount", "group"} - crypto := new(mocks.Encryptor) - p := gcloudiam.NewProvider("", crypto) + p := gcloudiam.NewProvider("") actualAccountTypes := p.GetAccountTypes() diff --git a/plugins/providers/gcs/config.go b/plugins/providers/gcs/config.go index 83032cf94..fa4d5ea3d 100644 --- a/plugins/providers/gcs/config.go +++ b/plugins/providers/gcs/config.go @@ -40,7 +40,6 @@ var ( type Config struct { ProviderConfig *domain.ProviderConfig - crypto domain.Crypto validator *validator.Validate } @@ -49,41 +48,12 @@ type Credentials struct { ResourceName string `json:"resource_name" mapstructure:"resource_name" validate:"required"` } -func (c *Credentials) Decrypt(decryptor domain.Decryptor) error { - if c == nil { - return ErrUnableToDecryptNilCredentials - } - - decryptedServiceAccount, err := decryptor.Decrypt(c.ServiceAccountKey) - if err != nil { - return err - } - - c.ServiceAccountKey = decryptedServiceAccount - return nil -} - -func (c *Credentials) Encrypt(encryptor domain.Encryptor) error { - if c == nil { - return ErrUnableToEncryptNilCredentials - } - - encryptedServiceAccount, err := encryptor.Encrypt(c.ServiceAccountKey) - if err != nil { - return err - } - - c.ServiceAccountKey = encryptedServiceAccount - return nil -} - type Permission string -func NewConfig(pc *domain.ProviderConfig, crypto domain.Crypto) *Config { +func NewConfig(pc *domain.ProviderConfig) *Config { return &Config{ ProviderConfig: pc, validator: validator.New(), - crypto: crypto, } } diff --git a/plugins/providers/gcs/provider.go b/plugins/providers/gcs/provider.go index 27f1e7109..6768f321c 100644 --- a/plugins/providers/gcs/provider.go +++ b/plugins/providers/gcs/provider.go @@ -21,30 +21,23 @@ type GCSClient interface { ListAccess(context.Context, []*domain.Resource) (domain.MapResourceAccess, error) } -//go:generate mockery --name=Crypto --exported --with-expecter -type Crypto interface { - domain.Crypto -} - type Provider struct { provider.UnimplementedClient provider.PermissionManager typeName string Clients map[string]GCSClient - crypto Crypto } -func NewProvider(typeName string, crypto Crypto) *Provider { +func NewProvider(typeName string) *Provider { return &Provider{ typeName: typeName, Clients: map[string]GCSClient{}, - crypto: crypto, } } func (p *Provider) CreateConfig(pc *domain.ProviderConfig) error { - c := NewConfig(pc, p.crypto) + c := NewConfig(pc) if err := c.parseAndValidate(); err != nil { return err @@ -55,10 +48,6 @@ func (p *Provider) CreateConfig(pc *domain.ProviderConfig) error { return ErrInvalidCredentialsType } - if err := credentials.Encrypt(c.crypto); err != nil { - return fmt.Errorf("encrypting creds: %w", err) - } - c.ProviderConfig.Credentials = credentials return nil } @@ -207,10 +196,6 @@ func (p *Provider) getGCSClient(pc domain.ProviderConfig) (GCSClient, error) { return nil, fmt.Errorf("decoding credentials: %w", err) } - if err := creds.Decrypt(p.crypto); err != nil { - return nil, fmt.Errorf("decrypting credentials: %w", err) - } - projectID := strings.Replace(creds.ResourceName, "projects/", "", 1) if p.Clients[projectID] != nil { return p.Clients[projectID], nil diff --git a/plugins/providers/gcs/provider_test.go b/plugins/providers/gcs/provider_test.go index 11ae3b741..68a3c9231 100644 --- a/plugins/providers/gcs/provider_test.go +++ b/plugins/providers/gcs/provider_test.go @@ -3,7 +3,6 @@ package gcs_test import ( "context" "encoding/base64" - "errors" "fmt" "testing" @@ -17,8 +16,7 @@ import ( func TestGetType(t *testing.T) { t.Run("should return the typeName of the provider", func(t *testing.T) { expectedTypeName := "test-typeName" - crypto := new(mocks.Crypto) - p := gcs.NewProvider(expectedTypeName, crypto) + p := gcs.NewProvider(expectedTypeName) actualTypeName := p.GetType() @@ -28,9 +26,8 @@ func TestGetType(t *testing.T) { func TestCreateConfig(t *testing.T) { t.Run("should return error if error in parse and validate configurations", func(t *testing.T) { - crypto := new(mocks.Crypto) client := new(mocks.GCSClient) - p := gcs.NewProvider("", crypto) + p := gcs.NewProvider("") p.Clients = map[string]gcs.GCSClient{ "test-resource-name": client, } @@ -80,7 +77,6 @@ func TestCreateConfig(t *testing.T) { }, }, } - crypto.On("Encrypt", `{"type":"service_account"}`).Return(`{"type":"service_account"}`, nil) for _, tc := range testcases { t.Run(tc.name, func(t *testing.T) { @@ -90,37 +86,8 @@ func TestCreateConfig(t *testing.T) { } }) - t.Run("should return error if error in encrypting the credentials", func(t *testing.T) { - providerURN := "test-URN" - crypto := new(mocks.Crypto) - client := new(mocks.GCSClient) - p := gcs.NewProvider("", crypto) - p.Clients = map[string]gcs.GCSClient{ - "test-resource-name": client, - } - pc := &domain.ProviderConfig{ - Resources: []*domain.ResourceConfig{ - { - Type: gcs.ResourceTypeBucket, - Roles: []*domain.Role{}, - }, - }, - Credentials: gcs.Credentials{ - ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte(`{"type":"service_account"}`)), - ResourceName: "projects/test-resource-name", - }, - URN: providerURN, - } - expectedError := errors.New("error in encrypting SAK") - crypto.On("Encrypt", `{"type":"service_account"}`).Return("", expectedError) - actualError := p.CreateConfig(pc) - - assert.ErrorIs(t, actualError, expectedError) - }) - t.Run("should make the provider config, parse and validate the credentials and permissions and return nil error on success", func(t *testing.T) { - crypto := new(mocks.Crypto) - p := gcs.NewProvider("gcs", crypto) + p := gcs.NewProvider("gcs") providerURN := "test-resource-name" pc := &domain.ProviderConfig{ Type: domain.ProviderTypeGCS, @@ -143,11 +110,9 @@ func TestCreateConfig(t *testing.T) { }, }, } - crypto.On("Encrypt", `{"type":"service_account"}`).Return("encrypted Service Account Key", nil) actualError := p.CreateConfig(pc) assert.NoError(t, actualError) - crypto.AssertExpectations(t) }) } @@ -175,55 +140,13 @@ func TestGetResources(t *testing.T) { assert.Error(t, actualError) }) - t.Run("should return error if error in decrypting the service account key", func(t *testing.T) { - crypto := new(mocks.Crypto) - client := new(mocks.GCSClient) - p := gcs.NewProvider("gcs", crypto) - p.Clients = map[string]gcs.GCSClient{ - "test-resource-name": client, - } - providerURN := "test-resource-name" - expectedError := errors.New("Error in decrypting service account key") - crypto.On("Decrypt", "c2VydmljZV9hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, expectedError) - - pc := &domain.ProviderConfig{ - Type: domain.ProviderTypeGCS, - URN: providerURN, - Credentials: gcs.Credentials{ - ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte("service_account-key-json")), - ResourceName: "projects/test-resource-name", - }, - Resources: []*domain.ResourceConfig{ - { - Type: gcs.ResourceTypeBucket, - Roles: []*domain.Role{ - { - ID: "Storage Legacy Bucket Writer", - Name: "Storage Legacy Bucket Writer", - Description: "Read access to buckets with object listing/creation/deletion", - Permissions: []interface{}{"roles/storage.legacyBucketWriter"}, - }, - }, - }, - }, - } - - actualResources, actualError := p.GetResources(pc) - - assert.Nil(t, actualResources) - assert.Error(t, actualError) - crypto.AssertExpectations(t) - }) - t.Run("should get the bucket resources defined in the provider config", func(t *testing.T) { - crypto := new(mocks.Crypto) client := new(mocks.GCSClient) - p := gcs.NewProvider("gcs", crypto) + p := gcs.NewProvider("gcs") p.Clients = map[string]gcs.GCSClient{ "test-resource-name": client, } providerURN := "test-resource-name" - crypto.On("Decrypt", "c2VydmljZV9hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, nil) pc := &domain.ProviderConfig{ Type: domain.ProviderTypeGCS, @@ -371,70 +294,12 @@ func TestGrantAccess(t *testing.T) { assert.Error(t, actualError) }) - t.Run("should return error if error in decrypting the service account key", func(t *testing.T) { - expectedAccountType := "user" - expectedAccountID := "test@email.com" - crypto := new(mocks.Crypto) - client := new(mocks.GCSClient) - p := gcs.NewProvider("gcs", crypto) - p.Clients = map[string]gcs.GCSClient{ - "test-resource-name": client, - } - providerURN := "test-resource-name" - expectedError := errors.New("Error in decrypting service account key") - crypto.On("Decrypt", "c2VydmljZV9hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, expectedError) - - pc := &domain.ProviderConfig{ - Type: domain.ProviderTypeGCS, - URN: providerURN, - Credentials: gcs.Credentials{ - ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte("service_account-key-json")), - ResourceName: "projects/test-resource-name", - }, - Resources: []*domain.ResourceConfig{ - { - Type: gcs.ResourceTypeBucket, - Roles: []*domain.Role{ - { - ID: "Storage Legacy Bucket Writer", - Name: "Storage Legacy Bucket Writer", - Description: "Read access to buckets with object listing/creation/deletion", - Permissions: []interface{}{"roles/storage.legacyBucketWriter"}, - }, - }, - }, - }, - } - g := domain.Grant{ - Role: "Storage Legacy Bucket Writer", - Resource: &domain.Resource{ - URN: "test-bucket-name", - Name: "test-bucket-name", - ProviderType: "gcs", - ProviderURN: "test-resource-name", - Type: "bucket", - }, - ID: "999", - ResourceID: "999", - AccountType: expectedAccountType, - AccountID: expectedAccountID, - Permissions: []string{"Storage Legacy Bucket Writer"}, - } - - actualError := p.GrantAccess(pc, g) - - assert.Error(t, actualError) - }) - t.Run("should return error if error in getting the gcs client", func(t *testing.T) { expectedAccountType := "user" expectedAccountID := "test@email.com" - crypto := new(mocks.Crypto) - p := gcs.NewProvider("gcs", crypto) + p := gcs.NewProvider("gcs") providerURN := "test-resource-name" - crypto.On("Decrypt", "c2VydmljZV9hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, nil) - pc := &domain.ProviderConfig{ Type: domain.ProviderTypeGCS, URN: providerURN, @@ -481,15 +346,13 @@ func TestGrantAccess(t *testing.T) { expectedAccountType := "user" expectedAccountID := "test@email.com" - crypto := new(mocks.Crypto) client := new(mocks.GCSClient) - p := gcs.NewProvider("gcs", crypto) + p := gcs.NewProvider("gcs") p.Clients = map[string]gcs.GCSClient{ "test-resource-name": client, } providerURN := "test-resource-name" - crypto.On("Decrypt", "c2VydmljZV9hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, nil) client.On("GrantBucketAccess", mock.Anything, mock.Anything, mock.Anything, mock.Anything).Return(nil).Once() pc := &domain.ProviderConfig{ Type: domain.ProviderTypeGCS, @@ -637,70 +500,12 @@ func TestRevokeAccess(t *testing.T) { assert.Error(t, actualError) }) - t.Run("should return error if error in decrypting the service account key", func(t *testing.T) { - expectedAccountType := "user" - expectedAccountID := "test@email.com" - crypto := new(mocks.Crypto) - client := new(mocks.GCSClient) - p := gcs.NewProvider("gcs", crypto) - p.Clients = map[string]gcs.GCSClient{ - "test-resource-name": client, - } - providerURN := "test-resource-name" - expectedError := errors.New("Error in decrypting service account key") - crypto.On("Decrypt", "c2VydmljZV9hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, expectedError) - - pc := &domain.ProviderConfig{ - Type: domain.ProviderTypeGCS, - URN: providerURN, - Credentials: gcs.Credentials{ - ServiceAccountKey: base64.StdEncoding.EncodeToString([]byte("service_account-key-json")), - ResourceName: "projects/test-resource-name", - }, - Resources: []*domain.ResourceConfig{ - { - Type: gcs.ResourceTypeBucket, - Roles: []*domain.Role{ - { - ID: "Storage Legacy Bucket Writer", - Name: "Storage Legacy Bucket Writer", - Description: "Read access to buckets with object listing/creation/deletion", - Permissions: []interface{}{"roles/storage.legacyBucketWriter"}, - }, - }, - }, - }, - } - a := domain.Grant{ - Role: "Storage Legacy Bucket Writer", - Resource: &domain.Resource{ - URN: "test-bucket-name", - Name: "test-bucket-name", - ProviderType: "gcs", - ProviderURN: "test-resource-name", - Type: "bucket", - }, - ID: "999", - ResourceID: "999", - AccountType: expectedAccountType, - AccountID: expectedAccountID, - Permissions: []string{"Storage Legacy Bucket Writer"}, - } - - actualError := p.RevokeAccess(pc, a) - - assert.Error(t, actualError) - }) - t.Run("should return error if error in getting the gcs client", func(t *testing.T) { expectedAccountType := "user" expectedAccountID := "test@email.com" - crypto := new(mocks.Crypto) - p := gcs.NewProvider("gcs", crypto) + p := gcs.NewProvider("gcs") providerURN := "test-resource-name" - crypto.On("Decrypt", "c2VydmljZV9hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, nil) - pc := &domain.ProviderConfig{ Type: domain.ProviderTypeGCS, URN: providerURN, @@ -747,15 +552,13 @@ func TestRevokeAccess(t *testing.T) { expectedAccountType := "user" expectedAccountID := "test@email.com" - crypto := new(mocks.Crypto) client := new(mocks.GCSClient) - p := gcs.NewProvider("gcs", crypto) + p := gcs.NewProvider("gcs") p.Clients = map[string]gcs.GCSClient{ "test-resource-name": client, } providerURN := "test-resource-name" - crypto.On("Decrypt", "c2VydmljZV9hY2NvdW50LWtleS1qc29u").Return(`{"type":"service_account"}`, nil) client.On("RevokeBucketAccess", mock.Anything, mock.Anything, mock.Anything, mock.Anything).Return(nil).Once() pc := &domain.ProviderConfig{ Type: domain.ProviderTypeGCS, @@ -830,21 +633,18 @@ func TestGetAccountType(t *testing.T) { } func TestListAccess(t *testing.T) { - crypto := new(mocks.Crypto) client := new(mocks.GCSClient) - p := gcs.NewProvider("gcs", crypto) + p := gcs.NewProvider("gcs") providerURN := "test-resource-name" p.Clients = map[string]gcs.GCSClient{ providerURN: client, } - saKey := "service_account-key-json" - encryptedSAKey := "encrypted-service_account-key-json" dummyProviderConfig := &domain.ProviderConfig{ Type: domain.ProviderTypeGCS, URN: providerURN, Credentials: gcs.Credentials{ - ServiceAccountKey: encryptedSAKey, + ServiceAccountKey: "service_account-key-json", ResourceName: "projects/test-resource-name", }, Resources: []*domain.ResourceConfig{ @@ -862,7 +662,6 @@ func TestListAccess(t *testing.T) { }, } - crypto.EXPECT().Decrypt(encryptedSAKey).Return(saKey, nil).Once() dummyResources := []*domain.Resource{} expectedResourcesAccess := domain.MapResourceAccess{} client.EXPECT(). @@ -873,11 +672,9 @@ func TestListAccess(t *testing.T) { assert.Nil(t, err) assert.Equal(t, expectedResourcesAccess, actualResourcesAccess) - crypto.AssertExpectations(t) client.AssertExpectations(t) } func initProvider() *gcs.Provider { - crypto := new(mocks.Crypto) - return gcs.NewProvider("gcs", crypto) + return gcs.NewProvider("gcs") } diff --git a/plugins/providers/grafana/config.go b/plugins/providers/grafana/config.go index ada985be0..710516183 100644 --- a/plugins/providers/grafana/config.go +++ b/plugins/providers/grafana/config.go @@ -24,34 +24,6 @@ type Credentials struct { Password string `json:"password" mapstructure:"password" validate:"required"` } -func (c *Credentials) Encrypt(encryptor domain.Encryptor) error { - if c == nil { - return ErrUnableToEncryptNilCredentials - } - - encryptedPassword, err := encryptor.Encrypt(c.Password) - if err != nil { - return err - } - - c.Password = encryptedPassword - return nil -} - -func (c *Credentials) Decrypt(decryptor domain.Decryptor) error { - if c == nil { - return ErrUnableToDecryptNilCredentials - } - - decryptedPassword, err := decryptor.Decrypt(c.Password) - if err != nil { - return err - } - - c.Password = decryptedPassword - return nil -} - var permissionCodes = map[string]int{ "view": 1, "edit": 2, @@ -64,15 +36,13 @@ type Config struct { ProviderConfig *domain.ProviderConfig valid bool - crypto domain.Crypto validator *validator.Validate } -func NewConfig(pc *domain.ProviderConfig, crypto domain.Crypto) *Config { +func NewConfig(pc *domain.ProviderConfig) *Config { return &Config{ ProviderConfig: pc, validator: validator.New(), - crypto: crypto, } } @@ -80,24 +50,6 @@ func (c *Config) ParseAndValidate() error { return c.parseAndValidate() } -func (c *Config) EncryptCredentials() error { - if err := c.parseAndValidate(); err != nil { - return err - } - - credentials, ok := c.ProviderConfig.Credentials.(*Credentials) - if !ok { - return ErrInvalidCredentials - } - - if err := credentials.Encrypt(c.crypto); err != nil { - return err - } - - c.ProviderConfig.Credentials = credentials - return nil -} - func (c *Config) parseAndValidate() error { if c.valid { return nil diff --git a/plugins/providers/grafana/config_test.go b/plugins/providers/grafana/config_test.go index 54861e8be..0b89c281c 100644 --- a/plugins/providers/grafana/config_test.go +++ b/plugins/providers/grafana/config_test.go @@ -1,95 +1 @@ package grafana_test - -import ( - "errors" - "testing" - - "github.com/goto/guardian/mocks" - "github.com/goto/guardian/plugins/providers/grafana" - "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/mock" -) - -func TestCredentials(t *testing.T) { - encryptor := new(mocks.Encryptor) - decryptor := new(mocks.Decryptor) - - t.Run("encrypt", func(t *testing.T) { - t.Run("should return error if creds is nil", func(t *testing.T) { - var creds *grafana.Credentials - expectedError := grafana.ErrUnableToEncryptNilCredentials - - actualError := creds.Encrypt(encryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return error if encryptor failed to encrypt the creds", func(t *testing.T) { - creds := grafana.Credentials{} - expectedError := errors.New("encryptor error") - encryptor.On("Encrypt", mock.Anything).Return("", expectedError).Once() - - actualError := creds.Encrypt(encryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return encrypted password inside Credentials on success", func(t *testing.T) { - username := "username" - password := "password" - creds := grafana.Credentials{ - Host: "http://localhost:4000", - Username: username, - Password: password, - } - - expectedEncryptedApiKey := "encrypted_api_key" - encryptor.On("Encrypt", password).Return(expectedEncryptedApiKey, nil).Once() - - actualError := creds.Encrypt(encryptor) - - assert.Nil(t, actualError) - assert.Equal(t, expectedEncryptedApiKey, creds.Password) - }) - }) - - t.Run("decrypt", func(t *testing.T) { - t.Run("should return error if creds is nil", func(t *testing.T) { - var creds *grafana.Credentials - - expectedError := grafana.ErrUnableToDecryptNilCredentials - - actualError := creds.Decrypt(decryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return error if decryptor failed to decrypt the creds", func(t *testing.T) { - creds := grafana.Credentials{} - expectedError := errors.New("decryptor error") - decryptor.On("Decrypt", mock.Anything).Return("", expectedError).Once() - - actualError := creds.Decrypt(decryptor) - - assert.EqualError(t, actualError, expectedError.Error()) - }) - - t.Run("should return decrypted password inside Credentials on success", func(t *testing.T) { - username := "username" - password := "encrypted_password" - creds := grafana.Credentials{ - Host: "http://localhost:3000", - Username: username, - Password: password, - } - - expectedDecryptedApiKey := "decrypted_api_key" - decryptor.On("Decrypt", password).Return(expectedDecryptedApiKey, nil).Once() - - actualError := creds.Decrypt(decryptor) - - assert.Nil(t, actualError) - assert.Equal(t, expectedDecryptedApiKey, creds.Password) - }) - }) -} diff --git a/plugins/providers/grafana/provider.go b/plugins/providers/grafana/provider.go index 61ca20f7a..bcc449ac2 100644 --- a/plugins/providers/grafana/provider.go +++ b/plugins/providers/grafana/provider.go @@ -12,14 +12,12 @@ type provider struct { typeName string Clients map[string]GrafanaClient - crypto domain.Crypto } -func NewProvider(typeName string, crypto domain.Crypto) *provider { +func NewProvider(typeName string) *provider { return &provider{ typeName: typeName, Clients: map[string]GrafanaClient{}, - crypto: crypto, } } @@ -28,13 +26,8 @@ func (p *provider) GetType() string { } func (p *provider) CreateConfig(pc *domain.ProviderConfig) error { - c := NewConfig(pc, p.crypto) - - if err := c.ParseAndValidate(); err != nil { - return err - } - - return c.EncryptCredentials() + c := NewConfig(pc) + return c.ParseAndValidate() } func (p *provider) GetResources(pc *domain.ProviderConfig) ([]*domain.Resource, error) { @@ -142,10 +135,6 @@ func (p *provider) getClient(providerURN string, credentials Credentials) (Grafa return p.Clients[providerURN], nil } - if err := credentials.Decrypt(p.crypto); err != nil { - return nil, err - } - org := providerURN client, err := NewClient(&ClientConfig{ Host: credentials.Host, diff --git a/plugins/providers/grafana/provider_test.go b/plugins/providers/grafana/provider_test.go index a8246e460..4df4aab07 100644 --- a/plugins/providers/grafana/provider_test.go +++ b/plugins/providers/grafana/provider_test.go @@ -14,8 +14,7 @@ import ( func TestGetType(t *testing.T) { t.Run("should return provider type name", func(t *testing.T) { expectedTypeName := domain.ProviderTypeGrafana - crypto := new(mocks.Crypto) - p := grafana.NewProvider(expectedTypeName, crypto) + p := grafana.NewProvider(expectedTypeName) actualTypeName := p.GetType() @@ -26,9 +25,8 @@ func TestGetType(t *testing.T) { func TestCreateConfig(t *testing.T) { t.Run("should return error if there credentials are invalid", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -64,9 +62,8 @@ func TestCreateConfig(t *testing.T) { t.Run("should return error if there resource config is invalid", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -118,13 +115,11 @@ func TestCreateConfig(t *testing.T) { t.Run("should not return error if parse and valid of Credentials are correct", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } - crypto.On("Encrypt", "test-password").Return("encrypted-test-pasword", nil) testcases := []struct { pc *domain.ProviderConfig @@ -179,15 +174,13 @@ func TestCreateConfig(t *testing.T) { for _, tc := range testcases { actualError := p.CreateConfig(tc.pc) assert.Equal(t, tc.expectedError, actualError) - crypto.AssertExpectations(t) } }) } func TestGetResources(t *testing.T) { t.Run("should return error if credentials is invalid", func(t *testing.T) { - crypto := new(mocks.Crypto) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") pc := &domain.ProviderConfig{ Credentials: "invalid-creds", @@ -200,28 +193,24 @@ func TestGetResources(t *testing.T) { }) t.Run("should return error if there are any on client initialization", func(t *testing.T) { - crypto := new(mocks.Crypto) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") - expectedError := errors.New("decrypt error") - crypto.On("Decrypt", "test-password").Return("", expectedError).Once() pc := &domain.ProviderConfig{ Credentials: map[string]interface{}{ - "password": "test-password", + "password": 1, }, } actualResources, actualError := p.GetResources(pc) assert.Nil(t, actualResources) - assert.EqualError(t, actualError, expectedError.Error()) + assert.ErrorContains(t, actualError, "1 error(s) decoding:\n\n* 'password' expected type 'string', got unconvertible type 'int'") }) t.Run("should return error if got any on getting folder resources", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -241,9 +230,8 @@ func TestGetResources(t *testing.T) { t.Run("should return error if got any on getting dashboard resources", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -270,9 +258,8 @@ func TestGetResources(t *testing.T) { t.Run("should return list of resources and nil error on success", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -314,8 +301,7 @@ func TestGetResources(t *testing.T) { func TestGrantAccess(t *testing.T) { t.Run("should return error if credentials is invalid", func(t *testing.T) { - crypto := new(mocks.Crypto) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") pc := &domain.ProviderConfig{ Credentials: "invalid-credentials", @@ -343,18 +329,9 @@ func TestGrantAccess(t *testing.T) { }) t.Run("should return error if there are any on client initialization", func(t *testing.T) { - password := "test-password" - crypto := new(mocks.Crypto) - p := grafana.NewProvider("", crypto) - expectedError := errors.New("decrypt error") - crypto.On("Decrypt", password).Return("", expectedError).Once() - + p := grafana.NewProvider("") pc := &domain.ProviderConfig{ - Credentials: grafana.Credentials{ - Host: "localhost", - Username: "test-username", - Password: password, - }, + Credentials: grafana.Credentials{}, // empty credentials Resources: []*domain.ResourceConfig{ { Type: "test-type", @@ -376,19 +353,17 @@ func TestGrantAccess(t *testing.T) { actualError := p.GrantAccess(pc, a) - assert.EqualError(t, actualError, expectedError.Error()) + assert.Error(t, actualError) }) t.Run("should return error if resource type in unknown", func(t *testing.T) { password := "test-password" - crypto := new(mocks.Crypto) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") expectedError := errors.New("invalid resource type") - crypto.On("Decrypt", password).Return("", expectedError).Once() pc := &domain.ProviderConfig{ Credentials: grafana.Credentials{ - Host: "localhost", + Host: "http://localhost", Username: "test-username", Password: password, }, @@ -421,9 +396,8 @@ func TestGrantAccess(t *testing.T) { t.Run("should return error if there is an error in granting dashboard access", func(t *testing.T) { providerURN := "test-provider-urn" expectedError := errors.New("client error") - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -465,7 +439,6 @@ func TestGrantAccess(t *testing.T) { t.Run("should return nil error if granting access is successful", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) expectedDatabase := &grafana.Dashboard{ Title: "test-dashboard", @@ -473,7 +446,7 @@ func TestGrantAccess(t *testing.T) { } expectedUser := "test@email.com" expectedRole := grafana.DashboardRoleViewer - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -519,8 +492,7 @@ func TestGrantAccess(t *testing.T) { func TestRevokeAccess(t *testing.T) { t.Run("should return error if credentials is invalid", func(t *testing.T) { - crypto := new(mocks.Crypto) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") pc := &domain.ProviderConfig{ Credentials: "invalid-credentials", @@ -548,18 +520,9 @@ func TestRevokeAccess(t *testing.T) { }) t.Run("should return error if there are any on client initialization", func(t *testing.T) { - password := "test-password" - crypto := new(mocks.Crypto) - p := grafana.NewProvider("", crypto) - expectedError := errors.New("decrypt error") - crypto.On("Decrypt", password).Return("", expectedError).Once() - + p := grafana.NewProvider("") pc := &domain.ProviderConfig{ - Credentials: grafana.Credentials{ - Host: "localhost", - Username: "test-username", - Password: password, - }, + Credentials: grafana.Credentials{}, // empty credentials Resources: []*domain.ResourceConfig{ { Type: "test-type", @@ -581,19 +544,17 @@ func TestRevokeAccess(t *testing.T) { actualError := p.RevokeAccess(pc, a) - assert.EqualError(t, actualError, expectedError.Error()) + assert.Error(t, actualError) }) t.Run("should return error if resource type in unknown", func(t *testing.T) { password := "test-password" - crypto := new(mocks.Crypto) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") expectedError := errors.New("invalid resource type") - crypto.On("Decrypt", password).Return("", expectedError).Once() pc := &domain.ProviderConfig{ Credentials: grafana.Credentials{ - Host: "localhost", + Host: "http://localhost", Username: "test-username", Password: password, }, @@ -626,9 +587,8 @@ func TestRevokeAccess(t *testing.T) { t.Run("should return error if there is an error in revoking dashboard access", func(t *testing.T) { providerURN := "test-provider-urn" expectedError := errors.New("client error") - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -671,7 +631,6 @@ func TestRevokeAccess(t *testing.T) { t.Run("should return nil error if revoking access is successful", func(t *testing.T) { providerURN := "test-provider-urn" - crypto := new(mocks.Crypto) client := new(mocks.GrafanaClient) expectedDatabase := &grafana.Dashboard{ Title: "test-dashboard", @@ -679,7 +638,7 @@ func TestRevokeAccess(t *testing.T) { } expectedUser := "test@email.com" expectedRole := grafana.DashboardRoleViewer - p := grafana.NewProvider("", crypto) + p := grafana.NewProvider("") p.Clients = map[string]grafana.GrafanaClient{ providerURN: client, } @@ -727,8 +686,7 @@ func TestRevokeAccess(t *testing.T) { func TestGetRoles(t *testing.T) { t.Run("should return an error if invalid resource type", func(t *testing.T) { expectedError := grafana.ErrInvalidResourceType - crypto := new(mocks.Crypto) - pv := grafana.NewProvider("grafana", crypto) + pv := grafana.NewProvider("grafana") validconfig := &domain.ProviderConfig{ Type: "grafana", Credentials: grafana.Credentials{ @@ -758,8 +716,7 @@ func TestGetRoles(t *testing.T) { Permissions: []interface{}{"view"}, }, } - crypto := new(mocks.Crypto) - pv := grafana.NewProvider("grafana", crypto) + pv := grafana.NewProvider("grafana") validconfig := &domain.ProviderConfig{ Type: "grafana", Credentials: grafana.Credentials{ @@ -786,8 +743,7 @@ func TestGetRoles(t *testing.T) { func TestGetAccountTypes(t *testing.T) { t.Run("should return the list of supported account types (user only)", func(t *testing.T) { - crypto := new(mocks.Crypto) - pv := grafana.NewProvider("grafana", crypto) + pv := grafana.NewProvider("grafana") expectedAccountTypes := []string{"user"} actualAccountTypes := pv.GetAccountTypes()