Issuing an API request

The transaction starts right from when an API request comes into our system and routes to a controller or a resolver.

The transaction starts right from when an API request comes into our system and routes to a controller or a resolver.

# Using CURL to send an HTTP POST to a RESTful API

curl -d \
 '{"email":"khalil@apollographql.com", "password":"changeit"}' \
 -H "Content-Type: application/json" \
 -X POST https://api.dddforum.com/v1/users/new

If we're into GraphQL, it might look more like this.

# Using a GraphQL mutation to issue issue a command 
# into our system.

mutation {
  createUser(email: "khalil@apollographql.com", password: "changeit") {
    accessToken
    refreshToken
  }
}

Nonetheless, because we're using a Hexagonal Architecture, the type of API that we use doesn't affect how our command works. It just affects what calls our command. Let's not forget that GraphQL and RESTful APIs, while we can spend a lot of time on their design, are simply API styles that belong to the Infrastructure Layer and should have zero say as to how

Howdy 👋

This is an online wiki about the main topics over the last 40 years of software design, architecture & testing. It was created by Khalil Stemmler.

This wiki's mission is to help eliminate the unknown unknowns, helping you get up to speed on the best practices and principles to write testable, flexible, and maintainable code.

I created this wiki while I was connecting the dots on my own path. You can read more about that learning journey in the introduction

Already bought it?

If you’ve already purchased the book, click here to re-send your link. You can read the online wiki or download a copy of the book in PDF, EPUB, and Kindle versions.

Want access?

You can read the intro to the book for free and visit solidbook.io to buy the book/wiki! To get an idea of my writing, read some of my best free content here and here.

Need help?

Something not working? Have a question? You can reach me on at khalil@khalilstemmler.com.