Skip to content

Commit

Permalink
WIP: Uber plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
heeckhau committed Jun 18, 2024
1 parent 89e8b67 commit ea8ccf7
Show file tree
Hide file tree
Showing 2 changed files with 123 additions and 0 deletions.
14 changes: 14 additions & 0 deletions plugins/uber/index.d.ts
Original file line number Diff line number Diff line change
@@ -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;
}
}
109 changes: 109 additions & 0 deletions plugins/uber/index.js
Original file line number Diff line number Diff line change
@@ -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 };

0 comments on commit ea8ccf7

Please sign in to comment.