Skip to content

Commit

Permalink
🏗️ build(birth): wiped history and started over
Browse files Browse the repository at this point in the history
  • Loading branch information
ProfessorManhattan committed Dec 18, 2021
0 parents commit 6f29805
Show file tree
Hide file tree
Showing 303 changed files with 44,469 additions and 0 deletions.
105 changes: 105 additions & 0 deletions .config/Brewfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,105 @@
# Standard Homebrew taps
tap "homebrew/core"
tap "homebrew/bundle"
tap "homebrew/services"
tap "caskroom/cask"

# Homebrew Formulae
# e.g. `brew install <program>`
# @brew [Act](https://github.com/nektos/act) - Run GitHub Actions locally
brew "act"
brew "appium"
brew "bat"
brew "bitwarden-cli"
brew "croc"
brew "curl"
brew "dasel"
brew "direnv"
brew "dive"
if OS.linux?
brew "docker"
end
brew "dockle"
brew "goodwithtech/r/dockle"
brew "exiftool"
brew "ffsend"
brew "gh"
brew "git"
brew "gitleaks"
brew "glab"
brew "go"
brew "grex"
brew "htmlq"
brew "hyperfine"
brew "jo"
brew "jq"
brew "minio/stable/mc"
brew "mkcert"
brew "node"
brew "openssh"
brew "ots"
brew "oq"
brew "php", restart_service: true
brew "poetry"
brew "pup"
brew "python"
brew "rsync"
brew "ruby"
brew "hudochenkov/sshpass/sshpass"
brew "sysbench"
brew "go-task/tap/go-task"
brew "teleport"
brew "tokei"
brew "aquasecurity/trivy/trivy"
brew "up"
brew "hashicorp/tap/waypoint"
if OS.linux?
brew "wireshark"
end
brew "yarn"
brew "yq"
if OS.mac?
brew "coreutils"
end

# Homebrew Casks (only available on macOS)
# e.g. `brew install --cask <program>`
# @cask [Docker](https://docker.com) - Description
cask "altair"
cask "balenaetcher"
cask "bitwarden"
cask "docker"
cask "firefox"
cask "gimp"
cask "google-chrome"
cask "iterm2"
cask "java" unless system "/usr/libexec/java_home --failfast"
cask "lens"
cask "microsoft-teams"
cask "postman"
cask "slack"
cask "skype"
cask "teamviewer"
cask "vagrant"
cask "virtualbox"
cask "visual-studio-code"
cask "vmware-fusion"
cask "wireshark"

# Examples below
# 'brew install --with-rmtp', 'brew services restart' on version changes
# brew "denji/nginx/nginx-full", args: ["with-rmtp"], restart_service: :changed
# 'brew install', always 'brew services restart', 'brew link', 'brew unlink mysql' (if it is installed)
# brew "[email protected]", restart_service: true, link: true, conflicts_with: ["mysql"]
# 'brew install --cask'
# cask "google-chrome"
# 'brew install --cask --appdir=~/my-apps/Applications'
# cask "firefox", args: { appdir: "~/my-apps/Applications" }
# always upgrade auto-updated or unversioned cask to latest version even if already installed
# cask "opera", greedy: true
# 'brew install --cask' only if '/usr/libexec/java_home --failfast' fails
# cask "java" unless system "/usr/libexec/java_home --failfast"
# 'mas install'
# mas "1Password", id: 443987910
# 'whalebrew install'
# whalebrew "whalebrew/wget"
33 changes: 33 additions & 0 deletions .config/ansible-lint.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
---
enable_list:
- fqcn-builtins
- no-log-password
- no-same-owner

exclude_paths:
- ../.autodoc/
- ../.cache/
- ../.common/
- ../.config/
- ../.git/
- ../.github/
- ../.gitlab/
- ../.husky/
- ../.modules/
- ../.npm/
- ../.pnpm-store/
- ../.shared/
- ../.task/
- ../.venv/
- ../.vscode/
- ../build/
- ../dist/
- ../molecule/
- ../node_modules/
- ../pnpm-lock.yaml
- ../roles/
- ../venv/

offline: true

