diff options
Diffstat (limited to 'cmd/api')
-rw-r--r-- | cmd/api/datamaps.go | 23 | ||||
-rw-r--r-- | cmd/api/healthcheck.go | 12 | ||||
-rw-r--r-- | cmd/api/main.go | 63 | ||||
-rw-r--r-- | cmd/api/routes.go | 13 |
4 files changed, 111 insertions, 0 deletions
diff --git a/cmd/api/datamaps.go b/cmd/api/datamaps.go new file mode 100644 index 0000000..53f08bf --- /dev/null +++ b/cmd/api/datamaps.go @@ -0,0 +1,23 @@ +package main + +import ( + "fmt" + "net/http" + "strconv" +) + +func (app *application) createDatamapHandler(w http.ResponseWriter, r *http.Request) { + fmt.Fprintln(w, "create new datamaps page") +} + +func (app *application) showDatamapHandler(w http.ResponseWriter, r *http.Request) { + id := r.PathValue("id") + app.logger.Info("the id requested", "id", id) + id_int, err := strconv.ParseInt(id, 10, 64) + // TODO: Handle negative integers passed in the URL here + if err != nil { + http.NotFound(w, r) + return + } + fmt.Fprintf(w, "show the details for datamap %d\n", id_int) +} diff --git a/cmd/api/healthcheck.go b/cmd/api/healthcheck.go new file mode 100644 index 0000000..68bed0d --- /dev/null +++ b/cmd/api/healthcheck.go @@ -0,0 +1,12 @@ +package main + +import ( + "fmt" + "net/http" +) + +func (app *application) healthcheckHandler(w http.ResponseWriter, r *http.Request) { + fmt.Fprintln(w, "status: available") + fmt.Fprintf(w, "environment: %s\n", app.config.env) + fmt.Fprintf(w, "version: %s\n", version) +} diff --git a/cmd/api/main.go b/cmd/api/main.go new file mode 100644 index 0000000..9d3e9bd --- /dev/null +++ b/cmd/api/main.go @@ -0,0 +1,63 @@ +package main + +import ( + "flag" + "fmt" + "log/slog" + "net/http" + "os" + "time" +) + +const version = "1.0.0" + +// holds the config for our application +// We will read this from the command line flags when we run the application +type config struct { + port int + env string +} + +// This application struct holds the dependencies for our HTTP handlers, helpers and +// middleware. +type application struct { + config config + logger *slog.Logger +} + +func main() { + // Instance of config + var cfg config + + // Read the flags into the config struct. Defaults are provided if none given. + flag.IntVar(&cfg.port, "port", 4000, "API server port") + flag.StringVar(&cfg.env, "env", "development", "Environment (development|staging|production)") + flag.Parse() + + // Initialize a new structured logger which writes to stdout + logger := slog.New(slog.NewTextHandler(os.Stdout, nil)) + + // An instance of application struct, containing the config struct and the logger + app := &application{ + config: cfg, + logger: logger, + } + + // Declare an http server which listens provided in the config struct and has + // sensible timeout settings and writes log messages to the structured logger at + // Error level. + srv := &http.Server{ + Addr: fmt.Sprintf(":%d", cfg.port), + Handler: app.routes(), + IdleTimeout: time.Minute, + ReadTimeout: 5 * time.Second, + WriteTimeout: 10 * time.Second, + ErrorLog: slog.NewLogLogger(logger.Handler(), slog.LevelError), + } + + logger.Info("startings server", "addr", srv.Addr, "env", cfg.env) + + err := srv.ListenAndServe() + logger.Error(err.Error()) + os.Exit(1) +} diff --git a/cmd/api/routes.go b/cmd/api/routes.go new file mode 100644 index 0000000..acf13d0 --- /dev/null +++ b/cmd/api/routes.go @@ -0,0 +1,13 @@ +package main + +import "net/http" + +func (app *application) routes() *http.ServeMux { + + mux := http.NewServeMux() + + mux.HandleFunc("GET /v1/healthcheck", app.healthcheckHandler) + mux.HandleFunc("POST /v1/datamaps", app.createDatamapHandler) + mux.HandleFunc("GET /v1/datamaps/{id}", app.showDatamapHandler) + return mux +} |