Compare commits
22 Commits
f0cbbadb27
...
5f97005a9a
Author | SHA1 | Date |
---|---|---|
Victor Frazao | 5f97005a9a | |
Thomas Hobson | 1e3b01283e | |
Thomas Hobson | f590f85d6d | |
Thomas Hobson | 0e6f082f5f | |
Thomas Hobson | 45eb4c799d | |
Thomas Hobson | 8e7279ce69 | |
Dan Vargas | 09e347a098 | |
Thomas Hobson | 7e1960302d | |
Thomas Hobson | 258539d593 | |
Thomas Hobson | 30fa1d1425 | |
Dan Vargas | 6d2814880f | |
Thomas Hobson | e96be60e7a | |
Thomas Hobson | 35c807dac1 | |
Thomas Hobson | 8a7022f025 | |
Thomas Hobson | ccd6baf11a | |
Thomas Hobson | a328b3eeda | |
Thomas Hobson | 77ad337e1d | |
Dan Vargas | 5f267a98b4 | |
Thomas Hobson | ccc1e4c08b | |
Thomas Hobson | 3b25ec4386 | |
Thomas Hobson | f24c48400b | |
Thomas Hobson | fefd1fa8e8 |
|
@ -88,16 +88,16 @@ jobs:
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: |
|
run: |
|
||||||
ls -la
|
ls -la
|
||||||
docker run -v $(pwd)'/repo:/piston/repo' -v $(pwd)'/packages:/piston/packages' -d --name piston_fs_repo docker.pkg.github.com/engineer-man/piston/repo-builder --no-build
|
docker run -v $(pwd)'/repo:/piston/repo' -v $(pwd)'/packages:/piston/packages' -d --name repo docker.pkg.github.com/engineer-man/piston/repo-builder --no-build
|
||||||
docker run --network container:piston_fs_repo -v $(pwd)'/data:/piston' -d --name api docker.pkg.github.com/engineer-man/piston/api
|
docker run --network container:repo -v $(pwd)'/data:/piston' -d --name api docker.pkg.github.com/engineer-man/piston/api
|
||||||
echo Waiting for API to start..
|
echo Waiting for API to start..
|
||||||
docker run --network container:api appropriate/curl -s --retry 10 --retry-connrefused http://localhost:2000/runtimes
|
docker run --network container:api appropriate/curl -s --retry 10 --retry-connrefused http://localhost:2000/runtimes
|
||||||
|
|
||||||
echo Waiting for Index to start..
|
echo Waiting for Index to start..
|
||||||
docker run --network container:piston_fs_repo appropriate/curl -s --retry 999 --retry-max-time 0 --retry-connrefused http://localhost:8000/index
|
docker run --network container:repo appropriate/curl -s --retry 999 --retry-max-time 0 --retry-connrefused http://localhost:8000/index
|
||||||
|
|
||||||
echo Adjusting index
|
echo Adjusting index
|
||||||
sed -i 's/piston_fs_repo/localhost/g' repo/index
|
sed -i 's/repo/localhost/g' repo/index
|
||||||
|
|
||||||
echo Listing Packages
|
echo Listing Packages
|
||||||
PACKAGES_JSON=$(docker run --network container:api appropriate/curl -s http://localhost:2000/packages)
|
PACKAGES_JSON=$(docker run --network container:api appropriate/curl -s http://localhost:2000/packages)
|
||||||
|
|
|
@ -17,7 +17,7 @@ let gid = 0;
|
||||||
|
|
||||||
class Job {
|
class Job {
|
||||||
|
|
||||||
constructor({ runtime, files, args, stdin, timeouts, alias }) {
|
constructor({ runtime, files, args, stdin, timeouts }) {
|
||||||
this.uuid = uuidv4();
|
this.uuid = uuidv4();
|
||||||
this.runtime = runtime;
|
this.runtime = runtime;
|
||||||
this.files = files.map((file,i) => ({
|
this.files = files.map((file,i) => ({
|
||||||
|
@ -28,7 +28,6 @@ class Job {
|
||||||
this.args = args;
|
this.args = args;
|
||||||
this.stdin = stdin;
|
this.stdin = stdin;
|
||||||
this.timeouts = timeouts;
|
this.timeouts = timeouts;
|
||||||
this.alias = alias;
|
|
||||||
|
|
||||||
this.uid = config.runner_uid_min + uid;
|
this.uid = config.runner_uid_min + uid;
|
||||||
this.gid = config.runner_gid_min + gid;
|
this.gid = config.runner_gid_min + gid;
|
||||||
|
@ -90,7 +89,7 @@ class Job {
|
||||||
const proc = cp.spawn(proc_call[0], proc_call.splice(1) ,{
|
const proc = cp.spawn(proc_call[0], proc_call.splice(1) ,{
|
||||||
env: {
|
env: {
|
||||||
...this.runtime.env_vars,
|
...this.runtime.env_vars,
|
||||||
PISTON_ALIAS: this.alias
|
PISTON_LANGUAGE: this.runtime.language
|
||||||
},
|
},
|
||||||
stdio: 'pipe',
|
stdio: 'pipe',
|
||||||
cwd: this.dir,
|
cwd: this.dir,
|
||||||
|
|
|
@ -50,7 +50,7 @@ const app = express();
|
||||||
.flat()
|
.flat()
|
||||||
.filter(pkg => fss.exists_sync(path.join(pkg, globals.pkg_installed_file)));
|
.filter(pkg => fss.exists_sync(path.join(pkg, globals.pkg_installed_file)));
|
||||||
|
|
||||||
installed_languages.forEach(pkg => new runtime.Runtime(pkg));
|
installed_languages.forEach(pkg => runtime.load_package(pkg));
|
||||||
|
|
||||||
logger.info('Starting API Server');
|
logger.info('Starting API Server');
|
||||||
logger.debug('Constructing Express App');
|
logger.debug('Constructing Express App');
|
||||||
|
@ -100,7 +100,8 @@ const app = express();
|
||||||
return {
|
return {
|
||||||
language: rt.language,
|
language: rt.language,
|
||||||
version: rt.version.raw,
|
version: rt.version.raw,
|
||||||
aliases: rt.aliases
|
aliases: rt.aliases,
|
||||||
|
runtime: rt.runtime
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,22 @@ int main(int argc, char *argv[])
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add 32 bit and 64 bit architectures to seccomp filter
|
||||||
|
int rc;
|
||||||
|
uint32_t arch[] = {SCMP_ARCH_X86_64, SCMP_ARCH_X86, SCMP_ARCH_X32};
|
||||||
|
// We first remove the existing arch, otherwise our subsequent call to add
|
||||||
|
// it will fail
|
||||||
|
seccomp_arch_remove(ctx, seccomp_arch_native());
|
||||||
|
for (int i = 0; i < sizeof(arch) / sizeof(arch[0]); i++)
|
||||||
|
{
|
||||||
|
rc = seccomp_arch_add(ctx, arch[i]);
|
||||||
|
if (rc != 0)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "Unable to add arch: %d\n", arch[i]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Add a seccomp rule to the syscall blacklist - blacklist the socket syscall
|
// Add a seccomp rule to the syscall blacklist - blacklist the socket syscall
|
||||||
if (seccomp_rule_add(ctx, SCMP_ACT_ERRNO(EACCES), SCMP_SYS(socket), 0) < 0)
|
if (seccomp_rule_add(ctx, SCMP_ACT_ERRNO(EACCES), SCMP_SYS(socket), 0) < 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -85,7 +85,7 @@ class Package {
|
||||||
});
|
});
|
||||||
|
|
||||||
logger.debug('Registering runtime');
|
logger.debug('Registering runtime');
|
||||||
new runtime.Runtime(this.install_path);
|
runtime.load_package(this.install_path);
|
||||||
|
|
||||||
logger.debug('Caching environment');
|
logger.debug('Caching environment');
|
||||||
const get_env_command = `cd ${this.install_path}; source environment; env`;
|
const get_env_command = `cd ${this.install_path}; source environment; env`;
|
||||||
|
@ -136,7 +136,7 @@ class Package {
|
||||||
logger.info(`Uninstalling ${this.language}-${this.version.raw}`);
|
logger.info(`Uninstalling ${this.language}-${this.version.raw}`);
|
||||||
|
|
||||||
logger.debug("Finding runtime")
|
logger.debug("Finding runtime")
|
||||||
const found_runtime = runtime.get_latest_runtime_matching_language_version(this.language, this.version.raw);
|
const found_runtime = runtime.get_runtime_by_name_and_version(this.language, this.version.raw);
|
||||||
|
|
||||||
if(!found_runtime){
|
if(!found_runtime){
|
||||||
logger.error(`Uninstalling ${this.language}-${this.version.raw} failed: Not installed`)
|
logger.error(`Uninstalling ${this.language}-${this.version.raw} failed: Not installed`)
|
||||||
|
|
|
@ -9,17 +9,21 @@ const runtimes = [];
|
||||||
|
|
||||||
class Runtime {
|
class Runtime {
|
||||||
|
|
||||||
constructor(package_dir){
|
constructor({language, version, aliases, pkgdir, runtime}){
|
||||||
|
this.language = language;
|
||||||
|
this.version = version;
|
||||||
|
this.aliases = aliases || [];
|
||||||
|
this.pkgdir = pkgdir;
|
||||||
|
this.runtime = runtime;
|
||||||
|
}
|
||||||
|
|
||||||
|
static load_package(package_dir){
|
||||||
let info = JSON.parse(
|
let info = JSON.parse(
|
||||||
fss.read_file_sync(path.join(package_dir, 'pkg-info.json'))
|
fss.read_file_sync(path.join(package_dir, 'pkg-info.json'))
|
||||||
);
|
);
|
||||||
|
|
||||||
const { language, version, build_platform, aliases } = info;
|
let { language, version, build_platform, aliases, provides } = info;
|
||||||
|
version = semver.parse(version);
|
||||||
this.pkgdir = package_dir;
|
|
||||||
this.language = language;
|
|
||||||
this.version = semver.parse(version);
|
|
||||||
this.aliases = aliases;
|
|
||||||
|
|
||||||
if (build_platform !== globals.platform) {
|
if (build_platform !== globals.platform) {
|
||||||
logger.warn(
|
logger.warn(
|
||||||
|
@ -28,9 +32,29 @@ class Runtime {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(provides){
|
||||||
|
// Multiple languages in 1 package
|
||||||
|
provides.forEach(lang => {
|
||||||
|
runtimes.push(new Runtime({
|
||||||
|
language: lang.language,
|
||||||
|
aliases: lang.aliases,
|
||||||
|
version,
|
||||||
|
pkgdir: package_dir,
|
||||||
|
runtime: language
|
||||||
|
}));
|
||||||
|
});
|
||||||
|
}else{
|
||||||
|
runtimes.push(new Runtime({
|
||||||
|
language,
|
||||||
|
version,
|
||||||
|
aliases,
|
||||||
|
pkgdir: package_dir
|
||||||
|
}))
|
||||||
|
}
|
||||||
|
|
||||||
logger.debug(`Package ${language}-${version} was loaded`);
|
logger.debug(`Package ${language}-${version} was loaded`);
|
||||||
|
|
||||||
runtimes.push(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
get compiled() {
|
get compiled() {
|
||||||
|
@ -79,3 +103,9 @@ module.exports.get_latest_runtime_matching_language_version = function(lang, ver
|
||||||
return module.exports.get_runtimes_matching_language_version(lang, ver)
|
return module.exports.get_runtimes_matching_language_version(lang, ver)
|
||||||
.sort((a,b) => semver.rcompare(a.version, b.version))[0];
|
.sort((a,b) => semver.rcompare(a.version, b.version))[0];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
module.exports.get_runtime_by_name_and_version = function(runtime, ver){
|
||||||
|
return runtimes.find(rt => (rt.runtime == runtime || (rt.runtime === undefined && rt.language == runtime)) && semver.satisfies(rt.version, ver));
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports.load_package = Runtime.load_package;
|
|
@ -1,3 +0,0 @@
|
||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Put instructions to compile source code, remove this file if the language does not require this stage
|
|
|
@ -1,5 +1,10 @@
|
||||||
{
|
{
|
||||||
"language": "gawk",
|
"language": "gawk",
|
||||||
"version": "5.1.0",
|
"version": "5.1.0",
|
||||||
"aliases": ["awk"]
|
"provides": [
|
||||||
|
{
|
||||||
|
"language": "awk",
|
||||||
|
"aliases": ["gawk"]
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,21 +3,21 @@
|
||||||
# Put instructions to compile source code, remove this file if the language does not require this stage
|
# Put instructions to compile source code, remove this file if the language does not require this stage
|
||||||
|
|
||||||
|
|
||||||
case "${PISTON_ALIAS}" in
|
case "${PISTON_LANGUAGE}" in
|
||||||
gcc | c)
|
c)
|
||||||
rename 's/$/\.c/' "$@" # Add .c extension
|
rename 's/$/\.c/' "$@" # Add .c extension
|
||||||
gcc -std=c11 *.c -lm
|
gcc -std=c11 *.c -lm
|
||||||
;;
|
;;
|
||||||
g++ | c++ | cpp)
|
c++)
|
||||||
rename 's/$/\.cpp/' "$@" # Add .cpp extension
|
rename 's/$/\.cpp/' "$@" # Add .cpp extension
|
||||||
g++ -std=c++17 *.cpp
|
g++ -std=c++17 *.cpp
|
||||||
;;
|
;;
|
||||||
gdc | d)
|
d)
|
||||||
rename 's/$/\.d/' "$@" # Add .d extension
|
rename 's/.code$/\.d/' "$@" # Add .d extension
|
||||||
gdc *.d
|
gdc *.d
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo "How did you get here? (${PISTON_ALIAS})"
|
echo "How did you get here? (${PISTON_LANGUAGE})"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
|
@ -1,5 +1,18 @@
|
||||||
{
|
{
|
||||||
"language": "gcc",
|
"language": "gcc",
|
||||||
"version": "10.2.0",
|
"version": "10.2.0",
|
||||||
"aliases": ["c", "g++", "c++", "cpp", "gdc", "d"]
|
"provides": [
|
||||||
|
{
|
||||||
|
"language":"c",
|
||||||
|
"aliases": ["gcc"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"language": "c++",
|
||||||
|
"aliases": ["cpp", "g++"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"language": "d",
|
||||||
|
"aliases": ["gdc"]
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
GOCACHE=$PWD go run "$@"
|
mv $1 $1.go
|
||||||
|
filename=$1.go
|
||||||
|
shift
|
||||||
|
GOCACHE=$PWD go run $filename "$@"
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
csc "$@"
|
rename 's/$/\.cs/' "$@" # Add .cs extension
|
||||||
|
csc -out:out *.cs
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
export PATH=$PWD/mono-6.12.0:$PATH
|
export PATH=$PWD/bin:$PATH
|
|
@ -1,5 +1,10 @@
|
||||||
{
|
{
|
||||||
"language": "mono",
|
"language": "mono",
|
||||||
"version": "6.12.0",
|
"version": "6.12.0",
|
||||||
"aliases": ["csharp", "cs"]
|
"provides": [
|
||||||
|
{
|
||||||
|
"language": "csharp",
|
||||||
|
"aliases": ["mono", "mono-csharp", "mono-c#", "mono-cs", "c#", "cs"]
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
CODE=${1/cs/exe}
|
|
||||||
shift
|
shift
|
||||||
mono $CODE "$@"
|
mono out "$@"
|
|
@ -3,7 +3,7 @@
|
||||||
# Put instructions to compile source code, remove this file if the language does not require this stage
|
# Put instructions to compile source code, remove this file if the language does not require this stage
|
||||||
|
|
||||||
|
|
||||||
case "${PISTON_ALIAS}" in
|
case "${PISTON_LANGUAGE}" in
|
||||||
nasm)
|
nasm)
|
||||||
nasm -f elf32 -o binary.o "$@"
|
nasm -f elf32 -o binary.o "$@"
|
||||||
ld -m elf_i386 binary.o -o binary
|
ld -m elf_i386 binary.o -o binary
|
||||||
|
@ -13,7 +13,7 @@ case "${PISTON_ALIAS}" in
|
||||||
ld -m elf_x86_64 binary.o -o binary
|
ld -m elf_x86_64 binary.o -o binary
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo "How did you get here? (${PISTON_ALIAS})"
|
echo "How did you get here? (${PISTON_LANGUAGE})"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
|
@ -1,5 +1,14 @@
|
||||||
{
|
{
|
||||||
"language": "nasm",
|
"language": "nasm",
|
||||||
"version": "2.15.5",
|
"version": "2.15.5",
|
||||||
"aliases": ["nasm64"]
|
"provides": [
|
||||||
|
{
|
||||||
|
"language": "nasm",
|
||||||
|
"aliases": ["asm", "nasm32"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"language": "nasm64",
|
||||||
|
"aliases": ["asm64"]
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,10 @@
|
||||||
{
|
{
|
||||||
"language": "node",
|
"language": "node",
|
||||||
"version": "15.10.0",
|
"version": "15.10.0",
|
||||||
|
"provides": [
|
||||||
|
{
|
||||||
|
"language": "javascript",
|
||||||
"aliases": ["node-javascript", "node-js", "javascript", "js"]
|
"aliases": ["node-javascript", "node-js", "javascript", "js"]
|
||||||
}
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Compile pony file(s)
|
# Compile pony file(s)
|
||||||
rename 's/$/\.pong/' "$@" # Add .pony extension
|
rename 's/$/\.pony/' "$@" # Add .pony extension
|
||||||
ponyc -b out
|
ponyc -b out
|
|
@ -1,4 +1,7 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Put instructions to run the runtime
|
# Put instructions to run the runtime
|
||||||
scala "$@"
|
mv $1 $1.scala
|
||||||
|
filename=$1.scala
|
||||||
|
shift
|
||||||
|
scala $filename "$@"
|
||||||
|
|
|
@ -5,7 +5,8 @@ AUTH_HEADER="Authorization: $API_KEY"
|
||||||
for test_file in */*/test.*
|
for test_file in */*/test.*
|
||||||
do
|
do
|
||||||
IFS='/' read -ra test_parts <<< "$test_file"
|
IFS='/' read -ra test_parts <<< "$test_file"
|
||||||
language=${test_parts[0]}
|
IFS='.' read -ra file_parts <<< "$(basename $test_file)"
|
||||||
|
language=${file_parts[1]}
|
||||||
lang_ver=${test_parts[1]}
|
lang_ver=${test_parts[1]}
|
||||||
|
|
||||||
test_src=$(python3 -c "import json; print(json.dumps(open('$test_file').read()))")
|
test_src=$(python3 -c "import json; print(json.dumps(open('$test_file').read()))")
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
case $1 in
|
||||||
|
dev)
|
||||||
|
shift
|
||||||
|
docker-compose -f docker-compose.dev.yaml "$@"
|
||||||
|
;;
|
||||||
|
prod)
|
||||||
|
shift
|
||||||
|
docker-compose -f docker-compose.yaml "$@"
|
||||||
|
;;
|
||||||
|
update)
|
||||||
|
git pull
|
||||||
|
docker-compose pull api
|
||||||
|
docker-compose up -d api
|
||||||
|
;;
|
||||||
|
clean-pkgs)
|
||||||
|
git clean -fqXd packages
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
node cli/index.js "$@"
|
||||||
|
;;
|
||||||
|
esac
|
|
@ -1,4 +1,4 @@
|
||||||
BASEURL=http://piston_fs_repo:8000/
|
BASEURL=http://repo:8000/
|
||||||
|
|
||||||
i=0
|
i=0
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue