diff options
Diffstat (limited to 'lasso/xml/saml_name_identifier.c')
-rw-r--r-- | lasso/xml/saml_name_identifier.c | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/lasso/xml/saml_name_identifier.c b/lasso/xml/saml_name_identifier.c new file mode 100644 index 00000000..16f03df8 --- /dev/null +++ b/lasso/xml/saml_name_identifier.c @@ -0,0 +1,126 @@ +/* $Id$ + * + * Lasso - A free implementation of the Samlerty Alliance specifications. + * + * Copyright (C) 2004 Entr'ouvert + * http://lasso.entrouvert.org + * + * Author: Valery Febvre <vfebvre@easter-eggs.com> + * + * This program 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. + * + * This program 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +#include <lasso/xml/saml_name_identifier.h> + +/* +The schema fragment (oasis-sstc-saml-schema-assertion-1.0.xsd): + +<element name="NameIdentifier" type="saml:NameIdentifierType"/> +<complexType name="NameIdentifierType"> + <simpleContent> + <extension base="string"> + <attribute name="NameQualifier" type="string" use="optional"/> + <attribute name="Format" type="anyURI" use="optional"/> + </extension> + </simpleContent> +</complexType> +*/ + +/*****************************************************************************/ +/* public methods */ +/*****************************************************************************/ + +void +lasso_saml_name_identifier_set_nameQualifier(LassoSamlNameIdentifier *node, + const xmlChar *nameQualifier) +{ + g_assert(LASSO_IS_SAML_NAME_IDENTIFIER(node)); + g_assert(nameQualifier != NULL); + + LassoNodeClass *class = LASSO_NODE_GET_CLASS(node); + class->set_prop(LASSO_NODE (node), "NameQualifier", nameQualifier); +} + +void +lasso_saml_name_identifier_set_format(LassoSamlNameIdentifier *node, + const xmlChar *format) +{ + g_assert(LASSO_IS_SAML_NAME_IDENTIFIER(node)); + g_assert(format != NULL); + + LassoNodeClass *class = LASSO_NODE_GET_CLASS(node); + class->set_prop(LASSO_NODE (node), "Format", format); +} + +/*****************************************************************************/ +/* instance and class init functions */ +/*****************************************************************************/ + +static void +lasso_saml_name_identifier_instance_init(LassoSamlNameIdentifier *instance) +{ + LassoNode *node = LASSO_NODE(instance); + LassoNodeClass *class = LASSO_NODE_GET_CLASS(node); + + class->new_ns(node, "urn:oasis:names:tc:SAML:1.0:assertion", "saml"); + class->set_name(node, "NameIdentifier"); +} + +static void +lasso_saml_name_identifier_class_init(LassoSamlNameIdentifierClass *klass) +{ +} + +GType lasso_saml_name_identifier_get_type() { + static GType this_type = 0; + + if (!this_type) { + static const GTypeInfo this_info = { + sizeof (LassoSamlNameIdentifierClass), + NULL, + NULL, + (GClassInitFunc) lasso_saml_name_identifier_class_init, + NULL, + NULL, + sizeof(LassoSamlNameIdentifier), + 0, + (GInstanceInitFunc) lasso_saml_name_identifier_instance_init, + }; + + this_type = g_type_register_static(LASSO_TYPE_NODE, + "LassoSamlNameIdentifier", + &this_info, 0); + } + return this_type; +} + +/** + * lasso_saml_name_identifier_new: + * + * Creates a new <saml:NameIdentifier> node object. + * + * Return value: the new @LassoSamlNameIdentifier + **/ +LassoNode* lasso_saml_name_identifier_new(xmlChar *content) +{ + LassoNode *node; + + g_assert(content != NULL); + + node = LASSO_NODE(g_object_new(LASSO_TYPE_SAML_NAME_IDENTIFIER, NULL)); + xmlNodeSetContent(LASSO_NODE_GET_CLASS(node)->get_xmlNode(node), + content); + return (node); +} |