-
Notifications
You must be signed in to change notification settings - Fork 47
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
cf5d492
commit 964066f
Showing
58 changed files
with
5,410 additions
and
337 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
root = true | ||
|
||
[*.java] | ||
indent_style = space | ||
indent_size = 4 |
Binary file not shown.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,180 @@ | ||
#!/usr/bin/env python3 | ||
import sys | ||
import os | ||
import logging | ||
import pathlib | ||
from mako.template import Template | ||
from enum import Enum, auto | ||
import tempfile | ||
import boto3 | ||
from botocore.exceptions import ClientError | ||
|
||
class CI(Enum): | ||
UNKNOWN = auto() | ||
GITHUB_ACTIONS = auto() | ||
|
||
def pretty_ci_name(ci): | ||
return str(ci).split(".")[-1].replace("_", "-").lower() | ||
|
||
def is_pr(ci): | ||
if ci == CI.GITHUB_ACTIONS: | ||
cond1 = os.getenv("GITHUB_HEAD_REF", "") != "" | ||
cond2 = not (os.getenv("GITHUB_REPOSITORY", "").startswith("open-obfuscator/") or os.getenv("GITHUB_REPOSITORY", "").startswith("romainthomas/")) | ||
return cond1 or cond2 | ||
return True | ||
|
||
def get_branch(ci): | ||
if ci == CI.GITHUB_ACTIONS: | ||
return os.getenv("GITHUB_REF").replace("refs/heads/", "") | ||
return None | ||
|
||
def get_ci_workdir(ci): | ||
if ci == CI.GITHUB_ACTIONS: | ||
return os.getenv("GITHUB_WORKSPACE") | ||
logger.critical("Unsupported CI to resolve working directory") | ||
sys.exit(1) | ||
|
||
def get_tag(ci): | ||
if ci == CI.GITHUB_ACTIONS: | ||
ref = os.getenv("GITHUB_REF", "") | ||
logger.info("Github Action tag: {}".format(ref)) | ||
if ref.startswith("refs/tags/"): | ||
return ref.replace("refs/tags/", "") | ||
return "" | ||
|
||
logger.critical("Unsupported CI to resolve working directory") | ||
sys.exit(1) | ||
|
||
LOG_LEVEL = logging.INFO | ||
|
||
logging.getLogger().addHandler(logging.StreamHandler(stream=sys.stdout)) | ||
logging.getLogger().setLevel(LOG_LEVEL) | ||
logger = logging.getLogger(__name__) | ||
|
||
CURRENT_CI = CI.GITHUB_ACTIONS | ||
|
||
CI_PRETTY_NAME = pretty_ci_name(CURRENT_CI) | ||
logger.info("CI: %s", CI_PRETTY_NAME) | ||
|
||
ALLOWED_BRANCHES = {"main", "deploy", "devel"} | ||
BRANCH_NAME = get_branch(CURRENT_CI) | ||
TAG_NAME = get_tag(CURRENT_CI) | ||
IS_TAGGED = TAG_NAME is not None and len(TAG_NAME) > 0 | ||
|
||
logger.info("Branch: %s", BRANCH_NAME) | ||
logger.info("Tag: %s", TAG_NAME) | ||
|
||
if BRANCH_NAME.startswith("release-"): | ||
logger.info("Branch release") | ||
elif BRANCH_NAME not in ALLOWED_BRANCHES and not IS_TAGGED: | ||
logger.info("Skip deployment for branch '%s'", BRANCH_NAME) | ||
sys.exit(0) | ||
|
||
if is_pr(CURRENT_CI): | ||
logger.info("Skip pull request") | ||
sys.exit(0) | ||
|
||
CURRENTDIR = pathlib.Path(__file__).resolve().parent | ||
REPODIR = CURRENTDIR / ".." / ".." | ||
|
||
# According to Scaleway S3 documentation, the endpoint | ||
# should starts with '<bucket>'.s3.<region>.scw.cloud | ||
# Nevertheless boto3 uses /{Bucket} endpoints suffix | ||
# which create issues (see: https://stackoverflow.com/a/70383653) | ||
DPROTECT_S3_REGION = "fr-par" | ||
DPROTECT_S3_ENDPOINT = "https://s3.{region}.scw.cloud".format(region=DPROTECT_S3_REGION) | ||
DPROTECT_S3_BUCKET = "obfuscator" | ||
DPROTECT_S3_KEY = os.getenv("DPROTECT_S3_KEY", None) | ||
DPROTECT_S3_SECRET = os.getenv("DPROTECT_S3_SECRET", None) | ||
|
||
if DPROTECT_S3_KEY is None or len(DPROTECT_S3_KEY) == 0: | ||
logger.error("OPEN_OBFUSCATOR_S3_KEY is not set!") | ||
sys.exit(1) | ||
|
||
if DPROTECT_S3_SECRET is None or len(DPROTECT_S3_SECRET) == 0: | ||
logger.error("OPEN_OBFUSCATOR_S3_SECRET is not set!") | ||
sys.exit(1) | ||
|
||
CI_CWD = pathlib.Path(get_ci_workdir(CURRENT_CI)) | ||
|
||
if CI_CWD is None: | ||
logger.error("Can't resolve CI working dir") | ||
sys.exit(1) | ||
|
||
DIST_DIR = REPODIR / "dist" | ||
|
||
logger.info("Working directory: %s", CI_CWD) | ||
|
||
INDEX_TEMPLATE = r""" | ||
<!DOCTYPE html> | ||
<html> | ||
<title>Packages for dProtect</title> | ||
<body> | ||
<h1>Packages for dProtect</h1> | ||
% for path, filename in files: | ||
<a href="/${path}">${filename}</a><br /> | ||
% endfor | ||
</body> | ||
</html> | ||
""" | ||
|
||
SKIP_LIST = ["index.html"] | ||
|
||
s3 = boto3.resource( | ||
's3', | ||
region_name=DPROTECT_S3_REGION, | ||
use_ssl=True, | ||
endpoint_url=DPROTECT_S3_ENDPOINT, | ||
aws_access_key_id=DPROTECT_S3_KEY, | ||
aws_secret_access_key=DPROTECT_S3_SECRET | ||
) | ||
|
||
|
||
def push(file: str, dir_name: str): | ||
zipfile = pathlib.Path(file) | ||
dst = f"{dir_name}/dprotect/{zipfile.name}" | ||
logger.info("Uploading %s to %s", file, dst) | ||
try: | ||
obj = s3.Object(DPROTECT_S3_BUCKET, dst) | ||
obj.put(Body=zipfile.read_bytes()) | ||
return 0 | ||
except ClientError as e: | ||
logger.error("S3 push failed: %s", e) | ||
return 1 | ||
|
||
|
||
def filename(object): | ||
return pathlib.Path(object.key).name | ||
|
||
def generate_index(dir_name: str): | ||
files = s3.Bucket(DPROTECT_S3_BUCKET).objects.filter(Prefix=f'{dir_name}/dprotect') | ||
tmpl_info = [(object.key, filename(object)) for object in files if filename(object) not in SKIP_LIST] | ||
html = Template(INDEX_TEMPLATE).render(files=tmpl_info) | ||
return html | ||
|
||
dir_name = "latest" | ||
|
||
if BRANCH_NAME != "main": | ||
dir_name = "{}".format(BRANCH_NAME.replace("/", "-").replace("_", "-")) | ||
|
||
if BRANCH_NAME.startswith("release-"): | ||
_, dir_name = BRANCH_NAME.split("release-") | ||
|
||
if IS_TAGGED: | ||
dir_name = str(TAG_NAME) | ||
|
||
logger.info("Destination directory: %s", dir_name) | ||
|
||
for file in DIST_DIR.glob("*.zip"): | ||
logger.info("[ZIP ] Uploading '%s'", file.as_posix()) | ||
push(file.as_posix(), dir_name) | ||
|
||
nightly_index = generate_index(dir_name) | ||
with tempfile.TemporaryDirectory() as tmp: | ||
tmp = pathlib.Path(tmp) | ||
index = (tmp / "index.html") | ||
index.write_text(nightly_index) | ||
push(index.as_posix(), dir_name) | ||
|
||
logger.info("Done!") | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
name: 'dProtect Main' | ||
on: [push, workflow_dispatch] | ||
|
||
jobs: | ||
build: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v2 | ||
with: | ||
fetch-depth: 0 | ||
- name: Build dProtect-core & dProtect | ||
shell: bash | ||
run: | | ||
mkdir -p $GITHUB_WORKSPACE/dist | ||
docker run --rm \ | ||
-v $GITHUB_WORKSPACE:/dprotect \ | ||
openobfuscator/dprotect-build:latest bash /dprotect/scripts/docker/gh_action.sh | ||
- name: Deploy | ||
env: | ||
DPROTECT_S3_KEY: ${{ secrets.DPROTECT_S3_KEY }} | ||
DPROTECT_S3_SECRET: ${{ secrets.DPROTECT_S3_SECRET }} | ||
shell: bash | ||
run: | | ||
docker run \ | ||
-v $GITHUB_WORKSPACE:/dprotect \ | ||
-e GITHUB_ACTIONS="true" \ | ||
-e GITHUB_WORKSPACE=$GITHUB_WORKSPACE \ | ||
-e GITHUB_REF=$GITHUB_REF \ | ||
-e GITHUB_REPOSITORY=$GITHUB_REPOSITORY \ | ||
-e DPROTECT_S3_KEY=$DPROTECT_S3_KEY \ | ||
-e DPROTECT_S3_SECRET=$DPROTECT_S3_SECRET \ | ||
--rm \ | ||
openobfuscator/deployment python3 /dprotect/.github/scripts/s3-deploy.py | ||
Oops, something went wrong.