Skip to main content

Realnet command line interface

Project description

realnet

Architecture

Coming soon

Prerequisites

For now, before attempting to configure, make sure that you have:

  1. a valid postgres database and an account that can manage creation and alteration of tables - you will need url, database name, username and password
  2. a valid AWS SQS url, AWS S3 url and AWS key and secret that allow write access to them
  3. Replace each CHANGE_OTHERWISE_NO_SECURITY in your config/.env with a separate cryptographically secure hash - remember to always store this kind of information securely

optional: 4. A valid ChatGPT API Key

How to run on linux/windows from source

The realnet server needs to be configured and running. How to do that can be found in the readme.md for https://github.com/virtual-space/realnet/ If you are on Windows, we suggest you use WSL2...

  • Clone out the repo
git clone https://github.com/virtual-space/realnet/realnet.git
  • Go to the repo root folder
cd realnet
  • In the repo root folder create an .env file with the following content:
REALNET_SERVER_HOST='0.0.0.0'
REALNET_SERVER_PORT='8080'

#API KEYS
REALNET_CHATGPT_API_KEY='sk-w32yourchatgptkeygoeshere'
REALNET_CHATGPT_API_URL='https://api.openai.com/v1/chat/completions'


# Local
REALNET_DB_USER='yourdbusername'
REALNET_DB_HOST='localhost'
REALNET_DB_PASS='CHANGE_OTHERWISE_NO_SECURITY'
REALNET_DB_PORT='5432'
REALNET_DB_NAME='realnet'
REALNET_URI='http://localhost:8080'
REALNET_REDIRECT_URI='http://localhost:4200/callback'
REALNET_MOBILE_REDIRECT_URI='io.realnet.app:/oauth2redirect'
REALNET_USERNAME='admin'
REALNET_PASSWORD='CHANGE_OTHERWISE_NO_SECURITY'
REALNET_EMAIL='admin@yourcompanydomain'
REALNET_SQS_URL=yourawssqsurl
REALNET_STORAGE_S3_BUCKET=yourrealnets3storagebucketname
REALNET_STORAGE_TYPE='s3'
REALNET_STORAGE_S3_KEY=yourrealnets3storagekey
REALNET_STORAGE_S3_SECRET=yourrealnets3storagesecret
REALNET_STORAGE_S3_REGION=yourrealnets3storageregion
# REALNET_BASE64_ENCODE_DATA='True'
REALNET_NAME='public'
REALNET_DB_TYPE=postgresql
REALNET_APP_SECRET='CHANGE_OTHERWISE_NO_SECURITY'
REALNET_USE_S3_UPLOAD_URL='True'
REALNET_TOKEN='[generated by realnet auth token]'
REALNET_CLIENT_KEY='[Retrieve by running command "realnet server initialize"]'
REALNET_CLIENT_SECRET='[Retrieve by running command "realnet server initialize"]'
REALNET_URL='[get from realnet server serve command or use 'https://realnet.io' for public]'
  • run command
chmod 700 .env
  • run the following commands:
python -m venv venv
. ./venv/bin/activate
python setup.py install
realnet server initialize
  • finally to start realnet and see available commands, run the following command:
realnet server start
  • for further info about the commands, run the following command:
realnet -h

How to build a Docker image and run it locally

TODO please validate and correct

docker build -t realnet:latest .
docker run -d -p 8080:8080 realnet:latest

How to install a pip package and run it locally

TODO please validate and correct

Make sure that you have the .env file present with the folder with the right values (see other sections). Your python version should probably be 3.10.11 or later

python3 -m venv venv
. ./venv/bin/activate
pip install realnet
realnet server initialize
realnet server start

How to run on kubernetes via docker

deployment.yaml:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: realnet
spec:
  replicas: 1
  selector:
    matchLabels:
      app: realnet
  template:
    metadata:
      labels:
        app: realnet
    spec:
      containers:
        - name: realnet
          image: 'l33tsys/realnet'
          imagePullPolicy: "Always"
          ports:
            - containerPort: 8080
          envFrom:
            - configMapRef:
                name: realnet-config

configmap.yaml

apiVersion: v1
kind: ConfigMap
metadata:
  name: realnet-config
  labels:
    app: realnet
