]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
func_uuid: Add a new dialplan function to generate UUIDs
authorMaksim Nesterov <braamsdev@gmail.com>
Sun, 1 Dec 2024 19:42:50 +0000 (19:42 +0000)
committerAsterisk Development Team <asteriskteam@digium.com>
Thu, 23 Jan 2025 18:39:41 +0000 (18:39 +0000)
This function is useful for uniquely identifying calls, recordings, and other entities in distributed environments, as well as for generating an argument for the AudioSocket application.

(cherry picked from commit ba01e712da0204ddc790e17c648030e5e57249c8)

funcs/func_uuid.c [new file with mode: 0644]

diff --git a/funcs/func_uuid.c b/funcs/func_uuid.c
new file mode 100644 (file)
index 0000000..05dfde3
--- /dev/null
@@ -0,0 +1,76 @@
+/*
+* Asterisk -- An open source telephony toolkit.
+ *
+ * Copyright (C) 2024, Maksim Nesterov
+ *
+ * See http://www.asterisk.org for more information about
+ * the Asterisk project. Please do not directly contact
+ * any of the maintainers of this project for assistance;
+ * the project provides a web site, mailing lists and IRC
+ * channels for your use.
+ *
+ * This program is free software, distributed under the terms of
+ * the GNU General Public License Version 2. See the LICENSE file
+ * at the top of the source tree.
+ */
+
+/*! \file
+ *
+ * \brief UUID dialplan function
+ *
+ * \author Maksim Nesterov <braamsdev@gmail.com>
+ *
+ * \ingroup functions
+ */
+
+/*** MODULEINFO
+       <support_level>extended</support_level>
+ ***/
+
+#include "asterisk.h"
+
+#include "asterisk/module.h"
+#include "asterisk/pbx.h"
+#include "asterisk/uuid.h"
+
+/*** DOCUMENTATION
+       <function name="UUID" language="en_US">
+               <synopsis>
+                       Generates an UUID.
+               </synopsis>
+               <syntax>
+               </syntax>
+               <description>
+                       <para>Returns a version 4 (random) Universally Unique Identifier (UUID) as a string.</para>
+                       <example title="Generate an UUID">
+                       same => n,Set(uuid=${UUID()})
+                       </example>
+               </description>
+       </function>
+ ***/
+
+static int uuid(struct ast_channel *chan, const char *cmd, char *data,
+                               char *buf, size_t len)
+{
+       ast_uuid_generate_str(buf, AST_UUID_STR_LEN);
+       return 0;
+}
+
+static struct ast_custom_function uuid_function = {
+       .name = "UUID",
+       .read = uuid,
+       .read_max = AST_UUID_STR_LEN,
+};
+
+static int unload_module(void)
+{
+       return ast_custom_function_unregister(&uuid_function);
+}
+
+static int load_module(void)
+{
+       return ast_custom_function_register(&uuid_function);
+}
+
+AST_MODULE_INFO_STANDARD_EXTENDED(ASTERISK_GPL_KEY,
+                                                                 "UUID generation dialplan function");