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

New org components #713

Merged
merged 37 commits into from
Nov 19, 2024
Merged
Show file tree
Hide file tree
Changes from 29 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
57c3b55
Initital component refactoring
goruha Oct 18, 2024
0a51a8b
Added first version
goruha Oct 21, 2024
8a464ae
Added documentation
goruha Oct 24, 2024
642edfd
Added documentation
goruha Oct 24, 2024
ee8b9e0
Merge branch 'master' into new-org-components
goruha Oct 24, 2024
034eb1b
Added documentation
goruha Oct 25, 2024
dc7fb06
Merge branch 'new-org-components' of github.com:cloudposse/docs into …
goruha Oct 25, 2024
1af4d44
Fix rendering readme'
goruha Oct 25, 2024
75f1b42
Remove readme
goruha Oct 25, 2024
b6becb3
Fix site build
goruha Oct 25, 2024
a7a2510
Fix subdirs
goruha Oct 25, 2024
c0c6c44
Migrate docs to new components
goruha Nov 4, 2024
be033af
Remove minfied static files
goruha Nov 4, 2024
f60a5c5
Fix terraform values
goruha Nov 8, 2024
14dab10
Fix terraform docs generation
goruha Nov 9, 2024
ec827d8
Fix terraform docs generation
goruha Nov 9, 2024
03951ec
Enable retry github requests
goruha Nov 9, 2024
8100f83
Enable retry github requests
goruha Nov 9, 2024
2a78fcf
Fix repo renaming
goruha Nov 10, 2024
3eaea49
Remove debug output
goruha Nov 10, 2024
74f09cf
Refactor component renderer
goruha Nov 11, 2024
e551bed
Refactor component renderer
goruha Nov 11, 2024
5154286
Refactor component renderer
goruha Nov 11, 2024
4190b62
Fix modules
goruha Nov 11, 2024
b127c8d
Fix modules
goruha Nov 11, 2024
69fe4bd
Refactor components
goruha Nov 11, 2024
19535ca
Fix grouping
goruha Nov 12, 2024
e462b22
Fix grouping
goruha Nov 12, 2024
d20f0cf
Fix grouping
goruha Nov 12, 2024
2a97dfb
Cleanup trunk codes
goruha Nov 19, 2024
756f47f
Added spacelift readme
goruha Nov 19, 2024
721c667
Fix links
goruha Nov 19, 2024
220e3d5
Fix links
goruha Nov 19, 2024
7458e13
Fix links
goruha Nov 19, 2024
02e7db0
Fix links
goruha Nov 19, 2024
04edc44
Fix links
goruha Nov 19, 2024
9bd60d0
Fix links
goruha Nov 19, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion docs/layers/software-delivery/eks-argocd/eks-argocd.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -337,7 +337,7 @@ runs:
### Implementation

