2016-09-08 21:13:10 +04:00
|
|
|
(**************************************************************************)
|
|
|
|
(* *)
|
|
|
|
(* Copyright (c) 2014 - 2016. *)
|
|
|
|
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
|
|
|
|
(* *)
|
|
|
|
(* All rights reserved. No warranty, explicit or implicit, provided. *)
|
|
|
|
(* *)
|
|
|
|
(**************************************************************************)
|
|
|
|
|
|
|
|
let version_key = ["version"]
|
2017-02-24 18:38:42 +04:00
|
|
|
|
2016-09-08 21:13:10 +04:00
|
|
|
(* This key should always be populated for every version of the
|
|
|
|
protocol. It's absence meaning that the context is empty. *)
|
2017-02-25 02:17:00 +04:00
|
|
|
let version_value = "alpha"
|
2016-09-08 21:13:10 +04:00
|
|
|
|
|
|
|
(* This is the genesis protocol: initialise the state *)
|
2017-02-24 18:38:42 +04:00
|
|
|
let initialize ~from_genesis (ctxt:Context.t) =
|
2016-09-08 21:13:10 +04:00
|
|
|
Context.set ctxt version_key (MBytes.of_string version_value) >>= fun ctxt ->
|
|
|
|
Storage.prepare ctxt >>=? fun store ->
|
|
|
|
Storage.get_genesis_time store >>= fun time ->
|
|
|
|
Storage.Current_timestamp.init_set store time >>=? fun store ->
|
2017-02-25 21:10:29 +04:00
|
|
|
begin
|
|
|
|
if from_genesis then
|
|
|
|
return store
|
|
|
|
else
|
|
|
|
Fitness_storage.init store
|
|
|
|
end >>=? fun store ->
|
2016-09-08 21:13:10 +04:00
|
|
|
Level_storage.init store >>=? fun store ->
|
|
|
|
Roll_storage.init store >>=? fun store ->
|
2017-02-14 01:08:51 +04:00
|
|
|
Nonce_storage.init store >>=? fun store ->
|
2016-09-08 21:13:10 +04:00
|
|
|
Seed_storage.init store >>=? fun store ->
|
|
|
|
Contract_storage.init store >>=? fun store ->
|
|
|
|
Reward_storage.init store >>=? fun store ->
|
|
|
|
Bootstrap_storage.init store >>=? fun store ->
|
2016-10-26 19:02:10 +04:00
|
|
|
Roll_storage.freeze_rolls_for_cycle
|
2016-09-08 21:13:10 +04:00
|
|
|
store Cycle_repr.root >>=? fun store ->
|
2016-10-26 19:02:10 +04:00
|
|
|
Roll_storage.freeze_rolls_for_cycle
|
2016-09-08 21:13:10 +04:00
|
|
|
store Cycle_repr.(succ root) >>=? fun store ->
|
|
|
|
Vote_storage.init store >>=? fun store ->
|
|
|
|
return store
|
|
|
|
|
|
|
|
type error +=
|
|
|
|
| Incompatiple_protocol_version
|
|
|
|
| Unimplemented_sandbox_migration
|
|
|
|
|
|
|
|
let may_initialize ctxt =
|
|
|
|
Context.get ctxt version_key >>= function
|
|
|
|
| None ->
|
|
|
|
(* This is the genesis protocol: The only acceptable preceding
|
|
|
|
version is an empty context *)
|
2017-02-24 18:38:42 +04:00
|
|
|
initialize ~from_genesis:false ctxt
|
2016-09-08 21:13:10 +04:00
|
|
|
| Some bytes ->
|
|
|
|
let s = MBytes.to_string bytes in
|
|
|
|
if Compare.String.(s = version_value)
|
|
|
|
then Storage.prepare ctxt
|
2017-02-24 18:38:42 +04:00
|
|
|
else if Compare.String.(s = "genesis") then
|
|
|
|
initialize ~from_genesis:true ctxt
|
2016-09-08 21:13:10 +04:00
|
|
|
else fail Incompatiple_protocol_version
|
|
|
|
|
|
|
|
let configure_sandbox ctxt json =
|
|
|
|
let json =
|
|
|
|
match json with
|
|
|
|
| None -> `O []
|
|
|
|
| Some json -> json in
|
|
|
|
Context.get ctxt version_key >>= function
|
|
|
|
| None ->
|
|
|
|
Storage.set_sandboxed ctxt json >>= fun ctxt ->
|
2017-02-24 18:38:42 +04:00
|
|
|
initialize ~from_genesis:false ctxt >>=? fun ctxt ->
|
2016-09-08 21:13:10 +04:00
|
|
|
return (Storage.recover ctxt)
|
|
|
|
| Some _ ->
|
|
|
|
Storage.get_sandboxed ctxt >>=? function
|
|
|
|
| None ->
|
|
|
|
fail Unimplemented_sandbox_migration
|
|
|
|
| Some _ ->
|
|
|
|
(* FIXME GRGR fail if parameter changed! *)
|
|
|
|
(* failwith "Changing sandbox parameter is not yet implemented" *)
|
|
|
|
return ctxt
|