Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Can't Reference Anchors from Within Another Anchor #412

Open
Vince-Smith opened this issue Dec 5, 2024 · 0 comments
Open

Can't Reference Anchors from Within Another Anchor #412

Vince-Smith opened this issue Dec 5, 2024 · 0 comments

Comments

@Vince-Smith
Copy link

Is your feature request related to a problem? Please describe.
I'm currently investigating swagger-jsdoc as potential solution for auto-generating my openapi spec.

One of the hard requirements I have is that my API is versioned, and there are occasions where a handler might be used across multiple versions.

I've been able to get this to work as a proof of concept with a simple /healthz endpoint, an example of this is below.

The problem
While the below example works, I am finding that it's a bit inflexible. Following the examples here I was hoping to define a directory of properties that could be referenced from my handler definitions. However, attempting to reference any anchors from within my templates ends up returning a null value.

For example the following spec

/**
 * @openapi
 * /v3/healthz:
 *   get: *getHealthzV3
 */
export const getHealthz = (_req, res) => {
    res.json({
        status: '😎 Alriiight'
    })
}

/**
 * @openapi
 * x-template:
 *   get: &getHealthzV3
 *     description: Find out if the service is healthy and coooool
 *     responses:
 *       '200':
 *         description: OK - API is healthy
 *         content:
 *           text/plain:
 *             schema:
 *               type: object
 *               properties:
 *                 status: *healthStatus
 *             examples:
 *               healthyResponse:
 *                 summary: A healthy API response
 *                 value: '😎 Alriiight'
 */

/**
 * @openapi
 * x-template:
 *   healthStatus: &healthStatus
 *     type: string
 *     description: The Servers Status
 *     enum:
 *       - OK
 *       - DEAD
 */

will generate

{
  "openapi": "3.1.0",
  "info": {
    "title": "Test",
    "version": "v3.0.0"
  },
  "paths": {
    "/healthz": {
      "get": {
        "description": "Find out if the service is healthy and coooool",
        "responses": {
          "200": {
            "description": "OK - API is healthy",
            "content": {
              "text/plain": {
                "schema": {
                  "type": "object",
                  "properties": {
                    "status": null
                  }
                },
                "examples": {
                  "healthyResponse": {
                    "summary": "A healthy API response",
                    "value": "😎 Alriiight"
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

Further example of my overall goals in this design below:

// versionSelectionMiddleware inspects headers to determine if this handler is valid for this request
// otherwise it cascades to the next handler 
/**
 * @openapi
 * /v1/healthz:
 *   get: *getHealthzV1
 *
 * /v2/healthz:
 *   get: *getHealthzV1
 */
router.get('/', versionSelectionMiddleware('v1', 'v2'), getHealthz.V1)

/**
 * @openapi
 * /v3/healthz:
 *   get: *getHealthzV3
 */
router.get('/', versionSelectionMiddleware('v3'), getHealthz.V3)

Ultimately I suppose I just have two questions:

  1. Is this a bug? Are you supposed to be able to reference anchors from within other anchors?
  2. Is this the correct approach? Or would this be something that would make more sense to references as components instead of as anchors?
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant