<!doctype html>
<html>
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <link
      rel="stylesheet"
      href="https://cdnjs.cloudflare.com/ajax/libs/github-markdown-css/5.2.0/github-markdown.min.css"
    />
    <title>haunt98 posts</title>
  </head>
  <style>
    .markdown-body {
      box-sizing: border-box;
      min-width: 200px;
      max-width: 980px;
      margin: 0 auto;
      padding: 45px;
    }

    @media (max-width: 767px) {
      .markdown-body {
        padding: 15px;
      }
    }
  </style>
  <body class="markdown-body">
    <h2>
      <a href="index.html"><code>~</code></a>
    </h2>
    <h1 id="user-content-swagger-or-openapi">
      <a class="heading-link" href="#swagger-or-openapi"
        >Swagger or OpenAPI<span
          aria-hidden="true"
          class="octicon octicon-link"
        ></span
      ></a>
    </h1>
    <p>My company currently use Swagger 2 to document API.</p>
    <p>
      I want to work with OpenAPI 3 but too lazy to convert (for now of course).
    </p>
    <p>So step by step:</p>
    <ul>
      <li>Write API spec in <code>YAML</code>.</li>
      <li>Convert to API spec in <code>JSON</code>.</li>
      <li>Format spec files.</li>
      <li>Render spec in local.</li>
      <li>Push to company host for other teams to see.</li>
    </ul>
    <p>
      Only step 1 is manual, aka I write my API spec completely with my hand (no
      auto gen from code whatever). The others can be done with tools:
    </p>
    <div class="highlight highlight-source-shell">
      <pre><span class="pl-c"><span class="pl-c">#</span> Convert</span>
go install github.com/mikefarah/yq/v4@latest
yq -o=json <span class="pl-s"><span class="pl-pds">'</span>.<span class="pl-pds">'</span></span> ./docs/swagger.yaml <span class="pl-k">&gt;</span> ./docs/swagger.json

<span class="pl-c"><span class="pl-c">#</span> Format</span>
bunx prettier --write ./docs/swagger.yaml ./docs/swagger.json

<span class="pl-c"><span class="pl-c">#</span> Render locally</span>
bunx @redocly/cli preview-docs ./docs/swagger.json</pre>
    </div>
    <h2 id="user-content-thanks">
      <a class="heading-link" href="#thanks"
        >Thanks<span aria-hidden="true" class="octicon octicon-link"></span
      ></a>
    </h2>
    <ul>
      <li><a href="https://github.com/mikefarah/yq">mikefarah/yq</a></li>
      <li><a href="https://github.com/oven-sh/bun">oven-sh/bun</a></li>
      <li>
        <a href="https://github.com/prettier/prettier">prettier/prettier</a>
      </li>
      <li>
        <a href="https://github.com/Redocly/redocly-cli">Redocly/redocly-cli</a>
      </li>
    </ul>

    <div>
      Feel free to ask me via
      <a href="mailto:hauvipapro+posts@gmail.com">email</a> or
      <a rel="me" href="https://hachyderm.io/@haunguyen">Mastodon</a>.
      <br />Source code is available on
      <a href="https://github.com/haunt98/posts-go">GitHub</a>
      <a href="https://codeberg.org/yoshie/posts-go">Codeberg</a>
      <a href="https://git.sr.ht/~youngyoshie/posts-go">sourcehut</a>
      <a href="https://gitea.treehouse.systems/yoshie/posts-go">Treehouse</a>
      <a href="https://gitlab.com/youngyoshie/posts-go">GitLab</a>
    </div>
  </body>
</html>