docs/script
Peter Bengtsson c5f4f5f1a6
remove all uses of loadSiteData (#33881)
2023-01-11 18:45:47 +00:00
..
actions script to find unicorn action SHAs (#33446) 2022-12-12 16:56:08 +00:00
bookmarklets
content-migrations Translation cleanup (#33738) 2023-01-04 18:06:51 +00:00
deployment fix Fastly purge key for API from indexing (#33327) 2022-12-07 18:33:00 +00:00
dev-toc make script/dev-toc/generate work like the olden days (#32481) 2022-11-10 13:35:43 +00:00
early-access Upgrade commander (#28613) 2022-06-17 16:43:02 +00:00
enterprise-server-deprecations remove openapi dereferenced static files (#33297) 2022-12-13 12:38:30 -08:00
enterprise-server-releases remove openapi dereferenced static files (#33297) 2022-12-13 12:38:30 -08:00
graphql update GraphQL workflow post-translations removal (#33875) 2023-01-10 22:57:36 +00:00
helpers Fix bug in lint-versions test (#33798) 2023-01-06 17:21:19 +00:00
i18n Fix translation reporting (round 1!) (#33754) 2023-01-05 20:16:38 +00:00
rest [December 15, 2022] - Secret Scanning Experience for Free Public Repos (Public Beta) (#32702) 2022-12-15 16:28:55 +00:00
search remove LFS from codebase (#33777) 2023-01-06 18:57:36 +00:00
README.md Translation cleanup (#33738) 2023-01-04 18:06:51 +00:00
anonymize-branch.js
bootstrap
check-for-node
check-github-github-links.js github/github link checker issue with particular link (#31814) 2022-10-18 16:53:40 +00:00
content-changes-table-comment.js Notice product landing pages too (#33833) 2023-01-10 17:26:45 +00:00
copy-to-test-repo.sh remove LFS from codebase (#33777) 2023-01-06 18:57:36 +00:00
create-glossary-from-spreadsheet.js
domwaiter.js merge in domwaiter (#31197) 2022-09-27 14:38:12 -04:00
find-orphaned-assets.js more exceptions when looking for orphaned assets (#33478) 2022-12-14 14:38:06 +00:00
get-new-dotcom-path.js
kill-server-for-jest.js Next12 now supports ESM (#29295) 2022-07-26 17:53:23 +00:00
list-image-sizes.js
move-category-to-product.js Upgrade commander (#28613) 2022-06-17 16:43:02 +00:00
move-content.js Update translation directory dependencies in top-level `script/` (#31839) 2022-10-19 16:18:52 +00:00
pages-with-liquid-titles.js
prevent-pushes-to-main.js
purge-fastly
purge-fastly-by-url.js Upgrade commander (#28613) 2022-06-17 16:43:02 +00:00
reconcile-category-dirs-with-ids.js remove all uses of loadSiteData (#33881) 2023-01-11 18:45:47 +00:00
reconcile-filenames-with-ids.js
rendered-content-link-checker.js make it possible to filter by version (#33628) 2023-01-04 00:12:34 +00:00
server
server-all-languages Translation cleanup (#33738) 2023-01-04 18:06:51 +00:00
server-for-jest.js Next12 now supports ESM (#29295) 2022-07-26 17:53:23 +00:00
standardize-frontmatter-order.js
start-server-for-jest.js Next12 now supports ESM (#29295) 2022-07-26 17:53:23 +00:00
test
todo
toggle-ghae-feature-flags.js Support GHAE internal-only semantic versioning (#29178) 2022-09-22 08:26:58 +02:00
update-enterprise-dates.js
update-internal-links.js remove all uses of loadSiteData (#33881) 2023-01-11 18:45:47 +00:00
update-readme.js
update-tocs.js Script to create or update index.md files (#32416) 2022-11-07 19:17:18 +00:00

README.md

Scripts

Scripts to rule them all

This directory follows the Scripts to Rule Them All pattern:

bootstrap

Installs/updates all dependencies necessary for the docs environment. Equivalent of npm install.


server

Starts the local development server. Equivalent of npm start.

To keep things snappy, only English and Japanese are enabled. To run the server with all languages enabled, run script/server-all-languages


test

Runs tests. Equivalent of npm test.


Additional scripts

anonymize-branch.js

Flatten all the commits in the current branch into a single anonymized @Octomerger commit

Usage: script/anonymize-branch.js [base-branch] Example: script/anonymize-branch.js "nothing to see here" If the optional [base-branch] argument is omitted, it will default to main


bookmarklets/add-pr-links.js


bookmarklets/open-in-vscode.js



bookmarklets/view-in-development.js


bookmarklets/view-in-production.js


check-for-node

This script is run automatically when you run the server locally. It checks whether Node.js is installed.


check-github-github-links.js

Run this script to get all broken docs.github.com links in github/github


content-migrations/add-early-access-tocs.js


content-migrations/add-ghec-to-schema.js

A one-time use script to add GHEC to the REST schema on github/github.


content-migrations/add_mini_toc_frontmatter.js

Run this one time script to add max mini toc to rest reference documentation


content-migrations/comment-on-open-prs.js

This script finds all open PRs from active branches that touch content files, and adds a comment with steps to run some commands. The idea is to help writers and other Hubbers update their open branches and mitigate conflicts with the main branch.


content-migrations/convert-if-to-ifversion.js

Run this one-time script to convert if <feature name> Liquid tags to ifversion <feature name>.


content-migrations/create-csv-of-short-titles.js


content-migrations/move-unique-image-assets.js


content-migrations/remove-html-comments-from-index-files.js


content-migrations/topics-upcase.js


content-migrations/update-developer-site-links.js


content-migrations/update-headers.js

Run this one time script to update headers for accessibility Changing H3 to H2, H4 to H3, H5 to H4, and H6 to H5


content-migrations/update-versioning-in-files.js


content-migrations/use-short-versions.js

Run this script to convert long form Liquid conditionals (e.g., {% if currentVersion == "free-pro-team" %}) to the new custom tag (e.g., {% ifversion fpt %}) and also use the short names in versions frontmatter.


copy-to-test-repo.sh


create-glossary-from-spreadsheet.js

This script turns a Google Sheets CSV spreadsheet into a YAML file.


deployment/purge-edge-cache.js


dev-toc/generate.js


dev-toc/index.js


dev-toc/layout.html


domwaiter.js


early-access/clone-locally

This script is run on a writer's machine to begin developing Early Access content locally.


early-access/create-branch

This script is run on a writer's machine to create an Early Access branch that matches the current docs-internal branch.


This script is run on a writer's machine while developing Early Access content locally. You must pass the script the location of your local copy of the github/docs-early-access git repo as the first argument.


early-access/update-data-and-image-paths.js

This script is run on a writer's machine while developing Early Access content locally. It updates the data and image paths to either include early-access or remove it.


enterprise-server-deprecations/archive-version.js

Run this script during the Enterprise deprecation process to download static copies of all pages for the oldest supported Enterprise version. See the Enterprise deprecation issue template for instructions.

NOTE: If you get this error:

Error [ERR_MODULE_NOT_FOUND]: Cannot find package 'website-scraper' ...

it's because you haven't installed all the optional dependencies. To do that, run:

npm install --include=optional


enterprise-server-deprecations/remove-static-files.js

This script removes the static GraphQL, REST, and webhook files for any deprecated GHES versions.


enterprise-server-deprecations/remove-version-markup.js

Run this script after an Enterprise deprecation to remove Liquid statements and frontmatter that contain the deprecated Enterprise version. See the Enterprise deprecation issue template for instructions.


enterprise-server-releases/add-ghec-to-fpt.js

Run this script to add versions frontmatter and Liquid conditionals for GitHub Enterprise Cloud, based on anything currently versioned for the specified release of free-pro-team.


enterprise-server-releases/create-graphql-files.js

This script creates the static GraphQL files for a new version.


enterprise-server-releases/create-webhook-files.js

This script creates new static webhook payload files for a new version.


enterprise-server-releases/release-banner.js

This script creates or removes a release candidate banner for a specified version.


find-orphaned-assets.js

Print a list of all the asset files that can't be found mentioned in any of the source files (content & code).


get-new-dotcom-path.js

Pass this script any old dotcom path (e.g., articles/foo or foo.md) and it will output the new path in the content/github directory.


graphql/build-changelog.js


graphql/update-files.js


graphql/utils/data-filenames.json


graphql/utils/process-previews.js


graphql/utils/process-schemas.js


graphql/utils/process-upcoming-changes.js


graphql/utils/schema-helpers.js


helpers/action-injections.js


helpers/add-redirect-to-frontmatter.js


helpers/get-liquid-conditionals.js


helpers/get-version-blocks.js


helpers/git-utils.js


helpers/github.js


helpers/remove-deprecated-frontmatter.js


helpers/remove-liquid-statements.js


helpers/retry-on-error-test.js

Return a function that you can use to run any code within and if it throws you get a chance to say whether to sleep + retry. Example:

async function mainFunction() { if (Math.random() > 0.9) throw new Error('too large') return 'OK' }

const errorTest = (err) => err instanceof Error && err.message.includes('too large') const config = { // all optional attempts: 3, sleepTime: 800, onError: (err, attempts) => console.warn(Failed ${attempts} attempts) } const ok = await retry(errorTest, mainFunction, config)


helpers/walk-files.js

A helper that returns an array of files for a given path and file extension.


i18n/test-html-pages.js


kill-server-for-jest.js


list-image-sizes.js

This script lists all local image files, sorted by their dimensions.

NOTE: If you get this error:

Error [ERR_MODULE_NOT_FOUND]: Cannot find package 'image-size' ...

it's because you haven't installed all the optional dependencies. To do that, run:

npm install --include=optional


move-category-to-product.js

Move the files from a category directory to a top-level product and add redirects.


move-content.js

Helps you move (a.k.a. rename) a file or a folder and does what's needed with frontmatter redirect_from.


pages-with-liquid-titles.js

This is a temporary script to visualize which pages have liquid (and conditionals) in their title frontmatter


prevent-pushes-to-main.js

This script is intended to be used as a git "prepush" hook. If the current branch is main, it will exit unsuccessfully and prevent the push.


purge-fastly

Run this script to manually purge the Fastly cache. Note this script requires a FASTLY_SERVICE_ID and FASTLY_TOKEN in your .env file.


purge-fastly-by-url.js

Run this script to manually purge the Fastly cache for all language variants of a single URL or for a batch of URLs in a file. This script does not require authentication.


reconcile-category-dirs-with-ids.js

An automated test checks for discrepancies between category directory names and slugified category titles as IDs.

If the test fails, a human needs to run this script to update the directory names and add appropriate redirects.

This script is not currently supported on Windows.


reconcile-filenames-with-ids.js

An automated test checks for discrepancies between filenames and autogenerated heading IDs. If the test fails, a human needs to run this script to update the filenames.

This script is not currently supported on Windows.


This script goes through all content and renders their HTML and from there can analyze for various flaws (e.g. broken links)


rest/openapi-check.js

Run this script to check if OpenAPI files can be decorated successfully.


rest/test-open-api-schema.js

Run this script to check if OpenAPI operations match versions in content/rest operations


rest/update-files.js

Run this script to pull openAPI files from github/github, dereference them, and decorate them.


rest/utils/create-rest-examples.js


rest/utils/decorator.js


rest/utils/get-body-params.js


rest/utils/get-operations.js


rest/utils/operation-schema.js


rest/utils/operation.js


rest/utils/rest-api-overrides.json


rest/utils/webhook-schema.js


rest/utils/webhook.js


search/analyze-text.js

See how a piece of text gets turned into tokens by the different analyzers. Requires that the index exists in Elasticsearch.

Example:

./script/search/analyze-text.js my words to tokenize


search/build-records.js


search/find-indexable-pages.js


search/index-elasticsearch.js

Creates Elasticsearch index, populates from records, moves the index alias, deletes old indexes.


search/parse-page-sections-into-records.js


search/popular-pages.js


search/search-index-records.js


search/sync-search-indices.js

This script is run automatically via GitHub Actions on every push to main to generate searchable data. It can also be run manually. For more info see contributing/search.md


search/sync.js


search/validate-records.js


server-all-languages

Starts the local development server with all of the available languages enabled.


server-for-jest.js


standardize-frontmatter-order.js

Run this script to standardize frontmatter fields in all content files, per the order: - title - intro - product callout - productVersion - map topic status - hidden status - layout - redirect


start-server-for-jest.js


todo

List all the TODOs in our JavaScript files and stylesheets.


toggle-ghae-feature-flags.js

Find and replace lightweight feature flags for GitHub AE content.


update-enterprise-dates.js

This script fetches data from https://github.com/github/enterprise-releases/blob/master/releases.json and updates lib/enterprise-dates.json, which the site uses for various functionality.


update-internal-links.js

Run this script to find internal links in all content and data Markdown files, check if either the title or link (or both) are outdated, and automatically update them if so.

Exceptions: * Links with fragments (e.g., Bar) will get their root links updated if necessary, but the fragment and title will be unchanged (e.g., Bar). * Links with hardcoded versions (e.g., Foo) will get their root links updated if necessary, but the hardcoded versions will be preserved (e.g., Foo). * Links with Liquid in the titles will have their root links updated if necessary, but the titles will be preserved.


update-readme.js

This script crawls the script directory, hooks on special comment markers in each script, and adds the comment to script/README.md.