Files
api-guidelines/guides/complete-api-development.md
apidesigner 906a191766 Updates guides/complete-api-development.md
Auto commit by GitBook Editor
2017-06-07 12:11:52 +00:00

5.1 KiB

The Complete API Development Guide

  1. Design the API

  2. Analyze business requirements

  3. Identify affordances

    e.g.: Create user, Submit order, Search for an article

  4. Identify resources

    e.g.: User, Order, Article

  5. Identify relations

    e.g.: User has many Orders via order relation, all of the required affordances should be mapped to relations.

  6. Formalize the design in the Open API Specification (OAS, formerly known as "Swagger") format

  7. Follow the adidas API guidelines

  8. Put the OAS file into Apiary adidas group

  9. Make sure the OAS file passes all adidas API Apiary style guide checks

  10. Verify the design using Apiary Documentation and Apiary Mock Service

  11. Review the API Design

  12. Put the OAS file in a version control system (VCS) repository

  13. Set up a CD pipeline to push OAS file from VCS to Apiary, whenever the file is changed

  14. Develop the API

  15. Check out the VCS repository with the OAS file

  16. Set up the Dredd API testing tool locally

  17. Configure the Dredd for your project

    $ dredd init
    
  18. Run the Dredd test locally

    Against locally running API implementation, Every test should fail.

  19. Implement the API

    Keep running the Dredd locally to see the progress.

  20. Set up a CI/CD pipeline to run the Dredd tests automatically

    NOTE: Both TeamCity and Jenkis enviroments are available, contact adidas API evangelist for details.

  21. Deploy the API

  22. Deploy the service

  23. Update the OAS file to add the deployment HOST

    host: adidas.api.mashery.com
    basePath: /demo-approval-api
    
  24. Verify the deployment with Dredd

    Use dredd pointed towards the deployment host, be careful to NOT run it against the production OR using real production credentials.

  25. Monitor the API usage "From performance and technical standpoint"

  26. Expose the API using Mashery

  27. API

1. Create new API Definition in Mashery

1. Create a new API Endpoint the API Definition

    > Set the "Your Endpoint Address" to the internal deployment HOST.
  
1. Create a new API Package in Mashery

1. Create a new API Plan within the API Package

1. Use Mashery API Designer to add the newly created API Definitions' API Endpoint to the 
API Plan

1. Revisit the API Plan's API key default settings

1. Revisit the API Plan's API default rate limits 

1. Revisit the API Plan's access policy / authorization
  1. API Documentation
1. Create new adidas API developer's portal page in the Mashery

  > Manage > Content > Documentation > APIs
  
1. [Embed Apiary documentation](https://help.apiary.io/tools/embed/#apiary-embed-api-reference) on the newly created API Page

1. Revisit the API documentation access policy / authorization
  1. Use the API

    This step can be done at the same time as "Develop the API" thank to Apiary hosted Mock, Inspector and Documentation.

  2. Read API documentation at Apiary

  3. Use API mock service provided by Apiary

  4. Use API call inspector provided by Apiary

  5. Obtain your API key

> The key is part of the API Plan created in Mashery and can be requested from your dashboard in the adidas API developer's portal.
  1. When available use API implementation via Apiary proxy to debug the API calls

  2. Use production deployment

  3. Analyze the API

  4. Analyze the use of production API Using Mashery

  5. Analyze the technical performance metrics

  6. Collect the feedback from users

  7. Update API Design

Based on the analysis, new or changing business requirements

  1. Create a new branch in the VCS repository with OAS file

  2. Create a new project (alternative) in Apiary

  3. Make sure the CI/CD pipeline is:

1. Set to push the OAS file to Apiary but make sure to modify the Apiary project name

1. Set to run Dredd test in the CI/CD
  1. Modify the design (OAS file) accordingly, follow the "Design API" step

  2. Follow the rules for extending and adidas API guidelines versioning policies

  3. Use VCS pull request (PR) to propose the change to review

  4. After the API Design change is verified, reviewed and approved, continue with the "Develop the API" phase

  5. Eventually, when the updated design is ready to be deployed for production, merge the branch to the production branch

  6. Follow this guide from "Expose the API using Mashery" step