Skip to content

Latest commit

 

History

History
187 lines (143 loc) · 6.42 KB

README.md

File metadata and controls

187 lines (143 loc) · 6.42 KB

Xcelvie-rest

An example REST API controller written in spring-boot with minimal dependencies. The application implemments a product / order book HTTP API for a sample pharmeceutical company. Given the API, a client can query the product catalogue for published products. Query the catalogue by product title. Insert a new product, update a product and delete a product. Clients can also place orders for products.

Prerequisites

  • This application was writen ussing InteliJ IDE.
  • This application was written using an open source JDK (Open JDK VM Correto 11).
  • This application saves data to an instance of mmongodb (no password is set, runnning on the standard port).
  • This application uses Postman to test API calls.
  • This application uses Maven for life-cyle management and depenndency management.
  • This appliication is compatible with Java SE 8.

Installation for Postman, Mongo, xcelvie-rest

A linux OS was used to install the application. I assume you have an IDE and a JDK installed.For Postman and Mongo, you can follow these steps.

  1. Install a community version of mongo locally: https://www.mongodb.com/try/download/community
  2. Install Postman locally: https://www.postman.com/downloads/
  3. Clone this project in your deployment directory
~/dev git clone [email protected]:contexua/xcelvie-rest.git

After you have checked out the project, you need to build it using maven:

~/dev cd xcelvie-rest

~/dev/xcelvie-rest/mvn clean install

Usage - Spring

  • Start the application. It's a spring boot server using an embedded catalina engine running on 8080:
~/dev/xcelvie-rest/mvn spring-boot:run

Note the progress of the spring boot startup log and ensure the tests run correctly.

  • Open a 'browser of your choice' and paste in the swagger URL: http://localhost:8080/swagger-ui/
  • Follow the instructions in the swagger UI to perform the API functions:

an image of swagger used to acccess the API for xcelvie-rest by kevin hamid.

Usage - Mongo

  • Ensure your mongodb is running - Mine runs as a service:
~/dev/xcelvie-rest/systemctl status mongodb
 

 mongodb.service - An object/document-oriented database
   Loaded: loaded (/lib/systemd/system/mongodb.service; enabled; vendor preset: enabled)
   Active: active (running) since Mon 2020-09-14 06:27:17 CEST; 1h 11min ago
     Docs: man:mongod(1)
 Main PID: 867 (mongod)
    Tasks: 24 (limit: 4915)
   Memory: 187.2M
   CGroup: /system.slice/mongodb.service
           └─867 /usr/bin/mongod --unixSocketPrefix=/run/mongodb --config /etc/mongodb.conf

Sep 14 10:27:17 kevin-notebook systemd[1]: Started An object/document-oriented database.

Its always good to inspect the raw data in mongo after creating records via the API. Some commands to help are:

mongo
MongoDB shell version v3.6.8
connecting to: mongodb://127.0.0.1:27017
Implicit session: session { "id" : UUID("c525e9d2-3be8-4d72-a812-b26f5342594f") }
MongoDB server version: 3.6.8
Server has startup warnings: 
2020-09-14T06:27:17.510+0200 I STORAGE  [initandlisten] 
2020-09-14T06:27:17.510+0200 I STORAGE  [initandlisten] ** WARNING: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine
2020-09-14T06:27:17.510+0200 I STORAGE  [initandlisten] **          See http://dochub.mongodb.org/core/prodnotes-filesystem
2020-09-14T06:27:19.154+0200 I CONTROL  [initandlisten] 
2020-09-14T06:27:19.154+0200 I CONTROL  [initandlisten] ** WARNING: Access control is not enabled for the database.
2020-09-14T06:27:19.154+0200 I CONTROL  [initandlisten] **          Read and write access to data and configuration is unrestricted.
2020-09-14T06:27:19.154+0200 I CONTROL  [initandlisten] 
> use xcelvie_salesledger_db
switched to db xcelvie_salesledger_db
> show collections
orderbooks
products
> 
> db.orderbooks.find().pretty()
{
	"_id" : ObjectId("5f5f3662218f1609a2789e63"),
	"createdDate" : ISODate("2020-09-14T09:22:42.976Z"),
	"clientEmail" : "kevin",
	"_class" : "com.contexua.xcelvie.models.OrderBook"
}
{
	"_id" : ObjectId("5f5f3d7e1915a85bf01d196e"),
	"createdDate" : ISODate("2020-09-14T09:53:02.134Z"),
	"clientEmail" : "jimbo",
	"orders" : [
		{
			"orderId" : "jimbo_205977",
			"orderTotal" : 0
		},
		{
			"orderId" : "jimbo_41428",
			"orderTotal" : 958.5,
			"orderItems" : [
				{
					"skuid" : "Genfro_200_286",
					"quantity" : 9,
					"lineItemTotal" : 319.5
				},
				{
					"skuid" : "Genfro_200_286",
					"quantity" : 9,
					"lineItemTotal" : 319.5
				},
				{
					"skuid" : "Genfro_200_286",
					"quantity" : 9,
					"lineItemTotal" : 319.5
				}
			]
		},
		{
			"createdDate" : ISODate("2020-09-14T12:24:10.356Z"),
			"orderId" : "jimbo_159255",
			"orderTotal" : 14519.5,
			"orderItems" : [
				{
					"skuid" : "Genfro_200_286",
					"quantity" : 9,
					"lineItemTotal" : 319.5
				},
				{
					"skuid" : "Genfro_200_286",
					"quantity" : 200,
					"lineItemTotal" : 7100
				},
				{
					"skuid" : "Genfro_200_286",
					"quantity" : 200,
					"lineItemTotal" : 7100
				}
			]
		}
	],
	"_class" : "com.contexua.xcelvie.models.OrderBook"
}
> 

Contributing

If you have any general questions about the function of the API, then the documentation via Swagger or via the code should help. You can leave comments against this reopository if you like.

Improvements

  • Testing is pretty basic - just testing the controller httpstatus messages, I mocked the service call, but still need to mock the DAO's
  • Persistence should probably be via a que, but for this example the service is on the same JVM.
  • Service helpers are hardcoded, business domain services should be used.
  • No instructions for running in a Microsoft Windows environment.
  • Candidate for containerisation.

License

This application is free to use in any scenario with no responsibility owned by Kevin Hamid.