-
Notifications
You must be signed in to change notification settings - Fork 322
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
Showing
80 changed files
with
521 additions
and
866 deletions.
There are no files selected for viewing
12 changes: 6 additions & 6 deletions
12
.github/workflows/omm-ci.yaml → .github/workflows/hma-ci.yaml
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 was deleted.
Oops, something went wrong.
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 |
---|---|---|
@@ -1,142 +1,18 @@ | ||
# See here for image contents: https://github.com/microsoft/vscode-dev-containers/tree/v0.163.1/containers/javascript-node/.devcontainer/base.Dockerfile | ||
FROM mcr.microsoft.com/vscode/devcontainers/python:3.11-bullseye | ||
|
||
# [Install python] | ||
# TODO: pin version later. Otherwise starting up will be too slow. | ||
# Note: We specify AMD64 architecture as it is currently the only one supported for this devcontainer | ||
# relevant for ARM architecture machines as using `python:3.8-buster` will have it try to use that instead | ||
FROM amd64/python:3.9-buster | ||
RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \ | ||
&& apt-get -y install --no-install-recommends postgresql-client \ | ||
&& apt-get clean -y && rm -rf /var/lib/apt/lists/* | ||
|
||
# [Unixname wrestling] | ||
# Some of our script (docker-related) are dependent on the unixname. Would | ||
# need to setup the environment with *your* unixname as the defualt user. | ||
ARG unixname | ||
RUN groupadd --gid 1000 developers \ | ||
&& useradd --uid 1000 --gid developers --shell /bin/bash --create-home $unixname \ | ||
&& usermod -aG sudo $unixname | ||
ARG NODE_VERSION="none" | ||
RUN if [ "${NODE_VERSION}" != "none" ]; then su vscode -c "umask 0002 && . /usr/local/share/nvm/nvm.sh && nvm install ${NODE_VERSION} 2>&1"; fi | ||
|
||
# [Install Tools!] | ||
RUN apt-get update && DEBIAN_FRONTEND=noninteractive \ | ||
apt-get -y install --no-install-recommends git make jq sudo \ | ||
software-properties-common apt-transport-https ca-certificates curl \ | ||
gnupg lsb-release tmux zsh vim less | ||
|
||
# [Allow sudo] Need sudo later in post-create to open up docker socket | ||
ARG unixname | ||
RUN echo "$unixname ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers | ||
|
||
# [Install node] Node.js version: 16 only. Stolen from: https://github.com/nodejs/docker-node/blob/main/16/buster/Dockerfile | ||
RUN groupadd --gid 1001 node \ | ||
&& useradd --uid 1001 --gid node --shell /bin/bash --create-home node | ||
|
||
ENV NODE_VERSION 16.16.0 | ||
|
||
RUN ARCH= && dpkgArch="$(dpkg --print-architecture)" \ | ||
&& case "${dpkgArch##*-}" in \ | ||
amd64) ARCH='x64';; \ | ||
ppc64el) ARCH='ppc64le';; \ | ||
s390x) ARCH='s390x';; \ | ||
arm64) ARCH='arm64';; \ | ||
armhf) ARCH='armv7l';; \ | ||
i386) ARCH='x86';; \ | ||
*) echo "unsupported architecture"; exit 1 ;; \ | ||
esac \ | ||
# gpg keys listed at https://github.com/nodejs/node#release-keys | ||
&& set -ex \ | ||
&& for key in \ | ||
4ED778F539E3634C779C87C6D7062848A1AB005C \ | ||
94AE36675C464D64BAFA68DD7434390BDBE9B9C5 \ | ||
74F12602B6F1C4E913FAA37AD3A89613643B6201 \ | ||
71DCFD284A79C3B38668286BC97EC7A07EDE3FC1 \ | ||
8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 \ | ||
C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8 \ | ||
C82FA3AE1CBEDC6BE46B9360C43CEC45C17AB93C \ | ||
DD8F2338BAE7501E3DD5AC78C273792F7D83545D \ | ||
A48C2BEE680E841632CD4E44F07496B3EB3C1762 \ | ||
108F52B48DB57BB0CC439B2997B01419BD92F80A \ | ||
B9E2F5981AA6E0CD28160D9FF13993A75599653C \ | ||
; do \ | ||
gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" || \ | ||
gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" ; \ | ||
done \ | ||
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" \ | ||
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" \ | ||
&& gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc \ | ||
&& grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - \ | ||
&& tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner \ | ||
&& rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt \ | ||
&& ln -s /usr/local/bin/node /usr/local/bin/nodejs \ | ||
# smoke tests | ||
&& node --version \ | ||
&& npm --version | ||
|
||
ENV YARN_VERSION 1.22.15 | ||
|
||
RUN set -ex \ | ||
&& for key in \ | ||
6A010C5166006599AA17F08146C2130DFD2497F5 \ | ||
; do \ | ||
gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" || \ | ||
gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" ; \ | ||
done \ | ||
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" \ | ||
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" \ | ||
&& gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \ | ||
&& mkdir -p /opt \ | ||
&& tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ \ | ||
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn \ | ||
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg \ | ||
&& rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \ | ||
# smoke test | ||
&& yarn --version | ||
# [Install Node] complete | ||
|
||
# [Install Docker CLI] | ||
RUN export DEBIAN_FRONTEND=noninteractive \ | ||
&& curl -fsSL https://download.docker.com/linux/debian/gpg | gpg \ | ||
--dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg \ | ||
&& echo \ | ||
"deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/debian \ | ||
$(lsb_release -cs) stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null \ | ||
&& apt-get update && apt-get -y install docker-ce-cli | ||
|
||
# [Install Terraform CLI] | ||
RUN curl -fsSL https://apt.releases.hashicorp.com/gpg | apt-key add - \ | ||
&& apt-add-repository "deb [arch=amd64] https://apt.releases.hashicorp.com $(lsb_release -cs) main" \ | ||
&& apt-get update && apt-get install terraform | ||
|
||
# [Install GitHub CLI] | ||
RUN apt-key adv --keyserver keyserver.ubuntu.com --recv-key 23F3D4EA75716059 \ | ||
&& apt-add-repository https://cli.github.com/packages \ | ||
&& apt update \ | ||
&& apt install gh | ||
|
||
# [Shell Dotfiles] | ||
ARG unixname | ||
COPY --chown=${unixname} zshrc /home/$unixname/.zshrc | ||
|
||
ARG unixname | ||
COPY --chown=${unixname} bashrc /home/$unixname/.bashrc | ||
|
||
# [Shell Histories] The volume is mounted in devcontainer.json | ||
ARG unixname | ||
RUN BASH_SNIPPET="export PROMPT_COMMAND='history -a' && export HISTFILE=/commandhistory/.bash_history" \ | ||
&& ZSH_SNIPPET="HISTFILE=/commandhistory/.zsh_history" \ | ||
&& mkdir -p /commandhistory \ | ||
&& touch /commandhistory/.bash_history \ | ||
&& touch /commandhistory/.zsh_history \ | ||
&& chown -R $unixname /commandhistory \ | ||
&& echo $BASH_SNIPPET >> "/home/$unixname/.bashrc" \ | ||
&& echo $ZSH_SNIPPET >> "/home/$unixname/.zshrc" \ | ||
&& echo $ZSH_SNIPPET >> "/home/$unixname/.profile" | ||
# Also appends ZSH_SNIPPET to ~/.profile in case users want to overwrite zshrc file | ||
# e.g. https://code.visualstudio.com/docs/remote/containers#_personalizing-with-dotfile-repositories | ||
|
||
|
||
# [Forward Docker requests to host docker engine] | ||
# Volume is mounted and so is the socket. The socket configuration is within | ||
# devcontainer.json | ||
VOLUME [ "/var/lib/docker"] | ||
|
||
# [Install AWS CLI] Using pip install because the apt version is old. Doesn't | ||
# support all ecr commands. | ||
RUN pip3 install awscli --upgrade | ||
&& chown -R vscode /commandhistory \ | ||
&& echo $BASH_SNIPPET >> "/home/vscode/.bashrc" \ | ||
&& echo $ZSH_SNIPPET >> "/home/vscode/.zshrc" \ | ||
&& echo $ZSH_SNIPPET >> "/home/vscode/.profile" |
This file was deleted.
Oops, something went wrong.
121 changes: 45 additions & 76 deletions
121
hasher-matcher-actioner/.devcontainer/devcontainer.json
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 |
---|---|---|
@@ -1,83 +1,52 @@ | ||
// For format details, see https://aka.ms/devcontainer.json. | ||
{ | ||
"build": { | ||
"dockerfile": "Dockerfile", | ||
"args": { | ||
// MacOS and Linux use ${localEnv:USER}, Windows uses ${localEnv:USERNAME} | ||
"unixname": "${localEnv:USER}${localEnv:USERNAME}" | ||
} | ||
}, | ||
// MacOS and Linux use ${env:USER}, Windows uses ${env:USERNAME} | ||
"remoteUser": "${localEnv:USER}${localEnv:USERNAME}", | ||
"mounts": [ | ||
"source=/var/run/docker.sock,target=/var/run/docker.sock,type=bind", | ||
// MacOS and Linux use ${localEnv:HOME}, Windows uses ${localEnv:USERPROFILE} | ||
"source=${localEnv:HOME}${localEnv:USERPROFILE}/.aws,target=/var/run/aws-config,type=bind,consistency=cached", | ||
"source=${localEnv:HOME}${localEnv:USERPROFILE}/.hma-cmdhist,target=/commandhistory,type=bind" | ||
"name": "open-media-match", | ||
"dockerComposeFile": "docker-compose.yaml", | ||
"service": "app", | ||
"workspaceFolder": "/workspace", | ||
"forwardPorts": [ | ||
8080, | ||
5432 | ||
], | ||
"name": "hma-devserver", | ||
// Set *default* container specific settings.json values on container create. | ||
"settings": { | ||
"terminal.integrated.profiles.linux": { | ||
"bash": { | ||
"path": "/bin/bash", | ||
"args": [ | ||
"-l" | ||
] | ||
}, | ||
"zsh": { | ||
"path": "/bin/zsh", | ||
"args": [ | ||
"-l" | ||
] | ||
"customizations": { | ||
"vscode": { | ||
"extensions": [ | ||
"ms-python.python", | ||
"ms-python.vscode-pylance", | ||
"ms-python.black-formatter", | ||
"ms-python.mypy-type-checker", | ||
"mtxr.sqltools", | ||
"mtxr.sqltools-driver-pg", | ||
"tamasfe.even-better-toml", | ||
"humao.rest-client" | ||
], | ||
"settings": { | ||
"python.defaultInterpreterPath": "/usr/local/bin/python", | ||
"sqltools.connections": [ | ||
{ | ||
"name": "Container database", | ||
"driver": "PostgreSQL", | ||
"previewLimit": 50, | ||
"server": "localhost", | ||
"port": 5432, | ||
"database": "media_match", | ||
"username": "media_match", | ||
"password": "hunter2" | ||
} | ||
], | ||
"files.exclude": { | ||
"**/*.egg-info": true, | ||
"**/__pycache__": true | ||
}, | ||
"mypy-type-checker.path": ["/usr/local/py-utils/bin/mypy"], | ||
"black-formatter.path": ["/usr/local/py-utils/bin/black"] | ||
} | ||
}, | ||
"editor.formatOnSave": true, | ||
"python.formatting.blackPath": "black", | ||
"python.formatting.provider": "black", | ||
"python.testing.pytestArgs": [ | ||
"." | ||
], | ||
"python.testing.unittestEnabled": false, | ||
"python.testing.nosetestsEnabled": false, | ||
"python.testing.pytestEnabled": true, | ||
"python.analysis.extraPaths": [ | ||
// Unless we do this, pylance is not able to resolve imports | ||
"~/.local/lib/python3.9/site-packages" | ||
], | ||
"[javascriptreact]": { | ||
"editor.defaultFormatter": "rvest.vs-code-prettier-eslint" | ||
}, | ||
"[typescriptreact]": { | ||
"editor.defaultFormatter": "rvest.vs-code-prettier-eslint" | ||
}, | ||
"[typescript]": { | ||
"editor.defaultFormatter": "rvest.vs-code-prettier-eslint" | ||
} | ||
}, | ||
// Add the IDs of extensions you want installed when the container is created. | ||
"extensions": [ | ||
"ms-python.python", | ||
"rvest.vs-code-prettier-eslint", | ||
"ms-azuretools.vscode-docker", | ||
"hashicorp.terraform", | ||
"eamodio.gitlens", | ||
"stkb.rewrap" | ||
"remoteUser": "vscode", | ||
"postCreateCommand": "pip install --editable .[all]", | ||
"mounts": [ | ||
"source=python-threatexchange-cmdhistory,target=/commandhistory,type=volume", | ||
"source=${localEnv:HOME}${localEnv:USERPROFILE},target=/host-home-folder,type=bind,consistency=cached" | ||
], | ||
// Use 'postCreateCommand' to run commands after the container is created. | ||
"postCreateCommand": "sh .devcontainer/post-create", | ||
// Use 'portsAttributes' to set default properties for specific forwarded ports. | ||
"portsAttributes": { | ||
"3000": { | ||
"label": "Hello Remote World", | ||
"onAutoForward": "notify" | ||
} | ||
}, | ||
"remoteEnv": { | ||
"IN_DEVCONTAINER": "true" | ||
}, | ||
"overrideCommand": true, | ||
"features": { | ||
"docker-in-docker": "latest" | ||
} | ||
"postAttachCommand": "/workspace/.devcontainer/startup.sh" | ||
} |
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file was deleted.
Oops, something went wrong.
File renamed without changes.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.