summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Estabrook <jestabro@vyos.io>2025-03-18 10:24:56 -0500
committerGitHub <noreply@github.com>2025-03-18 10:24:56 -0500
commit5f15d8095efd11756a867e552a3f8fe6c77e57cc (patch)
tree23129d1414aba7e5faedeb5f61fecfd15001f936
parent1b4173b8371d1f15ac91f615af1e70e2a4cde898 (diff)
parent97cdcfaa28c5275912e3828ee8ea23fcfe918877 (diff)
downloadlibvyosconfig-5f15d8095efd11756a867e552a3f8fe6c77e57cc.tar.gz
libvyosconfig-5f15d8095efd11756a867e552a3f8fe6c77e57cc.zip
Merge pull request #26 from jestabro/commitd
T7121: Set up communication vyconfd to vyos-commitd
-rw-r--r--Makefile2
-rwxr-xr-xbuild.sh4
-rwxr-xr-xdebian/rules2
-rw-r--r--lib/bindings.ml40
4 files changed, 45 insertions, 3 deletions
diff --git a/Makefile b/Makefile
index 0ba31e2..b61d0d2 100644
--- a/Makefile
+++ b/Makefile
@@ -2,7 +2,7 @@ BUILDDIR=_build
VPATH=$(BUILDDIR)
OCAMLDIR=$(shell ocamlopt -where)
$(shell mkdir -p $(BUILDDIR) $(BUILDDIR)/stub $(BUILDDIR)/lib $(BUILDDIR)/stub_generator $(BUILDDIR)/test $(BUILDDIR)/generated)
-PACKAGES=vyos1x-config,re,ctypes.stubs,ctypes.foreign
+PACKAGES=vyos1x-config,vyconf.vyconfd-config,vyconf.vycall-client,re,ctypes.stubs,ctypes.foreign
GENERATOR_FILES=$(BUILDDIR)/lib/bindings.cmx \
$(BUILDDIR)/stub_generator/generate.cmx
diff --git a/build.sh b/build.sh
index 054ade4..f4da007 100755
--- a/build.sh
+++ b/build.sh
@@ -2,8 +2,8 @@
DIR=$1
-sudo sh -c 'eval $(opam env --root=/opt/opam --set-root) && opam pin add vyos1x-config https://github.com/vyos/vyos1x-config.git#be576e9d9281d8b97059bba3882be8deac4f724d -y'
-sudo sh -c 'eval $(opam env --root=/opt/opam --set-root) && opam pin add vyconf https://github.com/vyos/vyconf.git#a375860a302a224722d254c31a1cb210cb12d972 -y'
+sudo sh -c 'eval $(opam env --root=/opt/opam --set-root) && opam pin add vyos1x-config https://github.com/vyos/vyos1x-config.git#d08be19809a3e1c8413e0d98556273244dc18e77 -y'
+sudo sh -c 'eval $(opam env --root=/opt/opam --set-root) && opam pin add vyconf https://github.com/vyos/vyconf.git#33cc7567d909c776d43ea6698267125ea1ec2f66 -y'
eval `opam config env`
make clean
diff --git a/debian/rules b/debian/rules
index 99a5ee2..eb80bf0 100755
--- a/debian/rules
+++ b/debian/rules
@@ -4,6 +4,7 @@ DIR := debian/tmp
OCAML_DIR := /opt/opam/${OCAML_VERSION}
VYCONF := usr/libexec/vyos/vyconf
VYCONF_CONF := $(VYCONF)/config
+VYCONF_SESSION := $(VYCONF)/session
VYCONF_DATA := usr/share/vyos/vyconf
VYCONF_DEF := etc/vyos
@@ -15,6 +16,7 @@ override_dh_auto_build:
override_dh_auto_install:
mkdir -p $(DIR)/$(VYCONF_CONF)
+ mkdir -p $(DIR)/$(VYCONF_SESSION)
mkdir -p $(DIR)/$(VYCONF_DATA)
mkdir -p $(DIR)/$(VYCONF_DEF)
cp $(OCAML_DIR)/share/vyconf/vyconf.proto $(DIR)/$(VYCONF_DATA)
diff --git a/lib/bindings.ml b/lib/bindings.ml
index 052495d..0ce05d1 100644
--- a/lib/bindings.ml
+++ b/lib/bindings.ml
@@ -2,9 +2,15 @@ open Ctypes
open Foreign
open Vyos1x
+open Vyconfd_config
+open Commitd_client
module CT = Config_tree
module CD = Config_diff
+module CM = Commit
+module VC = Vycall_client
+
+module I = Internal.Make(Config_tree)
let error_message = ref ""
@@ -23,6 +29,9 @@ let make_config_tree name = Ctypes.Root.create (CT.make name)
let destroy c_ptr =
Root.release c_ptr
+let equal c_ptr_l c_ptr_r =
+ (Root.get c_ptr_l) = (Root.get c_ptr_r)
+
let from_string s =
try
error_message := "";
@@ -53,6 +62,22 @@ let render_commands c_ptr op =
| _ ->
CT.render_commands ~op:CT.Set (Root.get c_ptr) []
+let read_internal file =
+ try
+ error_message := "";
+ let ct = I.read_internal file in
+ Ctypes.Root.create ct
+ with Internal.Read_error msg ->
+ error_message := msg; Ctypes.null
+
+let write_internal c_ptr file =
+ try
+ error_message := "";
+ let ct = Root.get c_ptr in
+ I.write_internal ct file
+ with Internal.Write_error msg ->
+ error_message := msg
+
let create_node c_ptr path =
let ct = Root.get c_ptr in
let path = split_on_whitespace path in
@@ -245,17 +270,30 @@ let mask_tree c_ptr_l c_ptr_r =
| CD.Incommensurable -> error_message := "Incommensurable"; Ctypes.null
| CD.Empty_comparison -> error_message := "Empty comparison"; Ctypes.null
+let show_commit_data c_ptr_a c_ptr_w =
+ let ct_a = Root.get c_ptr_a in
+ let ct_w = Root.get c_ptr_w in
+ CM.show_commit_data ct_a ct_w
+
+let test_commit c_ptr_a c_ptr_w =
+ let ct_a = Root.get c_ptr_a in
+ let ct_w = Root.get c_ptr_w in
+ VC.test_commit ct_a ct_w
+
module Stubs(I : Cstubs_inverted.INTERNAL) =
struct
let () = I.internal "make" (string @-> returning (ptr void)) make_config_tree
let () = I.internal "destroy" ((ptr void) @-> returning void) destroy
+ let () = I.internal "equal" ((ptr void) @-> (ptr void) @-> returning bool) equal
let () = I.internal "from_string" (string @-> returning (ptr void)) from_string
let () = I.internal "get_error" (void @-> returning string) get_error
let () = I.internal "to_string" ((ptr void) @-> bool @-> returning string) render_config
let () = I.internal "to_json" ((ptr void) @-> returning string) render_json
let () = I.internal "to_json_ast" ((ptr void) @-> returning string) render_json_ast
let () = I.internal "to_commands" ((ptr void) @-> string @-> returning string) render_commands
+ let () = I.internal "read_internal" (string @-> returning (ptr void)) read_internal
+ let () = I.internal "write_internal" ((ptr void) @-> string @-> returning void) write_internal
let () = I.internal "create_node" ((ptr void) @-> string @-> returning int) create_node
let () = I.internal "set_add_value" ((ptr void) @-> string @-> string @-> returning int) set_add_value
let () = I.internal "set_replace_value" ((ptr void) @-> string @-> string @-> returning int) set_replace_value
@@ -278,4 +316,6 @@ struct
let () = I.internal "tree_union" ((ptr void) @-> (ptr void) @-> returning (ptr void)) tree_union
let () = I.internal "reference_tree_to_json" (string @-> string @-> string @-> returning int) reference_tree_to_json
let () = I.internal "mask_tree" ((ptr void) @-> (ptr void) @-> returning (ptr void)) mask_tree
+ let () = I.internal "show_commit_data" ((ptr void) @-> (ptr void) @-> returning string) show_commit_data
+ let () = I.internal "test_commit" ((ptr void) @-> (ptr void) @-> returning void) test_commit
end