Skip to content

Commit

Permalink
Merge pull request #202 from csfloat/feature/access-token-prover
Browse files Browse the repository at this point in the history
Adds Access Token Prover
  • Loading branch information
Step7750 authored Apr 5, 2024
2 parents df66c75 + b80838d commit a3bbc19
Show file tree
Hide file tree
Showing 6 changed files with 72 additions and 12 deletions.
4 changes: 4 additions & 0 deletions src/lib/bridge/handlers/handlers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ import {AnnotateOffer} from './annotate_offer';
import {ExtensionVersion} from './extension_version';
import {SendCookies} from './send_cookies';
import {HasPermissions} from './has_permissions';
import {MetaSettings} from './meta_settings';
import {ProveTradesToken} from './prove_trades_token';

export const HANDLERS_MAP: {[key in RequestType]: RequestHandler<any, any>} = {
[RequestType.EXECUTE_SCRIPT_ON_PAGE]: ExecuteScriptOnPage,
Expand All @@ -30,4 +32,6 @@ export const HANDLERS_MAP: {[key in RequestType]: RequestHandler<any, any>} = {
[RequestType.EXTENSION_VERSION]: ExtensionVersion,
[RequestType.SEND_COOKIES]: SendCookies,
[RequestType.HAS_PERMISSIONS]: HasPermissions,
[RequestType.META_SETTINGS]: MetaSettings,
[RequestType.PROVE_TRADES_TOKEN]: ProveTradesToken,
};
18 changes: 18 additions & 0 deletions src/lib/bridge/handlers/meta_settings.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import {EmptyRequestHandler} from './main';
import {RequestType} from './types';

export interface MetaSettingsResponse {
enable_auto_trade: boolean;
}

export const MetaSettings = new EmptyRequestHandler<MetaSettingsResponse>(RequestType.META_SETTINGS, async (req) => {
const resp = await fetch(`https://csfloat.com/api/v1/meta/extension`, {
credentials: 'include',
});

if (resp.status !== 200) {
throw new Error('invalid status');
}

return resp.json() as Promise<MetaSettingsResponse>;
});
25 changes: 25 additions & 0 deletions src/lib/bridge/handlers/prove_trades_token.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import {EmptyRequestHandler, SimpleHandler} from './main';
import {RequestType} from './types';

export interface ProveTradesTokenRequest {
token: string;
}

export interface ProveTradesTokenResponse {
message: string;
}

export const ProveTradesToken = new SimpleHandler<ProveTradesTokenRequest, ProveTradesTokenResponse>(
RequestType.PROVE_TRADES_TOKEN,
async (req) => {
const resp = await fetch(`https://csfloat.com/api/v1/trades/prove-token?token=${req.token}`, {
credentials: 'include',
});

if (resp.status !== 200) {
throw new Error('failed to prove, are you logged into CSFloat?');
}

return resp.json() as Promise<ProveTradesTokenResponse>;
}
);
2 changes: 2 additions & 0 deletions src/lib/bridge/handlers/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,6 @@ export enum RequestType {
EXTENSION_VERSION,
SEND_COOKIES,
HAS_PERMISSIONS,
META_SETTINGS,
PROVE_TRADES_TOKEN,
}
27 changes: 16 additions & 11 deletions src/lib/components/trade_history/trade_proof.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,14 @@ import {CustomElement, InjectAppend, InjectionMode} from '../injectors';
import {FloatElement} from '../custom';
import {fetchListingTime} from './helpers';
import '../common/ui/steam-button';
import {ProveTradesToken} from '../../bridge/handlers/prove_trades_token';
import {ClientSend} from '../../bridge/client';

@CustomElement()
@InjectAppend('.tradehistoryrow .tradehistory_content', InjectionMode.CONTINUOUS)
export class TradeProof extends FloatElement {
@state()
private proofNumber: number | undefined;
private message: string | undefined;

@state()
private isProcessing = false;
Expand All @@ -20,12 +22,12 @@ export class TradeProof extends FloatElement {
}

render() {
return this.proofNumber
? html` <span>Proof: ${this.proofNumber}</span> `
return this.message
? html` <span>${this.message}</span> `
: html`
<csfloat-steam-button
@click="${this.onClick}"
.text="${this.isProcessing ? 'Computing Proof...' : 'CSFloat Proof'}"
.text="${this.isProcessing ? 'Proving...' : 'Prove Trade on CSFloat'}"
>
</csfloat-steam-button>
`;
Expand All @@ -34,14 +36,17 @@ export class TradeProof extends FloatElement {
private async onClick() {
this.isProcessing = true;

const index = $J('.tradehistoryrow').index($J(this).parent().parent());
const token = document
.getElementById('application_config')
?.getAttribute('data-loyalty_webapi_token')
?.replace('"', '')
.replace('"', '');

try {
this.proofNumber = await fetchListingTime(index);
} catch (e) {
alert(
"Failed to parse time, make sure you're on an english version of the page by appending ?l=english to the url"
);
const resp = await ClientSend(ProveTradesToken, {token});
this.message = resp.message;
} catch (e: any) {
alert(e.toString());
}
this.isProcessing = false;
}
}
8 changes: 7 additions & 1 deletion src/lib/components/trade_offers/auto_track.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import {ClientSend} from '../../bridge/client';
import {state} from 'lit/decorators.js';
import {FetchPendingTrades} from '../../bridge/handlers/fetch_pending_trades';
import {HasPermissions} from '../../bridge/handlers/has_permissions';
import {MetaSettings} from '../../bridge/handlers/meta_settings';

@CustomElement()
@InjectAfter(
Expand Down Expand Up @@ -56,14 +57,19 @@ export class AutoTrackWidget extends FloatElement {
super.connectedCallback();

try {
const meta = await ClientSend(MetaSettings, {});
if (!meta.enable_auto_trade) {
return;
}

await ClientSend(FetchPendingTrades, {});

const hasPermissions = await ClientSend(HasPermissions, {permissions: ['cookies', 'alarms']});
if (!hasPermissions) {
this.show = true;
}
} catch (e) {
console.info('user is not logged into CSFloat');
console.info('user is not logged into CSFloat or something went wrong');
}
}

Expand Down

0 comments on commit a3bbc19

Please sign in to comment.