- [`eks/argocd`](/components/library/aws/eks/argocd/): This component is responsible for provisioning [ArgoCD](https://argoproj.github.io/cd/).
- [`argocd-repo`](/components/library/aws/argocd-repo/): This component is responsible for creating and managing an ArgoCD desired state repository.
- [`argocd-repo`](/components/library/aws/eks/argocd-repo/): This component is responsible for creating and managing an ArgoCD desired state repository.
goruha marked this conversation as resolved.
Show resolved Hide resolved
- [`sso-saml-provider`](/components/library/aws/sso-saml-provider/): This component reads sso credentials from SSM Parameter store and provides them as outputs

## References
Expand Down
7 changes: 5 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 4 additions & 0 deletions scripts/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,10 @@ FROM python:3.9-slim
# Set the working directory
WORKDIR /

RUN apt-get update && apt-get install -y apt-utils curl
RUN curl -1sLf 'https://dl.cloudsmith.io/public/cloudposse/packages/cfg/setup/bash.deb.sh' | bash
RUN apt-get install -y terraform-docs

# Copy the Python requirements file into the container
COPY ./docs-collator/requirements.txt scripts/docs-collator/requirements.txt

Expand Down
2 changes: 1 addition & 1 deletion scripts/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,4 @@ build:
docker build -t docs-collator --progress=plain .

run: build
docker run -it --rm -e PUBLIC_REPO_ACCESS_TOKEN=$(PUBLIC_REPO_ACCESS_TOKEN). -v $(PWD)/docs:/docs docs-collator /scripts/render-docs-for-components.sh
docker run -it --rm -e PUBLIC_REPO_ACCESS_TOKEN=$(PUBLIC_REPO_ACCESS_TOKEN) -v $(PWD)/docs:/docs docs-collator /scripts/render-docs-for-modules.sh
4 changes: 4 additions & 0 deletions scripts/docs-collator/AbstractRenderer.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,10 @@ def __init__(self, message):


class AbstractRenderer:

def render(self):
raise NotImplementedError

def _pre_rendering_fixes(self, repo, module_download_dir, submodule_dir=""):
readme_yaml_file = os.path.join(module_download_dir, submodule_dir, README_YAML)
content = io.read_file_to_string(readme_yaml_file)
Expand Down
142 changes: 0 additions & 142 deletions scripts/docs-collator/ComponentRenderer.py

This file was deleted.

45 changes: 34 additions & 11 deletions scripts/docs-collator/GitHubProvider.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,17 @@
import pickle
from github import Github, GithubException
from functools import lru_cache

from github import Auth

from utils import io

GITHUB_ORG = "cloudposse"
TERRAFORM_MODULE_NAME_PATTERN = re.compile(
"^terraform-[a-zA-Z0-9]+-.*"
) # convention is terraform-<PROVIDER>-<NAME>
COMPONENTS_NAME_PATTERN = re.compile(
"^[a-zA-Z0-9]+.*"
) # convention is terraform-<PROVIDER>-<NAME>
GITHUB_ACTION_NAME_PATTERN = re.compile(
"^github-action-.*"
) # convention is github-action-<NAME>
Expand All @@ -21,41 +26,59 @@


class GitHubProvider:
def __init__(self, github_api_token):
self.github = Github(github_api_token)
def __init__(self, github_api_token = None):
if github_api_token:
auth = Auth.Token(github_api_token)
else:
logging.info("No GitHub API token provided, using unauthenticated access")
auth = None
self.github = Github(auth=auth)
self.cache = self.load_cache(CACHE_FILE)
self.repos_cache = self.load_cache(REPOS_CACHE_FILE)

def get_terraform_repos(self, includes_csv, excludes_csv):
def __del__(self):
self.github.close()

def get_terraform_repos(self, github_org, includes_csv, excludes_csv):
key = (includes_csv, excludes_csv)
if key in self.repos_cache:
return self.repos_cache[key]
repos = self.__get_repos(
includes_csv, excludes_csv, TERRAFORM_MODULE_NAME_PATTERN
github_org, includes_csv, excludes_csv, TERRAFORM_MODULE_NAME_PATTERN
)
self.repos_cache[key] = repos
self.save_cache(REPOS_CACHE_FILE, self.repos_cache)
return repos

def get_github_actions_repos(self, includes_csv, excludes_csv):
return self.__get_repos(includes_csv, excludes_csv, GITHUB_ACTION_NAME_PATTERN)
def get_components_repos(self, github_org, includes_csv, excludes_csv):
key = (includes_csv, excludes_csv)
if key in self.repos_cache:
return self.repos_cache[key]
repos = self.__get_repos(
github_org, includes_csv, excludes_csv, COMPONENTS_NAME_PATTERN
)
self.repos_cache[key] = repos
self.save_cache(REPOS_CACHE_FILE, self.repos_cache)
return repos

def get_github_actions_repos(self, github_org, includes_csv, excludes_csv):
return self.__get_repos(github_org, includes_csv, excludes_csv, GITHUB_ACTION_NAME_PATTERN)

def __get_repos(self, includes_csv, excludes_csv, pattern):
def __get_repos(self, github_org, includes_csv, excludes_csv, pattern):
repos = []

excludes = self.__csv_to_set(excludes_csv)
includes = self.__csv_to_set(includes_csv)

if len(includes) > 0:
for include in includes:
repo = self.github.get_organization(GITHUB_ORG).get_repo(include)
repo = self.github.get_organization(github_org).get_repo(include)

if not self.__is_valid(repo, pattern):
continue

repos.append(repo)
else:
for repo in self.github.get_organization(GITHUB_ORG).get_repos():
for repo in self.github.get_organization(github_org).get_repos():
if not self.__is_valid(repo, pattern):
continue

Expand Down
Empty file.
Empty file.
85 changes: 85 additions & 0 deletions scripts/docs-collator/component/component.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
import os

from utils import io

README_YAML = "README.yaml"
README_MD = "README.md"
SUBMODULES_DIR = "modules"


class Component:
_terraform_dir = None
_name = None
_provider = None
_module_download_dir = None
_repo = None
_subdirs = []

def __init__(self, repo, module_download_dir, terraform_dir, name, subdirs=[]):
self._repo = repo
self._module_download_dir = module_download_dir
self._terraform_dir = terraform_dir
self._name = name
self._subdirs = subdirs

@property
def name(self):
return self._name

@property
def dir(self):
return self._module_download_dir

@property
def terraform_dir(self):
return self._terraform_dir

def has_readme_yaml(self):
return os.path.exists(os.path.join(self._module_download_dir, README_YAML))

@property
def provider(self):
return self._repo.provider

@property
def subdirs(self):
return self._subdirs

@property
def repo(self):
return self._repo

def modules(self):
extra_resources_dir = os.path.join(self._terraform_dir, SUBMODULES_DIR)
files = io.get_filenames_in_dir(extra_resources_dir, "*", True)
readme_files = {}

for file in files:
base_name = os.path.basename(file)
dir_name = os.path.dirname(file)
name = os.path.basename(os.path.dirname(file))

rel_dir = os.path.relpath(dir_name, self._terraform_dir).split("/")[:-1]

subdirs = self._subdirs.copy()
subdirs.append(self.name)
subdirs.extend(rel_dir)

if base_name == README_YAML:
readme_files[dir_name] = Component(
repo=self._repo,
module_download_dir=dir_name,
terraform_dir=dir_name,
name=name,
subdirs=subdirs
)
elif base_name == README_MD and dir_name not in readme_files:
readme_files[dir_name] = Component(
repo=self._repo,
module_download_dir=dir_name,
terraform_dir=dir_name,
name=name,
subdirs=subdirs
)

return readme_files.values()
Loading