モード機能

注意

モード機能は実験的機能のため、正式版では仕様が変更される可能性があります

概要

モード (mode) 機能 は、指定されているモードごとに Sora の挙動を変更する機能です。

目的

現在の Sora 自体には認証の機能を持っていないため、一時的に接続をブロックするといった仕組みがありません。もしやるとしても認証サーバー側で処理をすることになり不便でした。

そこで、Sora 側にモード機能を持たせることで、モードを切り替えることで接続を気軽にブロックする機能を追加します。

また、クラスター機能が有効な場合には、起動直後のノードやネットワーク障害などで孤立したノードに特別なモードを割り当てることで、 「同じチャネルが複数のノードで処理されている」などといった不整合が発生することを防いでいます。

モード

ノーマルモード

このモードは何もせず、すべての新規接続を受け入れます。

新規コネクションブロックモード

このモードは新規の接続をブロックします。すでに接続しているコネクションはそのままです。

新規セッションブロックモード

このモードは新規セッションの作成をブロックします。すでに接続しているセッションやコネクションはそのままです。

そのためセッション(チャネルに 1 人以上接続しているアクティブな状態)が存在する場合は接続できますが、セッションが存在しない場合は新規の接続をブロックします。

イニシャルモード

注意

このモードはクラスター機能が有効の際に起動時や孤立した際に割り当てられる特殊なモードです。

このモードはすべての接続をブロックします。

  • クラスターへ参加したタイミングでノーマルモードで自動で切り替わります

  • クラスターから孤立したタイミングでノーマルモードからイニシャルモードへ自動で切り替わります

    • ノーマルモード以外の場合には、切り替わらずに、その時のモードが維持されます

このモードを指定して変更することはできません。

ウェブフック

session.vanished

このウェブフックは、新規コネクションブロック、または新規セッションブロックモード時にすべてのセッションが破棄されたタイミングで送信されます。

{
     "type": "session.vanished",
}

API

ChangeMode

  • mode

    • normal

    • block_new_session

    • block_new_connection

$ http POST 127.0.0.1:3000 x-sora-target:Sora_20211215.ChangeMode mode=block_new_session -vvv
POST / HTTP/1.1
Accept: application/json, */*;q=0.5
Accept-Encoding: gzip, deflate
Connection: keep-alive
Content-Length: 29
Content-Type: application/json
Host: 127.0.0.1:3000
User-Agent: HTTPie/2.3.0
x-sora-target: Sora_20211215.ChangeMode

{
    "mode": "block_new_session"
}


HTTP/1.1 200 OK
access-control-allow-headers: Origin, X-Requested-With, Content-Type, Accept, x-sora-target
access-control-allow-methods: POST, OPTIONS
access-control-allow-origin: http://127.0.0.1:5000
access-control-max-age: 1000
content-length: 28
content-type: application/json
date: Wed, 06 Oct 2021 10:42:35 GMT
server: Cowboy

{
    "mode": "block_new_session"
}
$ http POST 127.0.0.1:3000 x-sora-target:Sora_20211215.ChangeMode mode=block_new_connection -vvv
POST / HTTP/1.1
Accept: application/json, */*;q=0.5
Accept-Encoding: gzip, deflate
Connection: keep-alive
Content-Length: 32
Content-Type: application/json
Host: 127.0.0.1:3000
User-Agent: HTTPie/2.3.0
x-sora-target: Sora_20211215.ChangeMode

{
    "mode": "block_new_connection"
}


HTTP/1.1 200 OK
access-control-allow-headers: Origin, X-Requested-With, Content-Type, Accept, x-sora-target
access-control-allow-methods: POST, OPTIONS
access-control-allow-origin: http://127.0.0.1:5000
access-control-max-age: 1000
content-length: 31
content-type: application/json
date: Wed, 06 Oct 2021 10:44:05 GMT
server: Cowboy

{
    "mode": "block_new_connection"
}

GetMode

$ http POST 127.0.0.1:3000 x-sora-target:Sora_20211215.GetMode -vvv
POST / HTTP/1.1
Accept: */*
Accept-Encoding: gzip, deflate
Connection: keep-alive
Content-Length: 0
Host: 127.0.0.1:3000
User-Agent: HTTPie/2.3.0
x-sora-target: Sora_20211215.GetMode



HTTP/1.1 200 OK
access-control-allow-headers: Origin, X-Requested-With, Content-Type, Accept, x-sora-target
access-control-allow-methods: POST, OPTIONS
access-control-allow-origin: http://127.0.0.1:5000
access-control-max-age: 1000
content-length: 17
content-type: application/json
date: Wed, 06 Oct 2021 10:42:19 GMT
server: Cowboy

{
    "mode": "normal"
}

クラスター機能

クラスター機能有効での Sora 起動時の mode

クラスター機能を利用した場合、 Sora 起動時の modeイニシャルモード になります。

クラスターへの参加に成功したタイミングで イニシャルモード から ノーマルモード へ変更されます。

チャネル ID のノード割り当て

クラスター機能を利用した場合、 mode新規セッションブロックモード または 新規コネクションブロックモード または イニシャルモード のノードに対して、 新規のチャネル ID を割り当てません。

シーケンス図

block_new_connection

sequenceDiagram participant client1 as クライアント1 participant client2 as クライアント2 participant sora as WebRTC SFU Sora participant app as アプリケーションサーバー note over sora: Sora 起動 note over sora: モード: normal client1->>sora: "type": "connect" note over client1,sora: クライアント1 WebRTC 確立 app->>sora: ChangeMod API<br/>mode=block_new_connection note over sora: モード: block_new_connection break 接続失敗 client2->>sora: "type": "connect" end app->>sora: ChangeMod API<br/>mode=normal note over sora: モード: normal client2->>sora: "type": "connect" note over client2,sora: クライアント2 WebRTC 確立

block_new_session

sequenceDiagram participant client1 as クライアント1 participant client2 as クライアント2 participant client3 as クライアント3 participant sora as WebRTC SFU Sora participant app as アプリケーションサーバー note over sora: Sora 起動 note over sora: モード: normal client1->>sora: "type": "connect"<br/>channel_id=spam note over client1,sora: クライアント1 WebRTC 確立 app->>sora: ChangeMod API<br/>mode=block_new_session note over sora: モード: block_new_session break 接続失敗 client2->>sora: "type": "connect"<br/>channel_id=ham end client3->>sora: "type": "connect"<br/>channel_id=spam note over client3,sora: クライアント2 WebRTC 確立
© Copyright 2023, Shiguredo Inc Created using Sphinx 6.2.1