Welcome to GTS Trading 👋

New here and it feels like a lot? It isn't. Everything you do follows one simple chain: write a condition → wrap it in a strategy → get alerted or trade it → watch it run. This guide answers the exact questions in the order most people ask them.

Tip: use the table of contents on the left to jump to any question. Click a question to expand its answer.

1 Getting started

Read this section first — it removes 90% of the confusion. The three words below (expression, strategy, handler) are the whole mental model.

Q What is this app and what can I do here?

GTS Trading lets you describe market conditions (e.g. "RSI on the 1h is below 30") and then choose what happens when that condition becomes true: get a signal/alert, or open and close positions on a connected exchange (paper or real).

You do all of this without writing code — though you can bring your own C++ or Lua if you want. The main areas, from the top nav:

AreaWhat it's for
BuilderCreate expressions, strategies & handlers. Where you start.
My ExpressionsYour saved conditions library.
My StrategiesStrategies you've assembled and can deploy.
Signal MonitorLive feed of which conditions/strategies are firing.
History RequestsRun a strategy over past data to see how it would have behaved.
MonitorDeep operational view of running strategies & positions.
Charts / SEC EdgarPrice charts and company filings for research.
Plans / Settings / API DocsBilling, exchange connections, programmatic access.
🖼️Top navigation barscreenshot: full-width nav — Builder · My Expressions · My Strategies · …
The top nav is your map. Builder on the left, account/quota on the right.
Q What's the difference between an Expression, a Strategy, and a Handler?

This is the thing to understand. They stack:

TermPlain meaningExample
ExpressionA single condition that is either true or false right now.RSI(14) < 30
HandlerThe "what to do" — open a buy, close, send an alert — and the rules around it (size, take-profit, stop-loss)."Buy 1 lot, TP +2%, SL −1%"
StrategyThe package: one or more expressions wired to handlers, on a symbol/timeframe, ready to deploy."On EURUSD 1h, when RSI<30 → buy; when RSI>70 → close"
Mental model: Expression = the trigger. Handler = the action. Strategy = trigger + action, deployed.
Q What's the typical flow from start to finish? (the 60-second tour)
1 · Write an expression 2 · Wrap it in a strategy + handler 3 · Choose alert or trade 4 · Deploy (paper or real) 5 · Watch it in Monitor
  1. In Builder → Expression Builder, type a condition in plain English and hit Parse. Save it.
  2. Switch to Builder → Strategy & Handler. Pick your expression as the entry condition, set the action (alert or open position).
  3. Decide: do you just want to be alerted, or do you want it to open/close positions?
  4. Deploy it. Start on paper/demo until you trust it.
  5. Open Monitor / Signal Monitor to watch fires and positions live.
