⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 base_unsubscribe.c

📁 jabber server jabber server jabber server jabber server
💻 C
字号:
/* -------------------------------------------------------------------------- * * License * * The contents of this file are subject to the Jabber Open Source License * Version 1.0 (the "JOSL").  You may not copy or use this file, in either * source code or executable form, except in compliance with the JOSL. You * may obtain a copy of the JOSL at http://www.jabber.org/ or at * http://www.opensource.org/.   * * Software distributed under the JOSL is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied.  See the JOSL * for the specific language governing rights and limitations under the * JOSL. * * Copyrights *  * Portions created by or assigned to Jabber.com, Inc. are  * Copyright (c) 1999-2002 Jabber.com, Inc.  All Rights Reserved.  Contact * information for Jabber.com, Inc. is available at http://www.jabber.com/. * * Portions Copyright (c) 1998-1999 Jeremie Miller. *  * Acknowledgements *  * Special thanks to the Jabber Open Source Contributors for their * suggestions and support of Jabber. *  * Alternatively, the contents of this file may be used under the terms of the * GNU General Public License Version 2 or later (the "GPL"), in which case * the provisions of the GPL are applicable instead of those above.  If you * wish to allow use of your version of this file only under the terms of the * GPL and not to allow others to use your version of this file under the JOSL, * indicate your decision by deleting the provisions above and replace them * with the notice and other provisions required by the GPL.  If you do not * delete the provisions above, a recipient may use your version of this file * under either the JOSL or the GPL.  *  *  * --------------------------------------------------------------------------*//** * @file base_unsubscribe.c * @brief base module base_unsubscribe: bounces messages and iqs, on receiving presences it sends unsubscribes * * This module is intended to be used, if the administrator of a server * discovers, that users of his server still have contacts on their rosters * for which there is no server anymore. Instead of getting the logging messages * telling about delivery failures, the admin can automatically create unsubscribes * to remove the contacts from the users' rosters and create bounces for other * stanzas. */#include "jabberd.h"/** * generate and send unsubscribe/unsubscribed packets * * @param id the instance we are running in * @param replied_stanza the stanza where sender and recipient address can be get from * @param type of reply to generate, either "unsubscribe" or "unsubscribed" */void base_unsubscribe_bounce_presence(instance id, xmlnode replied_stanza, const char* type) {    xmlnode reply = NULL;    const char *from = xmlnode_get_attrib(replied_stanza, "to");    const char *to = xmlnode_get_attrib(replied_stanza, "from");    reply = xmlnode_new_tag("presence");    xmlnode_put_attrib(reply, "from", from);    xmlnode_put_attrib(reply, "to", to);    xmlnode_put_attrib(reply, "type", type);    deliver(dpacket_new(reply), id);    /* deliver() already freed the pool of the reply xmlnode ... */    log_notice(id->id, "sent %s to %s for %s", type, to, from);}/** * handle stanza/packet deliveries to the base_unsubscribe module * * @param id the instance that handles the packet * @param p the packet to be handled * @param arg bounce reason (char *) * @return r_ERR on error, r_DONE if the packet is handled */result base_unsubscribe_deliver(instance id, dpacket p, void* arg) {    jpacket packet_to_handle = NULL;    /* check the params */    if (id == NULL || p == NULL) {	return r_ERR;    }    /* make a packet, as it is easier to be handled */    packet_to_handle = jpacket_new(p->x);    /* different actions base on packet types */    switch (packet_to_handle->type) {	case JPACKET_MESSAGE:	case JPACKET_IQ:	    deliver_fail(p, arg ? arg : "Destination blocked by server administrator");	    return r_DONE;	case JPACKET_PRESENCE:	    switch (packet_to_handle->subtype) {		/* we got presence -> unsubscribe */		case JPACKET__AVAILABLE:		case JPACKET__INVISIBLE:		    base_unsubscribe_bounce_presence(id, p->x, "unsubscribe");		    break;		/* we got probes -> unsubscribed */		case JPACKET__PROBE:		    base_unsubscribe_bounce_presence(id, p->x, "unsubscribed");		    break;	    }	    break;	case JPACKET_S10N:	    /* deny subscription requests */	    if (j_strcmp(xmlnode_get_attrib(p->x, "type"), "subscribe") == 0) {		base_unsubscribe_bounce_presence(id, p->x, "unsubscribed");	    }	    break;    }    /* we did not bounce or deliver the packet we got, free it */    pool_free(p->p);    return r_DONE;}/** * configuration handling * * @param id the instance to handle the configuration for, NULL for only validating the configuration * @param x the <unsubscribe/> element that has to be processed * @param arg unused/ignored * @return r_ERR on error, r_PASS on success */result base_unsubscribe_config(instance id, xmlnode x, void *arg) {    /* nothing has to be done for configuration validation */    if(id == NULL) {        return r_PASS;    }    log_debug2(ZONE, LOGT_INIT|LOGT_CONFIG, "base_unsubscribe configuring instance %s", id->id);    if(id->type != p_NORM) {        log_alert(NULL, "ERROR in instance %s: <unsubscribe>..</unsubscribe> element only allowed in service sections", id->id);        return r_ERR;    }    register_phandler(id, o_DELIVER, base_unsubscribe_deliver, (void*)xmlnode_get_data(x));    return r_DONE;}/** * load the base_unsubscribe base module by registering a configuration handler for <unsubscribe/> */void base_unsubscribe(void) {    log_debug2(ZONE, LOGT_INIT, "base_unsubscribe loading...");    register_config("unsubscribe",base_unsubscribe_config,NULL);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -