zrok/controller/sharePrivate.go

54 lines
1.8 KiB
Go
Raw Normal View History

2022-11-22 21:31:02 +01:00
package controller
import (
2023-05-25 17:50:38 +02:00
"github.com/openziti/edge-api/rest_management_api_client"
"github.com/openziti/zrok/controller/zrokEdgeSdk"
"github.com/openziti/zrok/rest_server_zrok/operations/share"
"github.com/openziti/zrok/sdk"
2022-11-22 21:31:02 +01:00
)
type privateResourceAllocator struct{}
func newPrivateResourceAllocator() *privateResourceAllocator {
return &privateResourceAllocator{}
}
2023-01-04 20:42:58 +01:00
func (a *privateResourceAllocator) allocate(envZId, shrToken string, params share.ShareParams, edge *rest_management_api_client.ZitiEdgeManagement) (shrZId string, frontendEndpoints []string, err error) {
var authUsers []*sdk.AuthUserConfig
2022-11-22 21:31:02 +01:00
for _, authUser := range params.Body.AuthUsers {
authUsers = append(authUsers, &sdk.AuthUserConfig{Username: authUser.Username, Password: authUser.Password})
2022-11-22 21:31:02 +01:00
}
2023-09-25 20:15:19 +02:00
authScheme, err := sdk.ParseAuthScheme(params.Body.AuthScheme)
if err != nil {
return "", nil, err
}
options := &zrokEdgeSdk.FrontendOptions{
2023-09-25 20:15:19 +02:00
AuthScheme: authScheme,
BasicAuthUsers: authUsers,
2023-09-25 20:06:14 +02:00
Oauth: &sdk.OauthConfig{
Provider: params.Body.OauthProvider,
EmailDomains: params.Body.OauthEmailDomains,
AuthorizationCheckInterval: params.Body.OauthAuthorizationCheckInterval,
},
}
cfgZId, err := zrokEdgeSdk.CreateConfig(zrokProxyConfigId, envZId, shrToken, options, edge)
2022-11-22 21:31:02 +01:00
if err != nil {
return "", nil, err
}
2023-01-04 20:42:58 +01:00
shrZId, err = zrokEdgeSdk.CreateShareService(envZId, shrToken, cfgZId, edge)
2022-11-22 21:31:02 +01:00
if err != nil {
return "", nil, err
}
2023-01-04 20:42:58 +01:00
if err := zrokEdgeSdk.CreateServicePolicyBind(envZId+"-"+shrZId+"-bind", shrZId, envZId, zrokEdgeSdk.ZrokShareTags(shrToken).SubTags, edge); err != nil {
2022-11-22 21:31:02 +01:00
return "", nil, err
}
2023-01-04 20:42:58 +01:00
if err := zrokEdgeSdk.CreateShareServiceEdgeRouterPolicy(envZId, shrToken, shrZId, edge); err != nil {
2022-11-22 21:31:02 +01:00
return "", nil, err
}
2023-01-04 20:42:58 +01:00
return shrZId, nil, nil
2022-11-22 21:31:02 +01:00
}