QuickStart for New Users

While there are many ways to interact with the Space and Time network, the Studio dapp is the easiest.

Welcome to Space and Time! This quick start guide will walk through creating a new user, running your first few queries, and creating and/or joining a subscription.

📘

All steps below can be completed using SxT API, CLI, or SDKs. That said, using the Space and Time Studio UI is the easiest method by-far, so this guide will focus on that path.

Create a New User

The UserID is your gateway into the Space and Time network. You use it to authenticate, to execute queries, hold funds, and join a subscription to work together with others.

A few noteworthy attributes of a Space and Time UserID:

  • They are globally unique - lock up your favorite early!
  • They are case sensitive - Suzy and suzy and SUZY are all different Usernames. If you get an error logging in, check your case.
  • They allow special characters - using your email, Telegram or Discord handle is fine.
  • They are free - you can create a trial user today, and add a subscription later
  • Wallet Addresses are considered keys, not a UserID - meaning you can have multiple wallets and ED25519 keypairs associated with your UserID. It's a best practice to keep UserIDs human readable, and add keys / wallets as appropriate.

Let's Go!

When creating a new user, you can choose to login with your wallet, or with a username / password. Ultimately you can configure your account to use either / both, so which you start with doesn't matter.

Create a new user with a username / password

There are several ways to create a new user in Space and Time, including the CLI, SDK, API, etc., but the fastest and easiest is using Space and Time Studio.

Navigate to the Space and Time Studio dapp and click on "Sign in" in the upper-right most corner. This will open the pop-out titled, "Login or Register Account".

At the bottom of the page, click on "Register". This will open a very traditional Username / Password / Confirmation / Email workflow. Enter the information and click "Create Account". Done!

There is an optional step to optionally enter a "Join Code". This is an invitation code provided by the Admin of an existing subscription. If you don't have one, no worry -- just leave the textbox blank, and your new User will placed into a "Trial" state.

👍

Congrats! You just created a UserID on the Space and Time network!


Create a new user with a web3 wallet

If you prefer, you can create a UserID using a web3 wallet first, rather than a UserName / Password. The outcome of both workflows is the same. To create a net-new user with a wallet address:

  1. Login to Space and Time Studio and click on "Sign in" in the upper-right most corner. (Remember, you can also complete these steps with the CLI or API!)
  2. Click on "Connect a wallet" and select your preferred wallet from the dropdown.
  3. This will display an input screen, where you are prompted for a:
    1. UserName, which will become your globally unique UserID
    2. Email, which is used to verify you're not (likely) a bot, and
    3. Join Code (optional), which is an invitation code provided by the Admin of an existing subscription. If you don't have one, no worry -- just leave the textbox blank, and your new User will placed into a "Trial" state.
  4. Your wallet extension will pop up and prompt you to sign a request from Space and Time - read the Signature Request statement, then click "Sign" in your wallet.

Once you sign the signature request, your account is created and associated with your wallet address! You can now login with your Web3 wallet!

You can add an optional password later, under "My Account" // "Account Settings" // "Profile". This (along with Email) is useful for recovering your account after a lost key or password.

👍

Congrats! You just created a Space and Time User!


If you find your Space and Time UserID is missing an email, consider adding an email. It allows you to recover your password should you ever forget it.

Add an Email to your UserID

If you plan to use Space and Time for real workloads, it is highly recommended you provide an email so we can notify you on updates or changes, or help recover your account. This is treated as a technical operations email, not a marketing channel - communications should be few and important.

To add an email to your UserID:

  1. Login to the Space and Time Studio
  2. Click on "My Account" in the upper-right (replaces "Sign In") and click on the "Account Settings"
  3. In the very first "Profile" section, you will see a location to add / change your email. Simply add a viable email and click "Add Email Address"

👍

Congrats! You've added an email to your UserID! We'll now be able to provide you proactive, important updates to the Space and Time network.


Add a New API Key for API Access

Often developers prefer a simple, application centric authentication method such as an API Key. Fortunately, Space and Time makes it very easy to generate and manage API Keys using Space and Time Studio!

