mirror of
https://github.com/cerc-io/mars-interface.git
synced 2025-01-20 10:14:35 +00:00
Add ability to specify endpoints
This commit is contained in:
parent
7423fb2afc
commit
d51db4bef7
7
.env.production
Normal file
7
.env.production
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
# DO NOT EDIT THIS FILE WHEN USING DOCKER
|
||||||
|
# These values are used to replace the values in the built app,
|
||||||
|
# you should pass environment variables as defined in README.md
|
||||||
|
NEXT_PUBLIC_NETWORK=APP_NEXT_NETWORK
|
||||||
|
NEXT_PUBLIC_RPC=APP_NEXT_RPC
|
||||||
|
NEXT_PUBLIC_GQL=APP_NEXT_GQL
|
||||||
|
NEXT_PUBLIC_REST=APP_NEXT_REST
|
12
Dockerfile
12
Dockerfile
@ -1,13 +1,6 @@
|
|||||||
FROM node:19-alpine as builder
|
FROM node:19-alpine as builder
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
# This overrides the parameters during the build time.
|
|
||||||
# You have to do this as passing env variables alone (or via .env file) is not enough.
|
|
||||||
ARG NEXT_PUBLIC_RPC=https://rpc-osmosis.blockapsis.com
|
|
||||||
ARG NEXT_PUBLIC_REST=https://lcd-osmosis.blockapsis.com
|
|
||||||
ARG NEXT_PUBLIC_NETWORK=mainnet
|
|
||||||
ARG NEXT_PUBLIC_GQL=https://rpc-osmosis.blockapsis.com
|
|
||||||
|
|
||||||
COPY package.json yarn.lock ./
|
COPY package.json yarn.lock ./
|
||||||
RUN yarn install
|
RUN yarn install
|
||||||
COPY . .
|
COPY . .
|
||||||
@ -24,6 +17,11 @@ COPY --from=builder /app/next.config.js .
|
|||||||
COPY --from=builder /app/public ./public
|
COPY --from=builder /app/public ./public
|
||||||
COPY --from=builder /app/.next/standalone ./
|
COPY --from=builder /app/.next/standalone ./
|
||||||
COPY --from=builder /app/.next/static ./.next/static
|
COPY --from=builder /app/.next/static ./.next/static
|
||||||
|
COPY entrypoint.sh .
|
||||||
|
|
||||||
|
RUN apk add --no-cache --upgrade bash
|
||||||
|
RUN ["chmod", "+x", "./entrypoint.sh"]
|
||||||
|
ENTRYPOINT ["./entrypoint.sh"]
|
||||||
|
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
CMD ["node", "server.js"]
|
CMD ["node", "server.js"]
|
||||||
|
28
README.md
28
README.md
@ -20,6 +20,34 @@ Start web server
|
|||||||
yarn && yarn dev
|
yarn && yarn dev
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### 2.1 Custom node endpoints using non-Docker deployments
|
||||||
|
|
||||||
|
Copy `.env.example` to `.env` and modify the values to suit your needs.
|
||||||
|
|
||||||
|
### 2.2 Custom node endpoints using Docker
|
||||||
|
|
||||||
|
We allow the use of environment variables to be passed to the Docker container to specify custom endpoints for the app. The variables are:
|
||||||
|
|
||||||
|
|
||||||
|
|Variable|Description|Default|
|
||||||
|
|--------|-----------|-------|
|
||||||
|
|NETWORK|Flag for mainnet or testnet|mainnet|
|
||||||
|
|URL_GQL|The Hive GraphQL endpoint to use|https://osmosis-node.marsprotocol.io/GGSFGSFGFG34/osmosis-hive-front/graphql|
|
||||||
|
|URL_REST|The node REST endpoint to use|https://lcd-osmosis.blockapsis.com|
|
||||||
|
|URL_RPC|The node RPC endpoint to use|https://rpc-osmosis.blockapsis.com|
|
||||||
|
|
||||||
|
**Sample Docker run command**
|
||||||
|
|
||||||
|
This command will start the container in interactive mode with port 3000 bound to localhost and print logs to stdout.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
docker run -it -p 3000:3000 \
|
||||||
|
-e NETWORK=mainnet \
|
||||||
|
-e URL_GQL=https://your-hive-endpoint.com \
|
||||||
|
-e URL_REST=https://your-rest-endpoint.com \
|
||||||
|
-e URL_RPC=https://your-rpc-endpoint.com mars-interface:latest
|
||||||
|
```
|
||||||
|
|
||||||
## 3. Text and translations
|
## 3. Text and translations
|
||||||
|
|
||||||
This repository makes use of a [translation repository](https://github.com/mars-protocol/translations). This repository containes all of the translation key values that are used within the UI. The rationale is to have no _hardcoded_ display string values in this repository.
|
This repository makes use of a [translation repository](https://github.com/mars-protocol/translations). This repository containes all of the translation key values that are used within the UI. The rationale is to have no _hardcoded_ display string values in this repository.
|
||||||
|
29
entrypoint.sh
Executable file
29
entrypoint.sh
Executable file
@ -0,0 +1,29 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# no verbose
|
||||||
|
set +x
|
||||||
|
nextFolder='/app/.next'
|
||||||
|
# create the config file from environment variables
|
||||||
|
envFilename='override.conf'
|
||||||
|
echo "APP_NEXT_NETWORK=$NETWORK" >> $envFilename
|
||||||
|
echo "APP_NEXT_GQL=$URL_GQL" >> $envFilename
|
||||||
|
echo "APP_NEXT_REST=$URL_REST" >> $envFilename
|
||||||
|
echo "APP_NEXT_RPC=$URL_RPC" >> $envFilename
|
||||||
|
function apply_path {
|
||||||
|
# read all config file
|
||||||
|
while read line; do
|
||||||
|
# no comment or not empty
|
||||||
|
if [ "${line:0:1}" == "#" ] || [ "${line}" == "" ]; then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
# split
|
||||||
|
configName="$(cut -d'=' -f1 <<<"$line")"
|
||||||
|
configValue="$(cut -d'=' -f2 <<<"$line")"
|
||||||
|
|
||||||
|
# replace all config values in built app with the ones defined in override
|
||||||
|
find $nextFolder \( -type d -name .git -prune \) -o -type f -print0 | xargs -0 sed -i "s#$configName#$configValue#g"
|
||||||
|
|
||||||
|
done < $envFilename
|
||||||
|
}
|
||||||
|
apply_path
|
||||||
|
exec "$@"
|
@ -9,7 +9,7 @@ import {
|
|||||||
} from '@marsprotocol/wallet-connector'
|
} from '@marsprotocol/wallet-connector'
|
||||||
import { useQueryClient } from '@tanstack/react-query'
|
import { useQueryClient } from '@tanstack/react-query'
|
||||||
import { MARS_SYMBOL } from 'constants/appConstants'
|
import { MARS_SYMBOL } from 'constants/appConstants'
|
||||||
import { IS_TESTNET } from 'constants/env'
|
import { NETWORK } from 'constants/env'
|
||||||
import {
|
import {
|
||||||
useBlockHeight,
|
useBlockHeight,
|
||||||
useDepositAndDebt,
|
useDepositAndDebt,
|
||||||
@ -77,7 +77,7 @@ export const CommonContainer = ({ children }: CommonContainerProps) => {
|
|||||||
// SETTERS
|
// SETTERS
|
||||||
// ------------------
|
// ------------------
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!IS_TESTNET) {
|
if (NETWORK === 'mainnet') {
|
||||||
setCurrentNetwork(Network.MAINNET)
|
setCurrentNetwork(Network.MAINNET)
|
||||||
}
|
}
|
||||||
loadNetworkConfig()
|
loadNetworkConfig()
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { ChainInfoID, WalletID, WalletManagerProvider } from '@marsprotocol/wallet-connector'
|
import { ChainInfoID, WalletID, WalletManagerProvider } from '@marsprotocol/wallet-connector'
|
||||||
import { CircularProgress, SVG } from 'components/common'
|
import { CircularProgress, SVG } from 'components/common'
|
||||||
import { IS_TESTNET } from 'constants/env'
|
import { NETWORK } from 'constants/env'
|
||||||
import { useEffect, useState } from 'react'
|
import { useEffect, useState } from 'react'
|
||||||
|
|
||||||
import styles from './CosmosWalletConnectProvider.module.scss'
|
import styles from './CosmosWalletConnectProvider.module.scss'
|
||||||
@ -21,7 +21,7 @@ export const CosmosWalletConnectProvider = ({ children }: Props) => {
|
|||||||
if (chainInfoOverrides) return
|
if (chainInfoOverrides) return
|
||||||
|
|
||||||
const fetchConfig = async () => {
|
const fetchConfig = async () => {
|
||||||
const file = await import(`../../../configs/${IS_TESTNET ? 'osmo-test-4' : 'osmosis-1'}.ts`)
|
const file = await import(`../../../configs/${NETWORK !== 'mainnet' ? 'osmo-test-4' : 'osmosis-1'}.ts`)
|
||||||
|
|
||||||
const networkConfig: NetworkConfig = file.NETWORK_CONFIG
|
const networkConfig: NetworkConfig = file.NETWORK_CONFIG
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
export const NETWORK = process.env.NEXT_PUBLIC_NETWORK
|
export const NETWORK = process.env.NEXT_PUBLIC_NETWORK
|
||||||
export const IS_TESTNET = NETWORK !== 'mainnet'
|
|
||||||
export const URL_GQL = process.env.NEXT_PUBLIC_GQL
|
export const URL_GQL = process.env.NEXT_PUBLIC_GQL
|
||||||
export const URL_REST = process.env.NEXT_PUBLIC_REST
|
export const URL_REST = process.env.NEXT_PUBLIC_REST
|
||||||
export const URL_RPC = process.env.NEXT_PUBLIC_RPC
|
export const URL_RPC = process.env.NEXT_PUBLIC_RPC
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
import { WalletID } from '@marsprotocol/wallet-connector'
|
import { WalletID } from '@marsprotocol/wallet-connector'
|
||||||
import { IS_TESTNET } from 'constants/env'
|
import { NETWORK } from 'constants/env'
|
||||||
import { DocURL } from 'types/enums/docURL'
|
import { DocURL } from 'types/enums/docURL'
|
||||||
|
|
||||||
export function getCouncilLink(currentProvider?: WalletID): string {
|
export function getCouncilLink(currentProvider?: WalletID): string {
|
||||||
if (IS_TESTNET) return DocURL.COUNCIL_TESTNET_URL
|
if (NETWORK !== 'mainnet') return DocURL.COUNCIL_TESTNET_URL
|
||||||
|
|
||||||
if (!currentProvider) return DocURL.COUNCIL_URL
|
if (!currentProvider) return DocURL.COUNCIL_URL
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user