Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
69aaa19
commit f9fec46
Showing
4 changed files
with
340 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# WARNING: do not run this directly, it should be run by the master Makefile | ||
|
||
include ../../Makefile.defs | ||
auto_gen= | ||
NAME=uuid.so | ||
|
||
ifeq ($(CROSS_COMPILE),) | ||
LIBS=-luuid | ||
DEFS+=-I$(SYSBASE)/include/uuid | ||
else | ||
DEFS+=-I$(SYSBASE)/include/uuid -I$(LOCALBASE)/include/uuid \ | ||
-I$(LOCALBASE)/include | ||
LIBS=-L$(SYSBASE)/include/lib -L$(LOCALBASE)/lib -luuid | ||
endif | ||
|
||
include ../../Makefile.modules |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
<?xml version="1.0" encoding='UTF-8'?> | ||
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN" | ||
"http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" [ | ||
|
||
|
||
<!ENTITY admin SYSTEM "uuid_admin.xml"> | ||
<!ENTITY contrib SYSTEM "contributors.xml"> | ||
|
||
|
||
<!-- Include general documentation entities --> | ||
<!ENTITY % docentities SYSTEM "../../../doc/entities.xml"> | ||
%docentities; | ||
|
||
]> | ||
|
||
<book> | ||
<bookinfo> | ||
<title>UUID Module</title> | ||
<productname class="trade">&osipsname;</productname> | ||
</bookinfo> | ||
<toc></toc> | ||
|
||
&admin; | ||
&contrib; | ||
|
||
&docCopyrights; | ||
<para>©right; 2019 &osipssol;</para> | ||
</book> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,131 @@ | ||
<!-- Module User's Guide --> | ||
|
||
<chapter> | ||
<title>&adminguide;</title> | ||
|
||
<section id="overview" xreflabel="Overview"> | ||
<title>Overview</title> | ||
|
||
<para> This module provides a way to generate universally unique identifiers | ||
(UUID) as specified in RFC 4122. The UUID is provided as a string | ||
representation by reading the <xref linkend="pv_uuid"/> | ||
pseudo-variable or calling the <xref linkend="func_uuid"/> | ||
script function. | ||
</para> | ||
</section> | ||
|
||
<section id="dependencies" xreflabel="Dependencies"> | ||
<title>Dependencies</title> | ||
|
||
<section> | ||
<title>&osips; Modules</title> | ||
<para> | ||
This module does not depend on other modules. | ||
</para> | ||
</section> | ||
<section> | ||
<title>External Libraries or Applications</title> | ||
<itemizedlist> | ||
<listitem> | ||
<para> <emphasis>libuuid</emphasis> - part of the util-linux | ||
package, can be downloaded from: | ||
ftp://ftp.kernel.org/pub/linux/utils/util-linux/</para> | ||
</listitem> | ||
</itemizedlist> | ||
</section> | ||
</section> | ||
|
||
<section id="exported_parameters" xreflabel="Exported Parameters"> | ||
<title>Exported Parameters</title> | ||
<para> | ||
The module does not export any parameters. | ||
</para> | ||
</section> | ||
|
||
<section id="exported_pseudo_variables" xreflabel="Exported Pseudo-Variables"> | ||
<title>Exported Pseudo-Variables</title> | ||
|
||
<section id="pv_uuid" xreflabel="$uuid"> | ||
<title><varname>$uuid</varname></title> | ||
<para> | ||
The <emphasis>$uuid</emphasis> variable returns a newly generated | ||
version 4 UUID based on high-quality randomness from /dev/urandom, | ||
if available. Otherwise, a version 1 UUID (based on | ||
current time and the local ethernet MAC address) will be generated. | ||
</para> | ||
|
||
<example> | ||
<title>$uuid usage</title> | ||
<programlisting format="linespecific"> | ||
xlog("generated uuid: $uuid\n"); | ||
</programlisting> | ||
</example> | ||
|
||
</section> | ||
</section> | ||
|
||
<section id="exported_functions" xreflabel="exported_functions"> | ||
<title>Exported Functions</title> | ||
|
||
<section id="func_uuid" xreflabel="uuid()"> | ||
<title> | ||
<function moreinfo="none"> | ||
uuid(out_var, [version]) | ||
</function> | ||
</title> | ||
<para> | ||
Generates a new UUID. | ||
</para> | ||
<itemizedlist> | ||
<listitem> | ||
<para> | ||
<emphasis>out_var</emphasis> - an output variable | ||
to return the generated UUID. | ||
</para> | ||
</listitem> | ||
<listitem> | ||
<para> | ||
<emphasis>version</emphasis> (optional) - UUID version | ||
number. The supported values are: | ||
<itemizedlist> | ||
<listitem> | ||
<para><emphasis>0</emphasis> - a RFC version 4 or | ||
version 1 UUID will be generated, depending on the | ||
availability of high-quality randomness from | ||
/dev/urandom. This is the default behavior, if the | ||
<emphasis>version</emphasis> parameter is missing.</para> | ||
</listitem> | ||
<listitem> | ||
<para><emphasis>1</emphasis> - version 1 UUID | ||
based on current time and the local ethernet MAC | ||
address</para> | ||
</listitem> | ||
<listitem> | ||
<para><emphasis>4</emphasis> - version 4 UUID | ||
based on a high-quality random number generator. If | ||
not available, a pseudo-random generator will be | ||
substituted.</para> | ||
</listitem> | ||
</itemizedlist> | ||
</para> | ||
</listitem> | ||
</itemizedlist> | ||
<para> | ||
If UUID version 1 is used, the function will return the value | ||
<emphasis>2</emphasis> if the UUID was generated in an unsafe | ||
manner. This refers to the posibility of two concurrently | ||
running processes generating the same UUID, in cases where | ||
synchronization mechanisms are not available (more details | ||
can be found in the <emphasis>uuid_generate</emphasis> man pages | ||
of <emphasis>libuuid</emphasis>). | ||
</para> | ||
<para> | ||
This function can be used from any route. | ||
</para> | ||
|
||
</section> | ||
|
||
</section> | ||
|
||
</chapter> | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,165 @@ | ||
/* | ||
* Copyright (C) 2019 OpenSIPS Solutions | ||
* | ||
* This file is part of opensips, a free SIP server. | ||
* | ||
* opensips is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License as published by | ||
* the Free Software Foundation; either version 2 of the License, or | ||
* (at your option) any later version | ||
* | ||
* opensips is distributed in the hope that it will be useful, | ||
* but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
* GNU General Public License for more details. | ||
* | ||
* You should have received a copy of the GNU General Public License | ||
* along with this program; if not, write to the Free Software | ||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | ||
* | ||
*/ | ||
|
||
#include "../../sr_module.h" | ||
#include "../../mod_fix.h" | ||
#include "../../dprint.h" | ||
|
||
#include <uuid/uuid.h> | ||
|
||
#define UUID_STR_BUFSIZE 37 | ||
|
||
#define RET_OK 1 | ||
#define RET_UNSAFE 2 | ||
|
||
enum uuid_gen_vers { | ||
UUID_VERS_0 = 0, /* generate either RFC verison 1 or 4 */ | ||
UUID_VERS_1 = 1, | ||
UUID_VERS_4 = 4, | ||
}; | ||
|
||
static uuid_t uuid; | ||
static char uuid_str[UUID_STR_BUFSIZE]; | ||
|
||
static int fixup_check_var(void** param); | ||
static int w_uuid(struct sip_msg *msg, pv_spec_t *out_var, int *vers_param); | ||
|
||
static int pv_get_uuid(struct sip_msg *msg, pv_param_t *param, | ||
pv_value_t *res); | ||
|
||
static pv_export_t mod_items[] = { | ||
{{"uuid", sizeof("uuid")-1}, 1000, pv_get_uuid, 0, 0, 0, 0, 0}, | ||
{{0, 0}, 0, 0, 0, 0, 0, 0, 0} | ||
}; | ||
|
||
static cmd_export_t cmds[] = { | ||
{"uuid", (cmd_function)w_uuid, { | ||
{CMD_PARAM_VAR, fixup_check_var, 0}, | ||
{CMD_PARAM_INT | CMD_PARAM_OPT, 0, 0}, {0,0,0}}, | ||
ALL_ROUTES}, | ||
{0,0,{{0,0,0}},0} | ||
}; | ||
|
||
struct module_exports exports= { | ||
"uuid", /* module's name */ | ||
MOD_TYPE_DEFAULT,/* class of this module */ | ||
MODULE_VERSION, | ||
DEFAULT_DLFLAGS, /* dlopen flags */ | ||
0, /* load function */ | ||
0, /* OpenSIPS module dependencies */ | ||
cmds, /* exported functions */ | ||
0, /* exported async functions */ | ||
0, /* param exports */ | ||
0, /* exported statistics */ | ||
0, /* exported MI functions */ | ||
mod_items, /* exported pseudo-variables */ | ||
0, /* exported transformations */ | ||
0, /* extra processes */ | ||
0, /* module initialization function */ | ||
0, /* reply processing function */ | ||
0, | ||
0 /* per-child init function */ | ||
}; | ||
|
||
static int gen_uuid(enum uuid_gen_vers vers, pv_value_t *res) | ||
{ | ||
int rc = RET_OK; | ||
|
||
switch (vers) { | ||
case UUID_VERS_0: | ||
uuid_generate(uuid); | ||
break; | ||
case UUID_VERS_1: | ||
rc = uuid_generate_time_safe(uuid) ? RET_UNSAFE : RET_OK; | ||
break; | ||
case UUID_VERS_4: | ||
uuid_generate_random(uuid); | ||
break; | ||
default: | ||
LM_BUG("Bad UUID generation algorithm selected\n"); | ||
return -1; | ||
} | ||
|
||
LM_DBG("Generated UUID version: %d\n", uuid_type(uuid)); | ||
|
||
uuid_unparse(uuid, uuid_str); | ||
res->rs.s = uuid_str; | ||
res->rs.len = UUID_STR_BUFSIZE-1; | ||
res->flags = PV_VAL_STR; | ||
|
||
return rc; | ||
} | ||
|
||
static int pv_get_uuid(struct sip_msg *msg, pv_param_t *param, | ||
pv_value_t *res) | ||
{ | ||
if (gen_uuid(UUID_VERS_0, res) == RET_UNSAFE) | ||
LM_DBG("Version 2 UUID generated unsafely\n"); | ||
|
||
return 0; | ||
} | ||
|
||
static int fixup_check_var(void** param) | ||
{ | ||
if (((pv_spec_t*)*param)->setf==NULL) { | ||
LM_ERR("Output parameter is not a writable variable\n"); | ||
return E_SCRIPT; | ||
} | ||
|
||
return 0; | ||
} | ||
|
||
static int w_uuid(struct sip_msg *msg, pv_spec_t *out_var, int *vers_param) | ||
{ | ||
int vers = UUID_VERS_0; | ||
int rc; | ||
pv_value_t out_val; | ||
|
||
if (vers_param) | ||
vers = *vers_param; | ||
|
||
switch (vers) { | ||
case 2: | ||
case 3: | ||
case 5: | ||
LM_WARN("UUID version: %d not supported! Using default algorithm\n", | ||
vers); | ||
vers = UUID_VERS_0; | ||
break; | ||
case UUID_VERS_0: | ||
case UUID_VERS_1: | ||
case UUID_VERS_4: | ||
break; | ||
default: | ||
LM_ERR("Bad UUID version: %d\n", vers); | ||
return -1; | ||
} | ||
|
||
if ((rc = gen_uuid(vers, &out_val)) == RET_UNSAFE) | ||
LM_DBG("Version 1 UUID generated unsafely\n"); | ||
|
||
if (pv_set_value(msg, (pv_spec_t*)out_var, 0, &out_val) != 0) { | ||
LM_ERR("failed to set the output variable!\n"); | ||
return -1; | ||
} | ||
|
||
return rc; | ||
} |