From 16cfb7b8c05358dd13b62cb9f021ccf0beb9e1f9 Mon Sep 17 00:00:00 2001 From: Wim Taymans Date: Tue, 9 Jul 2013 16:09:07 +0200 Subject: [PATCH] test: add permissions to auth test Ass some permissions to the media factory in the test. --- examples/test-auth.c | 46 +++++++++++++++++++++++++++++++++++++--------- 1 file changed, 37 insertions(+), 9 deletions(-) diff --git a/examples/test-auth.c b/examples/test-auth.c index 75455de..b4fc62a 100644 --- a/examples/test-auth.c +++ b/examples/test-auth.c @@ -65,8 +65,7 @@ main (int argc, char *argv[]) GstRTSPToken *token; gchar *basic; GstStructure *s; - gchar *role_user[] = { "user", NULL }; - gchar *role_admin[] = { "admin", NULL }; + GstRTSPPermissions *permissions; gst_init (&argc, &argv); @@ -90,10 +89,28 @@ main (int argc, char *argv[]) "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_mount_points_add_factory (mounts, "/test", factory); + /* allow user and admin to access this resource */ + permissions = gst_rtsp_permissions_new (); + gst_rtsp_permissions_add_role (permissions, "user", + gst_structure_new ("user", + "media.factory.access", G_TYPE_BOOLEAN, TRUE, + "media.factory.construct", G_TYPE_BOOLEAN, TRUE, NULL)); + gst_rtsp_permissions_add_role (permissions, "admin", + gst_structure_new ("admin", + "media.factory.access", G_TYPE_BOOLEAN, TRUE, + "media.factory.construct", G_TYPE_BOOLEAN, TRUE, NULL)); + /* admin2 can look at the media but not construct so he gets a + * 401 Unauthorized */ + gst_rtsp_permissions_add_role (permissions, "admin2", + gst_structure_new ("admin2", + "media.factory.access", G_TYPE_BOOLEAN, TRUE, + "media.factory.construct", G_TYPE_BOOLEAN, FALSE, NULL)); + gst_rtsp_media_factory_set_permissions (factory, permissions); + gst_rtsp_permissions_unref (permissions); + /* make another factory */ factory = gst_rtsp_media_factory_new (); gst_rtsp_media_factory_set_launch (factory, "( " @@ -102,6 +119,17 @@ main (int argc, char *argv[]) /* attach the test factory to the /test url */ gst_rtsp_mount_points_add_factory (mounts, "/test2", factory); + /* allow admin2 to access this resource */ + permissions = gst_rtsp_permissions_new (); + /* user and admin have no permissions so they can't even see the + * media and get a 404 Not Found */ + gst_rtsp_permissions_add_role (permissions, "admin2", + gst_structure_new ("admin2", + "media.factory.access", G_TYPE_BOOLEAN, TRUE, + "media.factory.construct", G_TYPE_BOOLEAN, TRUE, NULL)); + gst_rtsp_media_factory_set_permissions (factory, permissions); + gst_rtsp_permissions_unref (permissions); + /* don't need the ref to the mapper anymore */ g_object_unref (mounts); @@ -111,8 +139,8 @@ main (int argc, char *argv[]) /* make user token */ token = gst_rtsp_token_new (); s = gst_rtsp_token_writable_structure (token); - gst_structure_set (s, "manager.role", G_TYPE_STRING, "user", NULL); - gst_structure_set (s, "factory.media.roles", G_TYPE_STRV, role_user, NULL); + gst_structure_set (s, "resources.class", G_TYPE_STRING, "user", NULL); + gst_structure_set (s, "media.factory.role", G_TYPE_STRING, "user", NULL); basic = gst_rtsp_auth_make_basic ("user", "password"); gst_rtsp_auth_add_basic (auth, basic, token); g_free (basic); @@ -121,8 +149,8 @@ main (int argc, char *argv[]) /* make admin token */ token = gst_rtsp_token_new (); s = gst_rtsp_token_writable_structure (token); - gst_structure_set (s, "manager.role", G_TYPE_STRING, "admin", NULL); - gst_structure_set (s, "factory.media.roles", G_TYPE_STRV, role_admin, NULL); + gst_structure_set (s, "resources.class", G_TYPE_STRING, "admin", NULL); + gst_structure_set (s, "media.factory.role", G_TYPE_STRING, "admin", NULL); basic = gst_rtsp_auth_make_basic ("admin", "power"); gst_rtsp_auth_add_basic (auth, basic, token); g_free (basic); @@ -131,8 +159,8 @@ main (int argc, char *argv[]) /* make admin2 token */ token = gst_rtsp_token_new (); s = gst_rtsp_token_writable_structure (token); - gst_structure_set (s, "manager.role", G_TYPE_STRING, "admin", NULL); - gst_structure_set (s, "factory.media.roles", G_TYPE_STRV, role_admin, NULL); + gst_structure_set (s, "resources.class", G_TYPE_STRING, "admin", NULL); + gst_structure_set (s, "media.factory.role", G_TYPE_STRING, "admin2", NULL); basic = gst_rtsp_auth_make_basic ("admin2", "power2"); gst_rtsp_auth_add_basic (auth, basic, token); g_free (basic); -- 2.7.4