To Generate or Manage API Keys:

  1. Navigate to Space and Time Studio, click on "Sign in" in the upper-right most corner, and login.

  2. Click on "My Account" in the upper-right most corner (replaces "Sign in") and click on the "Permission and Keys" tab.

  3. On that tab, you will see an API Key section. If you have no defined API Keys, the UI will display the "Create API Key" view:

  4. To create a new API Key, simply add a note (to remind yourself where/how the key will be used) and click "Add"

🚧

Copy and save your API Key! It will never be shown again! If you forget to copy, you'll have to delete and re-create a new key.

👍

Congrats! You've just created your first API Key!


If you have existing keys, you should see the "API Key" management view instead:

From here, you can see existing keys and delete keys (using the trash-can icon on the right).

What is the difference between API Keys are Access Tokens?

An ACCESS_TOKEN is the cryptographic session to the Space and Time decentralized network, meaning you're connected to the network directly.

An API key is managed by a Space and Time Gateway / Secrets Proxy, meaning it is authenticating to a near-chain auth server, instead of the decentralized network itself. This allows access to a good number of APIs, but not the full set available to a decentralized ACCESS_TOKEN.

You can however use your authenticated API Key to request a full network ACCESS_TOKEN, allowing your application access to the entire suite of decentralized network APIs using an API Key.


Quick example of running a query using an API Key

Let's run this fairly simple TPS comparative query for January, 2024 - first using the API Key directly, then again using the Decentralized Network.

Select 'SUI' as Name, count(*)/86400.00 as TPS from SUI.TRANSACTIONS
where time_stamp between '2024-01-01' and  '2024-01-31'
  union all 
Select 'POLYGON' as Name, count(*)/86400.00 as TPS from POLYGON.TRANSACTIONS
where time_stamp between '2024-01-01' and  '2024-01-31'
  union all 
Select 'ETHEREUM' as Name, count(*)/86400.00 as TPS from ETHEREUM.TRANSACTIONS
where time_stamp between '2024-01-01' and  '2024-01-31'

Run a query with an API Key, using the proxy SQL API

  1. Navigate to the "Proxy SQL" API Endpoint, and fill in parameter values:
    1. apikey - this is your valid API Key
    2. sqlText - this is the SQL above
    3. All other parameters can be left blank
  2. You can click "Try It!" to run within the API Reference Doc, or click on the Copy Text Icon (lower-left) to copy the CURL request and run in a terminal window.

Use the API Key to get an Access_Token, then run a query

  1. Navigate to the "API Key Login" API Endpoint, and fill in parameter values:
    1. apikey - this is your valid API Key
    2. This will return an ACCESS_TOKEN
  2. Navigate to the "Execute SQL" API endpoint, and fill in parameter values:
    1. Authorization - (upper-right, also called Bearer token) this is your newly created ACCESS_TOKEN
    2. sqlText - this is the SQL above
    3. All other parameters can be left blank
  3. You can click "Try It!" to run within the API Reference Doc, or click on the Copy Text Icon (lower-left) to copy the CURL request and run in a terminal window.

👍

Congrats! You just ran a query using your API Key!

Space and Time provides API calls that allow you to exchange your Secrets Proxy API_Key, UserName/Password, or active Space and Time Studio SessionID for a decentralized ACCESS_TOKEN. This in turn allows you to operate any API on the entire Space and Time network.


Add a New Public/Private Keypair for decentralized API Access

If you plan to build applications or otherwise use any of the suite of Space and Time network APIs, you will need an ED25519 keypair associated with your UserID.

Curious On How Authentication Works?

The decentralized authentication is built on an ED25519 keypair challenge / response model, whereby the user or application requests and signs a challenge token with the local private key. The network then attempts to validate the with the pre-registered public key, and if successful, issues an ACCESS_TOKEN.

The steps for decentralized network authentication are as follows:

Local / ClientDecentralized Network
Request a challenge token for a particular UserID
Generates and returns a random challenge token for that UserID, which expires after 30 seconds
Sign the challenge token with the UserID's private key, and returns the signed challenge to the network
Authenticates the client's ownership of the UserID's private key by using the UserID's public key to validate the signed challenge, and returns an ACCESS_TOKEN (25 minute session), a REFRESH_TOKEN (30 minute time-out, for streamlined session refresh), and the epoch expiration time for both
Any time before the Refresh Token times out, can request a refreshed Access Token, which again comes with a new Refresh Token
Any session that has been active for 24 hours is terminated, forcing a full re-authentication

