api start creation
This commit is contained in:
parent
3157ab474d
commit
5b34f8fae3
61
cmd/mercadona.go
Normal file
61
cmd/mercadona.go
Normal file
@ -0,0 +1,61 @@
|
||||
package cmd
|
||||
|
||||
import (
|
||||
"flag"
|
||||
"net/http"
|
||||
"os"
|
||||
"os/signal"
|
||||
"syscall"
|
||||
|
||||
"github.com/julienschmidt/httprouter"
|
||||
|
||||
"git.espin.casa/albert/logger"
|
||||
"git.espin.casa/albert/mercadona/internal/client"
|
||||
"git.espin.casa/albert/mercadona/internal/routes"
|
||||
)
|
||||
|
||||
func Run() error {
|
||||
// setup flags
|
||||
apiAddr := flag.String("api-addr", "localhost:3000", "REST API server address")
|
||||
logLevel := flag.String("level", "debug", "Log level")
|
||||
flag.Parse()
|
||||
// logfields
|
||||
logFields := logger.LogFields{}
|
||||
|
||||
// setup logger
|
||||
log := logger.New(os.Stdout, *logLevel)
|
||||
// create router
|
||||
router := httprouter.New()
|
||||
client := client.NewClient()
|
||||
routes.CreateRoutes(router, client)
|
||||
// start http server
|
||||
go func() {
|
||||
http.ListenAndServe(*apiAddr, router)
|
||||
}()
|
||||
// info banner
|
||||
log.Info("started Mercadona api service", logFields)
|
||||
// wait signal to finish
|
||||
signal := WaitSignal()
|
||||
log.Info("signal received", logFields.Add(logger.LogFields{
|
||||
"signal": signal,
|
||||
}))
|
||||
return nil
|
||||
}
|
||||
|
||||
// WaitSignal catching exit signal
|
||||
func WaitSignal() os.Signal {
|
||||
ch := make(chan os.Signal, 2)
|
||||
signal.Notify(
|
||||
ch,
|
||||
syscall.SIGINT,
|
||||
syscall.SIGQUIT,
|
||||
syscall.SIGTERM,
|
||||
)
|
||||
for {
|
||||
sig := <-ch
|
||||
switch sig {
|
||||
case syscall.SIGINT, syscall.SIGQUIT, syscall.SIGTERM:
|
||||
return sig
|
||||
}
|
||||
}
|
||||
}
|
10
go.mod
10
go.mod
@ -1,3 +1,13 @@
|
||||
module git.espin.casa/albert/mercadona
|
||||
|
||||
go 1.24.0
|
||||
|
||||
require (
|
||||
git.espin.casa/albert/logger v1.0.0
|
||||
github.com/julienschmidt/httprouter v1.3.0
|
||||
)
|
||||
|
||||
require (
|
||||
github.com/sirupsen/logrus v1.9.3 // indirect
|
||||
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8 // indirect
|
||||
)
|
||||
|
19
go.sum
Normal file
19
go.sum
Normal file
@ -0,0 +1,19 @@
|
||||
git.espin.casa/albert/logger v1.0.0 h1:DF+SwwkptiZBiB1HUIPcKRRoLuUC7fVUfnF/I9p5Cj4=
|
||||
git.espin.casa/albert/logger v1.0.0/go.mod h1:TXbZ7mayDtJvcs+DucVbs2klio9jq5k1eWFZ2wxgRGM=
|
||||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/julienschmidt/httprouter v1.3.0 h1:U0609e9tgbseu3rBINet9P48AI/D3oJs4dN7jwJOQ1U=
|
||||
github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM=
|
||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||
github.com/sirupsen/logrus v1.9.3 h1:dueUQJ1C2q9oE3F7wvmSGAaVtTmUizReu6fjN8uqzbQ=
|
||||
github.com/sirupsen/logrus v1.9.3/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ=
|
||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||
github.com/stretchr/testify v1.7.0 h1:nwc3DEeHmmLAfoZucVR881uASk0Mfjw8xYJ99tb5CcY=
|
||||
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8 h1:0A+M6Uqn+Eje4kHMK80dtF3JCXC4ykBgQG4Fe06QRhQ=
|
||||
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo=
|
||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
56
internal/client/client.go
Normal file
56
internal/client/client.go
Normal file
@ -0,0 +1,56 @@
|
||||
package client
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"io"
|
||||
"net/http"
|
||||
|
||||
"git.espin.casa/albert/mercadona/pkg/types/mercadona"
|
||||
)
|
||||
|
||||
const (
|
||||
BaseURL string = "https://tienda.mercadona.es"
|
||||
)
|
||||
|
||||
type IMercadona interface {
|
||||
// Get Mercadona products based on barcode scanned id
|
||||
GetMercadonaProduct(ctx context.Context, id string) (*mercadona.Product, error)
|
||||
}
|
||||
|
||||
type client struct{ url string }
|
||||
|
||||
// GetMercadonaProduct implements IMercadona.
|
||||
func (c client) GetMercadonaProduct(ctx context.Context, id string) (*mercadona.Product, error) {
|
||||
// product holder
|
||||
product := &mercadona.Product{}
|
||||
// crate url endpoint
|
||||
url := fmt.Sprintf("%s/api/products/%s/xselling/?lang=es&wh=bcn1&exclude=", BaseURL, id)
|
||||
// create http Get Request
|
||||
resp, err := http.Get(url)
|
||||
// check if error
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// close body response
|
||||
defer resp.Body.Close()
|
||||
// read body response
|
||||
body, err := io.ReadAll(resp.Body)
|
||||
// check if error on read body
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// unmarshal json body response
|
||||
if err := json.Unmarshal(body, product); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return product, nil
|
||||
}
|
||||
|
||||
func NewClient() IMercadona {
|
||||
url := BaseURL
|
||||
return client{
|
||||
url: url,
|
||||
}
|
||||
}
|
14
internal/handlers/product.go
Normal file
14
internal/handlers/product.go
Normal file
@ -0,0 +1,14 @@
|
||||
package handlers
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"git.espin.casa/albert/mercadona/internal/client"
|
||||
"github.com/julienschmidt/httprouter"
|
||||
)
|
||||
|
||||
func GetMercadonaProduct(client client.IMercadona) httprouter.Handle {
|
||||
return func(w http.ResponseWriter, r *http.Request, p httprouter.Params) {
|
||||
|
||||
}
|
||||
}
|
11
internal/routes/routes.go
Normal file
11
internal/routes/routes.go
Normal file
@ -0,0 +1,11 @@
|
||||
package routes
|
||||
|
||||
import (
|
||||
"git.espin.casa/albert/mercadona/internal/client"
|
||||
"git.espin.casa/albert/mercadona/internal/handlers"
|
||||
"github.com/julienschmidt/httprouter"
|
||||
)
|
||||
|
||||
func CreateRoutes(r *httprouter.Router, client client.IMercadona) {
|
||||
r.GET("/mercadona/product/:id", handlers.GetMercadonaProduct(client))
|
||||
}
|
13
main.go
Normal file
13
main.go
Normal file
@ -0,0 +1,13 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"os"
|
||||
|
||||
"git.espin.casa/albert/mercadona/cmd"
|
||||
)
|
||||
|
||||
func main() {
|
||||
if err := cmd.Run(); err != nil {
|
||||
os.Exit(1)
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user