Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@github/rest-api-operations

Package Overview
Dependencies
Maintainers
16
Versions
87
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@github/rest-api-operations

A Node.js module that decorates GitHub's OpenAPI schemas for rendering on docs.github.com

  • 3.8.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
17
decreased by-51.43%
Maintainers
16
Weekly downloads
 
Created
Source

This project is no longer maintained!

The decorated OpenAPI files are no longer generated from this repository. The code in this repository has been migrated over to github/docs-internal and a workflow automatically runs a script to decorate dereferenced OpenAPI schema files when PRs are opened in the github/docs-internal repo by github-openapi-bot.








@github/rest-api-operations

A Node.js module that decorates GitHub OpenAPI schemas for rendering on docs.github.com.

What it does

  • Generates arrays of Operation objects from GitHub OpenAPI schemas
  • Validates generated operations using a JSON schema
  • Generates code samples for curl, @octokit/core.js, and octokit.rb. See Extensions.
  • Renders operation markdown properties to HTML using hubdown:
    • descriptions
    • code samples
    • response payloads
    • parameter descriptions
    • body paramater descriptions
    • preview notices
  • Adds slug properties to each operation for use as unique DOM ids using github-slugger
  • Adds HTTP status messages to responses using http-status-code
  • Derives category and subcategory to support legacy /v3/{category}/{subcategory} URLs
  • Matches internal nomenclature for GitHub product variants, e.g. dotcom and 2.20

Publishing process

This project uses semantic-release and a GitHub Actions workflow to automatically publish a new version of the npm package whenever pull requests are merged to the default branch. To enable this, we give our pull request titles semantic prefixes like fix: and feat: . To learn more about semantic-release and semantic commit messages, watch this YouTube video.

Installation

npm install @github/rest-api-operations

Usage

The npm module exports a single property schemas which is an object containing multiple versions of the GitHub REST API schema for api.github.com and all currently supported versions of GitHub Enterprise Server.

const { schemas } = require('@github/rest-api-operations')

console.log(Object.keys(schemas))
// [
//   'api.github.com',
//   'ghes-2.17',
//   'ghes-2.18',
//   'ghes-2.19',
//   'ghes-2.20'
// ]

console.log(schemas['ghes-2.20'])
// [
//   { Operation },
//   { Operation },
//   { Operation },
//   ...
// ]

Previewing changes locally

Sometimes it's helpful to preview changes you've made to this module on your local checkout of the GitHub Docs website. Assuming you have the two repositories checked out in the same parent directory, run the following:

cd ~/your-checkout-of/github/docs-internal
npm link ../rest-api-operations
cd ../rest-api-operations
npm run watch

This creates a symlink between the two projects and starts a watcher process that runs the @github/rest-api-operations build script whenever you make changes to its source files. These changes should be visible on your local development server.

When you're done previewing changes, remove the symlink:

cd ~/your-checkout-of/github/docs-internal
npm unlink ../rest-api-operations

FAQs

Package last updated on 01 Dec 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc