Skip to content

Latest commit

 

History

History
200 lines (125 loc) · 4.98 KB

README.md

File metadata and controls

200 lines (125 loc) · 4.98 KB

Morpheus Front-end

This is a front-end for the Morpheus local install. It connects directly to agents that expose an API in OpenAI chat completion format, e.g.

messages = [{"role":"user","content":"swap 1 eth"}]

Configuration

Adding a new agent

Edit frontend/config.ts

Usage

npm install

Run the development server:

npm run dev

Open http://localhost:3000 with your browser to see the result.

API Endpoints

Your agent should expose the following endpoints:

1. Chat

This is the main endpoint for chatting with the agent.

http://127.0.0.1:5000/

The chat API accepts inputs in OpenAI chat completion format - see the example below:

url = 'http://127.0.0.1:5000/
message={"role":"user","content":"swap 1 eth"}
data = {'prompt':message,'chain_id':56}
response = requests.post(url, json=data)

The response will also be in this format.

response = {"role":"assistant","content":"To proceed with the swap, I need to know which crypto currency you want to 
buy in exchange for 1 ETH. Could you please specify the target crypto currency?"}

If the agent has enough information (buy token, sell token, amount) it will then look up the token addresses on the current chain.

If the token symbols are valid, it will then check the user has sufficient balance of the sell token.

If there is sufficient balance, the agent will provide a response containing a quote. This quote is structured with json so that the UI may present the information in a suitable way.

response = {"role": "swap",
  "content": { "dst": "USDT", "dst_address": "0x55d398326f99059ff775485246999027b3197955", "dst_amount": "3000",
  "src": "ETH", "src_address": "0x2170ed0880ac9a755fd29b2688956bd959f933f8", "src_amount": "1",
  "approve_tx_cb": "/approve",
  "swap_tx_cb": "/swap"
  }
}

If the user wants to perform a swap based on the quote, the following steps are required:

1) Check allowance 
2) If allowance < swap amount, send an approve transaction
3) If allowance >= swap amount, send a swap transaction

2. Check Allowance

http://127.0.0.1:5000/allowance

url='http://127.0.0.1:5000/allowance
    data = {
              "tokenAddress":"token address here",
              "walletAddress":"wallet address here",
              "chain_id":56
            }
    response = requests.post(url, json=data)
    swap_transaction=response.text

And then this api will return allowance value either 0 or 1

3. Generate Approve TX

http://127.0.0.1:5000/approve

url='http://127.0.0.1:5000/approve
      data = {
                "tokenAddress":"token address here",
                "amount": 10 , #amount to be swapped here
                "chain_id":56
              }
      response = requests.post(url, json=data)
      swap_transaction=response.text

4. Generate Swap tx

http://127.0.0.1:5000/swap

url='http://127.0.0.1:5000/swap
      data = {
                  "src": token1_address,
                  "dst": token2_address,
                  "amount": amount,
                  "from": walletAddress,
                  "slippage": slippage
              }
      response = requests.post(url, json=data)
      swap_transaction=response.text

5. Transaction status

http://127.0.0.1:5000/tx_status

This endpoint is used to inform the back-end of the status of transactions that have been signed by the user's wallet on the front-end.

Status values:

  • "cancel" = swap cancelled by user
  • "success" = swap successful
  • "fail" = swap failed for some other reason
url = 'http://127.0.0.1:5000/tx_status'
data={'flag':"success"}
response = requests.post(url, json=data)

print(response.text)

When this status information is received, the agent will clear it's context and you can start a new conversation.

6. Messages

Get message history

http://127.0.0.1:5000/messages

Conversation history is stored in the backend.

url = 'http://127.0.0.1:5000/messages'
response = requests.get(url)

result=response.text
{"messages":[
  {"content":"swap 1 eth","role":"user"},
  {"content":"To proceed with the swap, I need to know which crypto currency you want to buy in exchange for 1 ETH. Could you please specify the target crypto currency?","role":"assistant"}
])

Clear message history

url = http://127.0.0.1:5000/clear_messages
response = requests.get(url, json=data)

Learn More

This is a RainbowKit + wagmi + Next.js project bootstrapped with create-rainbowkit.

To learn more about this stack, take a look at the following resources: