From 5fef342ec2767a0c6d4dba91330dbb752b89064b Mon Sep 17 00:00:00 2001 From: s3rj1k Date: Thu, 11 Jul 2024 21:59:10 +0200 Subject: [PATCH] Add reusable workflows for `repo-auth-client`. --- .../actions/repo-auth-client-nonce/action.yml | 57 +++++++++++++++++++ .../actions/repo-auth-client-token/action.yml | 57 +++++++++++++++++++ 2 files changed, 114 insertions(+) create mode 100644 .github/actions/repo-auth-client-nonce/action.yml create mode 100644 .github/actions/repo-auth-client-token/action.yml diff --git a/.github/actions/repo-auth-client-nonce/action.yml b/.github/actions/repo-auth-client-nonce/action.yml new file mode 100644 index 00000000..0d8ddae2 --- /dev/null +++ b/.github/actions/repo-auth-client-nonce/action.yml @@ -0,0 +1,57 @@ +name: Repository AUTH client Nonce + +inputs: + domain: + required: false + default: 'repo-auth-service.freeswitch.org' + description: Domain of AUTH service +outputs: + nonce: + description: Nonce value from AUTH service + value: ${{ steps.get-nonce.outputs.nonce }} + +runs: + using: "composite" + steps: + - name: Get Nonce + id: get-nonce + shell: python + run: | + import requests + from requests.adapters import HTTPAdapter, Retry + from urllib.parse import urlencode + import sys + import os + + def create_https_session_with_retries( + retries=5, backoff_factor=1.0, status_forcelist=(500, 502, 504, 400, 403, 404) + ): + session = requests.Session() + retry = Retry( + total=retries, + read=retries, + connect=retries, + backoff_factor=backoff_factor, + status_forcelist=status_forcelist, + ) + adapter = HTTPAdapter(max_retries=retry) + session.mount("https://", adapter) + return session + + def GET(url, session): + response = session.get(url) + response.raise_for_status() + return response.text.strip() + + session = create_https_session_with_retries() + + try: + nonce = GET( + f"https://${{ inputs.domain }}/?auth=1", session + ) + + with open(os.getenv('GITHUB_OUTPUT'), 'a') as f: + f.write(f'nonce={nonce}\n') + except requests.exceptions.RequestException as e: + print(f"An error occurred: {e}") + sys.exit(1) diff --git a/.github/actions/repo-auth-client-token/action.yml b/.github/actions/repo-auth-client-token/action.yml new file mode 100644 index 00000000..cb55a024 --- /dev/null +++ b/.github/actions/repo-auth-client-token/action.yml @@ -0,0 +1,57 @@ +name: Repository AUTH client Token + +inputs: + domain: + required: false + default: 'repo-auth-service.freeswitch.org' + description: Domain of AUTH service +outputs: + token: + description: Token value from AUTH service + value: ${{ steps.get-token.outputs.token }} + +runs: + using: "composite" + steps: + - name: Get Token + id: get-token + shell: python + run: | + import requests + from requests.adapters import HTTPAdapter, Retry + from urllib.parse import urlencode + import sys + import os + + def create_https_session_with_retries( + retries=5, backoff_factor=1.0, status_forcelist=(500, 502, 504, 400, 403, 404) + ): + session = requests.Session() + retry = Retry( + total=retries, + read=retries, + connect=retries, + backoff_factor=backoff_factor, + status_forcelist=status_forcelist, + ) + adapter = HTTPAdapter(max_retries=retry) + session.mount("https://", adapter) + return session + + def GET(url, session): + response = session.get(url) + response.raise_for_status() + return response.text.strip() + + session = create_https_session_with_retries() + + try: + token = GET( + f'https://${{ inputs.domain }}/?{urlencode({"verify": "${{ env.NONCE }}"})}', session + ) + + with open(os.getenv('GITHUB_OUTPUT'), 'a') as f: + f.write(f'token={token}\n') + except requests.exceptions.RequestException as e: + print(f"An error occurred: {e}") + sys.exit(1)