From bae6594517fc641a7d9e04744cc28238faafbc18 Mon Sep 17 00:00:00 2001 From: javierbrk Date: Mon, 8 Apr 2024 12:12:54 -0300 Subject: [PATCH 1/2] adds shared-state rpcd data,error output format --- .../files/usr/libexec/rpcd/shared-state-async | 106 +++++++----------- .../tests/test_rpcd_shared-state-async.lua | 23 ++-- .../files/usr/libexec/rpcd/shared-state | 46 ++++---- .../tests/test_rpcd_shared-state.lua | 40 ++++--- 4 files changed, 101 insertions(+), 114 deletions(-) diff --git a/packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async b/packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async index a96d872f4..3edaaa13d 100755 --- a/packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async +++ b/packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async @@ -1,63 +1,43 @@ -#!/usr/bin/env lua - ---[[ -Shared State Async - -Copyright (c) 2024 Javier Jorge -Copyright (c) 2024 Instituto Nacional de Tecnolog..a Industrial -Copyright (C) 2024 Asociacion Civil Altermundi - -This is free software, licensed under the GNU AFFERO GENERAL PUBLIC LICENSE Version 3 -]] --- -local utils = require('lime.utils') -local json = require 'luci.jsonc' - -local function get(msg) - local error = os.execute("shared-state-async get " .. - msg.data_type .. " 2>/dev/null ") - -- if os.execute dont fail will print the output and rpcd wont execute - -- the following lines. If there is an error the above code wont print - -- anything and this code will return the error code. - utils.printJson({ - error = error - }) -end - -local function sync(msg) - local error = os.execute("shared-state-async sync " .. - msg.data_type .. " " .. table.concat(msg.peers_ip or {}, " ") .. " 2>/dev/null ") - utils.printJson({ - error = error - }) -end - ---{"data_type":"data","peers_ip":["10.0.0.1","10.0.0.2"]} ---{"data_type":"data","peers_ip":["10.0.0.1"]} -local methods = { - get = { - data_type = 'value' - }, - sync = { - data_type = 'value', - peers_ip = 'value' - } -} - -if arg[1] == 'list' then - utils.printJson(methods) -end - -if arg[1] == 'call' then - local msg = utils.rpcd_readline() - msg = json.parse(msg) - if arg[2] == 'get' then - get(msg) - elseif arg[2] == 'sync' then - sync(msg) - else - utils.printJson({ - error = "Method not found" - }) - end -end +#!/bin/sh +# --[[ +# Shared State Async + +# Copyright (c) 2024 Javier Jorge +# Copyright (c) 2024 Instituto Nacional de Tecnologia Industrial +# Copyright (C) 2024 Asociacion Civil Altermundi + +# SPDX-License-Identifier: AGPL-3.0-only +# ]] + +sinc_args="" + +case "$1" in + list) + echo '{ "sync": { "data_type": "str", "peers_ip": "str" }, "get": { "data_type": "str" } }' + ;; + call) + # source jshn shell library + . /usr/share/libubox/jshn.sh + read nmsg + json_load $nmsg + json_get_vars data_type + json_get_vars peers_ip + case "$2" in + get) + if output=$(shared-state-async get $data_type 2>/dev/null) + then + echo {\"data\": $output , \"error\" :$?} + else + echo {\"data\": {} , \"error\": $? } + fi + ;; + sync) + shared-state-async sync $data_type ${peers_ip//,/ } > /dev/null 2>&1 + echo {\"data\": {} , \"error\": $? } + ;; + *) + echo '{\"data\" {} ,\"error\" = "Method not found"}' + ;; + esac + ;; +esac diff --git a/packages/shared-state-async/tests/test_rpcd_shared-state-async.lua b/packages/shared-state-async/tests/test_rpcd_shared-state-async.lua index fcacfa3d9..f63f02ef0 100644 --- a/packages/shared-state-async/tests/test_rpcd_shared-state-async.lua +++ b/packages/shared-state-async/tests/test_rpcd_shared-state-async.lua @@ -3,10 +3,10 @@ local sharedState = require("shared-state") local json = require("luci.jsonc") local testFileName = "packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async" -local sharedStateRpc = testUtils.load_lua_file_as_function(testFileName) -local rpcdCall = testUtils.rpcd_call + --since there is no Shared State async binary, testing possiblities are reduced +--also testing the full --manual testing can be done on a router with bat-hosts package using this commands: --ubus -S call shared-state-async get "{'data_type': 'bat-hosts'}" --ubus -S call shared-state-async sync "{'data_type': 'bat-hosts'}" @@ -14,21 +14,12 @@ local rpcdCall = testUtils.rpcd_call describe('ubus-shared-state tests #ubus-shared-state', function() - before_each('', function() - testDir = testUtils.setup_test_dir() - sharedState.DATA_DIR = testDir - sharedState.PERSISTENT_DATA_DIR = testDir - end) - - after_each('', function() - testUtils.teardown_test_dir() - end) it('test list methods', function() - local response = rpcdCall(sharedStateRpc, {'list'}) - assert.is.equal("value", response.get.data_type) - assert.is.equal("value", response.sync.data_type) - assert.is.equal("value", response.sync.peers_ip) - + local response = utils.unsafe_shell(testFileName.." list") + response = json.parse(response) + assert.is.equal("str", response.get.data_type) + assert.is.equal("str", response.sync.data_type) + assert.is.equal("str", response.sync.peers_ip) end) end) diff --git a/packages/shared-state/files/usr/libexec/rpcd/shared-state b/packages/shared-state/files/usr/libexec/rpcd/shared-state index 4fb387a6b..e84b88223 100755 --- a/packages/shared-state/files/usr/libexec/rpcd/shared-state +++ b/packages/shared-state/files/usr/libexec/rpcd/shared-state @@ -1,5 +1,5 @@ -#!/usr/bin/env lua ---[[ +#!/usr/bin/env lua +--[[ Shared State Copyright (c) 2023 Javier Jorge @@ -7,7 +7,8 @@ Copyright (c) 2023 Instituto Nacional de Tecnología Industrial Copyright (C) 2023 Asociación Civil Altermundi This is free software, licensed under the GNU AFFERO GENERAL PUBLIC LICENSE Version 3 -]] -- +]] + -- local ubus = require "ubus" local utils = require('lime.utils') local shared_state = require("shared-state") @@ -15,31 +16,36 @@ local json = require 'luci.jsonc' require("nixio.util") -local function getFromSharedState(msg) - local sharedState = shared_state.SharedState:new(msg.data_type, - nixio.syslog) +local response_template = {data = {}, error = 500} + +local function showData(sharedState) local resultTable = sharedState:get() - local response ={} - for k,v in pairs(resultTable) do - response[k]=v.data + if next(resultTable) == nill then + response_template.error = 404 + else + for k, v in pairs(resultTable) do + response_template.data[k] = v.data + end + response_template.error = 0 end - utils.printJson(response) + utils.printJson(response_template) +end + +local function getFromSharedState(msg) + local sharedState = shared_state.SharedState:new(msg.data_type, + nixio.syslog) + showData(sharedState) end local function getFromSharedStateMultiWriter(msg) - local sharedState = shared_state.SharedStateMultiWriter:new(msg.data_type, - nixio.syslog) - local resultTable = sharedState:get() - local response ={} - for k,v in pairs(resultTable) do - response[k]=v.data - end - utils.printJson(response) + local sharedState = shared_state.SharedStateMultiWriter:new(msg.data_type, + nixio.syslog) + showData(sharedState) end local function insertIntoSharedStateMultiWriter(msg) - local sharedState = shared_state.SharedStateMultiWriter:new(msg.data_type, - nixio.syslog) + local sharedState = shared_state.SharedStateMultiWriter:new(msg.data_type, + nixio.syslog) local inputTable = msg.json or {} sharedState:insert(inputTable) end diff --git a/packages/shared-state/tests/test_rpcd_shared-state.lua b/packages/shared-state/tests/test_rpcd_shared-state.lua index e118126b1..24903bf7d 100644 --- a/packages/shared-state/tests/test_rpcd_shared-state.lua +++ b/packages/shared-state/tests/test_rpcd_shared-state.lua @@ -38,11 +38,21 @@ describe('ubus-shared-state tests #ubus-shared-state', function() assert.is.equal(dbA.zig.data, 'zag') local response = rpcdCall(sharedStateRpc, {'call', 'getFromSharedState'}, '{"data_type": "wifi_links_info"}') - assert.is.equal(response.bar, 'foo') - assert.is.equal(response.baz, 'qux') - assert.is.equal(response.zig, 'zag') + assert.is.equal(response.data.bar, 'foo') + assert.is.equal(response.data.baz, 'qux') + assert.is.equal(response.data.zig, 'zag') end) + it('test get multiwriter data from empty data_type ', function() + local sharedStateA = sharedState.SharedStateMultiWriter:new('EMPTY') + + local response = rpcdCall(sharedStateRpc, {'call', + 'getFromSharedStateMultiWriter'}, '{"data_type": "EMPTY"}') + assert.is.equal(response.error, 404) + assert.is.equal(next(response.data), next({})) + end) + + it('test get multiwriter data ', function() local sharedStateA = sharedState.SharedStateMultiWriter:new('A') sharedStateA:insert({ @@ -55,9 +65,9 @@ describe('ubus-shared-state tests #ubus-shared-state', function() assert.is.equal('zag', dbA.zig.data) local response = rpcdCall(sharedStateRpc, {'call', 'getFromSharedStateMultiWriter'}, '{"data_type": "A"}') - assert.is.equal(response.bar, 'foo') - assert.is.equal(response.baz, 'qux') - assert.is.equal(response.zig, 'zag') + assert.is.equal(response.data.bar, 'foo') + assert.is.equal(response.data.baz, 'qux') + assert.is.equal(response.data.zig, 'zag') end) it('test insert multiwriter data ', function() @@ -87,8 +97,8 @@ describe('ubus-shared-state tests #ubus-shared-state', function() }) local response = rpcdCall(sharedStateRpc, {'call', 'getFromSharedStateMultiWriter'}, '{"data_type": "A"}') - assert.is.equal('foo', response.bar) - assert.is.equal('zag', response.zig) + assert.is.equal('foo', response.data.bar) + assert.is.equal('zag', response.data.zig) response.zig="newzag" callargs = '{"data_type": "A", "json": '..json.stringify(response)..'}' local response = rpcdCall(sharedStateRpc, {'call', @@ -143,7 +153,7 @@ describe('ubus-shared-state tests #ubus-shared-state', function() '{"data_type": "A", "json": {"zig": "zag"}}') response = rpcdCall(sharedStateRpc, {'call', 'getFromSharedStateMultiWriter'}, '{"data_type": "A"}') - assert.is.equal(response.zig, 'zag') + assert.is.equal(response.data.zig, 'zag') response = rpcdCall(sharedStateRpc, {'call', 'insertIntoSharedStateMultiWriter'}, @@ -151,8 +161,8 @@ describe('ubus-shared-state tests #ubus-shared-state', function() response = rpcdCall(sharedStateRpc, {'call', 'getFromSharedStateMultiWriter'}, '{"data_type": "ref_state_wifilinks"}') - assert.is.equal(response.primero.bleachTTL, 23) - assert.is.equal(response.primero.author, "primero") + assert.is.equal(response.data.primero.bleachTTL, 23) + assert.is.equal(response.data.primero.author, "primero") response = rpcdCall(sharedStateRpc, {'call', 'insertIntoSharedStateMultiWriter'},wifiStatusJsonsample27) @@ -161,8 +171,8 @@ describe('ubus-shared-state tests #ubus-shared-state', function() 'getFromSharedStateMultiWriter'}, '{"data_type": "ref_state_wifilinks"}') - assert.is.equal(response.primero.bleachTTL, 27) - assert.is.equal(response.primero.author, "primero") + assert.is.equal(response.data.primero.bleachTTL, 27) + assert.is.equal(response.data.primero.author, "primero") response = rpcdCall(sharedStateRpc, {'call', 'insertIntoSharedStateMultiWriter'}, @@ -170,7 +180,7 @@ describe('ubus-shared-state tests #ubus-shared-state', function() response = rpcdCall(sharedStateRpc, {'call', 'getFromSharedStateMultiWriter'}, '{"data_type": "ref_state_wifilinks"}') - assert.is.equal(response.primero.bleachTTL, 23) - assert.is.equal(response.primero.author, "primero") + assert.is.equal(response.data.primero.bleachTTL, 23) + assert.is.equal(response.data.primero.author, "primero") end) end) From e331e1b8605193ee611c2ed8711948e7ad6c9b40 Mon Sep 17 00:00:00 2001 From: javierbrk Date: Thu, 11 Apr 2024 17:18:17 -0300 Subject: [PATCH 2/2] shared-state-ubus: fix licence comments and variable names --- .../files/usr/libexec/rpcd/shared-state-async | 10 ++++------ .../files/usr/libexec/rpcd/shared-state | 13 +++++-------- 2 files changed, 9 insertions(+), 14 deletions(-) diff --git a/packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async b/packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async index 3edaaa13d..fdcb6ed04 100755 --- a/packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async +++ b/packages/shared-state-async/files/usr/libexec/rpcd/shared-state-async @@ -1,13 +1,11 @@ #!/bin/sh -# --[[ -# Shared State Async +# Shared State Async # Copyright (c) 2024 Javier Jorge # Copyright (c) 2024 Instituto Nacional de Tecnologia Industrial # Copyright (C) 2024 Asociacion Civil Altermundi - # SPDX-License-Identifier: AGPL-3.0-only -# ]] + sinc_args="" @@ -18,8 +16,8 @@ case "$1" in call) # source jshn shell library . /usr/share/libubox/jshn.sh - read nmsg - json_load $nmsg + read msg + json_load $msg json_get_vars data_type json_get_vars peers_ip case "$2" in diff --git a/packages/shared-state/files/usr/libexec/rpcd/shared-state b/packages/shared-state/files/usr/libexec/rpcd/shared-state index e84b88223..08e4f3dfb 100755 --- a/packages/shared-state/files/usr/libexec/rpcd/shared-state +++ b/packages/shared-state/files/usr/libexec/rpcd/shared-state @@ -1,14 +1,11 @@ #!/usr/bin/env lua ---[[ -Shared State -Copyright (c) 2023 Javier Jorge -Copyright (c) 2023 Instituto Nacional de Tecnología Industrial -Copyright (C) 2023 Asociación Civil Altermundi +--! Shared State +--! Copyright (c) 2023 Javier Jorge +--! Copyright (c) 2023 Instituto Nacional de Tecnología Industrial +--! Copyright (C) 2023 Asociación Civil Altermundi +--! SPDX-License-Identifier: AGPL-3.0-only -This is free software, licensed under the GNU AFFERO GENERAL PUBLIC LICENSE Version 3 -]] - -- local ubus = require "ubus" local utils = require('lime.utils') local shared_state = require("shared-state")