Skip to content

Commit

Permalink
Added code for Apigee environment groups (#4570)
Browse files Browse the repository at this point in the history
* Added code for Apigee Environment

* Update api.yaml

* Update api.yaml

* Added code for Apigee Environment

* Added code for Apigee environment groups

* Update api.yaml

* Added code for Apigee Environment

* Update api.yaml

* Update api.yaml

* Added code for Apigee Environment

* Incorporating review comments for Apigee environment groups

* Incorporating review comments for Apigee environment groups

* Update reverse_check_membership.sh

* Update reverse_check_membership.sh

* Update check_membership.sh

* Update mmv1/products/apigee/api.yaml

Co-authored-by: Sam Levenick <slevenick@google.com>

* Added code for Apigee Environment

* Update api.yaml

* Update api.yaml

* Added code for Apigee Environment

* Update api.yaml

* Added code for Apigee Environment

* Update api.yaml

* Update api.yaml

* Added code for Apigee Environment

* Update api.yaml

* Update api.yaml

* Added code for Apigee Environment

* Update api.yaml

* Added code for Apigee Environment

* Update api.yaml

* Update api.yaml

* Added code for Apigee Environment

* Update mmv1/products/apigee/api.yaml

Co-authored-by: Sam Levenick <slevenick@google.com>

* fixing .ci errors

Co-authored-by: Sam Levenick <slevenick@google.com>
  • Loading branch information
priya-saxena21 and slevenick authored Mar 10, 2021
1 parent 7acd4f9 commit 1f1a032
Show file tree
Hide file tree
Showing 5 changed files with 209 additions and 0 deletions.
51 changes: 51 additions & 0 deletions mmv1/products/apigee/api.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -263,3 +263,54 @@ objects:
'Creating an environment':
'https://cloud.google.com/apigee/docs/api-platform/get-started/create-environment'
api: 'https://cloud.google.com/apigee/docs/reference/apis/apigee/rest/v1/organizations.environments/create'
- !ruby/object:Api::Resource
name: 'Envgroup'
base_url: 'envgroups'
create_url: '{{org_id}}/envgroups'
self_link: '{{org_id}}/envgroups/{{name}}'
async: !ruby/object:Api::OpAsync
operation: !ruby/object:Api::OpAsync::Operation
path: 'name'
base_url: '{{op_id}}'
wait_ms: 1000
result: !ruby/object:Api::OpAsync::Result
path: 'response'
resource_inside_response: true
status: !ruby/object:Api::OpAsync::Status
path: 'done'
complete: True
allowed:
- True
- False
error: !ruby/object:Api::OpAsync::Error
path: 'error'
message: 'message'
description: |
An `Environment group` in Apigee.
parameters:
- !ruby/object:Api::Type::String
name: 'orgId'
description: |
The Apigee Organization associated with the Apigee environment group,
in the format `organizations/{{org_name}}`.
required: true
input: true
url_param_only: true
properties:
- !ruby/object:Api::Type::String
name: 'name'
description: |
The resource ID of the environment group.
required: true
input: true
- !ruby/object:Api::Type::Array
name: 'hostnames'
description: |
Hostnames of the environment group.
required: false
item_type: Api::Type::String
references: !ruby/object:Api::Resource::ReferenceLinks
guides:
'Creating an environment':
'https://cloud.google.com/apigee/docs/api-platform/get-started/create-environment'
api: 'https://cloud.google.com/apigee/docs/reference/apis/apigee/rest/v1/organizations.envgroups/create'
23 changes: 23 additions & 0 deletions mmv1/products/apigee/terraform.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,29 @@ overrides: !ruby/object:Overrides::ResourceOverrides
delete_minutes: 30
custom_code: !ruby/object:Provider::Terraform::CustomCode
custom_import: templates/terraform/custom_import/apigee_environment.go.erb
Envgroup: !ruby/object:Overrides::Terraform::ResourceOverride
autogen_async: true
import_format: ["{{org_id}}/envgroups/{{name}}", "{{org_id}}/{{name}}"]
examples:
- !ruby/object:Provider::Terraform::Examples
name: "apigee_environment_group_basic"
skip_test: true
- !ruby/object:Provider::Terraform::Examples
# This is a more verbose version of the above that creates all
# the resources needed for the acceptance test.
name: "apigee_environment_group_basic_test"
primary_resource_id: "apigee_environment_group"
test_env_vars:
org_id: :ORG_ID
billing_account: :BILLING_ACCT
skip_docs: true
# Resource creation race
skip_vcr: true
timeouts: !ruby/object:Api::Timeouts
insert_minutes: 30
delete_minutes: 30
custom_code: !ruby/object:Provider::Terraform::CustomCode
custom_import: templates/terraform/custom_import/apigee_environment_group.go.erb
files: !ruby/object:Provider::Config::Files
# These files have templating (ERB) code that will be run.
# This is usually to add licensing info, autogeneration notices, etc.
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
config := meta.(*Config)

// current import_formats cannot import fields with forward slashes in their value
if err := parseImportId([]string{"(?P<name>.+)"}, d, config); err != nil {
return nil, err
}

nameParts := strings.Split(d.Get("name").(string), "/")
if len(nameParts) == 4 {
// `organizations/{{org_name}}/envgroups/{{name}}`
orgId := fmt.Sprintf("organizations/%s", nameParts[1])
if err := d.Set("org_id", orgId); err != nil {
return nil, fmt.Errorf("Error setting org_id: %s", err)
}
if err := d.Set("name", nameParts[3]); err != nil {
return nil, fmt.Errorf("Error setting name: %s", err)
}
} else if len(nameParts) == 3 {
// `organizations/{{org_name}}/{{name}}`
orgId := fmt.Sprintf("organizations/%s", nameParts[1])
if err := d.Set("org_id", orgId); err != nil {
return nil, fmt.Errorf("Error setting org_id: %s", err)
}
if err := d.Set("name", nameParts[2]); err != nil {
return nil, fmt.Errorf("Error setting name: %s", err)
}
} else {
return nil, fmt.Errorf(
"Saw %s when the name is expected to have shape %s or %s",
d.Get("name"),
"organizations/{{org_name}}/envgroups/{{name}}",
"organizations/{{org_name}}/{{name}}")
}

// Replace import id for the resource id
id, err := replaceVars(d, config, "{{org_id}}/envgroups/{{name}}")
if err != nil {
return nil, fmt.Errorf("Error constructing id: %s", err)
}
d.SetId(id)

return []*schema.ResourceData{d}, nil
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
data "google_client_config" "current" {}

resource "google_compute_network" "apigee_network" {
name = "apigee-network"
}

resource "google_compute_global_address" "apigee_range" {
name = "apigee-range"
purpose = "VPC_PEERING"
address_type = "INTERNAL"
prefix_length = 16
network = google_compute_network.apigee_network.id
}

resource "google_service_networking_connection" "apigee_vpc_connection" {
network = google_compute_network.apigee_network.id
service = "servicenetworking.googleapis.com"
reserved_peering_ranges = [google_compute_global_address.apigee_range.name]
}

resource "google_apigee_organization" "apigee_org" {
analytics_region = "us-central1"
project_id = data.google_client_config.current.project
authorized_network = google_compute_network.apigee_network.id
depends_on = [google_service_networking_connection.apigee_vpc_connection]
}

resource "google_apigee_envgroup" "env_grp" {
name = "tf-test%{random_suffix}"
hostnames = ["abc.foo.com"]
org_id = google_apigee_organization.apigee_org.id
}

Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
resource "google_project" "project" {
project_id = "tf-test%{random_suffix}"
name = "tf-test%{random_suffix}"
org_id = "<%= ctx[:test_env_vars]['org_id'] %>"
billing_account = "<%= ctx[:test_env_vars]['billing_account'] %>"
}

resource "google_project_service" "apigee" {
project = google_project.project.project_id
service = "apigee.googleapis.com"
}

resource "google_project_service" "compute" {
project = google_project.project.project_id
service = "compute.googleapis.com"
}

resource "google_project_service" "servicenetworking" {
project = google_project.project.project_id
service = "servicenetworking.googleapis.com"
}

resource "google_compute_network" "apigee_network" {
name = "apigee-network"
project = google_project.project.project_id
depends_on = [google_project_service.compute]
}

resource "google_compute_global_address" "apigee_range" {
name = "apigee-range"
purpose = "VPC_PEERING"
address_type = "INTERNAL"
prefix_length = 16
network = google_compute_network.apigee_network.id
project = google_project.project.project_id
}

resource "google_service_networking_connection" "apigee_vpc_connection" {
network = google_compute_network.apigee_network.id
service = "servicenetworking.googleapis.com"
reserved_peering_ranges = [google_compute_global_address.apigee_range.name]
depends_on = [google_project_service.servicenetworking]
}

resource "google_apigee_organization" "apigee_org" {
analytics_region = "us-central1"
project_id = google_project.project.project_id
authorized_network = google_compute_network.apigee_network.id
depends_on = [
google_service_networking_connection.apigee_vpc_connection,
google_project_service.apigee,
]
}

resource "google_apigee_envgroup" "<%= ctx[:primary_resource_id] %>" {
org_id = google_apigee_organization.apigee_org.id
name = "tf-test%{random_suffix}"
hostnames = ["abc.foo.com"]
}

0 comments on commit 1f1a032

Please sign in to comment.