2020-11-23 11:07:07 +03:00
|
|
|
module Update exposing (update)
|
|
|
|
|
|
|
|
{-| Copyright 2020 Fluence Labs Limited
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
|
|
|
|
-}
|
|
|
|
|
2020-11-23 14:27:33 +03:00
|
|
|
import Air
|
2020-11-23 15:44:45 +03:00
|
|
|
import Browser
|
|
|
|
import Browser.Navigation as Nav
|
2020-11-23 17:39:32 +03:00
|
|
|
import Dict
|
2020-11-25 05:20:20 +03:00
|
|
|
import Json.Decode exposing (decodeValue, list, string)
|
|
|
|
import Json.Encode exposing (Value)
|
2020-11-23 11:07:07 +03:00
|
|
|
import Model exposing (Model)
|
|
|
|
import Msg exposing (..)
|
2020-11-23 14:27:33 +03:00
|
|
|
import Port exposing (sendAir)
|
2020-11-23 15:44:45 +03:00
|
|
|
import Route
|
2020-11-25 05:20:20 +03:00
|
|
|
import Services.Air
|
2020-11-23 15:44:45 +03:00
|
|
|
import Url
|
2020-11-23 11:07:07 +03:00
|
|
|
|
2020-11-25 05:20:20 +03:00
|
|
|
maybeValueToString : Maybe Value -> String
|
|
|
|
maybeValueToString mv =
|
|
|
|
case mv of
|
|
|
|
Just v ->
|
|
|
|
case (decodeValue string v) of
|
|
|
|
Ok value ->
|
|
|
|
value
|
|
|
|
|
|
|
|
Err error ->
|
|
|
|
"error"
|
|
|
|
|
|
|
|
Nothing ->
|
|
|
|
""
|
|
|
|
|
|
|
|
-- list of lists of strings in json to list of strings from first element if it is an array
|
|
|
|
maybeValueToListString : Maybe Value -> List String
|
|
|
|
maybeValueToListString mv =
|
|
|
|
case mv of
|
|
|
|
Just v ->
|
|
|
|
case (decodeValue (list (list string)) v) of
|
|
|
|
Ok value ->
|
|
|
|
Maybe.withDefault [] (List.head value)
|
|
|
|
|
|
|
|
Err error ->
|
|
|
|
let
|
|
|
|
_ = Debug.log "error" error
|
|
|
|
in
|
|
|
|
case (decodeValue (list string) v) of
|
|
|
|
Ok value ->
|
|
|
|
value
|
|
|
|
Err err ->
|
|
|
|
let
|
|
|
|
_ = Debug.log "err" err
|
|
|
|
in
|
|
|
|
["error"]
|
|
|
|
|
|
|
|
Nothing ->
|
|
|
|
[]
|
2020-11-23 11:07:07 +03:00
|
|
|
|
|
|
|
update : Msg -> Model -> ( Model, Cmd Msg )
|
|
|
|
update msg model =
|
|
|
|
case msg of
|
|
|
|
NoOp ->
|
|
|
|
( model, Cmd.none )
|
|
|
|
|
2020-11-23 15:44:45 +03:00
|
|
|
UrlChanged url ->
|
|
|
|
let
|
|
|
|
route =
|
2020-11-23 16:31:31 +03:00
|
|
|
Route.parse url
|
2020-11-23 14:27:33 +03:00
|
|
|
|
2020-11-23 15:44:45 +03:00
|
|
|
cmd =
|
|
|
|
Route.routeCommand model route
|
|
|
|
in
|
|
|
|
( { model | url = url }, cmd )
|
|
|
|
|
|
|
|
LinkClicked urlRequest ->
|
|
|
|
case urlRequest of
|
|
|
|
Browser.Internal url ->
|
|
|
|
( model, Nav.pushUrl model.key (Url.toString url) )
|
|
|
|
|
|
|
|
Browser.External href ->
|
|
|
|
( model, Nav.load href )
|
2020-11-23 14:27:33 +03:00
|
|
|
|
2020-11-23 15:44:45 +03:00
|
|
|
AquamarineEvent { name, args } ->
|
2020-11-23 17:39:32 +03:00
|
|
|
case name of
|
|
|
|
"peers_discovered" ->
|
2020-11-23 18:09:31 +03:00
|
|
|
-- TODO call different function to parse args and change model
|
2020-11-23 17:39:32 +03:00
|
|
|
let
|
2020-11-25 05:20:20 +03:00
|
|
|
peer =
|
|
|
|
maybeValueToString (List.head args)
|
|
|
|
|
|
|
|
peers = maybeValueToListString (List.head (List.drop 1 args))
|
2020-11-23 17:39:32 +03:00
|
|
|
|
2020-11-25 05:20:20 +03:00
|
|
|
b = Debug.log "peer" peer
|
|
|
|
c = Debug.log "peers" peers
|
2020-11-23 17:39:32 +03:00
|
|
|
|
2020-11-25 05:20:20 +03:00
|
|
|
peersMap = List.map (\p -> Tuple.pair p { interfaces = [] }) peers
|
|
|
|
newDict = Dict.fromList (peersMap)
|
|
|
|
updatedDict = Dict.union model.discoveredPeers newDict
|
2020-11-23 17:39:32 +03:00
|
|
|
in
|
|
|
|
-- TODO get data from args, propagate
|
2020-11-25 05:20:20 +03:00
|
|
|
( { model | discoveredPeers = updatedDict }, Cmd.none )
|
2020-11-23 17:39:32 +03:00
|
|
|
|
|
|
|
_ ->
|
|
|
|
let
|
|
|
|
a =
|
|
|
|
Debug.log "event in ELM" name
|
|
|
|
in
|
|
|
|
( model, Cmd.none )
|
2020-11-23 11:07:07 +03:00
|
|
|
|
2020-11-23 14:27:33 +03:00
|
|
|
Click ->
|
|
|
|
( model
|
2020-11-25 05:20:20 +03:00
|
|
|
, sendAir (Services.Air.air model.peerId model.relayId (Dict.keys model.discoveredPeers))
|
2020-11-23 14:27:33 +03:00
|
|
|
)
|
2020-11-23 11:07:07 +03:00
|
|
|
|
2020-11-23 14:27:33 +03:00
|
|
|
RelayChanged relayId ->
|
|
|
|
( { model | relayId = relayId }, Cmd.none )
|