docs/script
..
bookmarklets
content-migrations
deployment
dev-toc
helpers
README.md
accessibility-checks.js
anonymize-branch.js
bootstrap
check-for-node
check-github-github-links.js
cmp-files.js
content-changes-table-comment.js
copy-fixture-data.js
copy-to-test-repo.sh
create-glossary-from-spreadsheet.js
create-subject.js
domwaiter.js
kill-server-for-jest.js
move-category-to-product.js
move-content.js
pages-with-liquid-titles.js
prevent-pushes-to-main.js
purge-fastly
purge-fastly-by-url.js
reconcile-category-dirs-with-ids.js
reconcile-filenames-with-ids.js
server
server-all-languages
server-for-jest.js
standardize-frontmatter-order.js
start-server-for-jest.js
test
todo
update-readme.js
update-tocs.js
warmup-remotejson.js

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 @docs-bot 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.


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/git-utils.js


helpers/github.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.


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/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:

./src/scripts/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-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.