#include <gst/rtsp-server/rtsp-server.h>
+/* define this if you want the resource to only be available when using
+ * user/admin as the password */
+#undef WITH_AUTH
+/* this timeout is periodically run to clean up the expired sessions from the
+ * pool. This needs to be run explicitly currently but might be done
+ * automatically as part of the mainloop. */
static gboolean
-timeout (GstRTSPServer *server, gboolean ignored)
+timeout (GstRTSPServer * server, gboolean ignored)
{
GstRTSPSessionPool *pool;
GstRTSPServer *server;
GstRTSPMediaMapping *mapping;
GstRTSPMediaFactory *factory;
+#ifdef WITH_AUTH
+ GstRTSPAuth *auth;
+ gchar *basic;
+#endif
gst_init (&argc, &argv);
* that be used to map uri mount points to media factories */
mapping = gst_rtsp_server_get_media_mapping (server);
+#ifdef WITH_AUTH
+ /* make a new authentication manager. it can be added to control access to all
+ * the factories on the server or on individual factories. */
+ auth = gst_rtsp_auth_new ();
+ basic = gst_rtsp_auth_make_basic ("user", "admin");
+ gst_rtsp_auth_set_basic (auth, basic);
+ g_free (basic);
+ /* configure in the server */
+ gst_rtsp_server_set_auth (server, auth);
+#endif
+
/* make a media factory for a test stream. The default media factory can use
* gst-launch syntax to create pipelines.
* any launch line works as long as it contains elements named pay%d. Each
* element with pay%d names will be a stream */
factory = gst_rtsp_media_factory_new ();
gst_rtsp_media_factory_set_launch (factory, "( "
- "videotestsrc ! video/x-raw-yuv,width=352,height=288,framerate=15/1 ! "
- "x264enc ! rtph264pay name=pay0 pt=96 "
- "audiotestsrc ! audio/x-raw-int,rate=8000 ! "
- "alawenc ! rtppcmapay name=pay1 pt=97 "
- ")");
+ "videotestsrc ! video/x-raw,width=352,height=288,framerate=15/1 ! "
+ "x264enc ! rtph264pay name=pay0 pt=96 "
+ "audiotestsrc ! audio/x-raw,rate=8000 ! "
+ "alawenc ! rtppcmapay name=pay1 pt=97 " ")");
/* attach the test factory to the /test url */
gst_rtsp_media_mapping_add_factory (mapping, "/test", factory);
if (gst_rtsp_server_attach (server, NULL) == 0)
goto failed;
- g_timeout_add_seconds (2, (GSourceFunc) timeout, server);
+ /* add a timeout for the session cleanup */
+ g_timeout_add_seconds (2, (GSourceFunc) timeout, server);
- /* start serving */
+ /* start serving, this never stops */
+ g_print ("stream ready at rtsp://127.0.0.1:8554/test\n");
g_main_loop_run (loop);
return 0;