blob: 713026231b8caa9259a7516e703c878141c4831a [file] [log] [blame]
#!/usr/bin/env python3
import sys
from teaclave import (AuthenticationService, FrontendService,
AuthenticationClient, FrontendClient, FunctionInput,
FunctionOutput, OwnerList, DataMap)
from utils import (AUTHENTICATION_SERVICE_ADDRESS, FRONTEND_SERVICE_ADDRESS,
AS_ROOT_CA_CERT_PATH, ENCLAVE_INFO_PATH, USER_ID,
USER_PASSWORD)
def get_client(user_id, user_password):
auth_client = AuthenticationService(
AUTHENTICATION_SERVICE_ADDRESS, AS_ROOT_CA_CERT_PATH,
ENCLAVE_INFO_PATH).connect().get_client()
print("[+] registering user")
auth_client.user_register(user_id, user_password)
print("[+] login")
token = auth_client.user_login(user_id, user_password)
client = FrontendService(FRONTEND_SERVICE_ADDRESS, AS_ROOT_CA_CERT_PATH,
ENCLAVE_INFO_PATH).connect().get_client()
metadata = {"id": user_id, "token": token}
client.metadata = metadata
return client
def register_input_file(client):
"""
Commands when encrypting input files:
./teaclave_cli encrypt
--algorithm teaclave-file-128
--input-file ./tests/fixtures/functions/rsa_sign/key.der
--key 00000000000000000000000000000003
--output-file ./tests/fixtures/functions/rsa_sign/rsakey.enc
--cmac-flag
"""
url = "http://localhost:6789/fixtures/functions/rsa_sign/rsakey.enc"
cmac = "4de3bb77327c82923640835c6e5ada66"
schema = "teaclave-file-128"
key = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3]
iv = []
key_data_id = client.register_input_file(url, schema, key, iv, cmac)
return key_data_id
def register_func(client):
function_id = client.register_function(
name="builtin-rsa-sign",
description="Native Rsa Signing Function",
executor_type="builtin",
arguments=["data"],
inputs=[FunctionInput("rsa_key", "Input key file.")])
return function_id
def create_task(client, function_id, input_file_user):
task_id = client.create_task(
function_id=function_id,
executor="builtin",
function_arguments=({
"data": "test data",
}),
inputs_ownership=[OwnerList("rsa_key", [input_file_user])])
return task_id
def rsa_task():
client1 = get_client("rsa_sign_user1", "password1")
client2 = get_client("rsa_sign_user2", "password2")
print("[+] registering key file")
key_id = register_input_file(client1)
print("[+] key file id" + key_id)
print("[+] registering function")
function_id = register_func(client2)
print("[+] function id" + function_id)
print("[+] creating task")
task_id = create_task(client2, function_id, "rsa_sign_user1")
print("[+] task id" + task_id)
print("[+] assigning data to task")
client1.assign_data_to_task(task_id, [DataMap("rsa_key", key_id)], [])
print("[+] user1 approving task")
client1.approve_task(task_id)
print("[+] user2 approving task")
client2.approve_task(task_id)
print("[+] invoking task")
client2.invoke_task(task_id)
print("[+] getting result")
result = client2.get_task_result(task_id)
print("[+] done")
return bytes(result)
def main():
rt = rsa_task()
print("[+] function return: ", rt)
if __name__ == '__main__':
main()