mirror of
https://github.com/pomerium/pomerium.git
synced 2025-04-28 18:06:34 +02:00
* sessions: add impersonate_session_id, remove legacy impersonation
* show impersonated user details
* fix headers
* address feedback
* only check impersonate id on non-nil pbSession
* Revert "only check impersonate id on non-nil pbSession"
This reverts commit a6f7ca5abd
.
78 lines
1.7 KiB
Go
78 lines
1.7 KiB
Go
package criteria
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
"google.golang.org/protobuf/proto"
|
|
|
|
"github.com/pomerium/pomerium/pkg/grpc/session"
|
|
"github.com/pomerium/pomerium/pkg/grpc/user"
|
|
)
|
|
|
|
func TestEmails(t *testing.T) {
|
|
t.Run("no session", func(t *testing.T) {
|
|
res, err := evaluate(t, `
|
|
allow:
|
|
and:
|
|
- email:
|
|
is: test@example.com
|
|
`, []dataBrokerRecord{}, Input{Session: InputSession{ID: "SESSION_ID"}})
|
|
require.NoError(t, err)
|
|
require.Equal(t, false, res["allow"])
|
|
require.Equal(t, false, res["deny"])
|
|
})
|
|
t.Run("by email", func(t *testing.T) {
|
|
res, err := evaluate(t, `
|
|
allow:
|
|
and:
|
|
- email:
|
|
is: test@example.com
|
|
`,
|
|
[]dataBrokerRecord{
|
|
&session.Session{
|
|
Id: "SESSION_ID",
|
|
UserId: "USER_ID",
|
|
},
|
|
&user.User{
|
|
Id: "USER_ID",
|
|
Email: "test@example.com",
|
|
},
|
|
},
|
|
Input{Session: InputSession{ID: "SESSION_ID"}})
|
|
require.NoError(t, err)
|
|
require.Equal(t, true, res["allow"])
|
|
require.Equal(t, false, res["deny"])
|
|
})
|
|
t.Run("by impersonate session id", func(t *testing.T) {
|
|
res, err := evaluate(t, `
|
|
allow:
|
|
and:
|
|
- email:
|
|
is: test2@example.com
|
|
`,
|
|
[]dataBrokerRecord{
|
|
&session.Session{
|
|
Id: "SESSION1",
|
|
UserId: "USER1",
|
|
ImpersonateSessionId: proto.String("SESSION2"),
|
|
},
|
|
&session.Session{
|
|
Id: "SESSION2",
|
|
UserId: "USER2",
|
|
},
|
|
&user.User{
|
|
Id: "USER1",
|
|
Email: "test1@example.com",
|
|
},
|
|
&user.User{
|
|
Id: "USER2",
|
|
Email: "test2@example.com",
|
|
},
|
|
},
|
|
Input{Session: InputSession{ID: "SESSION1"}})
|
|
require.NoError(t, err)
|
|
require.Equal(t, true, res["allow"])
|
|
require.Equal(t, false, res["deny"])
|
|
})
|
|
}
|