-
Notifications
You must be signed in to change notification settings - Fork 187
/
azuresqlmanageduser_manager.go
30 lines (23 loc) · 1.26 KB
/
azuresqlmanageduser_manager.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT License.
package azuresqlmanageduser
import (
"context"
"database/sql"
azuresql "github.com/Azure/azure-sdk-for-go/services/preview/sql/mgmt/v3.0/sql"
"github.com/Azure/azure-service-operator/api/v1alpha1"
"github.com/Azure/azure-service-operator/pkg/resourcemanager"
"github.com/Azure/azure-service-operator/pkg/secrets"
)
type SqlManagedUserManager interface {
GetDB(ctx context.Context, resourceGroupName string, serverName string, databaseName string) (azuresql.Database, error)
ConnectToSqlDbAsCurrentUser(ctx context.Context, drivername string, server string, dbname string) (*sql.DB, error)
DeleteSecrets(ctx context.Context, instance *v1alpha1.AzureSQLManagedUser, secretClient secrets.SecretClient) error
UpdateSecret(ctx context.Context, instance *v1alpha1.AzureSQLManagedUser, secretClient secrets.SecretClient) error
EnableUser(ctx context.Context, MIName string, MIUserClientId string, db *sql.DB) error
GrantUserRoles(ctx context.Context, user string, roles []string, db *sql.DB) error
DropUser(ctx context.Context, db *sql.DB, user string) error
UserExists(ctx context.Context, db *sql.DB, username string) (bool, error)
// also embed methods from AsyncClient
resourcemanager.ARMClient
}