05-search-query

command
v0.4.7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 1, 2023 License: MIT Imports: 15 Imported by: 0

README

Search Query Example

Tags: Models, Collections, Linked resources, Queries, Pagination, Store, Call methods, Resource parameters

Description

A customer management system, where you can search and filter customers by name and country. The search results are live and updated as customers are edited, added, or deleted by multiple users simultaneously.

Prerequisite

  • Download and install Go
  • Install NATS Server and Resgate (done with 3 docker commands).

Install and run

git clone https://github.com/jirenius/go-res
cd go-res/examples/05-search-query
go run .

Open the client

http://localhost:8085

Things to try out

Live query
  • Open the client in two separate tabs.
  • Make a query (eg. Set Filter to B, and Country to Germany) in one tab.
  • In a separate tab, try to:
    • create a New customer matching the query.
    • edit a customer so that it starts to match the query.
    • edit a customer so that it no longer matches the query.
    • delete a customer that matches the query.
  • In the tab with the query, try to:
    • edit the name of a customer so that it affects its sort order.
    • edit the country of a customer so that it no longer matches the query.
Persistence
  • Open the client and make some changes.
  • Restart the service and the client.
  • Observe that all changes are persisted (using Badger DB).

API

Request Resource Description
get search.customers?from=0&limit=5&name=A&country=Sweden Query collection of customer references. All query parameters are optional.
call search.customers.newCustomer Adds a new customer.
get search.customer.<ID> Models representing customers.
call search.customer.<ID>.set Sets the customers' name, email, and country properties.
call search.customer.<ID>.delete Deletes a customer.
get search.countries Collection of available countries.

REST API

Resources can be retrieved using ordinary HTTP GET requests, and methods can be called using HTTP POST requests.

Get customer query collection (all parameters are optional)
GET http://localhost:8080/api/search/customers?from=0&limit=5&name=A&country=Sweden
Add new customer
POST http://localhost:8080/api/search/customers/newCustomer

Body

{ "name": "John Doe", "email": "[email protected]", "country": "France" }
Get customer
GET http://localhost:8080/api/search/customer/<ID>
Update customer properties
POST http://localhost:8080/api/search/customer/<ID>/set

Body

{ "name": "Jane Doe", "country": "United Kingdom" }
Delete customer
POST http://localhost:8080/api/search/customer/<ID>/delete

No body

Get country collection
GET http://localhost:8080/api/search/countries

Documentation

Overview

A customer management system, where you can search and filter customers by name and country. The search results are live and updated as customers are edited, added, or deleted by multiple users simultaneously.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL