Skip to content
This repository has been archived by the owner on Aug 10, 2022. It is now read-only.

Latest commit

 

History

History
executable file
·
195 lines (104 loc) · 11.9 KB

README.md

File metadata and controls

executable file
·
195 lines (104 loc) · 11.9 KB

Lab 1 - Design & Create an API Proxy with OpenAPI Specification

Duration : 15 mins

Persona : API Team

Use case

You have a requirement to create a reverse proxy to handle requests from the Internet and forward them to an existing service. You have decided to follow a design first approach and built a reusable component, a specification which can be used to describe the API contract, generate API documentation, generate API test cases, etc., using the OpenAPI Specification. You would like to generate an Apigee API Proxy by using the OpenAPI Specification (fka: Swagger) instead of building the API Proxy from scratch.

How can Apigee API Management help?

Apigee enables you to quickly expose services as APIs. You do this by creating an API proxy, which provides a facade for the service that you want to expose, such as existing API endpoints, generic HTTP services, or applications (such as Node.js). The API proxy decouples your service implementation from the API endpoint that developers consume. This shields developers from future changes to your services as well as implementation complexities. As you update services, developers, insulated from those changes, can continue to call the API, uninterrupted. On Apigee, the API Proxy is also where runtime policy configuration is applied for API Management capabilites. For further information, please see: Understanding APIs and API Proxies.

Image of Apigee Proxy flow execution order

Apigee also supports the OpenAPI specification out of the box, allowing you to auto-generate API Proxies. Apigee has a built-in OpenAPI specification editor and store which you can use to design and maintain your OpenAPI specifications.

Image of Apigee OpenAPI Spec editor

In this lab, we will learn how to

  • design an OpenAPI specification for an existing HTTP service and store it within the Apigee platform, and
  • create an API proxy that routes inbound requests to an existing HTTP service.

Pre-requisites

Instructions

Note: During this workshop, as you may be working within an Apigee Organization (Org) that is shared by multiple users. Please prefix all asset names within the Org with your initials. For example, Spec name = {your-initials}_{spec name}, API proxy name = {your-initials}_{proxy name}, etc.

Create an OpenAPI Specification

During the course of this lab, the sample HTTP service we will expose as an API endpoint is the Hipster Products service located at http://cloud.hipster.s.apigee.com/products. First, we are going to design and create an OpenAPI specification for the different resource endpoints, i.e. /products and /products/{productId}.

  1. Go to https://apigee.com/edge and log in. This is the Apigee management UI.

  2. Select Develop → Specs in the side navigation menu

Image describing how to navigate to Apigee OpenAPI Spec editor using menu. Home - Develop - Specs

  1. As we have a pre-designed sample of the spec available for this lab, we will be importing it into your Apigee Org's Spec Store. Click +Spec. Click on Import URL to add a new spec from existing source.

Image describing how to import an OpenAPI Spec into Apigee via URL

  1. Enter spec details. Replace {your-initials} with the initials of your name.

Image describing the Import OpenAPI Spec wizard fields

  1. Verify the values and click Import. Spec has been imported into Apigee and is ready to use. You should see your spec in the list. For example,

Image showing newly imported OpenAPI Spec in the Specs view

  1. Click on {your-initials}_hipster_products_api_spec from the list to access the OpenAPI spec editor & interactive documentation that lists API details & API Resources.

Image of OpenAPI Spec editor.  Newly imported spec is loaded in the editor

Create an API Proxy

  1. It’s time to create Apigee API Proxy from an OpenAPI Specification. Click on Develop → API Proxies from side navigation menu.

Image describing how to navigate to the API Proxies view.  Home - Develop - API Proxies

  1. Click +Proxy The Build a Proxy wizard is invoked.

Image showing the location of the button to create an API Proxy.

  1. Select Reverse proxy, Click on Use OpenAPI below reverse proxy option.

Image showing selection of API Proxy type.  User has selected Reverse Proxy and clicked "Use OpenAPI Spec"

  1. You should see a popup with list of Specs. Select {your-initials}_hipster_products_api_spec and click Select.

Image showing selection of previously imported OpenAPI Spec from list of available specs.

  1. Enter details in the proxy wizard. Replace {your-initials} with the initials of your name.

    • Proxy Name: {your_initials}_Hipster-Products-API

    • Proxy Base Path: /v1/{your_initials}_hipster-products-api

    • Existing API: Observe the field value which is auto filled from OpenAPI Spec.