skip_list: []
9 changes: 9 additions & 0 deletions .config/commitlint.config.cjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
module.exports = {
extends: ['gitmoji'],
parserPreset: {
parserOpts: {
headerPattern: /^(:\w*:)(?:\s)(?:\((.*?)\))?\s((?:.*(?=\())|.*)(?:\(#(\d*)\))?/,
headerCorrespondence: ['type', 'scope', 'subject', 'ticket']
}
}
}
22 changes: 22 additions & 0 deletions .config/common-keywords.hbs.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
{
"keywords": [
"ansible",
"ansible-role",
"archlinux",
"centos",
"debian",
"doctor",
"fedora",
"install",
"installdoc",
"installdoctor",
"macos",
"mblabs",
"megabytelabs",
"molecule",
"professormanhattan",
"role",
"ubuntu",
"windows"
]
}
23 changes: 23 additions & 0 deletions .config/common-keywords.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
{
"keywords": [
"ansible",
"ansible-role",
"archlinux",
"centos",
"debian",
"doctor",
"fedora",
"install",
"installdoc",
"installdoctor",
"macos",
"mblabs",
"megabytelabs",
"molecule",
"professormanhattan",
"role",
"ubuntu",
"washingtondc",
"windows"
]
}
92 changes: 92 additions & 0 deletions .config/cspell.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
{
"$schema": "https://raw.githubusercontent.com/streetsidesoftware/cspell/master/cspell.schema.json",
"flagWords": [],
"ignorePaths": [
".autodoc/**",
".cache/**",
".common/**",
".config/**",
".git/**",
".github/**",
".gitlab/**",
".husky/**",
".modules/**",
".npm/**",
".pnpm-store/**",
".shared/**",
".task/**",
".venv/**",
".vscode/**",
"build/**",
"dist/**",
"package.json",
"package-lock.json",
"slim.report.json",
"yarn.lock",
"tsconfig.json",
"node_modules/**",
"pnpm-lock.yaml",
"roles/**",
"venv/**"
],
"language": "en",
"version": "0.1",
"words": [
"ansible",
"archlinux",
"autokey",
"bento",
"buildr",
"centos",
"chdir",
"choco",
"circleci",
"codecov",
"commitlint",
"cpus",
"dockerhub",
"editorconfig",
"enablerepo",
"epel",
"esnext",
"favicons",
"fontinstall",
"gitdocker",
"gitlab",
"hyperv",
"idempotence",
"koalaman",
"makepkg",
"megabytelabs",
"minikube",
"mkdir",
"modifyvm",
"natdnshostresolver",
"netaddr",
"noconfirm",
"noqa",
"optionator",
"pacman",
"pino",
"prfssr",
"professormanhattan",
"qubes",
"sandboxed",
"sbin",
"shellcheck",
"startmenu",
"submodule",
"submodules",
"tmpfs",
"transpiled",
"typedoc",
"untracked",
"venv",
"videoblobs",
"virtualbox",
"webp",
"yamllint",
"zalewski",
"zorin"
]
}
80 changes: 80 additions & 0 deletions .config/docs/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
<div align="center">
<center>
<a href="https://gitlab.com/megabyte-labs/documentation">
<img width="140" height="140" alt="Documentation logo" src="https://gitlab.com/megabyte-labs/documentation/shared/-/raw/master/logo.png" />
</a>
</center>
</div>
<div align="center">
<center><h1>Common Documentation</h1></center>
<center><h4 style="color: #18c3d1;">Documentation partials and JSON variables for generating sweet READMEs and templated files for hundreds of repositories</h4></center>
</div>

[![-----------------------------------------------------](https://gitlab.com/megabyte-labs/assets/-/raw/master/png/aqua-divider.png)](#table-of-contents)

## Table of Contents

- [➤ Summary](#summary)
- [➤ Repository Types](#repository-types)
- [➤ Requirements](#repository-pipeline-order)
- [➤ Flow Summary](#flow-summary)
- [`common.json`](#common-json)

[![-----------------------------------------------------](https://gitlab.com/megabyte-labs/assets/-/raw/master/png/aqua-divider.png)](#summary)

## Summary

In all of our projects, we strive to maintain useful and informative documentation. However, with hundreds of projects and limited man power, it can be tricky. To solve this problem, we re-use documentation partials to generate the documentation in each of our repositories.

There are two repositories responsible for generating the documentation for each project:

1. **[Shared documentation repository](https://gitlab.com/megabyte-labs/documentation/shared):** This repository contains documentation partials that are used throughout all of our repositories.
2. **Project-type documentation repository:** This repository is where we store documentation that is specific to the type of project that downstream repository is. For example, if the downstream project is an Ansible role, then the repositories that will be used to generate the documentation will be the shared documentation repository and the [Ansible documentation repository](https://gitlab.com/megabyte-labs/documentation/ansible).

[![-----------------------------------------------------](https://gitlab.com/megabyte-labs/assets/-/raw/master/png/aqua-divider.png)](#repository-types)

## Repository Types

We currently use this method to scaffold our projects of the following types:

1. [Angular](https://gitlab.com/megabyte-labs/documentation/angular)
2. [Ansible](https://gitlab.com/megabyte-labs/documentation/ansible)
3. [Dockerfile](https://gitlab.com/megabyte-labs/documentation/dockerfile)
4. [Go](https://gitlab.com/megabyte-labs/documentation/go)
5. [NPM](https://gitlab.com/megabyte-labs/documentation/npm)
6. [Packer](https://gitlab.com/megabyte-labs/documentation/packer)
7. [Python](https://gitlab.com/megabyte-labs/documentation/python)

[![-----------------------------------------------------](https://gitlab.com/megabyte-labs/assets/-/raw/master/png/aqua-divider.png)](#repository-pipeline-order)

## Repository Pipeline Order

Whenever a change is made to the shared documentation repository, the pipeline for the project-specific repositories will trigger (unless it is configured not to do so). Part of that pipeline includes cloning the shared documentation repository into the project-specific repository. When this happens, the `common/` folder in the shared repository is copied over to the project-specific repository.

After the `common/` folder is copied over, the project-specific repository will trigger the pipeline for the project-specific common files repository (e.g. [Ansible common files repository](https://gitlab.com/megabyte-labs/common/ansible)). When this is happens, the project-specific documentation repository is added to the project-specific common files repository in the `docs/` folder.

Finally, after the project-specific common files repository is up-to-date, the files it contains are propagated out to the individual projects that all of these repositories are for. This whole process allows us to update, say, a spelling error in the documentation to every project in our eco-system without an repetition.

[![-----------------------------------------------------](https://gitlab.com/megabyte-labs/assets/-/raw/master/png/aqua-divider.png)](#flow-summary)

## Flow Summary

To summarize, the order of the flow is:

1. [Shared documentation repository](https://gitlab.com/megabyte-labs/documentation/shared)
2. Project-specific documentation repository (e.g. [Ansible documentation](https://gitlab.com/megabyte-labs/documentation/ansible))
3. Project-specific common files repository (e.g. [Ansible common files](https://gitlab.com/megabyte-labs/common/ansible))
4. Individual project repository (e.g. [Ansible role for Android Studio](https://gitlab.com/megabyte-labs/ansible-roles/androidstudio))

So, with synchronization turned on, a change to the shared documentation repository would trigger updates for the most repositories since it is the highest upstream repository.

[![-----------------------------------------------------](https://gitlab.com/megabyte-labs/assets/-/raw/master/png/aqua-divider.png)](#common-json)

## `common.json`

In both the shared documentation repository and the project-specific documentation repositories there is a file called `common.json` in the root of the projects. These files contain variables that are used to dynamically inject variables into the documentation and other files. The `common.json` files in both repositories are merged when there are updates to create the `variables.json` file that is in each project-specific documentation repository. During this process, the variables in the project-specific `common.json` file takes precedence over the variables in the shared `common.json` file. There are a few other steps that are made to create the final version of the `.variables.json` that each project uses to generate documentation and other files. In order of precedence, the variables are acquired from:

1. The variables in the `"blueprint"` section of the `package.json` file that is located in each downstream project
2. The variables stored in the `common.{{ project_subgroup }}.json` file stored in the common files repository for each project type (e.g. the [Android Studio Ansible project](https://gitlab.com/megabyte-labs/ansible-roles/androidstudio) uses the `common.role.json` file in the [Ansible common files repository](https://gitlab.com/megabyte-labs/common/ansible) since the project subtype is a role)
3. The `common.json` file in the project-type-specific documentation repository (e.g. for the Android Studio Ansible role this would be the [Ansible documentation repository](https://gitlab.com/megabyte-labs/documentation/ansible))
4. The `common.json` file in the [shared documentation repository](https://gitlab.com/megabyte-labs/documentation/shared)
13 changes: 13 additions & 0 deletions .config/docs/blueprint-contributing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
{{ load:.config/docs/common/contributing/header.md }}
{{ template:toc }}
{{ load:.config/docs/common/contributing/code-of-conduct.md }}
{{ load:.config/docs/contributing/philosophy.md }}
{{ load:.config/docs/contributing/supported-os.md }}
{{ load:.config/docs/contributing/dev-environment.md }}
{{ load:.config/docs/contributing/pull-requests.md }}
{{ load:.config/docs/contributing/code-format.md }}
{{ load:.config/docs/contributing/code-style.md }}
{{ load:.config/docs/contributing/commenting.md }}
{{ load:.config/docs/contributing/docs.md }}
{{ load:.config/docs/contributing/testing.md }}
{{ load:.config/docs/contributing/linting.md }}
Loading

0 comments on commit 6f29805

Please sign in to comment.