🚧

Access Tokens ARE your session to the network. Never share or lose control of your Access Token, as it would allow others to issue commands to Space and Time network as you.


Adding a new ED25519 keypair to your account requires authenticating once (to verify you are in control of the UserID) then registering the locally generated public key. We'll use Space and Time Studio to authenticate and provide the ACCESS_TOKEN, which proves we are in control of the account. Then we can use that ACCESS_TOKEN and the SXTCLI to validate our account and register a new keypair.

To add a new ED25519 keypair to your account:

  1. Make sure the Space and Time CLI is installed.

  2. Open a terminal / command window and enter: sxtcli authenticate keypair
    ...which should produce an output similar to...

    ED25519 KeyPair (base64)
    Private key: ft2oz41+aXy1KtAyNzGOqxnHGbNSSXV8xpxN6FpN8w=
    Public key:  eIMaJpSbLC6jyAG9RfwvklgsXbDc/HI2eH7TitL2pA=
    

    Note: do not use the above keys - for proper security, please always generate your own new keys.

  3. STOP NOW and save your new keys to a secure repository, such as an enterprise secrets manager or password manager. Like web3 wallets, lost keys cannot be recovered!

  4. Navigate to Space and Time Studio, click on "Sign In" in the upper-right most corner, and log in with the same UserID which will receive the new keypair association.

  5. Click on "My Account" in the upper-right (replaces "Sign In") and make sure you're on the "My Account" tab.

  6. Scroll down to the section titled, "Quickly test out our API from Docs" and copy the "Access Token" show at the bottom:


  1. Return to your terminal window and use the SXTCLI to complete the registration process:

    sxtcli authenticate keychain \
    --accessToken="eyJ0eXBlIjoiYWNjZXNzIiwia2lkIjoiZTUxNDVkYmQtZGNmYi00ZjI4LTg3NzItZjVmNjN..." \
    --url="https://api.spaceandtime.dev" \
    add \
    --privateKey="ft2oz41taXy1KtAyNzGOqxnHGbNSSXV8xpxN6FpN8w=" \
    --publicKey="eIMaJpSbLC6jyAG9RfwvklgsXbDcdHI2eH7TitL2pA="
    
    1. Paste your ACCESS_TOKEN over the sample in line 2
    2. Paste your Private Key over the sample in line 5
    3. Paste your Public Key (wallet address) over the sample in line 6
    4. All other parameters can be left to default

If successful, you'll receive the message: key added to keychain.

👍

Congrats! You've successfully added a new keypair to your UserID's keychain!

You can add as many keypairs to your keychain as you'd like. For more information, check out this detailed article on connecting to the decentralized network.

🚧

To align with security best practices, Space and Time will never transmit your private key. Some tools like the SXTCLI will require your private key to cryptographically sign authentication challenge tokens, but that private key itself is never transmitted.


Add a Wallet to your UserID, using Space and Time Studio

If you created a standard UserID in Space and Time Studio, you may optionally choose to associate a wallet extension.

You can associate a wallet address with an existing UserID, allowing you to easily authenticate to Space and Time with a ECDSA wallet signature (such as MetaMask) instead of username/password or ED25519 keypair.

To add a wallet to your existing UserID using Space and Time Studio:
(note: the CLI or API can also do this, but Studio is by far the easiest)

  1. Login to Space and Time Studio
  2. Once logged in, click on "My Account" in the upper-right (replaces "Sign In") and make sure you're on the "My Account" tab. (Remember, you can also complete these steps with the CLI or API!)
  3. If you have more than one account in your wallet extension, make sure your preferred account is selected
  4. Below "Account Detail" section, click on "Connect a Wallet" and select your favorite supported wallet
  5. Your wallet extension should prompt you to sign a Space and Time transaction - complete that action in your wallet extension

