btnaughton
btnaughton
Mmarimo
Created by btnaughton on 1/8/2025 in #help-support
Serving multiple marimo apps on the same fastapi app
I foolishly returned to this problem and burned a couple of hours failing to get the websockets to authenticate. Posting here on the off chance someone sees an obvious problem! I think this version is probably the closest to working(?), but there's extra cruft in here too compared to other versions I tested. In other words, I very likely tested it without each individual function too.
7 replies
Mmarimo
Created by btnaughton on 1/8/2025 in #help-support
Serving multiple marimo apps on the same fastapi app
I had a pretty decent stab at this but I could not get the websocket stuff to work. There is a nice library that in theory should be exactly what is needed https://github.com/WSH032/fastapi-proxy-lib?tab=readme-ov-file but even my minimal code fails, so i gave up for now!
import uvicorn
from fastapi_proxy_lib.fastapi.app import reverse_http_app
app = reverse_http_app(base_url="http://localhost:8001/")
if __name__ == "__main__":
uvicorn.run(app, host="127.0.0.1", port=8000)
import uvicorn
from fastapi_proxy_lib.fastapi.app import reverse_http_app
app = reverse_http_app(base_url="http://localhost:8001/")
if __name__ == "__main__":
uvicorn.run(app, host="127.0.0.1", port=8000)
7 replies
Mmarimo
Created by btnaughton on 1/8/2025 in #help-support
Serving multiple marimo apps on the same fastapi app
thanks! i am now looking at spawning a marimo run --sandbox when the url is hit, and then using fastapi to proxy that port? i can't tell how janky that will be but i think it should work? i love sandbox and i think conflicts are unfortunately inevitable with bioinformatics tools!
7 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
thanks again
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
got it -- good to know the asgi app is run only
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
also i don't see how to edit the code, but i think that's just basic misunderstanding of marimo!
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
spoke a bit too soon, it dies after a few minutes, with a 401, so i assume it's changing containers or just dropping i tihnk that should be fixable with some kind of timeout or keep_warm or similar at some point modal has to disconnect or it's just a server...
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
ok as far as i can tell it's working 🎈 thanks!!
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
allow_concurrent_inputs=2, seems to fix it??
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
Ah....... thanks! I never would have thought of this. I am seeing the same thing, some kind of blockage. I do not see the POST /api/kernel/instantiate request any more for some reason so maybe it's getting stuck here. Thanks for unsticking me, I'll poke at it more now.
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
also you may be interested that the modal guys are "considering using marimo internally"
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
Thanks! I would be ashamed to admit how much time i've spent trying to get an AI to help figure out authentication here.....
27 replies
Mmarimo
Created by btnaughton on 8/28/2024 in #help-support
running marimo on modal
Here is some example middleware code where I am trying to allow everything (note this is one of several attempts. There is no authorization in the header, but there is marimo-server-token . I can try turning on and off the auth_header check, edit the headers, etc. and no matter how permissive I try to make it, I get the same 401):
def auth_middleware(app):
async def middleware(scope, receive, send):
if scope['type'] == 'http':
headers = dict(scope['headers'])
auth_header = headers.get(b'authorization', b'').decode()
expected_auth = f"Bearer {TOKEN}"

if auth_header != expected_auth:
print(f"Authentication failed. Expected: {expected_auth}, Got: {auth_header}")
await send({
'type': 'http.response.start',
'status': 401,
'headers': [(b'content-type', b'text/plain')]
})
await send({
'type': 'http.response.body',
'body': b'Unauthorized\n'
})
return
await app(scope, receive, send)

return middleware
def auth_middleware(app):
async def middleware(scope, receive, send):
if scope['type'] == 'http':
headers = dict(scope['headers'])
auth_header = headers.get(b'authorization', b'').decode()
expected_auth = f"Bearer {TOKEN}"

if auth_header != expected_auth:
print(f"Authentication failed. Expected: {expected_auth}, Got: {auth_header}")
await send({
'type': 'http.response.start',
'status': 401,
'headers': [(b'content-type', b'text/plain')]
})
await send({
'type': 'http.response.body',
'body': b'Unauthorized\n'
})
return
await app(scope, receive, send)

return middleware
27 replies