Skip to content

Commit

Permalink
missed
Browse files Browse the repository at this point in the history
  • Loading branch information
hinthornw committed Dec 19, 2024
1 parent fbd3b67 commit d90f691
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 21 deletions.
8 changes: 4 additions & 4 deletions docs/docs/how-tos/auth/custom_auth.md
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ Assuming you are using JWT token authentication, you could access your deploymen
url="http://localhost:2024",
headers={"Authorization": f"Bearer {my_token}"}
)
threads = await client.threads.list()
threads = await client.threads.search()
```

=== "Python RemoteGraph"
Expand All @@ -96,7 +96,7 @@ Assuming you are using JWT token authentication, you could access your deploymen
url="http://localhost:2024",
headers={"Authorization": f"Bearer {my_token}"}
)
threads = await remote_graph.threads.list()
threads = await remote_graph.ainvoke(...)
```

=== "JavaScript Client"
Expand All @@ -109,7 +109,7 @@ Assuming you are using JWT token authentication, you could access your deploymen
apiUrl: "http://localhost:2024",
headers: { Authorization: `Bearer ${my_token}` },
});
const threads = await client.threads.list();
const threads = await client.threads.search();
```

=== "JavaScript RemoteGraph"
Expand All @@ -123,7 +123,7 @@ Assuming you are using JWT token authentication, you could access your deploymen
url: "http://localhost:2024",
headers: { Authorization: `Bearer ${my_token}` },
});
const threads = await remoteGraph.threads.list();
const threads = await remoteGraph.invoke(...);
```

=== "CURL"
Expand Down
20 changes: 3 additions & 17 deletions docs/docs/tutorials/auth/resource_auth.md
Original file line number Diff line number Diff line change
Expand Up @@ -134,8 +134,8 @@ await bob.runs.create(
print(f"✅ Bob created his own thread: {bob_thread['thread_id']}")

# List threads - each user only sees their own
alice_threads = await alice.threads.list()
bob_threads = await bob.threads.list()
alice_threads = await alice.threads.search()
bob_threads = await bob.threads.search()
print(f"✅ Alice sees {len(alice_threads)} thread")
print(f"✅ Bob sees {len(bob_threads)} thread")
```
Expand Down Expand Up @@ -201,19 +201,6 @@ async def on_thread_read(
"""
return {"owner": ctx.user.identity}

@auth.on.threads.create_run
async def on_run_create(
ctx: Auth.types.AuthContext,
value: Auth.types.on.threads.create_run.value,
):
"""Only let thread owners create runs.
This handler runs when creating runs on a thread. The filter
applies to the parent thread, not the run being created.
This ensures only thread owners can create runs on their threads.
"""
return {"owner": ctx.user.identity}

@auth.on.assistants
async def on_assistants(
ctx: Auth.types.AuthContext,
Expand All @@ -231,8 +218,7 @@ Notice that instead of one global handler, we now have specific handlers for:

1. Creating threads
2. Reading threads
3. Creating runs
4. Accessing assistants
3. Accessing assistants

The first three of these match specific **actions** on each resource (see [resource actions](../../concepts/auth.md#resource-actions)), while the last one (`@auth.on.assistants`) matches _any_ action on the `assistants` resource. For each request, LangGraph will run the most specific handler that matches the resource and action being accessed. This means that the four handlers above will run rather than the broadly scoped "`@auth.on`" handler.

Expand Down

0 comments on commit d90f691

Please sign in to comment.