Juvix imports
module arch.node.engines.local_key_value_storage_behaviour;
import arch.node.engines.local_key_value_storage_messages open;
import arch.node.engines.local_key_value_storage_config open;
import arch.node.engines.local_key_value_storage_environment open;
import prelude open;
import arch.node.types.basics open;
import arch.node.types.identities open;
import arch.node.types.messages open;
import arch.node.types.engine open;
import arch.node.types.anoma as Anoma open;
Local Key-Value Storage Behaviour¶
Overview¶
The Local Key-Value Storage engine processes get, set, and delete operations on key-value pairs.
Action arguments¶
LocalKVStorageActionArgument
¶
type LocalKVStorageActionArgument := | LocalKVStorageReplyTo EngineID;
LocalKVStorageActionArguments
¶
LocalKVStorageActionArguments : Type := List LocalKVStorageActionArgument;
Actions¶
Auxiliary Juvix code
LocalKVStorageAction
¶
LocalKVStorageAction : Type :=
Action
LocalKVStorageCfg
LocalKVStorageLocalState
LocalKVStorageMailboxState
LocalKVStorageTimerHandle
LocalKVStorageActionArguments
Anoma.Msg
Anoma.Cfg
Anoma.Env;
LocalKVStorageActionInput
¶
LocalKVStorageActionInput : Type :=
ActionInput
LocalKVStorageCfg
LocalKVStorageLocalState
LocalKVStorageMailboxState
LocalKVStorageTimerHandle
LocalKVStorageActionArguments
Anoma.Msg;
LocalKVStorageActionEffect
¶
LocalKVStorageActionEffect : Type :=
ActionEffect
LocalKVStorageLocalState
LocalKVStorageMailboxState
LocalKVStorageTimerHandle
Anoma.Msg
Anoma.Cfg
Anoma.Env;
LocalKVStorageActionExec
¶
LocalKVStorageActionExec : Type :=
ActionExec
LocalKVStorageCfg
LocalKVStorageLocalState
LocalKVStorageMailboxState
LocalKVStorageTimerHandle
LocalKVStorageActionArguments
Anoma.Msg
Anoma.Cfg
Anoma.Env;
getValueAction
¶
Retrieve a value from storage by key.
- State update
- The state remains unchanged.
- Messages to be sent
- A
GetValueKVStoreResponse
message with the requested value. - Engines to be spawned
- No engines are created by this action.
- Timer updates
- No timers are set or cancelled.
getValueAction
(input : LocalKVStorageActionInput) : Option LocalKVStorageActionEffect :=
let
env := ActionInput.env input;
cfg := ActionInput.cfg input;
local := EngineEnv.localState env;
storage := LocalKVStorageLocalState.storage local;
trigger := ActionInput.trigger input;
in case getEngineMsgFromTimestampedTrigger trigger of
| some emsg :=
case emsg of {
| mkEngineMsg@{
msg := Anoma.MsgLocalKVStorage (LocalKVStorageMsgGetValueRequest req);
} :=
some
mkActionEffect@{
env := env;
msgs :=
[
mkEngineMsg@{
sender := getEngineIDFromEngineCfg cfg;
target := EngineMsg.sender emsg;
mailbox := some 0;
msg :=
Anoma.MsgLocalKVStorage
(LocalKVStorageMsgGetValueResponse
mkGetValueKVStoreResponse@{
key := GetValueKVStoreRequest.key req;
value :=
fromOption
(Map.lookup
(GetValueKVStoreRequest.key req)
storage)
"";
});
};
];
timers := [];
engines := [];
}
| _ := none
}
| _ := none;
setValueAction
¶
Store a value in storage with given key.
- State update
- The storage map is updated with new key-value pair.
- Messages to be sent
- A
SetValueKVStoreResponse
message indicating success/failure. - Several
LocalKVStorageMsgValueChanged
messages to those interested engines. - Engines to be spawned
- No engines are created by this action.
- Timer updates
- No timers are set or cancelled.
setValueAction
(input : LocalKVStorageActionInput) : Option LocalKVStorageActionEffect :=
let
env := ActionInput.env input;
cfg := ActionInput.cfg input;
local := EngineEnv.localState env;
storage := LocalKVStorageLocalState.storage local;
trigger := ActionInput.trigger input;
newTime := advanceTime (LocalKVStorageLocalState.localClock local);
in case getEngineMsgFromTimestampedTrigger trigger of
| some emsg :=
case emsg of {
| mkEngineMsg@{
msg := Anoma.MsgLocalKVStorage (LocalKVStorageMsgSetValueRequest req);
} :=
let
key := SetValueKVStoreRequest.key req;
value := SetValueKVStoreRequest.value req;
newStorage := Map.insert key value storage;
newLocal :=
local@LocalKVStorageLocalState{
storage := newStorage;
localClock := newTime;
};
newEnv := env@EngineEnv{localState := newLocal};
responseMsg :=
mkEngineMsg@{
sender := getEngineIDFromEngineCfg cfg;
target := EngineMsg.sender emsg;
mailbox := some 0;
msg :=
Anoma.MsgLocalKVStorage
(LocalKVStorageMsgSetValueResponse
mkSetValueKVStoreResponse@{
key := key;
success := true;
});
};
notificationMsg :=
\{target :=
mkEngineMsg@{
sender := getEngineIDFromEngineCfg cfg;
target := target;
mailbox := some 0;
msg :=
Anoma.MsgLocalKVStorage
(LocalKVStorageMsgValueChanged
mkValueChangedKVStore@{
key := key;
value := value;
timestamp := newTime;
});
}};
notificationMsgs :=
map notificationMsg (getNotificationTargets key);
in some
mkActionEffect@{
env := newEnv;
msgs := responseMsg :: notificationMsgs;
timers := [];
engines := [];
}
| _ := none
}
| _ := none;
deleteValueAction
¶
Remove a value from storage by key.
- State update
- The storage map is updated to remove the key-value pair.
- Messages to be sent
- A
DeleteValueKVStoreResponse message
indicating success/failure. - Several
LocalKVStorageMsgValueChanged
messages to those interested engines. - Engines to be spawned
- No engines are created by this action.
- Timer updates
- No timers are set or cancelled.
deleteValueAction
(input : LocalKVStorageActionInput) : Option LocalKVStorageActionEffect :=
let
env := ActionInput.env input;
cfg := ActionInput.cfg input;
local := EngineEnv.localState env;
storage := LocalKVStorageLocalState.storage local;
trigger := ActionInput.trigger input;
newTime := advanceTime (LocalKVStorageLocalState.localClock local);
in case getEngineMsgFromTimestampedTrigger trigger of
| some emsg :=
case emsg of {
| mkEngineMsg@{
msg := Anoma.MsgLocalKVStorage (LocalKVStorageMsgDeleteValueRequest req);
} :=
let
key := DeleteValueKVStoreRequest.key req;
newStorage := Map.delete key storage;
newLocal :=
local@LocalKVStorageLocalState{
storage := newStorage;
localClock := newTime;
};
newEnv := env@EngineEnv{localState := newLocal};
responseMsg :=
mkEngineMsg@{
sender := getEngineIDFromEngineCfg cfg;
target := EngineMsg.sender emsg;
mailbox := some 0;
msg :=
Anoma.MsgLocalKVStorage
(LocalKVStorageMsgDeleteValueResponse
mkDeleteValueKVStoreResponse@{
key := key;
success := true;
});
};
notificationMsg :=
\{target :=
mkEngineMsg@{
sender := getEngineIDFromEngineCfg cfg;
target := target;
mailbox := some 0;
msg :=
Anoma.MsgLocalKVStorage
(LocalKVStorageMsgValueChanged
mkValueChangedKVStore@{
key := key;
value := "";
timestamp := newTime;
});
}};
notificationMsgs :=
map notificationMsg (getNotificationTargets key);
in some
mkActionEffect@{
env := newEnv;
msgs := responseMsg :: notificationMsgs;
timers := [];
engines := [];
}
| _ := none
}
| _ := none;
Action Labels¶
getValueActionLabel
¶
getValueActionLabel : LocalKVStorageActionExec := Seq [getValueAction];
setValueActionLabel
¶
setValueActionLabel : LocalKVStorageActionExec := Seq [setValueAction];
deleteValueActionLabel
¶
deleteValueActionLabel : LocalKVStorageActionExec := Seq [deleteValueAction];
Guards¶
Auxiliary Juvix code
LocalKVStorageGuard
¶
LocalKVStorageGuard : Type :=
Guard
LocalKVStorageCfg
LocalKVStorageLocalState
LocalKVStorageMailboxState
LocalKVStorageTimerHandle
LocalKVStorageActionArguments
Anoma.Msg
Anoma.Cfg
Anoma.Env;
LocalKVStorageGuardOutput
¶
LocalKVStorageGuardOutput : Type :=
GuardOutput
LocalKVStorageCfg
LocalKVStorageLocalState
LocalKVStorageMailboxState
LocalKVStorageTimerHandle
LocalKVStorageActionArguments
Anoma.Msg
Anoma.Cfg
Anoma.Env;
LocalKVStorageGuardEval
¶
LocalKVStorageGuardEval : Type :=
GuardEval
LocalKVStorageCfg
LocalKVStorageLocalState
LocalKVStorageMailboxState
LocalKVStorageTimerHandle
LocalKVStorageActionArguments
Anoma.Msg
Anoma.Cfg
Anoma.Env;
getValueGuard
¶
- Condition
- Message type is
LocalKVStorageMsgGetValueRequest
.
getValueGuard
(trigger : LocalKVStorageTimestampedTrigger)
(cfg : EngineCfg LocalKVStorageCfg)
(env : LocalKVStorageEnv)
: Option LocalKVStorageGuardOutput :=
case getEngineMsgFromTimestampedTrigger trigger of
| some mkEngineMsg@{
msg := Anoma.MsgLocalKVStorage (LocalKVStorageMsgGetValueRequest _);
} :=
some
mkGuardOutput@{
action := getValueActionLabel;
args := [];
}
| _ := none;
setValueGuard
¶
- Condition
- Message type is
LocalKVStorageMsgSetValueRequest
.
setValueGuard
(trigger : LocalKVStorageTimestampedTrigger)
(cfg : EngineCfg LocalKVStorageCfg)
(env : LocalKVStorageEnv)
: Option LocalKVStorageGuardOutput :=
case getEngineMsgFromTimestampedTrigger trigger of
| some mkEngineMsg@{
msg := Anoma.MsgLocalKVStorage (LocalKVStorageMsgSetValueRequest _);
} :=
some
mkGuardOutput@{
action := setValueActionLabel;
args := [];
}
| _ := none;
deleteValueGuard
¶
- Condition
- Message type is
LocalKVStorageMsgDeleteValueRequest
.
deleteValueGuard
(trigger : LocalKVStorageTimestampedTrigger)
(cfg : EngineCfg LocalKVStorageCfg)
(env : LocalKVStorageEnv)
: Option LocalKVStorageGuardOutput :=
case getEngineMsgFromTimestampedTrigger trigger of
| some mkEngineMsg@{
msg := Anoma.MsgLocalKVStorage (LocalKVStorageMsgDeleteValueRequest _);
} :=
some
mkGuardOutput@{
action := deleteValueActionLabel;
args := [];
}
| _ := none;
The Local Key-Value Storage behaviour¶
LocalKVStorageBehaviour
¶
LocalKVStorageBehaviour : Type :=
EngineBehaviour
LocalKVStorageCfg
LocalKVStorageLocalState
LocalKVStorageMailboxState
LocalKVStorageTimerHandle
LocalKVStorageActionArguments
Anoma.Msg
Anoma.Cfg
Anoma.Env;
Instantiation¶
localKVStorageBehaviour : LocalKVStorageBehaviour :=
mkEngineBehaviour@{
guards := First [getValueGuard; setValueGuard; deleteValueGuard];
};