| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- // Copyright 2019 Yunion
- //
- // 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 cloudpods
- import (
- "yunion.io/x/cloudmux/pkg/cloudprovider"
- "yunion.io/x/cloudmux/pkg/multicloud"
- api "yunion.io/x/onecloud/pkg/apis/compute"
- modules "yunion.io/x/onecloud/pkg/mcclient/modules/compute"
- )
- type SSecurityGroup struct {
- multicloud.SSecurityGroup
- CloudpodsTags
- region *SRegion
- api.SecgroupDetails
- }
- func (self *SSecurityGroup) GetName() string {
- return self.Name
- }
- func (self *SSecurityGroup) GetDescription() string {
- return self.Description
- }
- func (self *SSecurityGroup) GetId() string {
- return self.Id
- }
- func (self *SSecurityGroup) GetGlobalId() string {
- return self.Id
- }
- func (self *SSecurityGroup) GetStatus() string {
- return self.Status
- }
- func (self *SSecurityGroup) GetProjectId() string {
- return self.TenantId
- }
- func (self *SSecurityGroup) GetRules() ([]cloudprovider.ISecurityGroupRule, error) {
- ret := []cloudprovider.ISecurityGroupRule{}
- rules := []SecurityGroupRule{}
- err := self.region.list(&modules.SecGroupRules, map[string]interface{}{"scope": "system", "secgroup_id": self.Id}, &rules)
- if err != nil {
- return nil, err
- }
- for i := range rules {
- rules[i].region = self.region
- ret = append(ret, &rules[i])
- }
- return ret, nil
- }
- func (self *SSecurityGroup) GetVpcId() string {
- return ""
- }
- func (self *SSecurityGroup) GetReferences() ([]cloudprovider.SecurityGroupReference, error) {
- params := map[string]interface{}{
- "secgroup_id": self.Id,
- }
- servers := []SInstance{}
- err := self.region.list(&modules.Servers, params, &servers)
- if err != nil {
- return nil, err
- }
- ret := []cloudprovider.SecurityGroupReference{}
- for i := range servers {
- ret = append(ret, cloudprovider.SecurityGroupReference{
- Id: servers[i].Id,
- Name: servers[i].Name,
- })
- }
- return ret, nil
- }
- func (self *SRegion) DeleteSecRule(id string) error {
- return self.cli.delete(&modules.SecGroupRules, id)
- }
- func (self *SSecurityGroup) CreateRule(opts *cloudprovider.SecurityGroupRuleCreateOptions) (cloudprovider.ISecurityGroupRule, error) {
- return self.region.CreateSecRule(self.Id, opts)
- }
- func (self *SRegion) CreateSecRule(secId string, opts *cloudprovider.SecurityGroupRuleCreateOptions) (*SecurityGroupRule, error) {
- input := api.SSecgroupRuleCreateInput{}
- input.SecgroupId = secId
- input.Priority = &opts.Priority
- input.Action = string(opts.Action)
- input.Protocol = string(opts.Protocol)
- input.Direction = string(opts.Direction)
- input.Description = opts.Desc
- input.CIDR = opts.CIDR
- input.Ports = opts.Ports
- ret := &SecurityGroupRule{region: self}
- err := self.create(&modules.SecGroupRules, input, &ret)
- if err != nil {
- return nil, err
- }
- return ret, nil
- }
- func (self *SSecurityGroup) Delete() error {
- return self.region.cli.delete(&modules.SecGroups, self.Id)
- }
- func (self *SRegion) GetSecurityGroups() ([]SSecurityGroup, error) {
- params := map[string]interface{}{
- "cloud_env": "onpremise",
- }
- ret := []SSecurityGroup{}
- return ret, self.cli.list(&modules.SecGroups, params, &ret)
- }
- func (self *SRegion) GetSecurityGroup(id string) (*SSecurityGroup, error) {
- secgroup := &SSecurityGroup{region: self}
- return secgroup, self.cli.get(&modules.SecGroups, id, nil, secgroup)
- }
- func (self *SRegion) CreateISecurityGroup(opts *cloudprovider.SecurityGroupCreateInput) (cloudprovider.ICloudSecurityGroup, error) {
- params := map[string]interface{}{
- "name": opts.Name,
- "description": opts.Desc,
- }
- if len(opts.ProjectId) > 0 {
- params["project_id"] = opts.ProjectId
- }
- secgroup := &SSecurityGroup{region: self}
- return secgroup, self.create(&modules.SecGroups, params, secgroup)
- }
- func (self *SRegion) GetISecurityGroups() ([]cloudprovider.ICloudSecurityGroup, error) {
- secgroups, err := self.GetSecurityGroups()
- if err != nil {
- return nil, err
- }
- ret := []cloudprovider.ICloudSecurityGroup{}
- for i := range secgroups {
- secgroups[i].region = self
- ret = append(ret, &secgroups[i])
- }
- return ret, nil
- }
- func (self *SRegion) GetISecurityGroupById(secgroupId string) (cloudprovider.ICloudSecurityGroup, error) {
- secgroup, err := self.GetSecurityGroup(secgroupId)
- if err != nil {
- return nil, err
- }
- return secgroup, nil
- }
|