diff --git a/examples/uber/index.d.ts b/examples/uber/index.d.ts new file mode 100644 index 0000000..283fe08 --- /dev/null +++ b/examples/uber/index.d.ts @@ -0,0 +1,14 @@ +declare module 'main' { + // Extism exports take no params and return an I32 + export function start(): I32; + export function two(): I32; + export function three(): I32; + export function config(): I32; +} + +declare module 'extism:host' { + interface user { + redirect(ptr: I64): void; + notarize(ptr: I64): I64; + } +} diff --git a/examples/uber/index.js b/examples/uber/index.js new file mode 100644 index 0000000..685c4ba --- /dev/null +++ b/examples/uber/index.js @@ -0,0 +1,109 @@ +function isValidHost(urlString) { + const url = new URL(urlString); + return url.hostname === 'riders.uber.com'; +} + +function gotoUber() { + const { redirect } = Host.getFunctions(); + const mem = Memory.fromString('https://riders.uber.com'); + redirect(mem.offset); +} + +function start() { + console.log(JSON.stringify('TLSN start')); + if (!isValidHost(Config.get('tabUrl'))) { + gotoUber(); + Host.outputString(JSON.stringify(false)); + return; + } + Host.outputString(JSON.stringify(true)); +} + +function two() { + const cookies = JSON.parse(Config.get('cookies'))['riders.uber.com']; + const headers = JSON.parse(Config.get('headers'))['riders.uber.com']; + console.log("TLSN cookies"); + console.log(JSON.stringify(cookies)); + console.log("TLSN headers"); + console.log(JSON.stringify(headers)); + + const sid = cookies.sid + const csid = cookies.csid + const jwt_session = cookies["jwt-session"] + console.log("JWT") + console.log(JSON.stringify(cookies["jwt-session"])) + + const query = '{ "query": "{ currentUser { email firstName lastName uuid formattedNumber signupCountry } }" }' + + Host.outputString( + JSON.stringify({ + url: 'https://riders.uber.com/graphql', + method: 'POST', + headers: { + 'content-type': 'application/json', + 'Accept': '*/*', + Cookie: `sid=${sid}; csid=${csid}; jwt-session=${jwt_session}`, + 'x-csrf-token': 'x', + Host: 'riders.uber.com', + 'Accept-Encoding': 'identity', + Connection: 'close', + }, + body: query + }), + ); +} + +function three() { + const params = JSON.parse(Host.inputString()); + const { notarize } = Host.getFunctions(); + + if (!params) { + Host.outputString(JSON.stringify(false)); + } else { + const mem = Memory.fromString(JSON.stringify(params)); + console.log("notarize", JSON.stringify(mem)) + const idOffset = notarize(mem.offset); + const id = Memory.find(idOffset).readString(); + Host.outputString(JSON.stringify(id)); + } +} + +function config() { + Host.outputString( + JSON.stringify({ + title: 'Uber Profile', + description: 'Notarize ownership of an Uber profile', + icon: '', + steps: [ + { + title: 'Visit Uber website', + cta: 'Go to uber.com', + action: 'start', + }, + { + title: 'Collect credentials', + description: "Login to your account if you haven't already", + cta: 'Checking cookies', + action: 'two', + }, + { + title: 'Notarize Uber profile', + cta: 'Notarize', + action: 'three', + prover: true, + }, + ], + hostFunctions: ['redirect', 'notarize'], + cookies: ['riders.uber.com'], + headers: ['riders.uber.com'], + requests: [ + { + url: 'https://riders.uber.com/graphql', + method: 'POST', + }, + ], + }), + ); +} + +module.exports = { start, config, two, three };