You can stop after step 3 if you only want alerts. Trading is optional.
Q Alerts vs trades — what actually happens when a signal fires?
  • Alert: you get notified (in Signal Monitor and any channels you've set up). Nothing is bought or sold.
  • Trade (paper): the strategy opens/closes a position on the GTS paper-trading account — a simulated account GTS manages. This is the default and needs no broker.
Important — no real trades. GTS does not place live orders on a real exchange. Execution only ever happens on the GTS paper account. Connecting a real exchange (Bybit / FXCM / Binance / OANDA) is for monitoring your account and alerting you — never for placing trades. See §7 connect an exchange.

2 Expressions (the Builder)

An expression is one true/false condition. There are four ways to make one — pick whichever feels easiest. They all produce the same thing.

🖼️Expression Builder — full screenscreenshot: Quick Create box + Generate with AI + JSON Import, left expression list
Expression Builder. Left = your library. Right = the four creation methods.
Q How do I build a simple expression in plain English?

The quickest way is a Quick Template: pick an indicator, fill in the params, and Save — done. Prefer to type it out in plain English? Use the Quick Create box at the top of the Expression Builder:

  1. Type the condition the way you'd say it: RSI(14) < 30 5min or MACD cross above signal 15min.
  2. Click ⚡ Parse.
  3. The builder fills in below. Give it a name and Save.

Don't know where to start? Click one of the example chips under the box — RSI(14) < 30, SMA(50) > SMA(200), Close > BB Upper — to load it instantly.

The basic shape is LEFT  OPERATOR  RIGHT with an optional timeframe (no symbol — on the trading side a symbol is applied later, at the strategy) — but Quick Create handles more than that:

  • Unary (getter) — a single value on its own, no operator, e.g. RSI(14) or Donchian upper. (A comparison like bullish engulfing > 0 is binary — it has two sides.)
  • Compound — type the whole condition and it auto-builds the legs plus combiner: RSI(14) < 30 and balance > 100, 3+ terms, mixed AND/OR with parentheses ((a OR b) AND c), and crossings (RSI(14) crossed 30). Intermediate steps are created automatically on Save.
  • Saved-expression refs — reuse a saved expression by name as an operand: My_SignalA AND My_SignalB.

Prefer plain English? The Generate with AI box turns a free-form description into a validated expression. Full syntax reference: Quick Create — NLP Reference.

🖼️Quick Create box with example chipsscreenshot: input + Parse + chips row
You can omit indicator parameters — sensible GTS defaults are used.
Quick Create is free and unlimited. Parsing is deterministic — it costs no AI tokens, on any plan including Free. Tokens are only spent by Generate with AI and AI JSON generation (next questions).
Q How do I let AI build the expression for me?

Use the Generate with AI box. Describe what you want in everyday language and the AI writes, validates, and loads the expression for you.

  1. Type a description: "EURUSD when RSI 14 on 1h is below 30" or "gold 5min close crosses above EMA 200".
  2. Press Generate with AI (or Ctrl+Enter).
  3. Review what it loaded, then Save.
Unlike Quick Create, AI generation calls a model and spends AI tokens from your daily allotment — shown right under the box (e.g. 0 / 8,000,000 tokens used · 100% left). Every paid plan includes a daily token allowance; the Free plan has none (use Quick Create instead). Run out? Buy a prepaid top-up pack or wait for the daily reset. See §6 plans & tokens.
Q How do I import an expression as JSON, or from ChatGPT / Claude?

Use JSON Import ADVANCED at the bottom of the Expression Builder.

  1. Have a complete expression JSON object? Paste it in the box and hit Import — it loads straight into the builder.
  2. Don't want to hand-write JSON? Click Copy AI Schema Link, paste it into ChatGPT / Claude / Gemini, and ask the model to generate the expression JSON for you.
  3. Paste the model's result back here and Import.
The schema link is self-contained — the model gets everything it needs to produce valid GTS JSON without browsing.
Pasting/importing JSON is free — no AI tokens. Tokens are only spent if you use the in-app Generate with AI to write the JSON for you; generating it in your own ChatGPT/Claude and pasting it back costs you nothing here.
Q How do I build an expression by hand (visual builder)?

Below the Quick Create methods is the visual operand builder for full control:

  1. Set the left operand (e.g. an indicator, price, or account value).
  2. Pick the operator (>, <, cross above, etc.).
  3. Set the right operand (another indicator, or a fixed value).
  4. Choose the symbol and timeframe, then Save.
🖼️Visual operand builderscreenshot: left panel / operator / right panel / timeframe
Q How do I add an expression from the Community?

There are tens of thousands of shared expressions you can reuse.

  1. In the left library panel, click the Community tab.
  2. Search or browse, then click an expression to preview it.
  3. Use Import / Copy to mine — it's added to My Expressions so you can edit it freely.
🖼️Community tab in the libraryscreenshot: ALL / MINE / COMMUNITY tabs + count
If an import says "Blocked / missing deps", the shared item is missing its building-block expressions. See §8 troubleshooting.
Q What's the difference between All / Mine / Community / Old?
  • All — everything visible to you.
  • Mine — only expressions you created or imported.
  • Community — shared by other users; import to reuse.
  • Old — archived/previous versions (e.g. items moved aside on a plan downgrade).

The filter chips ANY HELPER ALERT narrow the list by role (next question).

Q What's a Helper expression vs an Alert expression?
  • ALERT Alert expression — a complete condition meant to fire on its own (notify you / trigger a handler).
  • HELPER Helper expression — a reusable building block you reference inside bigger expressions. Helpers usually don't fire by themselves; they feed the ones that do.
Best practice: build small named helpers (atomic value-getters) first, then compose alert expressions on top of them. See composing complex expressions.
Q What expression types exist?

GTS has 35+ operand types — far more than the basics. Each is an ElementType plus that type's required fields, producing a value or a boolean event you compare. Grouped by family:

FamilyTypes (ElementType)What they read
IndicatorsTA_Indicators, ExtendedIndicatorsRSI, SMA, MACD, ATR… plus advanced tools (FVG, Order Block, SMC/ICT, adaptive & ML/regime)
Price & barsOHLC_Bar, Quotes, RenkoBar, HeikinAshiBar, TickRevBar, TicksPerPeriodOpen/High/Low/Close/volume, bid/ask, and alternative bar types
PatternsTA_CandlePatterns, PricePattern, ABCPattern, FibonnaciBar, PivotObjectCandlestick & price-structure events, pivots, Fibonacci, ABC waves
Trend & channelsTrendObject, ChannelObject, PriceMoveObject, ConsensusScoreTrend side/length/speed, channel bounds, price moves, multi-signal consensus
Account & positionsAccountObject, AccFrameObject, RollingAccFrameObject, LastOpenPositionObject, ClosePositionObject, StrategyOpenPositionsBalance, equity, used margin, open P&L, and open/closed position details
FundamentalsFundamentalEDGAR financials — revenue, EPS, ratios…
Date & timeDateValue, HourValueA date, or the hour of day
Fixed valuesFixedVal, SideValueA fixed number, or a trade direction (long / short)
Reference dataSymbolSymbol context — tick size, margin, contract specs, and other instrument reference data
Reusable & compositionUserExpression, StateMachineExpression, CollectionTransform, HistValue, ExpressionMetaAny saved expression is reusable — reference it by name as a UserExpression building block. Plus multi-step state machines, history lookback & transforms
Code (Private)LuaScriptOperand (Lua), CustomizedUserOperand (C++)Inject your own Lua or C++ operand — private servers only (2 code-injection types)
Candle patterns are boolean directional events — compare with > 0 (not == 100), and a trend is required.
Every expression you save becomes a reusable, composable building block: any element can be referenced by name (a UserExpression) inside a bigger expression. That's how small helpers compose upward into full alert/strategy logic.
Building by API / AI agent? GET /api/v1/expression-schema?type=<ElementType> returns that type's exact required fields and a runnable example (add ?format=json for structured output); POST /api/v1/expressions/validate checks any JSON against the live validator before saving; POST /api/v1/expressions pushes it. The schema endpoint is the authoritative, always-current list of every type — see Control via API.
Q How do I compose a complex expression?

Build bottom-up:

  1. Define the atomic value getters first as named, reusable helpers (e.g. a named "RSI 1h" or "ATR band").
  2. Compose the upper levels on top by referencing those helpers instead of re-typing them.
  3. Combine with AND / OR to express multi-condition logic.
For deeply nested logic, the Expression Creation Schema (used by JSON Import) is the most powerful path — NLP stays flat, complex goes through JSON.
Q How do I view / inspect an expression (and see its JSON)?

Click an expression in the left library to open the Expression Viewer. It shows the full definition — what it reads, the operator, the symbol/timeframe, and any helpers it references.

  • Copy JSON — copy the raw expression JSON (useful to share, version, or feed to an AI model).
  • Export — save the definition out (see Share / export).
  • Site link — get a link back to the expression.
🖼️Expression Viewer with Copy JSONscreenshot: viewer modal — definition + Copy JSON / Export buttons
Reading the JSON is the fastest way to learn how complex expressions are wired — it shows exactly which helpers feed the top-level condition.
Q How do I test an expression's live value before I save it?

As you build, the Expression Preview panel evaluates your expression and shows the result so you can sanity-check it before saving.

  1. Build or load the expression in the builder.
  2. Look at the Expression Preview panel — it reads "Build your expression above to see a preview here" until the expression is valid, then shows the evaluated value/result.
  3. If the preview looks wrong, fix the operands and watch it update.
🖼️Expression Preview panelscreenshot: live preview / evaluate result
A valid preview is the green light that the expression will work in a strategy or alert.
Q How do I edit, duplicate, or delete an expression?

Each item in the left library has three icons:

  • ✏️ Edit — load it back into the builder to change it.
  • 📋 Duplicate — make a copy to tweak without touching the original.
  • 🗑️ Delete — remove it from your library.
Deleting frees a slot against your saved quota (the 8/100000 saved counter in the header).
Q How do I share or export an expression?

Open the expression in the Expression Viewer and use:

  • Copy JSON — paste the definition anywhere (chat, docs, another account) and re-import via JSON Import.
  • Export — save the expression's JSON out as a file. There's also Export all expressions to back up your whole library at once.
About Community publishing: the Community library is curated — there isn't a one-click "publish to Community" button in the current build. To share publicly, export the JSON and send it, or contact support@gts-trade.com. Note: private expressions are never published automatically — only when you deliberately export/share them.
Q How do I create and control expressions remotely via the API?

Everything you do in the Builder you can also do programmatically with your API key (Settings / Account → API). The versioned endpoints:

ActionEndpoint
Create an expressionPOST /api/v1/expressions
List your expressionsGET /api/v1/expressions
Validate without savingPOST /api/v1/expressions/validate
Update an expressionPOST /api/v1/expressions/update
DuplicatePOST /api/v1/expressions/copy
Pause / unpausePOST /api/v1/expressions/pause · /unpause
DeletePOST /api/v1/expressions/delete
Browse communityGET /api/v1/community/expressions

Full request/response shapes and auth: API Docs.

Pair this with the JSON schema link to have an external AI model generate expressions, then POST them straight to /api/v1/expressions.

3 Using an expression as an Alert

The simplest use of an expression: get notified when it becomes true, without any trading.

Q How do I turn an expression into an alert?
  1. Make sure the expression is marked as an ALERT (not just a helper).
  2. Attach it to a strategy/handler whose action is alert / notify rather than open-position.
  3. Deploy it. It now evaluates on live data and notifies you when true.
Want alerts only and never trades? See "alert-only / report-only" below.
Q Where do alerts get delivered?

Fires show up in the Signal Monitor in-app feed. Additional delivery channels are configured in your account/settings.

🖼️Signal Monitor feedscreenshot: live fires list
Q How do I make something alert-only / report-only (no trade)?

Choose a handler action that notifies but never issues an order. In strategy terms this is a report/alert-only handler — it reports the fire and stops there, so no position is opened even on a real account.

This is the safe default while you're testing a new idea.
Q How do I pause or stop an alert?

Un-deploy / stop the strategy that carries the expression (from My Strategies or Monitor). The expression stays saved in your library; it just stops evaluating.

4 Strategies, handlers & positions

When you want the platform to actually open and close positions, you wrap expressions in handlers inside a strategy. Built in Builder → Strategy & Handler.

Q How do I build a strategy?
  1. Open Builder → Strategy & Handler.
  2. Pick the symbol. The timeframe is derived from the expressions you select — a default is used only if it can’t be derived.
  3. Add an entry handler: choose your expression as the trigger and the action (open position / alert).
  4. Add an exit handler: a condition or TP/SL that closes the position.
  5. Name and Save it — it appears under My Strategies.
🖼️Strategy & Handler builderscreenshot: Strategy & Handler sub-tab
Q How do I view / inspect a strategy?

Open My Strategies to see your library. Each strategy shows its symbol, timeframe, the expressions it uses, its handlers, and its current status (saved / deployed). Click one to inspect the full definition.

The strategy library has source tabs so you can also browse strategies that aren't hand-built:

  • Config — your own saved strategies.
  • Community — strategies shared by others.
  • Permutation — strategies generated by a Mass / permutation session.
🖼️My Strategies libraryscreenshot: strategy list with Config / Community / Permutation source tabs + status
Q How do I edit or duplicate a strategy?
  1. From My Strategies, open the strategy and choose Edit — it loads back into the Strategy & Handler builder.
  2. Change the symbol/timeframe, swap the arm expressions, or adjust the strategy parameters (position size, SL/TP, hedging, trailing).
  3. Save to update it.

To experiment without touching the original, Duplicate it first and edit the copy.

Editing a deployed strategy: stop/undeploy it first, make your changes, then re-deploy — otherwise the live run keeps the old definition.
Q How do expressions drive a strategy? (the 4 handler arms)

This is the key idea. A strategy has four handler arms, each with its own expression box:

ArmWhat it does when its expression is true
Open BidOpens a position on the bid side.
Open AskOpens a position on the ask side.
Close BidCloses the bid-side position.
Close AskCloses the ask-side position.

You map any saved expression into each arm's box. The rule is identical for all four arms: when that arm's expression evaluates true, that arm's operation fires. Open and close work exactly the same way — close is not a special case.

  1. Open Builder → Strategy & Handler.
  2. For each arm you want active, pick an expression in its box (leave arms you don't need empty).
  3. Set that arm's policy and zone, then Save.
🖼️The 4 handler-arm boxesscreenshot: Open Bid / Open Ask / Close Bid / Close Ask expression boxes side by side
Arm vs strategy — what lives where: an arm only carries its expression (the trigger) plus its policy/zone — it does not hold a size. Position size, SL/TP, hedging and trailing are strategy-level parameters set once for the whole strategy ("full position controls"). You don't set units per operation.
An expression must exist and validate before an arm can use it — the builder enforces this. The same expression can be reused across arms or strategies.
Q How does a position get opened?

You don't open it by hand — the engine does it for you. That's the whole point of algotrading: the strategy triggers the position automatically when your condition becomes true. There's no manual "buy" step.

  1. Put your entry expression in the Open Bid or Open Ask arm (whichever side you want).
  2. Deploy the strategy to a trading account.
  3. When that arm's expression evaluates true, the engine opens the position automatically — on the GTS paper-trading account (no real order is ever placed).

How big, and with what risk controls, is decided once at the strategy level — position size, SL/TP, hedging, trailing — not on the arm.

Alert vs trading: on an alert deployment no position is ever opened — you only get notified. Positions are only triggered on a trading deployment. Same expression, different action.
On crypto, fractional sizing (e.g. 0.01 units) may be needed — set the strategy size accordingly and check your symbol's minimum.
Q How do I close a position?

Closing works exactly like opening — you just use the Close Bid / Close Ask arms instead. Any expression you set in a close box can trigger the close; there is no special "exit expression" type.

  1. Put the condition you want to close on (e.g. RSI(14) > 70 or an account-P&L condition) into the Close Bid or Close Ask box.
  2. When that expression evaluates true, that side's position is closed automatically.

Because it's the same mechanism as open, you can close the bid side and the ask side dynamically and independently, each by whatever expression you choose. (Strategy-level SL/TP and trailing also close positions automatically — those are set once on the strategy, separate from the close arms.)

A complete strategy usually fills both an open arm and a matching close arm — otherwise positions only close via strategy-level SL/TP, or not at all.
Safe switch — you can always close on the exchange: regardless of what the strategy is doing, you can close a position directly on the exchange yourself at any time. Our system gets notified of that change and reconciles its state correctly — your strategy and Monitor stay in sync with what actually happened on the exchange.
Q What are Mass / Permutation strategies for?

The Mass Strategies tab generates many variations of a strategy at once — e.g. the same logic across many symbols, or sweeping a parameter (RSI 20/25/30…). It's how you test a whole grid of ideas instead of building each by hand.

🖼️Mass Strategies tabscreenshot: permutation builder
Q How do I deploy a strategy?
  1. From My Strategies (or the builder), choose Deploy.
  2. Confirm. It begins evaluating on live data; opened/closed positions and alerts appear in Monitor.
Where trades go: execution always lands on the GTS paper-trading account — the default, and the only place trades happen. GTS does not place live orders on a real exchange. Connecting a real exchange (next sections) adds account monitoring + alerting, it does not redirect your trades to a real broker.
Q How do I stop / undeploy a strategy?
  1. Go to My Strategies or Monitor and find the running strategy.
  2. Choose Stop / Undeploy. It stops evaluating live data and stops issuing alerts/orders.

The strategy definition stays saved — you can re-deploy it later. Undeploying is the safe way to pause something that's misbehaving.

Open positions are not auto-closed when you undeploy. If you have a live position you don't want left running, close it first (via an exit/close handler or directly on your exchange).
Q Why is my strategy limited when a real exchange is active?

Because GTS never places live orders, a strategy running against a real-mode exchange may only use account-monitoring expressions (e.g. account balance, margin, open P&L). There are no buy/sell orders to place on a real account — only metrics to watch and alert on. A safety guard at deploy time enforces this. Common causes of a block:

  • The strategy uses trade/entry expressions that aren't valid against a monitor-only real account.
  • The provider isn't connected, has no valid credentials, or isn't Set Active.
  • The strategy bundle didn't pass validation (missing handler/expression pieces).

Want order-opening behaviour? Run on the default GTS paper-trading account — paper execution has no such restriction. Use real-mode providers for monitoring + alerting on your actual account.

Q How do I delete a strategy?
  1. If it's deployed, stop/undeploy it first (see above).
  2. From My Strategies, choose Delete on the strategy.
Deleting stops its alerts/positions for good. Close any open positions on your exchange first if you don't want them left running. The expressions it used stay in your library — only the strategy is removed.
Q How do I share or export a strategy?

Use Export all strategies to save your strategies out as JSON — a portable backup you can re-import or hand to someone else.

Like expressions, there's no one-click "publish to Community" button in the current build — the Community strategy library is curated. To share publicly, export and send the JSON, or contact support@gts-trade.com. A shared strategy must carry its full set of referenced expressions or the import will be blocked (see §8).
Q How do I create and control strategies remotely via the API?

Everything in the Strategy builder is available programmatically with your API key:

ActionEndpoint
Create / save a strategyPOST /api/v1/strategies
List your strategiesGET /api/v1/strategies
Save a strategy + handlerPOST /api/v1/strategy-handler
Get the strategy JSON schemaGET /api/v1/strategy-schema
DuplicatePOST /api/v1/strategies/copy
DeletePOST /api/v1/strategies/delete
Deploy (one / many)POST /api/v1/deploy · /deploy-batch
List deployed strategiesGET /api/v1/deployed

Full request/response shapes and auth scopes: API Docs.

Fetch /api/v1/strategy-schema, give it to an AI model, and have it generate a valid strategy JSON you POST straight to /api/v1/strategies — the same pattern as expressions.

5 Monitoring & history

See what's firing now, and test how a strategy would have behaved in the past.

Q How do I see my live strategies and fired signals?

Two views:

  • Signal Monitor — a clean feed of conditions firing.
  • Monitor — the deep operational view: running strategies, open positions, P&L, status.
🖼️Monitor pagescreenshot: running strategies + positions
Q How do I run a History Request (backtest-style) and read the results?
  1. Open History Requests.
  2. Select the strategies to test (from Mine / Community / your permutation sessions).
  3. Submit the run. Submit = start, Cancel = stop.
  4. Watch status, then open the results to see how it would have behaved.
History runs are batch jobs and may be queued; they're separate from live deployment.
Q How do I view Charts?

Open Charts from the nav for price charts, or SEC Edgar for company filings/fundamentals research. These are read-only research tools — they don't change your strategies.

6 Quotas, limits & plans

Every plan has limits. The good news: the app shows them to you right in the header.

Q How do I know my quota?

Look at the top-right of the header — it shows live counters, e.g. 8 / 100000 saved and 2.4k / 100k fires. The kinds of quota:

QuotaWhere to see it
Saved expressions/strategiesHeader X/Y saved counter.
Signal firesHeader X/Y fires counter.
AI tokensUnder the Generate-with-AI box (0 / 8,000,000 used).
History runsOn the History Requests page.
Full breakdownAccount → Usage tab.
🖼️Header quota countersscreenshot: "8/100000 saved · 2.4k/100k fires"
Q What are the Plans and what does each include?

Open the Plans page from the nav to compare tiers and what each unlocks (limits on saved items, fires, AI tokens, history runs, real-account trading, API access). Upgrade/downgrade from there or the Account → Billing tab.

AI tokens — what each plan includes

Every paid plan comes with a free daily AI-token allotment that resets each day (a per-plan staircase — higher tiers get more). The Free plan includes no AI tokens, so use the always-free Quick Create there. Tokens are spent only by Generate with AI and in-app AI JSON generation — never by Quick Create, hand-building, or pasting your own JSON.

Need more than your daily amount? Buy a prepaid top-up pack from the Plans / Billing page. Top-up tokens are spent after your daily plan tokens are used up, and they don't expire at the daily reset. The live Plans page shows the exact daily amount and pack sizes for each tier.

Q What happens when I hit a limit or downgrade?

If you exceed a cap (or drop to a smaller plan), over-cap saved items aren't deleted — they're archived to a "Previous-Config" area and retained (90 days). Your live items keep working up to the new cap.

Archived items are read-only until you make room or upgrade. Nothing is silently destroyed.
Q How do I upgrade or restore archived config?
  1. Upgrade your plan from Plans or Account → Billing.
  2. Open the Previous-Config tab to review archived items.
  3. Restore the ones you want back into your active library (within the 90-day window).

7 Settings, account & deletion

Q How do I connect an exchange, and what does it do?

Open Settings → Providers. Supported providers: Bybit, FXCM, Binance, OANDA. Credentials are stored per-user.

  1. On the provider you want, click Configure and enter your API credentials. Pick the mode: Demo or Real (Run Mode).
  2. You must explicitly turn it on — flip Set Active on that provider's card. (Set Active stays disabled until valid credentials are saved.)
  3. Only one provider is active at a time — activating one switches the others off. Turning the active one off returns you to the GTS default stream + paper trading.
🖼️Settings → Providersscreenshot: Bybit / FXCM / Binance / OANDA cards with Configure + Set Active
What connecting does — and doesn't: a connected provider is for account monitoring + alerting only. GTS connects to that provider's account (demo or real) to watch balances, margin, positions and P&L, and alert you on any metric change. No trades are ever placed on the exchange — in real mode there is no live trading, only monitoring and alerting.
ModeWhat happens
No provider (default)GTS default stream + GTS paper-trading account. Strategies open/close positions internally. Nothing real.
Provider — Demo modeMonitors the provider's demo account + alerts on metric changes. No trades placed.
Provider — Real modeMonitors your real account + alerts on any metric change. Still no live trading.
GTS never holds your funds, and never sends buy/sell orders to your broker. Your keys are used only to read account state for monitoring/alerting.
Q How do I manage my account, security, and billing?

Click your avatar (top-right) to open Account. Tabs: Overview, Usage, Security (password / sessions), Billing (plan / invoices), and History.

Q How do I delete an expression, a strategy, or my account?
  • Expression / strategy — use the 🗑️ delete icon in its library list.
  • Deployed strategy — stop/un-deploy it first (Monitor / My Strategies), then delete.
  • Your account — Account → Security/Billing, or contact support@gts-trade.com.
Deleting a deployed strategy stops its alerts/positions. Close any open positions on your exchange first if you don't want them left running.
Q How do I use the API?

Open API Docs from the nav. The versioned /api/v1/* layer lets you create expressions/strategies, run permutations, deploy, and pull stats programmatically using a personal API key (read / write / control scopes).

Generating expression JSON via an external model? Point it at the schema link from JSON Import.

8 Troubleshooting

Q My expression won't parse or validate — why?
  • Check the LEFT OPERATOR RIGHT shape — a missing operand is the usual cause.
  • Candle patterns need a trend and compare > 0 (not == 100).
  • Decimal indicator params (e.g. SAR(0.02,0.2)) must use function syntax, not dot-notation.
  • Still stuck? Try Generate with AI — it validates as it builds — or check the NLP reference.
Q Why is a Community import "blocked / missing deps"?

The shared expression references helper building-blocks that weren't bundled when it was published, so its dependency closure is incomplete. It's a data issue with that shared item, not your account.

Pick a different community item, or rebuild the logic yourself with the four creation methods in §2.

Q My strategy didn't fire or didn't trade — why?
  • Not deployed, or deployed to the wrong account (paper vs real).
  • The condition simply wasn't true yet on live data — check Signal Monitor.
  • Real-account guard blocked the trade — see §4.
  • No exit path, so a position opened but never closed (or vice-versa).
  • You hit a fires/quota cap — check the header counters.
  • The handler is alert/report-only, so it notifies but never trades by design.