Image showing filling out of Proxy details.  User has added his or her initials as the prefix for "Name" and "Base path" per lab instructions.

  1. Verify the values and click Next.

  2. Select Pass through (none) for the authorization in order to choose not to apply any security policy for the proxy. Click Next.

Image describing Policy selection in API Proxy Wizard.  User has selected "Pass through".

  1. You can select which API resources, from the list configured in the OpenAPI Spec, should be exposed. Select all & Click on Next

Image describing ability to select or deselect individual operations impoted from OpenAPI Spec.  User has selected the default, which is all operations.

  1. Go with the secure Virtual Host configuration. Ensure that the default one is unchecked.

Image describing how to enable or disable the http and/or https virtual hosts.  User has unchecked "default" so only secure (https) is checked.

  1. Ensure that only the test environment is selected to deploy to and click Create and Deploy

Image describing selection of which environments to deploy API Proxy to via the wizard.  User has sselected "test" and left other environments unchecked.

  1. Once the API proxy is created and deployed click Edit Proxy to view your proxy in the proxy editor.

Image describing completion of wizard.  There is an "Edit proxy" button that will open the newly created proxy in the proxy editor.

  1. Congratulations! ...You have now built a reverse proxy for an existing backend service. You should see the proxy Overview tab.

Image describing various features of the API Proxy overview page.  Details about proxy revision, deployment state, virtual hosts, and proxy and target endpoints can be seen here.  Additionally there are links to open the "develop" view or the "trace" tool.

Test the API Proxy

Let us test the newly built API proxy. You can use any HTTP client like cURL or Postman, or the Apigee Trace Tool.

Using cURL

org = Organization name env = Environment where API is deployed

curl -X GET "https://{{org}}-{{env}}.apigee.net/{{your initials}}_hipster-products-api/products"

Using Trace Tool:

  • Navigate to your proxy's Trace tab.

  • Ensure that the deployed API revision is selected.

  • Hit Start Trace Session.

Image describing the API Proxy Trace Tool.  User has selected revision 1 to trace and then clicked the button labeled "Start Trace Session"

  • Wait for Trace session to start.

  • Modify the URL to send to a valid API resource - append a '/products' to the end of the URL.

  • Hit 'Send'.

Image describing invoking the trace tool.  User appended "/products" to the URL and clicked  the "send" button.

  • You will see that the API proxy recieved the request and sent back a HTTP status 200 response which was logged by the Trace session. You can click on the step shown below to view the response body.

Image depicting a successful trace response.  Left pane shows the HTTP method, status code, invoked URI, and elapsed response time.  User has also clicked a node in the visual transaction map that reveals the JSON response received from the server.

Save the API Proxy

  1. Let’s save the API Proxy locally as an API Bundle so that we can reuse it in other labs.

  2. Save the API Proxy by downloading the proxy bundle, See screenshot below for instructions.

Image describing the process of downloading an API Proxy locally.  User is on the "Overview" page of the API Proxy and has clicked "Project" then "Download Revision"

Lab Video

If you like to learn by watching, here is a short video on creating a reverse proxy using OpenAPI Specification - https://www.youtube.com/watch?v=3XBG9QOUPzg

Earn Extra-points

Now that you have created a reverse proxy using an OpenAPI spec, click on the Develop tab and explore the flow conditions populated from the OpenAPI spec. Further expore the trace tab in the API Proxy editor which supports filtering traces as well as downloading trace data for offline use. Also, explore the OpenAPI Spec editor which allows you to edit an OpenAPI specification and supports bidirectional navigation between the yaml/json and a live view of the rendered OpenAPI spec. See how you can generate an API Proxy using the "Generate proxy" action in the Specs view. Picture of "Generate proxy" action in Specs view

Quiz

  1. How do you import the proxy bundle you just downloaded?
  2. How does Apigee handle API versioning?
  3. Are there administrative APIs to create, update, or delete API proxies in Apigee?

Summary

That completes this hands-on lesson. In this simple lab you learned how to use Apigee to proxy an existing backend using an OpenAPI Specification and the Apigee proxy wizard.

References

Rate this lab

How did you like this lab? Rate here.

Now go to Lab-2