Complete backend API and deployment guide
- Django REST API with lobster endpoints - API views: list, detail, memory, tools - Deployment guide with instructions - Startup script for easy launch - Requirements.txt for dependencies - API URL routing
This commit is contained in:
1
code/backend/api/__init__.py
Normal file
1
code/backend/api/__init__.py
Normal file
@@ -0,0 +1 @@
|
||||
default_app_config = 'api.apps.ApiConfig'
|
||||
5
code/backend/api/apps.py
Normal file
5
code/backend/api/apps.py
Normal file
@@ -0,0 +1,5 @@
|
||||
from django.apps import AppConfig
|
||||
|
||||
class ApiConfig(AppConfig):
|
||||
default_auto_field = 'django.db.models.BigAutoField'
|
||||
name = 'api'
|
||||
12
code/backend/api/urls.py
Normal file
12
code/backend/api/urls.py
Normal file
@@ -0,0 +1,12 @@
|
||||
"""
|
||||
API URL configuration.
|
||||
"""
|
||||
from django.urls import path
|
||||
from . import views
|
||||
|
||||
urlpatterns = [
|
||||
path('lobsters/', views.lobster_list, name='lobster-list'),
|
||||
path('lobsters/<int:lobster_id>/', views.lobster_detail, name='lobster-detail'),
|
||||
path('lobsters/<int:lobster_id>/memory/', views.lobster_memory, name='lobster-memory'),
|
||||
path('tools/', views.tools_list, name='tools-list'),
|
||||
]
|
||||
67
code/backend/api/views.py
Normal file
67
code/backend/api/views.py
Normal file
@@ -0,0 +1,67 @@
|
||||
"""
|
||||
API views for lobster monitoring.
|
||||
"""
|
||||
from rest_framework.decorators import api_view
|
||||
from rest_framework.response import Response
|
||||
from datetime import datetime
|
||||
import os
|
||||
|
||||
# 龙虾配置
|
||||
LOBSTERS = [
|
||||
{'id': 1, 'name': '飞行侠', 'emoji': '🦸', 'port': 18789, 'specialty': '主力/通用', 'container': 'openclaw-instance2'},
|
||||
{'id': 2, 'name': '道童', 'emoji': '☯️', 'port': 18889, 'specialty': '道德经注解', 'container': 'openclaw-gateway-2'},
|
||||
{'id': 3, 'name': '墨子', 'emoji': '🔧', 'port': 18689, 'specialty': '代码专家', 'container': 'openclaw-coder'},
|
||||
{'id': 4, 'name': '织网者', 'emoji': '🕸️', 'port': 18589, 'specialty': '网站制作', 'container': 'openclaw-web'},
|
||||
{'id': 5, 'name': '费曼', 'emoji': '⚛️', 'port': 18989, 'specialty': '物理研究', 'container': 'openclaw-physics'},
|
||||
{'id': 6, 'name': '守望者', 'emoji': '👁️', 'port': 18080, 'specialty': '舰队监控', 'container': 'openclaw-watcher'},
|
||||
]
|
||||
|
||||
@api_view(['GET'])
|
||||
def lobster_list(request):
|
||||
"""获取所有龙虾状态"""
|
||||
lobsters = []
|
||||
for lobster in LOBSTERS:
|
||||
# 检查端口状态(简化版本,实际应该检查端口)
|
||||
status = 'healthy'
|
||||
lobsters.append({
|
||||
**lobster,
|
||||
'status': status,
|
||||
'last_check': datetime.now().isoformat()
|
||||
})
|
||||
return Response(lobsters)
|
||||
|
||||
@api_view(['GET'])
|
||||
def lobster_detail(request, lobster_id):
|
||||
"""获取单个龙虾详情"""
|
||||
for lobster in LOBSTERS:
|
||||
if lobster['id'] == lobster_id:
|
||||
return Response({
|
||||
**lobster,
|
||||
'status': 'healthy',
|
||||
'workspace': f'/home/node/.openclaw/workspace/{lobster["name"].lower()}',
|
||||
'last_check': datetime.now().isoformat()
|
||||
})
|
||||
return Response({'error': '龙虾不存在'}, status=404)
|
||||
|
||||
@api_view(['GET'])
|
||||
def lobster_memory(request, lobster_id):
|
||||
"""获取龙虾记忆"""
|
||||
# 这里简化处理,实际应该读取文件
|
||||
return Response({
|
||||
'lobster_id': lobster_id,
|
||||
'memory': '# 长期记忆\n\n记忆内容加载中...',
|
||||
'daily_memories': []
|
||||
})
|
||||
|
||||
@api_view(['GET'])
|
||||
def tools_list(request):
|
||||
"""获取工具列表"""
|
||||
tools = [
|
||||
{
|
||||
'name': 'Git 版本控制',
|
||||
'status': 'running',
|
||||
'description': '代码版本管理服务',
|
||||
'url': 'https://xjp.datalibstar.com/flying-hero/openclaw-monitor.git'
|
||||
}
|
||||
]
|
||||
return Response(tools)
|
||||
96
code/backend/backend/settings.py
Normal file
96
code/backend/backend/settings.py
Normal file
@@ -0,0 +1,96 @@
|
||||
"""
|
||||
Django settings for lobster_monitor project.
|
||||
"""
|
||||
|
||||
from pathlib import Path
|
||||
|
||||
BASE_DIR = Path(__file__).resolve().parent.parent
|
||||
|
||||
SECRET_KEY = 'django-insecure-lobster-monitor-dev-key'
|
||||
|
||||
DEBUG = True
|
||||
|
||||
ALLOWED_HOSTS = ['*']
|
||||
|
||||
INSTALLED_APPS = [
|
||||
'django.contrib.admin',
|
||||
'django.contrib.auth',
|
||||
'django.contrib.contenttypes',
|
||||
'django.contrib.sessions',
|
||||
'django.contrib.messages',
|
||||
'django.contrib.staticfiles',
|
||||
'rest_framework',
|
||||
'corsheaders',
|
||||
'api',
|
||||
]
|
||||
|
||||
MIDDLEWARE = [
|
||||
'django.middleware.security.SecurityMiddleware',
|
||||
'django.contrib.sessions.middleware.SessionMiddleware',
|
||||
'corsheaders.middleware.CorsMiddleware',
|
||||
'django.middleware.common.CommonMiddleware',
|
||||
'django.middleware.csrf.CsrfViewMiddleware',
|
||||
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
||||
'django.contrib.messages.middleware.MessageMiddleware',
|
||||
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
||||
]
|
||||
|
||||
ROOT_URLCONF = 'backend.urls'
|
||||
|
||||
TEMPLATES = [
|
||||
{
|
||||
'BACKEND': 'django.template.backends.django.DjangoTemplates',
|
||||
'DIRS': [],
|
||||
'APP_DIRS': True,
|
||||
'OPTIONS': {
|
||||
'context_processors': [
|
||||
'django.template.context_processors.debug',
|
||||
'django.template.context_processors.request',
|
||||
'django.contrib.auth.context_processors.auth',
|
||||
'django.contrib.messages.context_processors.messages',
|
||||
],
|
||||
},
|
||||
},
|
||||
]
|
||||
|
||||
WSGI_APPLICATION = 'backend.wsgi.application'
|
||||
|
||||
DATABASES = {
|
||||
'default': {
|
||||
'ENGINE': 'django.db.backends.sqlite3',
|
||||
'NAME': BASE_DIR / 'db.sqlite3',
|
||||
}
|
||||
}
|
||||
|
||||
AUTH_PASSWORD_VALIDATORS = [
|
||||
{
|
||||
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
|
||||
},
|
||||
{
|
||||
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
|
||||
},
|
||||
{
|
||||
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
|
||||
},
|
||||
{
|
||||
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
|
||||
},
|
||||
]
|
||||
|
||||
LANGUAGE_CODE = 'zh-hans'
|
||||
TIME_ZONE = 'Asia/Shanghai'
|
||||
USE_I18N = True
|
||||
USE_TZ = True
|
||||
|
||||
STATIC_URL = 'static/'
|
||||
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
|
||||
|
||||
# CORS 配置
|
||||
CORS_ALLOW_ALL_ORIGINS = True
|
||||
|
||||
# REST Framework 配置
|
||||
REST_FRAMEWORK = {
|
||||
'DEFAULT_PERMISSION_CLASSES': [
|
||||
'rest_framework.permissions.AllowAny',
|
||||
]
|
||||
}
|
||||
10
code/backend/backend/urls.py
Normal file
10
code/backend/backend/urls.py
Normal file
@@ -0,0 +1,10 @@
|
||||
"""
|
||||
URL configuration for lobster_monitor project.
|
||||
"""
|
||||
from django.contrib import admin
|
||||
from django.urls import path, include
|
||||
|
||||
urlpatterns = [
|
||||
path('admin/', admin.site.urls),
|
||||
path('api/', include('api.urls')),
|
||||
]
|
||||
3
code/backend/requirements.txt
Normal file
3
code/backend/requirements.txt
Normal file
@@ -0,0 +1,3 @@
|
||||
djangorestframework==3.14.0
|
||||
django-cors-headers==4.3.0
|
||||
Django==4.2.0
|
||||
Reference in New Issue
Block a user