Space and Time Studio will authenticate you to the network and save the association between your UserID and your wallet's address (aka public key). The next time you login, simply "connect a wallet", sign the transaction, and you're authenticated to Space and Time!


👍

Congrats! You've added your wallet address to your UserID, allowing you to login with your wallet!

These steps will associate your wallet address (aka public key) to your UserID's keychain. This means you can login with your wallet, but can also add and use other ED25519 keypairs, API Keys, UserName/Passwords, or even more than one wallet - all associated to the same UserID.


Add more than one Wallet to your UserID, using the SXTCLI

The Space and Time Studio allows users to easily add one wallet to their UserID, which is typically all most users need and very easy to accomplish in the Studio UI. Occasionally, users may want to add more than one wallets to their account - to do this, users can use the SXTCLI built-in ability to manage a UserID's keychain.

Adding a new web3 wallet your account requires authenticating once (to verify you are in control of the UserID) then registering the new wallet.

To add a new wallet to your account:

  1. Gather your wallet's keys, both public (aka wallet address) and private key.

    1. For the common wallet MetaMask, click on the extension, then on the three dots in the upper-right

    2. Select the "Account Details" option from the drop-down menu to see this screen:

    3. Your PUBLIC_KEY is your wallet address, displayed directly under the QR code.

    4. Your PRIVATE_KEY can be revealed by clicking on the "Show private key" button. You may have to re-enter your wallet software password

🚧

Never share your private key with anyone - they can take over your account and steal your funds!

  1. Install the Space and Time CLI.
  2. Navigate to Space and Time Studio, click on "Sign In" in the upper-right most corner, and log in with the same UserID which will receive the new keypair association.
  3. Click on "My Account" in the upper-right (replaces "Sign In") and make sure you're on the "My Account" tab.
  4. Scroll down to the section titled, "Quickly test out our API from Docs" and copy the "Access Token" show at the bottom:

🚧

Never share your ACCESS_TOKEN with anyone - while only active for 30 minutes, it would allow anyone to access your full SxT account!

  1. Finally, use the <<sxtSXTCLI to complete the registration process:
    sxtcli authenticate keychain \
    --accessToken="eyJ0eXBlIjoiYWNjZXNzIiwia2lkIjoiZTUxNDVkYmQtZGNmYi00ZjI4LTg3NzItZjVmNjN..." \
    --url="https://api.spaceandtime.app" \
    add \
    --privateKey="11ee85761391a6e23eefdd231b69f930ef3b492a538d11ea53882ee" \
    --publicKey="0xa777dC80B19EA7831D73523A726462471db75e7B" \
    --scheme=1
    
    1. Paste your ACCESS_TOKEN over the sample in line 2
    2. Paste your Private Key over the sample in line 5
    3. Paste your Public Key (wallet address) over the sample in line 6
    4. The Schema for EVM Mainnet should be 1. For more information on wallet schema codes, see EIP-155

If successful, you'll receive the message: key added to keychain.

👍

Congrats! You've successfully added a new wallet to your UserID's keychain!

You can add as many keypairs to your keychain as you'd like. For more information, check out this detailed article on connecting to the decentralized network.

🚧

To align with security best practices, Space and Time will never transmit your private key. Some tools like the SXTCLI will require your private key to cryptographically sign authentication challenge tokens, but that private key itself is never transmitted or stored.

Store your private key somewhere safe and private!




Join a Subscription

Subscriptions are a collection of Space and Time accounts, all using a singular payment method and shared visibility into each-other's objects. The most common use-case for subscriptions is a company or organization who pays for their employee's usage. Typically projects or smaller companies will have one subscription, while larger organizations may have several. An account can only belong to one subscription at a time.

There are several ways to become part of a subscription:

Join an Existing Subscription

If your organization already has an active Space and Time subscription that you'd like to join, your SxT admin must issue you a 'JoinCode'. The JoinCode they send you will look like a hexidecimal key, for example: 1115639b5baf85bba86153f8

