2018-08-23 00:50:52 +00:00
|
|
|
package identity
|
2018-04-23 17:46:14 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/vault/api"
|
|
|
|
vaulthttp "github.com/hashicorp/vault/http"
|
2019-04-12 21:54:35 +00:00
|
|
|
"github.com/hashicorp/vault/sdk/logical"
|
2018-04-23 17:46:14 +00:00
|
|
|
"github.com/hashicorp/vault/vault"
|
|
|
|
|
|
|
|
credLdap "github.com/hashicorp/vault/builtin/credential/ldap"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestIdentityStore_GroupAliasLocalMount(t *testing.T) {
|
|
|
|
coreConfig := &vault.CoreConfig{
|
|
|
|
CredentialBackends: map[string]logical.Factory{
|
|
|
|
"ldap": credLdap.Factory,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
cluster := vault.NewTestCluster(t, coreConfig, &vault.TestClusterOptions{
|
|
|
|
HandlerFunc: vaulthttp.Handler,
|
|
|
|
})
|
|
|
|
cluster.Start()
|
|
|
|
defer cluster.Cleanup()
|
|
|
|
|
|
|
|
core := cluster.Cores[0].Core
|
|
|
|
vault.TestWaitActive(t, core)
|
|
|
|
client := cluster.Cores[0].Client
|
|
|
|
|
|
|
|
// Create a local auth mount
|
|
|
|
err := client.Sys().EnableAuthWithOptions("ldap", &api.EnableAuthOptions{
|
|
|
|
Type: "ldap",
|
|
|
|
Local: true,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Extract out the mount accessor for LDAP auth
|
|
|
|
auths, err := client.Sys().ListAuth()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
ldapMountAccessor := auths["ldap/"].Accessor
|
|
|
|
|
|
|
|
// Create an external group
|
|
|
|
secret, err := client.Logical().Write("identity/group", map[string]interface{}{
|
|
|
|
"type": "external",
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
groupID := secret.Data["id"].(string)
|
|
|
|
|
|
|
|
// Attempt to create a group alias against a local mount should fail
|
|
|
|
secret, err = client.Logical().Write("identity/group-alias", map[string]interface{}{
|
|
|
|
"name": "testuser",
|
|
|
|
"mount_accessor": ldapMountAccessor,
|
|
|
|
"canonical_id": groupID,
|
|
|
|
})
|
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("expected error since mount is local")
|
|
|
|
}
|
|
|
|
}
|