Skip to content

Commit

Permalink
Merge branch 'main' of github.com:amun-ai/hypha
Browse files Browse the repository at this point in the history
  • Loading branch information
oeway committed Dec 18, 2024
2 parents 2cf2f3c + f6670f0 commit 2f6e752
Show file tree
Hide file tree
Showing 17 changed files with 36 additions and 26 deletions.
1 change: 1 addition & 0 deletions docs/_sidebar.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,5 @@
* [Launch Service](/launch-service)
* [Operate Files](/operate-files)
* [Artifact Manager](/artifact-manager)
* [Vector Search](/vector-search)
* [Development](/development)
8 changes: 4 additions & 4 deletions docs/getting-started.md
Original file line number Diff line number Diff line change
Expand Up @@ -220,7 +220,7 @@ svc = await get_remote_service("http://localhost:9527/ws-user-scintillating-lawy
Include the following script in your HTML file to load the `hypha-rpc` client:

```html
<script src="https://cdn.jsdelivr.net/npm/[email protected].42/dist/hypha-rpc-websocket.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected].44/dist/hypha-rpc-websocket.min.js"></script>
```

Use the following code in JavaScript to connect to the server and access an existing service:
Expand Down Expand Up @@ -445,13 +445,13 @@ async def start_server(server_url):
# Replace this with your own liveness check
return {"status": "ok"}

# Register a probe for the service
await server.register_probe({
# Register probes for the service
await server.register_probes({
"readiness": check_readiness,
"liveness": check_liveness,
})

# This will register a "probes" service where you can accessed via hypha or the HTTP proxy
# This will register probes service where you can accessed via hypha or the HTTP proxy
print(f"Probes registered at workspace: {server.config.workspace}")
print(f"Test it with the HTTP proxy: {server_url}/{server.config.workspace}/services/probes/readiness")

Expand Down
10 changes: 5 additions & 5 deletions docs/migration-guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ To connect to the server, instead of installing the `imjoy-rpc` module, you will
pip install -U hypha-rpc # new install
```

We also changed our versioning strategy, we use the same version number for the server and client, so it's easier to match the client and server versions. For example, `hypha-rpc` version `0.20.42` is compatible with Hypha server version `0.20.42`.
We also changed our versioning strategy, we use the same version number for the server and client, so it's easier to match the client and server versions. For example, `hypha-rpc` version `0.20.44` is compatible with Hypha server version `0.20.44`.

#### 2. Change the imports to use `hypha-rpc`

Expand Down Expand Up @@ -128,10 +128,10 @@ loop.run_forever()
To connect to the server, instead of using the `imjoy-rpc` module, you will need to use the `hypha-rpc` module. The `hypha-rpc` module is a standalone module that provides the RPC connection to the Hypha server. You can include it in your HTML using a script tag:

```html
<script src="https://cdn.jsdelivr.net/npm/[email protected].42/dist/hypha-rpc-websocket.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected].44/dist/hypha-rpc-websocket.min.js"></script>
```

We also changed our versioning strategy, we use the same version number for the server and client, so it's easier to match the client and server versions. For example, `hypha-rpc` version `0.20.42` is compatible with Hypha server version `0.20.42`.
We also changed our versioning strategy, we use the same version number for the server and client, so it's easier to match the client and server versions. For example, `hypha-rpc` version `0.20.44` is compatible with Hypha server version `0.20.44`.

#### 2. Change the connection method and use camelCase for service function names

Expand All @@ -149,7 +149,7 @@ Here is a suggested list of search and replace operations to update your code:
Here is an example of how the updated code might look:

```html
<script src="https://cdn.jsdelivr.net/npm/[email protected].42/dist/hypha-rpc-websocket.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected].44/dist/hypha-rpc-websocket.min.js"></script>
<script>
async function main(){
const server = await hyphaWebsocketClient.connectToServer({"server_url": "https://hypha.amun.ai"});
Expand Down Expand Up @@ -197,7 +197,7 @@ We created a tutorial to introduce this new feature: [service type annotation](.
Here is a quick example in JavaScript:

```html
<script src="https://cdn.jsdelivr.net/npm/[email protected].42/dist/hypha-rpc-websocket.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected].44/dist/hypha-rpc-websocket.min.js"></script>

<script>
async function main(){
Expand Down
2 changes: 1 addition & 1 deletion docs/service-type-annotation.md
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ if __name__ == "__main__":
**JavaScript Client: Service Usage**

```html
<script src="https://cdn.jsdelivr.net/npm/[email protected].42/dist/hypha-rpc-websocket.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected].44/dist/hypha-rpc-websocket.min.js"></script>
<script>
async function main() {
const server = await hyphaWebsocketClient.connectToServer({"server_url": "https://hypha.amun.ai"});
Expand Down
2 changes: 1 addition & 1 deletion docs/rag.md → docs/vector-search.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Tutorial: Using Vector Collections for Retrieval-Augmented Generation
# Tutorial: Vector Search for Retrieval-Augmented Generation

Vector collections are a powerful feature in the `Artifact Manager`, enabling the efficient management and querying of high-dimensional data, such as embeddings for text, images, or other data types. These collections are especially useful in advanced applications like Retrieval-Augmented Generation (RAG) systems.

Expand Down
2 changes: 1 addition & 1 deletion helm-charts/aks-hypha.md
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,7 @@ replicaCount: 1
image:
repository: ghcr.io/amun-ai/hypha
pullPolicy: IfNotPresent
tag: "0.20.42"
tag: "0.20.44"
serviceAccount:
create: true
Expand Down
2 changes: 1 addition & 1 deletion helm-charts/hypha-server/Chart.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ type: application
# This is the chart version. This version number should be incremented each time you make changes
# to the chart and its templates, including the app version.
# Versions are expected to follow Semantic Versioning (https://semver.org/)
version: 0.20.42
version: 0.20.44

# This is the version number of the application being deployed. This version number should be
# incremented each time you make changes to the application. Versions are not expected to
Expand Down
2 changes: 1 addition & 1 deletion helm-charts/hypha-server/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ image:
repository: ghcr.io/amun-ai/hypha
pullPolicy: IfNotPresent
# Overrides the image tag whose default is the chart appVersion.
tag: "0.20.42"
tag: "0.20.44"

imagePullSecrets: []
nameOverride: ""
Expand Down
2 changes: 1 addition & 1 deletion hypha/VERSION
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
{
"version": "0.20.42"
"version": "0.20.44"
}
3 changes: 2 additions & 1 deletion hypha/core/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ class StatusEnum(str, Enum):
class ServiceConfig(BaseModel):
"""Represent service config."""

model_config = ConfigDict(extra="allow")
model_config = ConfigDict(extra="allow", use_enum_values=False)

visibility: VisibilityEnum = VisibilityEnum.protected
require_context: Union[Tuple[str], List[str], bool] = False
Expand Down Expand Up @@ -688,6 +688,7 @@ async def stop(self):
async def _subscribe_redis(self):
cpu_count = os.cpu_count() or 1
concurrent_tasks = cpu_count * 10
logger.info(f"Starting Redis event bus with {concurrent_tasks} concurrent task processing")
pubsub = self._redis.pubsub()
self._stop = False
semaphore = asyncio.Semaphore(concurrent_tasks) # Limit concurrent tasks
Expand Down
15 changes: 11 additions & 4 deletions hypha/core/workspace.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
TokenConfig,
UserPermission,
ServiceTypeInfo,
VisibilityEnum,
)
from hypha.vectors import VectorSearchEngine
from hypha.core.auth import generate_presigned_token, create_scope, valid_token
Expand Down Expand Up @@ -1159,7 +1160,8 @@ async def register_service(
return
# Check if the service already exists
service_exists = await self._redis.keys(f"services:*|*:{service.id}@*")
key = f"services:{service.config.visibility.value}|{service.type}:{service.id}@{service.app_id}"
visibility = service.config.visibility.value if isinstance(service.config.visibility, VisibilityEnum) else service.config.visibility
key = f"services:{visibility}|{service.type}:{service.id}@{service.app_id}"

if service_exists:
# remove all the existing services
Expand Down Expand Up @@ -1315,7 +1317,8 @@ async def unregister_service(
assert ":" in service.id, "Service id info must contain ':'"
service.app_id = service.app_id or "*"
service.type = service.type or "*"
key = f"services:{service.config.visibility.value}|{service.type}:{service.id}@{service.app_id}"
visibility = service.config.visibility.value if isinstance(service.config.visibility, VisibilityEnum) else service.config.visibility
key = f"services:{visibility}|{service.type}:{service.id}@{service.app_id}"

# Check if the service exists before removal
service_keys = await self._redis.keys(key)
Expand Down Expand Up @@ -1758,6 +1761,11 @@ async def unload(self, context=None):
logger.warning(f"Workspace {ws} has already been unloaded.")
return
winfo = await self.load_workspace_info(ws)
# Mark the workspace as not ready
winfo.status = None
await self._redis.hset(
"workspaces", winfo.id, winfo.model_dump_json()
)
# list all the clients in the workspace and send a meesage to delete them
client_keys = await self._list_client_keys(winfo.id)
if len(client_keys) > 0:
Expand All @@ -1771,8 +1779,7 @@ async def unload(self, context=None):
)
await self._event_bus.emit(f"unload:{ws}", "Unloading workspace: " + ws)

# Mark the workspace as not ready
winfo.status = None


if not winfo.persistent:
# delete all the items in redis starting with `workspaces_name:`
Expand Down
2 changes: 1 addition & 1 deletion hypha/templates/hypha-core-app/hypha-app-webpython.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ loadPyodide().then(async (pyodide) => {
pyodide.setStderr({ batched: (msg) => console.error(msg) });
await pyodide.loadPackage("micropip");
const micropip = pyodide.pyimport("micropip");
await micropip.install('hypha-rpc==0.20.42');
await micropip.install('hypha-rpc==0.20.44');
const isWindow = typeof window !== "undefined";

setTimeout(() => {
Expand Down
2 changes: 1 addition & 1 deletion hypha/templates/ws/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,7 @@
<body class="bg-black text-white font-poppins">
<div id="app"></div>
<script type="module">
import { HyphaCore } from "https://cdn.jsdelivr.net/npm/[email protected].42/dist/hypha-core.mjs";
import { HyphaCore } from "https://cdn.jsdelivr.net/npm/[email protected].44/dist/hypha-core.mjs";

const defaultService = {
getServerConfig(context){
Expand Down
2 changes: 1 addition & 1 deletion hypha/websocket.py
Original file line number Diff line number Diff line change
Expand Up @@ -366,7 +366,7 @@ async def handle_disconnection(
finally:
await self.disconnect(
websocket,
"Client disconnected",
f"Client {workspace}/{client_id} disconnected",
code,
)

Expand Down
2 changes: 1 addition & 1 deletion requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ aiofiles==23.2.1
websockets==13.1
base58==2.1.1
fastapi==0.106.0
hypha-rpc==0.20.42
hypha-rpc==0.20.44
jinja2==3.1.4
lxml==4.9.3
msgpack==1.0.8
Expand Down
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
REQUIREMENTS = [
"aiofiles",
"fastapi>=0.70.0,<=0.106.0",
"hypha-rpc>=0.20.42",
"hypha-rpc>=0.20.44",
"msgpack>=1.0.2",
"numpy",
"pydantic[email]>=2.6.1",
Expand Down
3 changes: 2 additions & 1 deletion tests/test_vectors.py
Original file line number Diff line number Diff line change
Expand Up @@ -438,7 +438,8 @@ async def test_load_dump_vector_collections(
artifact_id=vector_collection.id,
vectors=vectors,
)
await asyncio.sleep(10)
await api.disconnect()
await asyncio.sleep(6)
async with connect_to_server(
{
"name": "test deploy client",
Expand Down

0 comments on commit 2f6e752

Please sign in to comment.