[vlc-devel] [PATCH v4 4/4] Add a libdsm based service discovery module to find CIFS speaking host on LAN
Julien 'Lta' BALLET
elthariel at gmail.com
Wed Jul 2 14:58:40 CEST 2014
From: Julien 'Lta' BALLET <contact at lta.io>
---
modules/access/Makefile.am | 2 +-
modules/access/bdsm/access.c | 8 +++
modules/access/bdsm/common.h | 4 ++
modules/access/bdsm/sd.c | 111 +++++++++++++++++++++++++++++++++
modules/services_discovery/Makefile.am | 2 +
5 files changed, 126 insertions(+), 1 deletion(-)
create mode 100644 modules/access/bdsm/sd.c
diff --git a/modules/access/Makefile.am b/modules/access/Makefile.am
index 8bf09b6..170cc0f 100644
--- a/modules/access/Makefile.am
+++ b/modules/access/Makefile.am
@@ -386,7 +386,7 @@ libsmb_plugin_la_LDFLAGS = $(AM_LDFLAGS) -rpath '$(accessdir)'
access_LTLIBRARIES += $(LTLIBsmb)
EXTRA_LTLIBRARIES += libsmb_plugin.la
-libdsm_plugin_la_SOURCES = access/bdsm/access.c \
+libdsm_plugin_la_SOURCES = access/bdsm/access.c access/bdsm/sd.c \
access/bdsm/common.h access/bdsm/browser.c
libdsm_plugin_la_CFLAGS = $(AM_CFLAGS) $(DSM_CFLAGS)
libdsm_plugin_la_LIBADD = $(DSM_LIBS)
diff --git a/modules/access/bdsm/access.c b/modules/access/bdsm/access.c
index 5cf89db..783e1c5 100644
--- a/modules/access/bdsm/access.c
+++ b/modules/access/bdsm/access.c
@@ -73,6 +73,14 @@ vlc_module_begin ()
add_shortcut( "smb", "cifs", "bdsm" )
set_callbacks( Open, Close )
+ add_submodule()
+ set_category( CAT_PLAYLIST )
+ set_subcategory( SUBCAT_PLAYLIST_SD )
+ set_capability( "services_discovery", 0 )
+ set_callbacks( SdOpen, SdClose )
+
+ VLC_SD_PROBE_SUBMODULE
+
vlc_module_end ()
/*****************************************************************************
diff --git a/modules/access/bdsm/common.h b/modules/access/bdsm/common.h
index 7b61d9f..cae5ab7 100644
--- a/modules/access/bdsm/common.h
+++ b/modules/access/bdsm/common.h
@@ -32,6 +32,10 @@
int Open( vlc_object_t * );
void Close( vlc_object_t * );
+int SdOpen( vlc_object_t * );
+void SdClose( vlc_object_t * );
+int vlc_sd_probe_Open( vlc_object_t * );
+
int BrowserInit( access_t *p_access );
struct access_sys_t
diff --git a/modules/access/bdsm/sd.c b/modules/access/bdsm/sd.c
new file mode 100644
index 0000000..ad2c5a0
--- /dev/null
+++ b/modules/access/bdsm/sd.c
@@ -0,0 +1,111 @@
+/**
+ * @file bdsm/sd.c
+ * @brief List host supporting NETBIOS on the local network
+ */
+/*****************************************************************************
+ * Copyright © 2014 Authors and the VideoLAN team
+ *
+ * Authors: - Julien 'Lta' BALLET <contact # lta 'dot' io>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU Lesser General Public License as published by
+ * the Free Software Foundation; either version 2.1 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 Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser 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.
+ *****************************************************************************/
+
+/*****************************************************************************
+ * Preamble
+ *****************************************************************************/
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include "common.h"
+
+struct services_discovery_sys_t
+{
+ netbios_ns *ns;
+};
+
+int vlc_sd_probe_Open (vlc_object_t *p_this)
+{
+ vlc_probe_t *p_probe = (vlc_probe_t *)p_this;
+
+ vlc_sd_probe_Add( p_probe, "dsm{longname=\"Windows networks\"}",
+ N_( "Windows networks" ), SD_CAT_LAN );
+
+ return VLC_PROBE_CONTINUE;
+}
+
+int SdOpen (vlc_object_t *p_this)
+{
+ services_discovery_t *p_sd = (services_discovery_t *)p_this;
+ services_discovery_sys_t *p_sys = malloc (sizeof (*p_sys));
+
+ if( p_sys == NULL )
+ return VLC_ENOMEM;
+ p_sd->p_sys = p_sys;
+
+ /* Let's create a NETBIOS name service object */
+ p_sys->ns = netbios_ns_new();
+ if( p_sys->ns == NULL )
+ goto error;
+
+ if( !netbios_ns_discover( p_sys->ns ) )
+ goto error;
+
+ for( ssize_t i = 0; i < netbios_ns_entry_count( p_sys->ns ); i++ )
+ {
+ netbios_ns_entry *p_entry = netbios_ns_entry_at( p_sys->ns, i );
+
+ if( p_entry->type == 0x20 )
+ {
+ input_item_t *p_item;
+ char *psz_mrl;
+
+ if( asprintf(&psz_mrl, "smb://%s", p_entry->name) < 0 )
+ goto error;
+
+ p_item = input_item_NewWithType( psz_mrl, p_entry->name, 0, NULL,
+ 0, -1, ITEM_TYPE_NODE );
+ msg_Dbg( p_sd, "Adding item %s", psz_mrl );
+
+ services_discovery_AddItem( p_sd, p_item, NULL );
+
+ free( psz_mrl );
+ }
+ }
+
+ return VLC_SUCCESS;
+
+ error:
+ if( p_sys->ns != NULL )
+ netbios_ns_destroy( p_sys->ns );
+ free( p_sys );
+ p_sd->p_sys = NULL;
+
+ return VLC_EGENERIC;
+}
+
+void SdClose (vlc_object_t *p_this)
+{
+ services_discovery_t *sd = (services_discovery_t *)p_this;
+ services_discovery_sys_t *p_sys = sd->p_sys;
+
+ if( p_sys == NULL )
+ return;
+
+ if( p_sys->ns != NULL )
+ netbios_ns_destroy( p_sys->ns );
+}
+
diff --git a/modules/services_discovery/Makefile.am b/modules/services_discovery/Makefile.am
index 11fca94..b526338 100644
--- a/modules/services_discovery/Makefile.am
+++ b/modules/services_discovery/Makefile.am
@@ -68,3 +68,5 @@ libos2drive_plugin_la_SOURCES = services_discovery/os2drive.c
if HAVE_OS2
sd_LTLIBRARIES += libos2drive_plugin.la
endif
+
+sd_LTLIBRARIES += $(LTLIBdsm)
--
2.0.0
More information about the vlc-devel
mailing list