libamxd  6.4.1
Data Model Manager
amxd_action_param_write.c
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** SPDX-License-Identifier: BSD-2-Clause-Patent
4 **
5 ** SPDX-FileCopyrightText: Copyright (c) 2023 SoftAtHome
6 **
7 ** Redistribution and use in source and binary forms, with or without modification,
8 ** are permitted provided that the following conditions are met:
9 **
10 ** 1. Redistributions of source code must retain the above copyright notice,
11 ** this list of conditions and the following disclaimer.
12 **
13 ** 2. Redistributions in binary form must reproduce the above copyright notice,
14 ** this list of conditions and the following disclaimer in the documentation
15 ** and/or other materials provided with the distribution.
16 **
17 ** Subject to the terms and conditions of this license, each copyright holder
18 ** and contributor hereby grants to those receiving rights under this license
19 ** a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable
20 ** (except for failure to satisfy the conditions of this license) patent license
21 ** to make, have made, use, offer to sell, sell, import, and otherwise transfer
22 ** this software, where such license applies only to those patent claims, already
23 ** acquired or hereafter acquired, licensable by such copyright holder or contributor
24 ** that are necessarily infringed by:
25 **
26 ** (a) their Contribution(s) (the licensed copyrights of copyright holders and
27 ** non-copyrightable additions of contributors, in source or binary form) alone;
28 ** or
29 **
30 ** (b) combination of their Contribution(s) with the work of authorship to which
31 ** such Contribution(s) was added by such copyright holder or contributor, if,
32 ** at the time the Contribution is added, such addition causes such combination
33 ** to be necessarily infringed. The patent license shall not apply to any other
34 ** combinations which include the Contribution.
35 **
36 ** Except as expressly stated above, no rights or licenses from any copyright
37 ** holder or contributor is granted under this license, whether expressly, by
38 ** implication, estoppel or otherwise.
39 **
40 ** DISCLAIMER
41 **
42 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
43 ** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
44 ** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
45 ** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
46 ** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
47 ** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
48 ** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
49 ** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
50 ** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
51 ** USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
52 **
53 ****************************************************************************/
54 
55 #include <stdlib.h>
56 
57 #include <amxc/amxc.h>
58 #include <amxp/amxp_signal.h>
59 
60 #include <amxd/amxd_types.h>
61 #include <amxd/amxd_dm.h>
62 #include <amxd/amxd_action.h>
63 #include <amxd/amxd_parameter.h>
64 #include <amxd/amxd_object.h>
65 
66 #include "amxd_priv.h"
67 #include "amxd_assert.h"
68 
70  amxd_param_t* param,
71  amxd_action_t reason,
72  const amxc_var_t* const args,
73  UNUSED amxc_var_t* const retval,
74  UNUSED void* priv) {
76 
77  when_null(param, exit);
78  when_true_status(reason != action_param_write,
79  exit,
81 
82  // key parameters are immutable, they can be written once, unless
83  // marked as mutable key
84  // so if the read-only attribute is not set the parameter can be changed,
85  when_true_status((amxd_param_is_attr_set(param, amxd_pattr_key) &&
87  exit,
89 
91  when_false_status(amxd_param_is_unique(amxd_object_get_parent(object), object, param, args),
92  exit,
94  }
95 
96  when_failed_status(amxc_var_convert(&param->value,
97  args,
98  amxc_var_type_of(&param->value)),
99  exit,
101 
102  // key parameters are immutable, once written they can not be changed
105  param->attr.read_only = 1;
106  }
108 
109 exit:
110  return status;
111 }
112 
114  const amxc_var_t* const value) {
116  amxc_var_t backup;
117  amxd_object_t* object = NULL;
118  int result = 0;
119  amxc_var_init(&backup);
120 
121  when_null(param, exit);
122  retval = amxc_var_compare(value, &param->value, &result) == 0 ?
124  // When the value is not changed, just leave
125  when_true(retval == amxd_status_ok && result == 0, exit);
126 
127  retval = amxd_param_validate(param, value);
128  when_failed(retval, exit);
129  amxc_var_copy(&backup, &param->value);
130 
131  object = amxd_param_get_owner(param);
132  retval = amxd_dm_invoke_action(object, param, action_param_write, value, NULL);
133 
134 exit:
135  if((retval != amxd_status_ok) &&
136  ( param != NULL) &&
137  !amxc_var_is_null(&backup)) {
138  amxc_var_copy(&param->value, &backup);
139  }
140  amxc_var_clean(&backup);
141  return retval;
142 }
Ambiorix Data Model Default actions header file.
amxd_status_t amxd_param_set_value(amxd_param_t *const param, const amxc_var_t *const value)
amxd_status_t amxd_action_param_write(amxd_object_t *object, amxd_param_t *param, amxd_action_t reason, const amxc_var_t *const args, UNUSED amxc_var_t *const retval, UNUSED void *priv)
#define when_failed_status(x, l, c)
Definition: amxd_assert.h:65
Ambiorix Data Model API header file.
amxd_status_t amxd_dm_invoke_action(amxd_object_t *object, amxd_param_t *param, amxd_action_t reason, const amxc_var_t *const args, amxc_var_t *const retval)
Definition: amxd_dm.c:591
Ambiorix Data Model API header file.
bool amxd_param_is_attr_set(const amxd_param_t *const param, const amxd_pattr_id_t attr)
amxd_status_t amxd_param_validate(amxd_param_t *const param, const amxc_var_t *const value)
amxd_object_t * amxd_param_get_owner(const amxd_param_t *const param)
bool PRIVATE amxd_param_is_unique(amxd_object_t *const templ, amxd_object_t *const current, amxd_param_t *const param, const amxc_var_t *const value)
@ amxd_pattr_mutable
Definition: amxd_types.h:365
@ amxd_pattr_key
Definition: amxd_types.h:362
@ amxd_pattr_read_only
Definition: amxd_types.h:358
@ action_param_write
Definition: amxd_types.h:113
enum _amxd_action amxd_action_t
enum _amxd_status amxd_status_t
@ amxd_status_invalid_attr
Definition: amxd_types.h:87
@ amxd_status_function_not_implemented
Definition: amxd_types.h:83
@ amxd_status_ok
Definition: amxd_types.h:78
@ amxd_status_unknown_error
Definition: amxd_types.h:79
@ amxd_status_invalid_value
Definition: amxd_types.h:88
@ amxd_object_instance
Definition: amxd_types.h:186
amxd_object_t * amxd_object_get_parent(const amxd_object_t *const object)
Get the parent object.
static amxd_object_type_t amxd_object_get_type(const amxd_object_t *const object)
Returns the object type.
Definition: amxd_object.h:586
uint32_t read_only
Definition: amxd_types.h:374
amxc_var_t value
Definition: amxd_types.h:390
amxd_param_attr_t attr
Definition: amxd_types.h:388
static amxd_status_t status