/go-scalar-api-reference

The Golang lib for Scalar - Beautiful API references from OpenAPI/Swagger files ✨

Primary LanguageGoMIT LicenseMIT

Overview 🌐

The Scalar package serves as a provider for the Scalar project. It offers a comprehensive suite of functions designed for generating API references in HTML format, specializing in JSON data handling and web presentation customization. This includes functions to serialize options into JSON, manage HTML escaping, and dynamically handle different types of specification content.

Features 🚀

JSON Serialization and HTML Escaping

  • safeJSONConfiguration 🔒: Serializes configuration options into JSON format and escapes HTML characters to prevent XSS attacks. This ensures that the JSON can be safely embedded within HTML documents.

Specification Content Handling

  • specContentHandler 📝: Dynamically handles different types of specification content. It can process content as a function returning a map, a direct map, or a plain string, converting the specification content into JSON format suitable for web use.

HTML Generation

  • ApiReferenceHTML 📄: Generates a complete HTML document for API reference. It allows for extensive customization, including themes, layouts, and CDN configuration. It handles both direct specification content and content fetched from a URL, providing error handling for missing specifications.

Customization Options ⚙️

The package allows extensive customization of the generated API reference through the Options struct, supporting:

  • CDN: URL of the CDN to load additional scripts or styles.
  • Theme: Customizable themes for styling the API reference.
  • Layout: Choice between modern and classic layout designs.
  • SpecURL: URL from which the specification content can be fetched.
  • Dark Mode: Option to enable a dark theme for the API reference.

Themes and Styles 🎨

  • Provides a default set of CSS styles for both light and dark themes.
  • Allows custom CSS injections to tailor the appearance to specific branding or aesthetic requirements.

Error Handling 🛠️

  • Robust error handling for scenarios where necessary parameters like SpecURL or SpecContent are missing.
  • Errors during the fetching of specification content from URLs are properly managed and reported.

Usage 📚

To use the Scalar package as a provider in your Go project for creating API references, follow the example below:

package main

import (
	"fmt"
	"net/http"

	"github.com/go-chi/chi/v5"
	"github.com/go-chi/chi/v5/middleware"

	"github.com/MarceloPetrucio/go-scalar-api-reference"
)

func main() {
	router := chi.NewRouter()

	router.Use(middleware.RequestID)
	router.Use(middleware.Logger)
	router.Use(middleware.Recoverer)

	router.Get("/", create)

	router.Get("/reference", func(w http.ResponseWriter, r *http.Request) {
		htmlContent, err := scalar.ApiReferenceHTML(&scalar.Options{
			// SpecURL: "https://generator3.swagger.io/openapi.json",// allow external URL or local path file
			SpecURL: "./docs/swagger.json", 
			CustomOptions: scalar.CustomOptions{
				PageTitle: "Simple API",
			},
			DarkMode: true,
		})

		if err != nil {
			fmt.Printf("%v", err)
		}

		fmt.Fprintln(w, htmlContent)
	})

	fmt.Printf("Starting web server on port :8000")
	http.ListenAndServe(":8000", router)
}