From d8e575d38618a62508043f7354d14539c84a637a Mon Sep 17 00:00:00 2001 From: Ty Fiero Date: Thu, 21 Mar 2024 14:20:50 -0700 Subject: [PATCH] Rename directories to software and source --- .github/workflows/lint.yml | 2 +- .github/workflows/test.yml | 2 +- .gitignore | 8 +- .pre-commit-config.yaml | 50 ++-- 01OS/tests/sample_test.py | 7 - README.md | 3 +- archive/.env.example | 50 ---- archive/start.sh | 255 ------------------ archive/tunnel.sh | 65 ----- docs/getting-started/introduction.mdx | 4 +- docs/getting-started/setup.mdx | 4 +- docs/server/setup.mdx | 2 +- {01OS => software}/.cursorignore | 0 {01OS => software}/README.md | 0 {01OS => software}/poetry.lock | 0 {01OS => software}/pyproject.toml | 2 +- software/pytest.ini | 9 + {01OS/01OS => software/source}/__init__.py | 0 .../source}/clients/__init__.py | 0 .../source}/clients/base_device.py | 0 .../source}/clients/esp32/README.md | 0 .../source}/clients/esp32/__init__.py | 0 .../clients/esp32/src/client/client.ino | 0 .../source}/clients/esp32/websocket_test.py | 0 .../source}/clients/linux/__init__.py | 0 .../source}/clients/linux/device.py | 0 .../source}/clients/mac/__init__.py | 0 .../source}/clients/mac/device.py | 0 .../source}/clients/rpi/__init__.py | 0 .../source}/clients/rpi/device.py | 0 .../source}/server/__init__.py | 0 software/source/server/conftest.py | 19 ++ .../conversations/another-interpreter.json | 0 {01OS/01OS => software/source}/server/i.py | 0 {01OS/01OS => software/source}/server/llm.py | 0 .../01OS => software/source}/server/server.py | 3 +- .../source}/server/services/__init__.py | 0 .../source}/server/services/llm/__init__.py | 0 .../server/services/llm/litellm/__init__.py | 0 .../server/services/llm/litellm/llm.py | 0 .../server/services/llm/llamaedge/__init__.py | 0 .../server/services/llm/llamaedge/llm.py | 0 .../server/services/llm/llamafile/__init__.py | 0 .../server/services/llm/llamafile/llm.py | 0 .../source}/server/services/stt/__init__.py | 0 .../services/stt/local-whisper/__init__.py | 0 .../server/services/stt/local-whisper/stt.py | 0 .../stt/local-whisper/whisper-rust/.gitignore | 0 .../stt/local-whisper/whisper-rust/Cargo.lock | 0 .../stt/local-whisper/whisper-rust/Cargo.toml | 0 .../local-whisper/whisper-rust/src/main.rs | 0 .../whisper-rust/src/transcribe.rs | 0 .../server/services/stt/openai/__init__.py | 0 .../source}/server/services/stt/openai/stt.py | 0 .../source}/server/services/tts/__init__.py | 0 .../server/services/tts/openai/__init__.py | 0 .../source}/server/services/tts/openai/tts.py | 0 .../server/services/tts/piper/__init__.py | 0 .../source}/server/services/tts/piper/tts.py | 0 .../source}/server/skills/__init__.py | 0 .../source}/server/skills/schedule.py | 0 .../system_messages/BaseSystemMessage.py | 0 .../system_messages/TeachModeSystemMessage.py | 0 .../server/system_messages/__init__.py | 0 .../source/server/tests}/__init__.py | 0 software/source/server/tests/test_run.py | 41 +++ .../01OS => software/source}/server/tunnel.py | 0 .../source/server/utils}/__init__.py | 0 .../source}/server/utils/bytes_to_wav.py | 0 .../source}/server/utils/get_system_info.py | 0 .../source}/server/utils/kernel.py | 0 .../source}/server/utils/logs.py | 0 .../source}/server/utils/process_utils.py | 0 .../source}/utils/accumulator.py | 0 .../source}/utils/print_markdown.py | 0 {01OS => software}/start.py | 7 +- 76 files changed, 113 insertions(+), 420 deletions(-) delete mode 100644 01OS/tests/sample_test.py delete mode 100644 archive/.env.example delete mode 100755 archive/start.sh delete mode 100755 archive/tunnel.sh rename {01OS => software}/.cursorignore (100%) rename {01OS => software}/README.md (100%) rename {01OS => software}/poetry.lock (100%) rename {01OS => software}/pyproject.toml (97%) create mode 100644 software/pytest.ini rename {01OS/01OS => software/source}/__init__.py (100%) rename {01OS/01OS => software/source}/clients/__init__.py (100%) rename {01OS/01OS => software/source}/clients/base_device.py (100%) rename {01OS/01OS => software/source}/clients/esp32/README.md (100%) rename {01OS/01OS => software/source}/clients/esp32/__init__.py (100%) rename {01OS/01OS => software/source}/clients/esp32/src/client/client.ino (100%) rename {01OS/01OS => software/source}/clients/esp32/websocket_test.py (100%) rename {01OS/01OS => software/source}/clients/linux/__init__.py (100%) rename {01OS/01OS => software/source}/clients/linux/device.py (100%) rename {01OS/01OS => software/source}/clients/mac/__init__.py (100%) rename {01OS/01OS => software/source}/clients/mac/device.py (100%) rename {01OS/01OS => software/source}/clients/rpi/__init__.py (100%) rename {01OS/01OS => software/source}/clients/rpi/device.py (100%) rename {01OS/01OS => software/source}/server/__init__.py (100%) create mode 100644 software/source/server/conftest.py rename {01OS/01OS => software/source}/server/conversations/another-interpreter.json (100%) rename {01OS/01OS => software/source}/server/i.py (100%) rename {01OS/01OS => software/source}/server/llm.py (100%) rename {01OS/01OS => software/source}/server/server.py (99%) rename {01OS/01OS => software/source}/server/services/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/llm/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/llm/litellm/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/llm/litellm/llm.py (100%) rename {01OS/01OS => software/source}/server/services/llm/llamaedge/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/llm/llamaedge/llm.py (100%) rename {01OS/01OS => software/source}/server/services/llm/llamafile/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/llm/llamafile/llm.py (100%) rename {01OS/01OS => software/source}/server/services/stt/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/stt/local-whisper/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/stt/local-whisper/stt.py (100%) rename {01OS/01OS => software/source}/server/services/stt/local-whisper/whisper-rust/.gitignore (100%) rename {01OS/01OS => software/source}/server/services/stt/local-whisper/whisper-rust/Cargo.lock (100%) rename {01OS/01OS => software/source}/server/services/stt/local-whisper/whisper-rust/Cargo.toml (100%) rename {01OS/01OS => software/source}/server/services/stt/local-whisper/whisper-rust/src/main.rs (100%) rename {01OS/01OS => software/source}/server/services/stt/local-whisper/whisper-rust/src/transcribe.rs (100%) rename {01OS/01OS => software/source}/server/services/stt/openai/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/stt/openai/stt.py (100%) rename {01OS/01OS => software/source}/server/services/tts/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/tts/openai/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/tts/openai/tts.py (100%) rename {01OS/01OS => software/source}/server/services/tts/piper/__init__.py (100%) rename {01OS/01OS => software/source}/server/services/tts/piper/tts.py (100%) rename {01OS/01OS => software/source}/server/skills/__init__.py (100%) rename {01OS/01OS => software/source}/server/skills/schedule.py (100%) rename {01OS/01OS => software/source}/server/system_messages/BaseSystemMessage.py (100%) rename {01OS/01OS => software/source}/server/system_messages/TeachModeSystemMessage.py (100%) rename {01OS/01OS => software/source}/server/system_messages/__init__.py (100%) rename {01OS/01OS/server/utils => software/source/server/tests}/__init__.py (100%) create mode 100644 software/source/server/tests/test_run.py rename {01OS/01OS => software/source}/server/tunnel.py (100%) rename {01OS/tests => software/source/server/utils}/__init__.py (100%) rename {01OS/01OS => software/source}/server/utils/bytes_to_wav.py (100%) rename {01OS/01OS => software/source}/server/utils/get_system_info.py (100%) rename {01OS/01OS => software/source}/server/utils/kernel.py (100%) rename {01OS/01OS => software/source}/server/utils/logs.py (100%) rename {01OS/01OS => software/source}/server/utils/process_utils.py (100%) rename {01OS/01OS => software/source}/utils/accumulator.py (100%) rename {01OS/01OS => software/source}/utils/print_markdown.py (100%) rename {01OS => software}/start.py (96%) diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index b48a61cb..29aab93f 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -27,7 +27,7 @@ jobs: run: sudo apt-get install portaudio19-dev python-all-dev - name: Install Poetry Package - working-directory: 01OS # Set the working directory to "01OS" + working-directory: software run: | pip install --upgrade pip pip install poetry==1.3.2 diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 2d6b0514..67be5961 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -21,7 +21,7 @@ jobs: defaults: run: - working-directory: 01OS + working-directory: software runs-on: ${{ matrix.os }} diff --git a/.gitignore b/.gitignore index e48a413d..aeaed365 100644 --- a/.gitignore +++ b/.gitignore @@ -4,9 +4,9 @@ __pycache__/ *.py[cod] *$py.class -01OS/01OS/server/conversations/user.json -01OS/01OS/server/tts/local_service/* -01OS/01OS/server/stt/local_service/* +software/source/server/conversations/user.json +software/source/server/tts/local_service/* +software/source/server/stt/local_service/* # C extensions *.so @@ -167,5 +167,5 @@ cython_debug/ # ignore the aifs index files _.aifs -01OS/output_audio.wav +software/output_audio.wav .DS_Store diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 6d514b2b..0d70cf2b 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -1,26 +1,26 @@ repos: -- repo: https://github.com/astral-sh/ruff-pre-commit - rev: "v0.2.2" - hooks: - - id: ruff - args: ["--fix"] - - id: ruff-format -- repo: https://github.com/pre-commit/pre-commit-hooks - rev: v4.5.0 - hooks: - - id: trailing-whitespace - - id: end-of-file-fixer - - id: fix-encoding-pragma - args: [--remove] - - id: check-yaml - - id: debug-statements - language_version: python3 -- repo: local - hooks: - - id: pytest - name: pytest - entry: pytest 01OS/tests - language: system - types: [python] - pass_filenames: false - always_run: true + - repo: https://github.com/astral-sh/ruff-pre-commit + rev: "v0.2.2" + hooks: + - id: ruff + args: ["--fix"] + - id: ruff-format + - repo: https://github.com/pre-commit/pre-commit-hooks + rev: v4.5.0 + hooks: + - id: trailing-whitespace + - id: end-of-file-fixer + - id: fix-encoding-pragma + args: [--remove] + - id: check-yaml + - id: debug-statements + language_version: python3 + - repo: local + hooks: + - id: pytest + name: pytest + entry: pytest software/tests + language: system + types: [python] + pass_filenames: false + always_run: true diff --git a/01OS/tests/sample_test.py b/01OS/tests/sample_test.py deleted file mode 100644 index 0cd45d53..00000000 --- a/01OS/tests/sample_test.py +++ /dev/null @@ -1,7 +0,0 @@ -def hello_world(): - return "Hello, World!" - - -# A test function to assert that hello_world() returns the expected string -def test_hello_world(): - assert hello_world() == "Hello, World!" diff --git a/README.md b/README.md index 01a64909..18a4f251 100644 --- a/README.md +++ b/README.md @@ -36,7 +36,7 @@ We intend to become the GNU/Linux of this space by staying open, modular, and fr ```shell git clone https://github.com/OpenInterpreter/01 # Clone the repository -cd 01/01OS # CD into the source directory +cd 01/software # CD into the source directory ``` @@ -146,7 +146,6 @@ The story of devices that came before the 01. Things we want to steal great ideas from. -
○ diff --git a/archive/.env.example b/archive/.env.example deleted file mode 100644 index 65670b58..00000000 --- a/archive/.env.example +++ /dev/null @@ -1,50 +0,0 @@ -### SETTINGS -# Copy this file and rename it to ".env" to use it. - -# If ALL_LOCAL is False, we'll use OpenAI's services -# else we use whisper.cpp and piper local models -ALL_LOCAL=False -WHISPER_MODEL_NAME="ggml-tiny.en.bin" -WHISPER_MODEL_URL="https://huggingface.co/ggerganov/whisper.cpp/resolve/main/" -TEACH_MODE=False - -# Uncomment to set your OpenAI API key -# OPENAI_API_KEY=sk-... - -# For TTS, we use the en_US-lessac-medium voice model by default -# Please change the voice URL and voice name if you wish to use another voice -PIPER_VOICE_URL="https://huggingface.co/rhasspy/piper-voices/resolve/main/en/en_US/lessac/medium/" -PIPER_VOICE_NAME="en_US-lessac-medium.onnx" - -# If SERVER_START, this is where we'll serve the server. -# If CLIENT_START, this is where the client expects the server to be. -# SERVER_URL=ws://localhost:10001/ -SERVER_URL=ws://0.0.0.0:10001/ -SERVER_START=True -CLIENT_START=True - -# The port to start the local server on -SERVER_LOCAL_PORT=10001 - -# Explicitly set the client type (macos, rpi) -CLIENT_TYPE=auto - -# Control where various operations happen— can be `client` or `server`. -CODE_RUNNER=server -TTS_RUNNER=server # If client, audio will be sent over websocket. -STT_RUNNER=client # If server, audio will be sent over websocket. - -# Image capture settings -CAMERA_ENABLED=False - -# Camera device selection (Typically 0 for built-in, 1 for USB) -CAMERA_DEVICE_INDEX=0 - -# Camera warmup time -# This is a workaround for some cameras that don't immediately -# return a properly exposed picture when they are first turned on -CAMERA_WARMUP_SECONDS=0.4 - -# Debug level -# LOG_LEVEL=DEBUG -LOG_LEVEL="INFO" \ No newline at end of file diff --git a/archive/start.sh b/archive/start.sh deleted file mode 100755 index 2a1086df..00000000 --- a/archive/start.sh +++ /dev/null @@ -1,255 +0,0 @@ -#!/usr/bin/env bash - -# Set python to prioritize the module files from the current directory -# If we don't do this, then the python interpreter will not be able to find the modules, -# and will throw an error like "ModuleNotFoundError: No module named '01OS'". -# If we solve the problem by pip installing the official 01OS package, then those -# modules will run instead of the local ones that we are trying to develop with. -export PYTHONPATH="$(pwd):$PYTHONPATH" - -### Import Environment Variables from .env -SCRIPT_DIR="$(dirname "$0")" -if [ ! -f "$SCRIPT_DIR/.env" ]; then - echo "No .env file found. Copying from .env.example..." - cp "$SCRIPT_DIR/.env.example" "$SCRIPT_DIR/.env" -fi -set -a; source "$SCRIPT_DIR/.env"; set +a - -### COMMAND LINE ARGUMENTS - -# Set both SERVER_START and CLIENT_START to False if "--server" or "--client" is passed as an argument -# (This way, --server runs only the server, --client runs only the client.) -if [[ "$@" == *"--server"* ]] || [[ "$@" == *"--client"* ]]; then - export SERVER_START="False" - export CLIENT_START="False" -fi - -# Check if "--local" is passed as an argument -if [[ "$@" == *"--local"* ]]; then - # If "--local" is passed, set ALL_LOCAL to True - export ALL_LOCAL="True" -fi - -# Check if "--server" is passed as an argument -if [[ "$@" == *"--server"* ]]; then - # If "--server" is passed, set SERVER_START to True - export SERVER_START="True" -fi - -# Check if "--teach" is passed as an argument -if [[ "$@" == *"--teach"* ]]; then - # If "--teach" is passed, set TEACH_MODE to True - export TEACH_MODE="True" -fi - -# Check if "--client" is passed as an argument -if [[ "$@" == *"--client"* ]]; then - # If "--client" is passed, set CLIENT_START to True - export CLIENT_START="True" - # Extract the client type from the arguments - CLIENT_TYPE=$(echo "$@" | sed -n -e 's/^.*--client //p' | awk '{print $1}') - # If client type is not empty, export it - if [[ ! -z "$CLIENT_TYPE" ]]; then - export CLIENT_TYPE - fi -fi - -# Check if "--expose" is passed as an argument -if [[ "$@" == *"--expose"* ]]; then - if [[ "$SERVER_START" != "True" ]]; then - echo "Error: Start script must be started with --serve for tunneling to work." - exit 1 - else - export TUNNEL_START="True" - - if [[ "$@" == *"--expose-with-bore"* ]]; then - export TUNNEL_METHOD="bore" - elif [[ "$@" == *"--expose-with-localtunnel"* ]]; then - export TUNNEL_METHOD="localtunnel" - elif [[ "$@" == *"--expose-with-ngrok"* ]]; then - export TUNNEL_METHOD="ngrok" - fi - - echo "exposing server" - fi -fi - -# Check if "--clear-local" is passed as an argument -if [[ "$@" == *"--clear-local"* ]]; then - # If "--clear-local" is passed, clear the contents of the folders in script_dir/01OS/server/{tts and stt}/local_service - echo "Clearing local services..." - rm -rf "$SCRIPT_DIR/01OS/server/tts/local_service"/* - rm -rf "$SCRIPT_DIR/01OS/server/stt/local_service"/* - echo "Exiting after clearing local services..." - exit 0 -fi - -### SKILLS PATH - -OI_SKILLS_PATH="$SCRIPT_DIR/01OS/server/skills" - -### SETUP - -if [[ "$ALL_LOCAL" == "True" ]]; then -# if using local models, install the models / executables - - CWD=$(pwd) - - # Whisper setup - STT_PATH="$SCRIPT_DIR/01OS/server/stt" - WHISPER_RUST_PATH="${STT_PATH}/whisper-rust" - cd ${WHISPER_RUST_PATH} - - # Check if whisper-rust executable exists before attempting to build - if [[ ! -f "${WHISPER_RUST_PATH}/target/release/whisper-rust" ]]; then - # Check if Rust is installed. Needed to build whisper executable - - if ! command -v rustc &> /dev/null; then - echo "Rust is not installed or is not in system PATH. Please install Rust before proceeding." - exit 1 - fi - # Build Whisper Rust executable if not found - cargo build --release - else - echo "Whisper Rust executable already exists. Skipping build." - fi - - WHISPER_MODEL_PATH="${STT_PATH}/local_service" - if [[ ! -f "${WHISPER_MODEL_PATH}/${WHISPER_MODEL_NAME}" ]]; then - mkdir -p "${WHISPER_MODEL_PATH}" - curl -L "${WHISPER_MODEL_URL}${WHISPER_MODEL_NAME}" -o "${WHISPER_MODEL_PATH}/${WHISPER_MODEL_NAME}" - else - echo "Whisper model already exists. Skipping download." - fi - - cd $CWD - - ## PIPER - PIPER_FOLDER_PATH="$SCRIPT_DIR/01OS/server/tts/local_service" - if [[ ! -d "$PIPER_FOLDER_PATH/piper" ]]; then # Check if the Piper directory exists - mkdir -p "${PIPER_FOLDER_PATH}" - - # Determine OS and architecture - OS=$(uname -s) - ARCH=$(uname -m) - if [ "$OS" = "Darwin" ]; then - OS="macos" - if [ "$ARCH" = "arm64" ]; then - ARCH="aarch64" - elif [ "$ARCH" = "x86_64" ]; then - ARCH="x64" - else - echo "Piper: unsupported architecture" - fi - fi - PIPER_ASSETNAME="piper_${OS}_${ARCH}.tar.gz" - PIPER_URL="https://github.com/rhasspy/piper/releases/latest/download/" - - # Save the current working directory - CWD=$(pwd) - - # Navigate to SCRIPT_DIR/01OS/server/tts/local_service - cd ${PIPER_FOLDER_PATH} - curl -L "${PIPER_URL}${PIPER_ASSETNAME}" -o "${PIPER_ASSETNAME}" - tar -xvzf $PIPER_ASSETNAME - cd piper - curl -OL "${PIPER_VOICE_URL}${PIPER_VOICE_NAME}" - curl -OL "${PIPER_VOICE_URL}${PIPER_VOICE_NAME}.json" - # Additional setup for macOS - if [ "$OS" = "macos" ]; then - if [ "$ARCH" = "x64" ]; then - softwareupdate --install-rosetta --agree-to-license - fi - PIPER_PHONEMIZE_ASSETNAME="piper-phonemize_${OS}_${ARCH}.tar.gz" - PIPER_PHONEMIZE_URL="https://github.com/rhasspy/piper-phonemize/releases/latest/download/" - curl -OL "${PIPER_PHONEMIZE_URL}${PIPER_PHONEMIZE_ASSETNAME}" - tar -xvzf $PIPER_PHONEMIZE_ASSETNAME - PIPER_DIR=`pwd` - install_name_tool -change @rpath/libespeak-ng.1.dylib "${PIPER_DIR}/piper-phonemize/lib/libespeak-ng.1.dylib" "${PIPER_DIR}/piper" - install_name_tool -change @rpath/libonnxruntime.1.14.1.dylib "${PIPER_DIR}/piper-phonemize/lib/libonnxruntime.1.14.1.dylib" "${PIPER_DIR}/piper" - install_name_tool -change @rpath/libpiper_phonemize.1.dylib "${PIPER_DIR}/piper-phonemize/lib/libpiper_phonemize.1.dylib" "${PIPER_DIR}/piper" - fi - - echo "Piper setup completed." - # Navigate back to the current working directory - cd $CWD - else - echo "Piper already set up. Skipping download." - fi -fi - -### START - -start_client() { - echo "Starting client..." - bash $SCRIPT_DIR/01OS/clients/start.sh & - CLIENT_PID=$! - echo "client started as process $CLIENT_PID" -} - -# Function to start server -start_server() { - echo "Starting server..." - python -m 01OS.server.server & - SERVER_PID=$! - echo "Server started as process $SERVER_PID" -} - -# Function to start tunnel service -start_tunnel() { - echo "Starting tunnel..." - ./tunnel.sh & - TUNNEL_PID=$! - echo "Tunnel started as process $TUNNEL_PID" -} - -stop_processes() { - if [[ -n $CLIENT_PID ]]; then - echo "Stopping client..." - kill $CLIENT_PID - fi - if [[ -n $SERVER_PID ]]; then - echo "Stopping server..." - kill $SERVER_PID - fi - if [[ -n $TUNNEL_PID ]]; then - echo "Stopping tunnel..." - kill $TUNNEL_PID - fi -} - -# Trap SIGINT and SIGTERM to stop processes when the script is terminated -trap stop_processes SIGINT SIGTERM - -# SERVER -# Start server if SERVER_START is True -if [[ "$SERVER_START" == "True" ]]; then - start_server -fi - -# CLIENT -# Start client if CLIENT_START is True -if [[ "$CLIENT_START" == "True" ]]; then - start_client -fi - -# TUNNEL -# Start tunnel if TUNNEL_START is True -if [[ "$TUNNEL_START" == "True" ]]; then - start_tunnel -fi - -# Wait for client and server processes to exit -wait $CLIENT_PID -wait $SERVER_PID -wait $TUNNEL_PID - -# TTS, STT - -# (todo) -# (i think we should start with hosted services) - -# LLM - -# (disabled, we'll start with hosted services) -# python core/llm/start.py & \ No newline at end of file diff --git a/archive/tunnel.sh b/archive/tunnel.sh deleted file mode 100755 index bc86dfdf..00000000 --- a/archive/tunnel.sh +++ /dev/null @@ -1,65 +0,0 @@ -#!/usr/bin/env bash - -# Get tunnel method from TUNNEL_METHOD environment variable, but default to bore -# Possible options; -# - bore -# - localtunnel -# - ngrok -TUNNEL_METHOD=${TUNNEL_METHOD:-bore} - -# Get the SERVER_PORT environment variable, but default to 10001 -SERVER_LOCAL_PORT=${SERVER_LOCAL_PORT:-10001} - -echo "Using $TUNNEL_METHOD to expose port $SERVER_LOCAL_PORT on localhost..." - -# If the TUNNEL_METHOD is bore, then we need to check if the bore-cli is installed -if [[ "$TUNNEL_METHOD" == "bore" ]]; then - - if ! command -v bore &> /dev/null; then - echo "The bore-cli command is not available. Please run 'cargo install bore-cli'." - echo "For more information, see https://github.com/ekzhang/bore" - exit 1 - else - bore local $SERVER_LOCAL_PORT --to bore.pub | while IFS= read -r line; do - if [[ "$line" == *"listening at bore.pub:"* ]]; then - remote_port=$(echo "$line" | grep -o 'bore.pub:[0-9]*' | cut -d':' -f2) - echo "Please set your client env variable for SERVER_URL=ws://bore.pub:$remote_port" - break - fi - done - fi - -elif [[ "$TUNNEL_METHOD" == "localtunnel" ]]; then - - if ! command -v lt &> /dev/null; then - echo "The 'lt' command is not available." - echo "Please ensure you have Node.js installed, then run 'npm install -g localtunnel'." - echo "For more information, see https://github.com/localtunnel/localtunnel" - exit 1 - else - npx localtunnel --port $SERVER_LOCAL_PORT | while IFS= read -r line; do - if [[ "$line" == *"your url is: https://"* ]]; then - remote_url=$(echo "$line" | grep -o 'https://[a-zA-Z0-9.-]*' | sed 's|https://||') - echo "Please set your client env variable for SERVER_URL=wss://$remote_url" - break - fi - done - fi - -elif [[ "$TUNNEL_METHOD" == "ngrok" ]]; then - - if ! command -v ngrok &> /dev/null; then - echo "The ngrok command is not available." - echo "Please install ngrok using the instructions at https://ngrok.com/docs/getting-started/" - exit 1 - else - ngrok http $SERVER_LOCAL_PORT --log stdout | while IFS= read -r line; do - if [[ "$line" == *"started tunnel"* ]]; then - remote_url=$(echo "$line" | grep -o 'https://[a-zA-Z0-9.-]*' | sed 's|https://||') - echo "Please set your client env variable for SERVER_URL=wss://$remote_url" - break - fi - done - fi - -fi diff --git a/docs/getting-started/introduction.mdx b/docs/getting-started/introduction.mdx index 705543d8..3bd1ca5d 100644 --- a/docs/getting-started/introduction.mdx +++ b/docs/getting-started/introduction.mdx @@ -30,9 +30,9 @@ sudo apt-get install portaudio19-dev ffmpeg cmake ### Install and run the 01 CLI ```bash -# Clone the repo and navigate into the 01OS directory +# Clone the repo and navigate into the software directory git clone https://github.com/OpenInterpreter/01.git -cd 01OS +cd software # Install dependencies and run 01 poetry install diff --git a/docs/getting-started/setup.mdx b/docs/getting-started/setup.mdx index 0f18339f..59dc4636 100644 --- a/docs/getting-started/setup.mdx +++ b/docs/getting-started/setup.mdx @@ -40,10 +40,10 @@ git clone https://github.com/OpenInterpreter/01.git In order to run 01 on your computer, use [Poetry](https://python-poetry.org/docs/#installing-with-the-official-installer) -Navigate to the project's 01OS directory: +Navigate to the project's software directory: ```bash -cd 01OS +cd software ``` Install your project along with its dependencies in a virtual environment managed by Poetry. diff --git a/docs/server/setup.mdx b/docs/server/setup.mdx index 44804c3d..e9e284a0 100644 --- a/docs/server/setup.mdx +++ b/docs/server/setup.mdx @@ -16,7 +16,7 @@ Open Interpreter is highly configurable and only requires updating a single file ```bash # Edit i.py -01OS/01OS/server/i.py +software/source/server/i.py ``` Properties such as `model`, `context_window`, and many more can be updated here. diff --git a/01OS/.cursorignore b/software/.cursorignore similarity index 100% rename from 01OS/.cursorignore rename to software/.cursorignore diff --git a/01OS/README.md b/software/README.md similarity index 100% rename from 01OS/README.md rename to software/README.md diff --git a/01OS/poetry.lock b/software/poetry.lock similarity index 100% rename from 01OS/poetry.lock rename to software/poetry.lock diff --git a/01OS/pyproject.toml b/software/pyproject.toml similarity index 97% rename from 01OS/pyproject.toml rename to software/pyproject.toml index b74c22f3..e76abae9 100644 --- a/01OS/pyproject.toml +++ b/software/pyproject.toml @@ -1,7 +1,7 @@ [tool.poetry] name = "01OS" packages = [ - {include = "01OS"}, + {include = "source"}, ] include = ["start.py"] version = "0.0.13" diff --git a/software/pytest.ini b/software/pytest.ini new file mode 100644 index 00000000..f8f4f2fa --- /dev/null +++ b/software/pytest.ini @@ -0,0 +1,9 @@ +; Config for Pytest Runner. +; suppress Deprecation Warning and User Warning to not spam the interface, but check periodically +[pytest] +python_files = tests.py test_*.py +filterwarnings = + ignore::UserWarning + ignore::DeprecationWarning +log_cli = true +log_cli_level = INFO diff --git a/01OS/01OS/__init__.py b/software/source/__init__.py similarity index 100% rename from 01OS/01OS/__init__.py rename to software/source/__init__.py diff --git a/01OS/01OS/clients/__init__.py b/software/source/clients/__init__.py similarity index 100% rename from 01OS/01OS/clients/__init__.py rename to software/source/clients/__init__.py diff --git a/01OS/01OS/clients/base_device.py b/software/source/clients/base_device.py similarity index 100% rename from 01OS/01OS/clients/base_device.py rename to software/source/clients/base_device.py diff --git a/01OS/01OS/clients/esp32/README.md b/software/source/clients/esp32/README.md similarity index 100% rename from 01OS/01OS/clients/esp32/README.md rename to software/source/clients/esp32/README.md diff --git a/01OS/01OS/clients/esp32/__init__.py b/software/source/clients/esp32/__init__.py similarity index 100% rename from 01OS/01OS/clients/esp32/__init__.py rename to software/source/clients/esp32/__init__.py diff --git a/01OS/01OS/clients/esp32/src/client/client.ino b/software/source/clients/esp32/src/client/client.ino similarity index 100% rename from 01OS/01OS/clients/esp32/src/client/client.ino rename to software/source/clients/esp32/src/client/client.ino diff --git a/01OS/01OS/clients/esp32/websocket_test.py b/software/source/clients/esp32/websocket_test.py similarity index 100% rename from 01OS/01OS/clients/esp32/websocket_test.py rename to software/source/clients/esp32/websocket_test.py diff --git a/01OS/01OS/clients/linux/__init__.py b/software/source/clients/linux/__init__.py similarity index 100% rename from 01OS/01OS/clients/linux/__init__.py rename to software/source/clients/linux/__init__.py diff --git a/01OS/01OS/clients/linux/device.py b/software/source/clients/linux/device.py similarity index 100% rename from 01OS/01OS/clients/linux/device.py rename to software/source/clients/linux/device.py diff --git a/01OS/01OS/clients/mac/__init__.py b/software/source/clients/mac/__init__.py similarity index 100% rename from 01OS/01OS/clients/mac/__init__.py rename to software/source/clients/mac/__init__.py diff --git a/01OS/01OS/clients/mac/device.py b/software/source/clients/mac/device.py similarity index 100% rename from 01OS/01OS/clients/mac/device.py rename to software/source/clients/mac/device.py diff --git a/01OS/01OS/clients/rpi/__init__.py b/software/source/clients/rpi/__init__.py similarity index 100% rename from 01OS/01OS/clients/rpi/__init__.py rename to software/source/clients/rpi/__init__.py diff --git a/01OS/01OS/clients/rpi/device.py b/software/source/clients/rpi/device.py similarity index 100% rename from 01OS/01OS/clients/rpi/device.py rename to software/source/clients/rpi/device.py diff --git a/01OS/01OS/server/__init__.py b/software/source/server/__init__.py similarity index 100% rename from 01OS/01OS/server/__init__.py rename to software/source/server/__init__.py diff --git a/software/source/server/conftest.py b/software/source/server/conftest.py new file mode 100644 index 00000000..46841945 --- /dev/null +++ b/software/source/server/conftest.py @@ -0,0 +1,19 @@ +import os +import sys +import pytest +from source.server.i import configure_interpreter +from unittest.mock import Mock +from interpreter import OpenInterpreter +from fastapi.testclient import TestClient +from .server import app + + +@pytest.fixture +def client(): + return TestClient(app) + + +@pytest.fixture +def mock_interpreter(): + interpreter = configure_interpreter(OpenInterpreter()) + return interpreter \ No newline at end of file diff --git a/01OS/01OS/server/conversations/another-interpreter.json b/software/source/server/conversations/another-interpreter.json similarity index 100% rename from 01OS/01OS/server/conversations/another-interpreter.json rename to software/source/server/conversations/another-interpreter.json diff --git a/01OS/01OS/server/i.py b/software/source/server/i.py similarity index 100% rename from 01OS/01OS/server/i.py rename to software/source/server/i.py diff --git a/01OS/01OS/server/llm.py b/software/source/server/llm.py similarity index 100% rename from 01OS/01OS/server/llm.py rename to software/source/server/llm.py diff --git a/01OS/01OS/server/server.py b/software/source/server/server.py similarity index 99% rename from 01OS/01OS/server/server.py rename to software/source/server/server.py index 52d5a975..5f9f222f 100644 --- a/01OS/01OS/server/server.py +++ b/software/source/server/server.py @@ -408,7 +408,8 @@ async def main(server_host, server_port, llm_service, model, llm_supports_vision "temperature": temperature }) - module = import_module(f'.server.services.{service}.{service_dict[service]}.{service}', package='01OS') + module = import_module(f'.server.services.{service}.{service_dict[service]}.{service}', package='source') + ServiceClass = getattr(module, service.capitalize()) service_instance = ServiceClass(config) globals()[service] = getattr(service_instance, service) diff --git a/01OS/01OS/server/services/__init__.py b/software/source/server/services/__init__.py similarity index 100% rename from 01OS/01OS/server/services/__init__.py rename to software/source/server/services/__init__.py diff --git a/01OS/01OS/server/services/llm/__init__.py b/software/source/server/services/llm/__init__.py similarity index 100% rename from 01OS/01OS/server/services/llm/__init__.py rename to software/source/server/services/llm/__init__.py diff --git a/01OS/01OS/server/services/llm/litellm/__init__.py b/software/source/server/services/llm/litellm/__init__.py similarity index 100% rename from 01OS/01OS/server/services/llm/litellm/__init__.py rename to software/source/server/services/llm/litellm/__init__.py diff --git a/01OS/01OS/server/services/llm/litellm/llm.py b/software/source/server/services/llm/litellm/llm.py similarity index 100% rename from 01OS/01OS/server/services/llm/litellm/llm.py rename to software/source/server/services/llm/litellm/llm.py diff --git a/01OS/01OS/server/services/llm/llamaedge/__init__.py b/software/source/server/services/llm/llamaedge/__init__.py similarity index 100% rename from 01OS/01OS/server/services/llm/llamaedge/__init__.py rename to software/source/server/services/llm/llamaedge/__init__.py diff --git a/01OS/01OS/server/services/llm/llamaedge/llm.py b/software/source/server/services/llm/llamaedge/llm.py similarity index 100% rename from 01OS/01OS/server/services/llm/llamaedge/llm.py rename to software/source/server/services/llm/llamaedge/llm.py diff --git a/01OS/01OS/server/services/llm/llamafile/__init__.py b/software/source/server/services/llm/llamafile/__init__.py similarity index 100% rename from 01OS/01OS/server/services/llm/llamafile/__init__.py rename to software/source/server/services/llm/llamafile/__init__.py diff --git a/01OS/01OS/server/services/llm/llamafile/llm.py b/software/source/server/services/llm/llamafile/llm.py similarity index 100% rename from 01OS/01OS/server/services/llm/llamafile/llm.py rename to software/source/server/services/llm/llamafile/llm.py diff --git a/01OS/01OS/server/services/stt/__init__.py b/software/source/server/services/stt/__init__.py similarity index 100% rename from 01OS/01OS/server/services/stt/__init__.py rename to software/source/server/services/stt/__init__.py diff --git a/01OS/01OS/server/services/stt/local-whisper/__init__.py b/software/source/server/services/stt/local-whisper/__init__.py similarity index 100% rename from 01OS/01OS/server/services/stt/local-whisper/__init__.py rename to software/source/server/services/stt/local-whisper/__init__.py diff --git a/01OS/01OS/server/services/stt/local-whisper/stt.py b/software/source/server/services/stt/local-whisper/stt.py similarity index 100% rename from 01OS/01OS/server/services/stt/local-whisper/stt.py rename to software/source/server/services/stt/local-whisper/stt.py diff --git a/01OS/01OS/server/services/stt/local-whisper/whisper-rust/.gitignore b/software/source/server/services/stt/local-whisper/whisper-rust/.gitignore similarity index 100% rename from 01OS/01OS/server/services/stt/local-whisper/whisper-rust/.gitignore rename to software/source/server/services/stt/local-whisper/whisper-rust/.gitignore diff --git a/01OS/01OS/server/services/stt/local-whisper/whisper-rust/Cargo.lock b/software/source/server/services/stt/local-whisper/whisper-rust/Cargo.lock similarity index 100% rename from 01OS/01OS/server/services/stt/local-whisper/whisper-rust/Cargo.lock rename to software/source/server/services/stt/local-whisper/whisper-rust/Cargo.lock diff --git a/01OS/01OS/server/services/stt/local-whisper/whisper-rust/Cargo.toml b/software/source/server/services/stt/local-whisper/whisper-rust/Cargo.toml similarity index 100% rename from 01OS/01OS/server/services/stt/local-whisper/whisper-rust/Cargo.toml rename to software/source/server/services/stt/local-whisper/whisper-rust/Cargo.toml diff --git a/01OS/01OS/server/services/stt/local-whisper/whisper-rust/src/main.rs b/software/source/server/services/stt/local-whisper/whisper-rust/src/main.rs similarity index 100% rename from 01OS/01OS/server/services/stt/local-whisper/whisper-rust/src/main.rs rename to software/source/server/services/stt/local-whisper/whisper-rust/src/main.rs diff --git a/01OS/01OS/server/services/stt/local-whisper/whisper-rust/src/transcribe.rs b/software/source/server/services/stt/local-whisper/whisper-rust/src/transcribe.rs similarity index 100% rename from 01OS/01OS/server/services/stt/local-whisper/whisper-rust/src/transcribe.rs rename to software/source/server/services/stt/local-whisper/whisper-rust/src/transcribe.rs diff --git a/01OS/01OS/server/services/stt/openai/__init__.py b/software/source/server/services/stt/openai/__init__.py similarity index 100% rename from 01OS/01OS/server/services/stt/openai/__init__.py rename to software/source/server/services/stt/openai/__init__.py diff --git a/01OS/01OS/server/services/stt/openai/stt.py b/software/source/server/services/stt/openai/stt.py similarity index 100% rename from 01OS/01OS/server/services/stt/openai/stt.py rename to software/source/server/services/stt/openai/stt.py diff --git a/01OS/01OS/server/services/tts/__init__.py b/software/source/server/services/tts/__init__.py similarity index 100% rename from 01OS/01OS/server/services/tts/__init__.py rename to software/source/server/services/tts/__init__.py diff --git a/01OS/01OS/server/services/tts/openai/__init__.py b/software/source/server/services/tts/openai/__init__.py similarity index 100% rename from 01OS/01OS/server/services/tts/openai/__init__.py rename to software/source/server/services/tts/openai/__init__.py diff --git a/01OS/01OS/server/services/tts/openai/tts.py b/software/source/server/services/tts/openai/tts.py similarity index 100% rename from 01OS/01OS/server/services/tts/openai/tts.py rename to software/source/server/services/tts/openai/tts.py diff --git a/01OS/01OS/server/services/tts/piper/__init__.py b/software/source/server/services/tts/piper/__init__.py similarity index 100% rename from 01OS/01OS/server/services/tts/piper/__init__.py rename to software/source/server/services/tts/piper/__init__.py diff --git a/01OS/01OS/server/services/tts/piper/tts.py b/software/source/server/services/tts/piper/tts.py similarity index 100% rename from 01OS/01OS/server/services/tts/piper/tts.py rename to software/source/server/services/tts/piper/tts.py diff --git a/01OS/01OS/server/skills/__init__.py b/software/source/server/skills/__init__.py similarity index 100% rename from 01OS/01OS/server/skills/__init__.py rename to software/source/server/skills/__init__.py diff --git a/01OS/01OS/server/skills/schedule.py b/software/source/server/skills/schedule.py similarity index 100% rename from 01OS/01OS/server/skills/schedule.py rename to software/source/server/skills/schedule.py diff --git a/01OS/01OS/server/system_messages/BaseSystemMessage.py b/software/source/server/system_messages/BaseSystemMessage.py similarity index 100% rename from 01OS/01OS/server/system_messages/BaseSystemMessage.py rename to software/source/server/system_messages/BaseSystemMessage.py diff --git a/01OS/01OS/server/system_messages/TeachModeSystemMessage.py b/software/source/server/system_messages/TeachModeSystemMessage.py similarity index 100% rename from 01OS/01OS/server/system_messages/TeachModeSystemMessage.py rename to software/source/server/system_messages/TeachModeSystemMessage.py diff --git a/01OS/01OS/server/system_messages/__init__.py b/software/source/server/system_messages/__init__.py similarity index 100% rename from 01OS/01OS/server/system_messages/__init__.py rename to software/source/server/system_messages/__init__.py diff --git a/01OS/01OS/server/utils/__init__.py b/software/source/server/tests/__init__.py similarity index 100% rename from 01OS/01OS/server/utils/__init__.py rename to software/source/server/tests/__init__.py diff --git a/software/source/server/tests/test_run.py b/software/source/server/tests/test_run.py new file mode 100644 index 00000000..823444bc --- /dev/null +++ b/software/source/server/tests/test_run.py @@ -0,0 +1,41 @@ +# test_main.py +import subprocess +import uuid +import pytest +from source.server.i import configure_interpreter +from unittest.mock import Mock +from fastapi.testclient import TestClient + + + +@pytest.mark.asyncio +def test_ping(client): + response = client.get("/ping") + assert response.status_code == 200 + assert response.text == "pong" + + +def test_interpreter_chat(mock_interpreter): + # Set up a sample conversation + messages = [ + {"role": "user", "type": "message", "content": "Hello."}, + {"role": "assistant", "type": "message", "content": "Hi there!"}, + # Add more messages as needed + ] + + # Configure the mock interpreter with the sample conversation + mock_interpreter.messages = messages + + # Simulate additional user input + user_input = {"role": "user", "type": "message", "content": "How are you?"} + mock_interpreter.chat([user_input]) + + # Ensure the interpreter processed the user input + assert len(mock_interpreter.messages) == len(messages) + assert mock_interpreter.messages[-1]["role"] == "assistant" + assert "don't have feelings" in mock_interpreter.messages[-1]["content"] + +def test_interpreter_configuration(mock_interpreter): + # Test interpreter configuration + interpreter = configure_interpreter(mock_interpreter) + assert interpreter is not None \ No newline at end of file diff --git a/01OS/01OS/server/tunnel.py b/software/source/server/tunnel.py similarity index 100% rename from 01OS/01OS/server/tunnel.py rename to software/source/server/tunnel.py diff --git a/01OS/tests/__init__.py b/software/source/server/utils/__init__.py similarity index 100% rename from 01OS/tests/__init__.py rename to software/source/server/utils/__init__.py diff --git a/01OS/01OS/server/utils/bytes_to_wav.py b/software/source/server/utils/bytes_to_wav.py similarity index 100% rename from 01OS/01OS/server/utils/bytes_to_wav.py rename to software/source/server/utils/bytes_to_wav.py diff --git a/01OS/01OS/server/utils/get_system_info.py b/software/source/server/utils/get_system_info.py similarity index 100% rename from 01OS/01OS/server/utils/get_system_info.py rename to software/source/server/utils/get_system_info.py diff --git a/01OS/01OS/server/utils/kernel.py b/software/source/server/utils/kernel.py similarity index 100% rename from 01OS/01OS/server/utils/kernel.py rename to software/source/server/utils/kernel.py diff --git a/01OS/01OS/server/utils/logs.py b/software/source/server/utils/logs.py similarity index 100% rename from 01OS/01OS/server/utils/logs.py rename to software/source/server/utils/logs.py diff --git a/01OS/01OS/server/utils/process_utils.py b/software/source/server/utils/process_utils.py similarity index 100% rename from 01OS/01OS/server/utils/process_utils.py rename to software/source/server/utils/process_utils.py diff --git a/01OS/01OS/utils/accumulator.py b/software/source/utils/accumulator.py similarity index 100% rename from 01OS/01OS/utils/accumulator.py rename to software/source/utils/accumulator.py diff --git a/01OS/01OS/utils/print_markdown.py b/software/source/utils/print_markdown.py similarity index 100% rename from 01OS/01OS/utils/print_markdown.py rename to software/source/utils/print_markdown.py diff --git a/01OS/start.py b/software/start.py similarity index 96% rename from 01OS/start.py rename to software/start.py index f7da8438..d6cbaf42 100644 --- a/01OS/start.py +++ b/software/start.py @@ -5,7 +5,9 @@ import threading import os import importlib -create_tunnel = importlib.import_module(".server.tunnel", package="01OS").create_tunnel +from source.server.tunnel import create_tunnel +from source.server.server import main + import signal app = typer.Typer() @@ -105,7 +107,6 @@ def handle_exit(signum, frame): signal.signal(signal.SIGINT, handle_exit) if server: - main = importlib.import_module(".server.server", package="01OS").main loop = asyncio.new_event_loop() asyncio.set_event_loop(loop) server_thread = threading.Thread(target=loop.run_until_complete, args=(main(server_host, server_port, llm_service, model, llm_supports_vision, llm_supports_functions, context_window, max_tokens, temperature, tts_service, stt_service),)) @@ -130,7 +131,7 @@ def handle_exit(signum, frame): except FileNotFoundError: client_type = "linux" - module = importlib.import_module(f".clients.{client_type}.device", package='01OS') + module = importlib.import_module(f".clients.{client_type}.device", package='source') client_thread = threading.Thread(target=module.main, args=[server_url]) client_thread.start()