HEX
Server: Microsoft-IIS/8.5
System: Windows NT YDAWBH120 6.3 build 9600 (Windows Server 2012 R2 Standard Edition) AMD64
User: tentjecom_web (0)
PHP: 7.4.14
Disabled: NONE
Upload Files
File: D:/HostingSpaces/RMourik/bassol.nl/CMS/CMSWebParts/Community/Profile/GroupSecurityMessage.ascx.cs
using System;
using System.Web;
using System.Web.UI;

using CMS.Community;
using CMS.Helpers;
using CMS.MacroEngine;
using CMS.PortalControls;
using CMS.PortalEngine;
using CMS.Base;
using CMS.DocumentEngine;
using CMS.SiteProvider;
using CMS.URLRewritingEngine;
using CMS.DataEngine;
using CMS.Membership;

public partial class CMSWebParts_Community_Profile_GroupSecurityMessage : CMSAbstractWebPart
{
    #region "Public properties"

    /// <summary>
    /// Gets or sets the text which should be displayed if group content is available only to site members.
    /// </summary>
    public string SiteMembersOnlyText
    {
        get
        {
            return DataHelper.GetNotEmpty(GetValue("SiteMembersOnlyText"), GetString("group.SiteMembersOnlyText"));
        }
        set
        {
            SetValue("SiteMembersOnlyText", value);
        }
    }


    /// <summary>
    /// Gets or sets the text which should be displayed if group content is available only to its members.
    /// </summary>
    public string GroupMembersOnlyText
    {
        get
        {
            return DataHelper.GetNotEmpty(GetValue("GroupMembersOnlyText"), GetString("group.GroupMembersOnlyText"));
        }
        set
        {
            SetValue("GroupMembersOnlyText", value);
        }
    }


    /// <summary>
    /// Gets or sets the text which should be displayed if group content is available only to its members and current user is site member.
    /// </summary>
    public string GroupMembersOnlyAuthenticatedText
    {
        get
        {
            return DataHelper.GetNotEmpty(GetValue("GroupMembersOnlyAuthenticatedText"), GetString("group.GroupMembersOnlyAuthenticatedText"));
        }
        set
        {
            SetValue("GroupMembersOnlyAuthenticatedText", value);
        }
    }


    /// <summary>
    /// URL where public user will be redirected.
    /// </summary>
    public string LoginURL
    {
        get
        {
            return ResolveUrl(DataHelper.GetNotEmpty(GetValue("LoginURL"), SettingsKeyInfoProvider.GetValue(SiteContext.CurrentSiteName + ".CMSSecuredAreasLogonPage")));
        }
        set
        {
            SetValue("LoginURL", value);
        }
    }


    /// <summary>
    /// Path to join group page.
    /// </summary>
    public string JoinGroupPath
    {
        get
        {
            // Get path from path selector
            string joinGroupPath = ValidationHelper.GetString(GetValue("JoinGroupPath"), "");

            // If not empty then transform alias path to link
            if (joinGroupPath != "")
            {
                joinGroupPath = URLHelper.ResolveUrl(DocumentURLProvider.GetUrl(MacroResolver.ResolveCurrentPath(joinGroupPath)));
            }

            return joinGroupPath;
        }
        set
        {
            SetValue("JoinGroupPath", value);
        }
    }

    #endregion


    /// <summary>
    /// Content loaded event handler.
    /// </summary>
    public override void OnContentLoaded()
    {
        base.OnContentLoaded();
        SetupControl();
    }


    /// <summary>
    /// Redirect to group page.
    /// </summary>
    /// <param name="group">Group info</param>
    private static void RedirectToGroupPage(GroupInfo group)
    {
        if ((group != null) && PortalContext.ViewMode.IsLiveSite())
        {
            URLHelper.Redirect(DocumentURLProvider.GetUrl(GroupInfoProvider.GetGroupProfilePath(group.GroupName, SiteContext.CurrentSiteName)));
        }
    }


    /// <summary>
    /// Initializes the control properties.
    /// </summary>
    protected void SetupControl()
    {
        if (StopProcessing)
        {
            // Do nothing
        }
        else
        {
            GroupInfo group = null;

            // Try to get group information from query string
            int groupId = QueryHelper.GetInteger("groupid", 0);
            group = (groupId > 0) ? GroupInfoProvider.GetGroupInfo(groupId) : CommunityContext.CurrentGroup;

            if (group != null)
            {
                // Check whether group is approved
                if (!group.GroupApproved)
                {
                    lblAccessInfo.Text = GetString("group.groupnotavailable");
                }
                else
                {
                    // Check permissions for current user
                    switch (group.GroupAccess)
                    {
                            // Anybody can view the content
                        default:
                        case SecurityAccessEnum.AllUsers:
                            // If content for selected group is available for all users redirect back to group page
                            RedirectToGroupPage(group);
                            break;

                            // Site members can view the content
                        case SecurityAccessEnum.AuthenticatedUsers:
                            if (!AuthenticationHelper.IsAuthenticated())
                            {
                                lblAccessInfo.Text = String.Format(SiteMembersOnlyText, "<a title=\"Sign in\" href=\"" + URLHelper.UpdateParameterInUrl(LoginURL, "returnurl", Server.UrlEncode(RequestContext.CurrentURL)) + "\">", "</a>");
                            }
                            else
                            {
                                RedirectToGroupPage(group);
                            }
                            break;

                            // Only group members can view the content
                        case SecurityAccessEnum.GroupMembers:
                            if (!MembershipContext.AuthenticatedUser.IsGroupMember(group.GroupID))
                            {
                                // If current user is public show text with sign in link
                                if (!AuthenticationHelper.IsAuthenticated())
                                {
                                    lblAccessInfo.Text = String.Format(GroupMembersOnlyText, "<a title=\"Sign in\" href=\"" + URLHelper.UpdateParameterInUrl(LoginURL, "returnurl", Server.UrlEncode(RequestContext.CurrentURL)) + "\">", "</a>");
                                }
                                else
                                {
                                    // For authenticate users display text with join the group text
                                    string link = string.Empty;

                                    // If join group path is defined use it, otherwise display join the group dialog
                                    if (String.IsNullOrEmpty(JoinGroupPath))
                                    {
                                        // Register the dialog script
                                        ScriptHelper.RegisterDialogScript(Page);

                                        string script = ScriptHelper.GetScript("function JoinToGroupAccessRequest() {\n" +
                                                                               "modalDialog('" + AuthenticationHelper.ResolveDialogUrl("~/CMSModules/Groups/CMSPages/JoinTheGroup.aspx") + "?groupid=" + group.GroupID + "','requestJoinToGroup', 500, 180); \n" +
                                                                               " } \n");
                                        ScriptHelper.RegisterClientScriptBlock(this, typeof(string), "JoinToGroupAccessRequest", script);

                                        link = "<a title=\"" + GetString("group.joingroup") + "\" href=\"" + RequestContext.CurrentURL + "\" onclick=\"JoinToGroupAccessRequest(); return false;\">";
                                    }
                                    else
                                    {
                                        link = "<a title=\"" + GetString("group.joingroup") + "\" href=\"" + JoinGroupPath + "\">";
                                    }

                                    lblAccessInfo.Text = String.Format(GroupMembersOnlyAuthenticatedText, link, "</a>");
                                }
                            }
                            else
                            {
                                RedirectToGroupPage(group);
                            }
                            break;
                    }
                }
            }
            else
            {
                Visible = false;
            }
        }
    }
}