mirror of
https://github.com/kubevela/kubevela.git
synced 2026-05-14 13:26:44 +00:00
* Feat: add the rbac data model Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: add some api about the project Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: add CRUD about the project and the project user Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: add CRUD about the role and perm check filter function Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: update swagger config Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: add default roles and perm policies Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: add perm check filter for all webservice Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: change the method that find project name Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: query applications and envs by user perm Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: support get login user info Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Fix: change default permissions Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: change PermPolicy to Permission Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Feat: add some unit test and fix the e2e test error Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Fix: change some comment word Signed-off-by: barnettZQG <barnett.zqg@gmail.com> * Fix: e2e api path error Signed-off-by: barnettZQG <barnett.zqg@gmail.com>
116 lines
3.6 KiB
Go
116 lines
3.6 KiB
Go
/*
|
|
Copyright 2022 The KubeVela Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package sync
|
|
|
|
import (
|
|
"context"
|
|
"strconv"
|
|
"strings"
|
|
|
|
"github.com/oam-dev/kubevela/apis/core.oam.dev/v1beta1"
|
|
"github.com/oam-dev/kubevela/pkg/apiserver/model"
|
|
"github.com/oam-dev/kubevela/pkg/apiserver/sync/convert"
|
|
"github.com/oam-dev/kubevela/pkg/oam"
|
|
"github.com/oam-dev/kubevela/pkg/workflow/step"
|
|
)
|
|
|
|
// ConvertApp2DatastoreApp will convert Application CR to datastore application related resources
|
|
func (c *CR2UX) ConvertApp2DatastoreApp(ctx context.Context, targetApp *v1beta1.Application) (*model.DataStoreApp, error) {
|
|
cli := c.cli
|
|
|
|
appName := c.getAppMetaName(ctx, targetApp.Name, targetApp.Namespace)
|
|
|
|
project := model.DefaultInitName
|
|
if _, ok := targetApp.Labels[oam.LabelAddonName]; ok && strings.HasPrefix(targetApp.Name, "addon-") {
|
|
project = model.DefaultAddonProject
|
|
}
|
|
appMeta := &model.Application{
|
|
Name: appName,
|
|
Description: model.AutoGenDesc,
|
|
Alias: targetApp.Name,
|
|
Project: project,
|
|
Labels: map[string]string{
|
|
model.LabelSyncNamespace: targetApp.Namespace,
|
|
model.LabelSyncGeneration: strconv.FormatInt(targetApp.Generation, 10),
|
|
model.LabelSourceOfTruth: model.FromCR,
|
|
},
|
|
}
|
|
|
|
// 1. convert app meta and env
|
|
dsApp := &model.DataStoreApp{
|
|
AppMeta: appMeta,
|
|
Env: &model.Env{
|
|
Name: model.AutoGenEnvNamePrefix + targetApp.Namespace,
|
|
Namespace: targetApp.Namespace,
|
|
Description: model.AutoGenDesc,
|
|
Project: project,
|
|
Alias: model.AutoGenEnvNamePrefix + targetApp.Namespace,
|
|
},
|
|
Eb: &model.EnvBinding{
|
|
AppPrimaryKey: appMeta.PrimaryKey(),
|
|
Name: model.AutoGenEnvNamePrefix + targetApp.Namespace,
|
|
AppDeployName: appMeta.GetAppNameForSynced(),
|
|
},
|
|
}
|
|
|
|
// 2. convert component and trait
|
|
for _, cmp := range targetApp.Spec.Components {
|
|
compModel, err := convert.FromCRComponent(appMeta.PrimaryKey(), cmp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
dsApp.Comps = append(dsApp.Comps, &compModel)
|
|
}
|
|
|
|
// 3. convert workflow
|
|
wf, steps, err := convert.FromCRWorkflow(ctx, cli, appMeta.PrimaryKey(), targetApp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
dsApp.Workflow = &wf
|
|
|
|
// 4. convert policy, some policies are references in workflow step, we need to sync all the outside policy to make that work
|
|
var innerPlc = make(map[string]struct{})
|
|
for _, plc := range targetApp.Spec.Policies {
|
|
innerPlc[plc.Name] = struct{}{}
|
|
}
|
|
outsidePLC, err := step.LoadExternalPoliciesForWorkflow(ctx, cli, targetApp.Namespace, steps, targetApp.Spec.Policies)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
for _, plc := range outsidePLC {
|
|
plcModel, err := convert.FromCRPolicy(appMeta.PrimaryKey(), plc, model.AutoGenRefPolicy)
|
|
if _, ok := innerPlc[plc.Name]; ok {
|
|
plcModel.Creator = model.AutoGenPolicy
|
|
}
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
dsApp.Policies = append(dsApp.Policies, &plcModel)
|
|
}
|
|
|
|
// TODO(wonderflow): we don't sync targets as it can't be judged well in velaux env
|
|
// if we want to sync, we can extract targets from status, like below:
|
|
/*
|
|
dsApp.Targets = ConvertFromCRTargets(targetApp)
|
|
for _, t := range dsApp.Targets {
|
|
dsApp.Env.Targets = append(dsApp.Env.Targets, t.Name)
|
|
}
|
|
*/
|
|
return dsApp, nil
|
|
}
|