Search & Gracefull Close on Websocket
This commit is contained in:
@@ -1,6 +1,8 @@
|
|||||||
package controllers
|
package controllers
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
"oc-catalog/infrastructure"
|
"oc-catalog/infrastructure"
|
||||||
|
|
||||||
@@ -60,25 +62,47 @@ func (o *GeneralController) GetAll() {
|
|||||||
o.ServeJSON()
|
o.ServeJSON()
|
||||||
}
|
}
|
||||||
|
|
||||||
func Websocket(user string, groups []string, dataType int, w http.ResponseWriter, r *http.Request) {
|
func Websocket(ctx context.Context, user string, groups []string, dataType int, r http.ResponseWriter, w *http.Request) {
|
||||||
websocket.Handler(func(ws *websocket.Conn) {
|
websocket.Handler(func(ws *websocket.Conn) {
|
||||||
|
done := make(chan struct{})
|
||||||
|
go func() {
|
||||||
|
var discard interface{}
|
||||||
|
for {
|
||||||
|
if websocket.JSON.Receive(ws, &discard) != nil {
|
||||||
|
close(done)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}()
|
||||||
defer func() {
|
defer func() {
|
||||||
ws.Close()
|
ws.Close()
|
||||||
infrastructure.SearchMu.Lock()
|
|
||||||
if ch, ok := infrastructure.SearchStream[user]; ok {
|
if ch, ok := infrastructure.SearchStream[user]; ok {
|
||||||
close(ch)
|
close(ch)
|
||||||
|
infrastructure.SearchMu.Lock()
|
||||||
delete(infrastructure.SearchStream, user)
|
delete(infrastructure.SearchStream, user)
|
||||||
|
infrastructure.SearchMu.Unlock()
|
||||||
}
|
}
|
||||||
infrastructure.SearchMu.Unlock()
|
fmt.Println("CLOSE !")
|
||||||
infrastructure.EmitNATS(user, groups, tools.PropalgationMessage{
|
infrastructure.EmitNATS(user, nil, tools.PropalgationMessage{
|
||||||
Action: tools.PB_CLOSE_SEARCH,
|
Action: tools.PB_CLOSE_SEARCH,
|
||||||
DataType: dataType,
|
DataType: dataType,
|
||||||
})
|
})
|
||||||
}()
|
}()
|
||||||
for msg := range infrastructure.SearchStream[user] {
|
for {
|
||||||
if websocket.JSON.Send(ws, msg) != nil {
|
select {
|
||||||
|
case msg, ok := <-infrastructure.SearchStream[user]:
|
||||||
|
fmt.Println("FOR", msg, ok)
|
||||||
|
if !ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if websocket.JSON.Send(ws, msg) != nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
case <-done:
|
||||||
|
return
|
||||||
|
case <-ctx.Done():
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}).ServeHTTP(w, r)
|
}).ServeHTTP(r, w)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -26,20 +26,18 @@ func EmitNATS(user string, groups []string, message tools.PropalgationMessage) {
|
|||||||
b, _ := json.Marshal(message)
|
b, _ := json.Marshal(message)
|
||||||
switch message.Action {
|
switch message.Action {
|
||||||
case tools.PB_SEARCH:
|
case tools.PB_SEARCH:
|
||||||
if slices.Contains(ressourceCols, oclib.LibDataEnum(message.DataType)) {
|
SearchMu.Lock()
|
||||||
SearchMu.Lock()
|
SearchStream[user] = make(chan resources.ResourceInterface, 128)
|
||||||
SearchStream[user] = make(chan resources.ResourceInterface, 128)
|
SearchMu.Unlock()
|
||||||
SearchMu.Unlock()
|
tools.NewNATSCaller().SetNATSPub(tools.PROPALGATION_EVENT, tools.NATSResponse{
|
||||||
}
|
FromApp: "oc-catalog",
|
||||||
|
Datatype: -1,
|
||||||
|
User: user,
|
||||||
|
Groups: groups,
|
||||||
|
Method: int(tools.PROPALGATION_EVENT),
|
||||||
|
Payload: b,
|
||||||
|
})
|
||||||
}
|
}
|
||||||
tools.NewNATSCaller().SetNATSPub(tools.PROPALGATION_EVENT, tools.NATSResponse{
|
|
||||||
FromApp: "oc-catalog",
|
|
||||||
Datatype: -1,
|
|
||||||
User: user,
|
|
||||||
Groups: groups,
|
|
||||||
Method: int(tools.PROPALGATION_EVENT),
|
|
||||||
Payload: b,
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// un ressource quand on l'ajoute à notre catalogue elle nous est étrangère.
|
// un ressource quand on l'ajoute à notre catalogue elle nous est étrangère.
|
||||||
@@ -70,6 +68,7 @@ func ListenNATS() {
|
|||||||
if err == nil {
|
if err == nil {
|
||||||
fmt.Println("SearchStream", p)
|
fmt.Println("SearchStream", p)
|
||||||
SearchMu.Lock()
|
SearchMu.Lock()
|
||||||
|
fmt.Println(SearchStream, resp.User)
|
||||||
SearchStream[resp.User] <- p // TODO when do we update it in our catalog ?*
|
SearchStream[resp.User] <- p // TODO when do we update it in our catalog ?*
|
||||||
SearchMu.Unlock()
|
SearchMu.Unlock()
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ func wsSearchHandler(dataType int) http.HandlerFunc {
|
|||||||
DataType: dataType,
|
DataType: dataType,
|
||||||
Payload: b,
|
Payload: b,
|
||||||
})
|
})
|
||||||
controllers.Websocket(user, groups, dataType, w, r)
|
controllers.Websocket(r.Context(), user, groups, dataType, w, r)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
2
ws.go
2
ws.go
@@ -26,7 +26,7 @@ func main() {
|
|||||||
// ws://localhost:8087/oc/processing/decentralized/all/search/<term>
|
// ws://localhost:8087/oc/processing/decentralized/all/search/<term>
|
||||||
// ws://localhost:8087/oc/storage/decentralized/all/search/<term>
|
// ws://localhost:8087/oc/storage/decentralized/all/search/<term>
|
||||||
// ws://localhost:8087/oc/workflow/decentralized/all/search/<term>
|
// ws://localhost:8087/oc/workflow/decentralized/all/search/<term>
|
||||||
url := "ws://localhost:8087/oc/resource/decentralized/all/search/demo"
|
url := "ws://localhost:8087/oc/resource/decentralized/known/search/builder"
|
||||||
token := ""
|
token := ""
|
||||||
|
|
||||||
if len(args) >= 1 {
|
if len(args) >= 1 {
|
||||||
|
|||||||
Reference in New Issue
Block a user