data:
  REALNET_SERVER_HOST: '0.0.0.0'
  REALNET_SERVER_PORT: '8080'
  # Local
  REALNET_DB_USER: 'postgres'
  REALNET_DB_HOST: 'localhost'
  REALNET_DB_PASS: 'CHANGE_OTHERWISE_NO_SECURITY'
  REALNET_DB_PORT: '5432'
  REALNET_DB_NAME: 'postgres'
  REALNET_URI: 'https://realnet.io'
  REALNET_REDIRECT_URI: 'https://www.realscape.io/callback'
  REALNET_MOBILE_REDIRECT_URI: 'io.realnet.app:/oauth2redirect'
  REALNET_USERNAME: 'admin'
  REALNET_PASSWORD: 'CHANGE_OTHERWISE_NO_SECURITY'
  REALNET_EMAIL: 'admin@yourcompanydomain'
  REALNET_SQS_URL: 'yourawssqsurl'
  REALNET_STORAGE_S3_BUCKET: yourrealnets3storagebucketname
  REALNET_STORAGE_TYPE: 's3'
  REALNET_STORAGE_S3_KEY: yourrealnets3storagekey
  REALNET_STORAGE_S3_SECRET: yourrealnets3storagesecret
  REALNET_STORAGE_S3_REGION: yourrealnets3storageregion
  REALNET_BASE64_ENCODE_DATA: 'True'
  REALNET_NAME: 'public'
  REALNET_DB_TYPE: postgresql
  REALNET_APP_SECRET: 'CHANGE_OTHERWISE_NO_SECURITY'
  REALNET_USE_S3_UPLOAD_URL: 'True'

service.yaml

apiVersion: v1
kind: Service
metadata:
  name: realnet
  annotations:
    external-dns.alpha.kubernetes.io/hostname: yourcompanydomain
    service.beta.kubernetes.io/aws-load-balancer-ssl-cert: yourlbcerturl
  labels:
    app: realnet
spec:
  type: LoadBalancer
  ports:
  - protocol: TCP
    port: 443
    targetPort: 8080
  selector:
   app: realnet

installation notes (python setup.py | pip install)

TODO: Review if below still applies

You may need to manually install some dependencies. The install command should tell you what is missing.

The Cryptography module takes a long time to compile.

Below is an incomplete list of installation instructions for dependencies. If you're not doing this on a fresh installation, you should run python setup.py install or pip install realnet to see what you need first.

  • Inside VENV
pip install --upgrade pip
pip install setuptools-rust
  • Outside VENV postgreSQL (pg_config is missing)
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
sudo apt-get update
sudo apt-get -y install postgresql

c/c++ compilers (gcc/g++ is missing)

sudo apt update
sudo apt install build-essential

Optional Man pages

sudo apt-get install manpages-dev

To test the C & C++ compiler installations run these commands:

gcc --version
g++ --version

bluetooth dev tools (bluetooth/bluetooth.h is missing)

sudo apt-get install libbluetooth-dev

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

realnet-0.0.80.tar.gz (862.4 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

realnet-0.0.80-py3.10.egg (1.0 MB view details)

Uploaded Egg

realnet-0.0.80-py3-none-any.whl (893.2 kB view details)

Uploaded Python 3

File details

Details for the file realnet-0.0.80.tar.gz.

File metadata

  • Download URL: realnet-0.0.80.tar.gz
  • Upload date:
  • Size: 862.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.11

File hashes

Hashes for realnet-0.0.80.tar.gz
Algorithm Hash digest
SHA256 114770aabb710cec215ebd1b57d1e7a9c150938a66984405abc6b2f1375a75c3
MD5 2860b92df59bbfcf5ab9c8f26bf37a72
BLAKE2b-256 6294a3da3296fb363253cf6a80e5a48dcceae79af4a0399fbb680cd9493f7ee5

See more details on using hashes here.

File details

Details for the file realnet-0.0.80-py3.10.egg.

File metadata

  • Download URL: realnet-0.0.80-py3.10.egg
  • Upload date:
  • Size: 1.0 MB
  • Tags: Egg
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.11

File hashes

Hashes for realnet-0.0.80-py3.10.egg
Algorithm Hash digest
SHA256 9b24fa30f3a714fafc8fcd6ad7c5c843d31c60c7b211280793fa57971e46c318
MD5 b29c56097a265b6a96ca461385433aab
BLAKE2b-256 1b47284ed7a1e84e85183ae84fc2774fff63c21d7ed2b80778513cf918d6c7ae

See more details on using hashes here.

File details

Details for the file realnet-0.0.80-py3-none-any.whl.

File metadata

  • Download URL: realnet-0.0.80-py3-none-any.whl
  • Upload date:
  • Size: 893.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.11

File hashes

Hashes for realnet-0.0.80-py3-none-any.whl
Algorithm Hash digest
SHA256 4fdfa95bfe4223e722e8d90765ee38a3ea7119dae75efb9f226df61aefa2dc71
MD5 e8e45971ff33fa23e248c65989cb8c7c
BLAKE2b-256 f65b51bb525c568b4dcff9327b08dd91a0cbe44cc91482123962e07b6d82b3a7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page