To Join a subscription with a JoinCode:

  1. Ask your internal Space and Time administrator to generate and send you a new JoinCode over a secure channel.
  2. Navigate to Space and Time Studio, click on "Sign In" in the upper-right most corner, and log in.
  3. Click on "My Account" in the upper-right (replaces "Sign In") and make sure you're on the "My Account" tab.
  4. In the section called "Join an Existing Subscription" find the text box labeled "Join Code."
  5. Copy/paste the JoinCode from your administrator in the text box, and click "Submit."

You should see a green confirmation message in the upper right, and this section of the UI will be replaced with information on you current subscription.

👍

Congrats! You've just joined a subscription!

🚧

The JoinCode expires 24 hours after generation and is consumed once used (for security) - so don't delay!


Create a New Subscription

If you are the project founder or function owner, and new to the Space and Time network, you can decide what subscription type makes sense for your use-case and get signed up!

Types of Subscriptions

There are three types of subscriptions available today in the Space and Time network, each with different capabilities:

Capability Trial User Price per Compute Fixed Rate
Run Queries (AI, optimistic, or tamperproof) 100 free queries (of any kind) ✅ Only pay for compute used ✅ Unlimited, for one fixed monthly cost
Create custom charts & dashboards ✅ Create any number of custom charts and dashboards ✅ Create any number of custom charts and dashboards ✅ Create any number of custom charts and dashboards
Access Indexed Blockchain Data ✅ Unlimited access to all indexed chains ✅ Unlimited access to all indexed chains ✅ Unlimited access to all indexed chains
Build Custom Smart Contract Indexing ✅ Create up to 10 new custom indexing tables ✅ Create up to 10 new custom indexing tables ✅ Create up to 10 new custom indexing tables
Create custom tables and views Cannot create custom tables Can create small to medium tables ✅ Create any number of any sized tables
Billing Method (multi-tenant) Free Charge per query, metered by CPU seconds used Unlimited queires for one fixed monthly amount

Check out our pricing page for the latest pricing. Also, if you're considering Price per Compute and looking to understand what different types of queries cost, check out this analysis on PPC .

There is no cost for data storage.

Create a New Subscription

Creating a new subscription is extremely simple using Space and Time Studio! Having a subscription opens up certain features (like creating tables) that are unavailable without a subscription.

To create a new subscription:

  1. Navigate to Space and Time Studio, click on "Sign In" in the upper-right most corner, and log in.
    Note: the UserID who creates the subscription will be the first "owner" and have full super-admin permissions.

  2. Click on "My Account" in the upper-right (replaces "Sign In") and make sure you're on the "My Account" tab.

  3. On the right side, you should find a section outlining the various subscriptions and payment options - select the option that best fits your use-case click Subscribe! Depending on your payment preferences, there will be a wizard to help you set-up your credit card or crypto wallet for payments.

If you're not sure, Price per Compute is a great way to get started, as it's a pay-as-you-go plan with no minimums on usage - only pay for what you use!

When you're ready, enter your payment information and join the usage based model, where you only pay for queries you run, no minimums. If you use 10¢ worth of compute, you're only charged 10¢. If you never run queries again, you're never charged again!


Once you successfully create your subscription, the information on the right will be replaced with ways to manage your subscription / organization, and your name will lose it's "trial" tag.

👍

Congrats! You now have a Space and Time subscription!


Find your Subscription ID

On rare occasionally you may need to reference your Subscription ID - for example, there is an initial soft-cap to the number of Users per Subscription. A simple request can increase that cap, however the process will require providing your Subscription ID.

To find your Subscription ID:

Click on "My Account" in the upper-right hand of the Space and Time Studio dapp and select "Pricing and Payments" to open your subscription page. Alternatively, you can click on "My Subscriptions" on the left-most selection pane from any "Account Settings" page.

Here you can find your Subscription Name, ID, current plan selected, billing amount and billing cycle. You can also change, leave, or cancel your subscription.

📘

Only the "Owner" of a subscription can "Change Plan" or "Cancel Subscription." Any member of that subscription can "Leave Subscription," as that affects only the user, it does not change the subscription.

The Subscription ID is a UUID and acts as the unique identifier to your Subscription. Any changes to the Subscription requires an authenticated "Owner", so the Subscription ID by itself is not sensitive. That said, it's probably best not to share it too widely, just as a best practice.