Wednesday, April 13, 2011

Sharepoint List/Doc Lib Related Code.

If you dont want to remember all Powershell commands for Sharepoint


1)


-----------------------------------------------------------------------------------------------------------------------------------
Write Log

  public void WriteULSTrace(string Message)
        {
            SPDiagnosticsService.Local.WriteTrace(0, new SPDiagnosticsCategory("EFormsGrid", TraceSeverity.Medium, EventSeverity.Information), TraceSeverity.Medium, Message, null);
        }





-----------------------------------------------------------------------------------------------------------------------------------
BatchProcessData  to delete files from document library



    private static void DeleteFiles()
        {
            string strSitename = ConfigurationManager.AppSettings["SITENAME"];
            string strDocLibName = ConfigurationManager.AppSettings["DOCLIBNAME"];

            using (SPSite site = new SPSite(strSitename))
            {

                using (SPWeb web = site.OpenWeb())
                {
                    SPList CurrentList = web.Lists[strDocLibName];
                 
                    StringBuilder sbDelete = new StringBuilder();
                    sbDelete.Append("<?xml version=\"1.0\" encoding=\"UTF-8\"?><Batch>");

                    int i = 0;
                    foreach (SPListItem item in CurrentList.Items)
                    {
                        SPFile file = item.File;

                        sbDelete.Append("<Method>");
                        sbDelete.Append("<SetList Scope=\"Request\">" + CurrentList.ID + "</SetList>");
                        sbDelete.Append("<SetVar Name=\"ID\">" + Convert.ToString(item.ID) + "</SetVar>");
                        sbDelete.Append("<SetVar Name=\"owsfileref\">" + file.ServerRelativeUrl + "</SetVar>");
                        sbDelete.Append("<SetVar Name=\"Cmd\">Delete</SetVar>");
                        sbDelete.Append("</Method>");
                        i++;
                    }

                    sbDelete.Append("</Batch>");

                    try
                    {
                        web.ProcessBatchData(sbDelete.ToString());
                    }
                    catch (Exception ex)
                    {

                        System.Diagnostics.EventLog.WriteEntry(ex.Source, ex.Message);
                    }


                }
            }

        }



-----------------------------------------------------------------------------------------------------------------------------------
Opening a New Window from server side code (asp.net)

<script language="javascript" type="text/javascript">

    function openNewWin(url) {

        var x = window.open(url, 'mynewwin', 'width=5,height=5,toolbar=1');

        //  x.focus();

    }

</script>


server side code
 this.Page.ClientScript.RegisterStartupScript(this.GetType(), "OpenWin", "<script>openNewWin('" + tmpUrl + "')</script>");


------------------------------------------------------------------------------------------------------------



Enumerating thought the Fields excluding Hidden and read only fields

foreach (SPListItem item in list.Items) {
foreach (SPField field in list.Fields) {
if (!field.Hidden && !field.ReadOnlyField)
Console.WriteLine("{0} = {1}", field.Title, item[field.Id]);
}
}
foreach (SPListItem item in list.Items) {
foreach (SPField field in list.Fields) {
if (!field.Hidden && !field.ReadOnlyField)
Console.WriteLine("{0} = {1}", field.Title, item[field.Id]);
}
}
-------------------------------------------------------------------------------------------------------------
SPSiteDataQuery Class
Imagine a scenario in which you want to run a single query against every list in the current site collection that has been created from the Announcements list type and return all list items that were created today. The following code sample demonstrates how to do this by creating an SPSiteDataQuery object, initializing it with the necessary CAML statements, and then passing it to the current SPWeb object’s GetSiteData method.

SPSiteDataQuery query = new SPSiteDataQuery();
query.Lists = @"";
query.ViewFields = @"";
query.Webs = "";

string queryText = @" ";


query.Query = queryText;

DataTable table = site.GetSiteData(query);

foreach (DataRow row in table.Rows) {
Console.WriteLine(row["Title"].ToString());
}

Using SPQuery to query specific items in the list
To get back specific results within a list, you can use the SPQuery object. When you use an SPQuery object, you will create CAML statements to select specific data within the target list. To select announcements that have expired, you may want to use a query built with CAML statements, as shown in the following example:
SPQuery query = new SPQuery();
query.ViewFields = @"";
query.Query =
@"
";

SPList list = site.Lists["Litware News"];
SPListItemCollection items = list.GetItems(query);
foreach (SPListItem expiredItem in items) {
Console.WriteLine(expiredItem["Title"]);
}
You must specify the fields you want returned in the query by using the ViewFields property. Also note that you must specify the fields in terms of the field Name, and not DisplayName. If you attempt to access fields without specifying them in ViewFields, you will experience an exception of type ArgumentException

-------------------------------------------------------------------------------------------------------------
Update a file to the Document Library
SPSite site = new SPSite("http://sharepoint:8558/");
SPWeb web = site.OpenWeb();
web.AllowUnsafeUpdates = true;
FileStream fs = File.Open(@"C:\Test.txt",FileMode.OpenOrCreate,FileAccess.Read);
SPFolder myfolder = web.Folders["Documents"];
myfolder.Files.Add("Test.txt", fs);
myfolder.Update();
web.AllowUnsafeUpdates = false;

Running a Code with Elevated Permissions
SPSecurity.RunWithElevatedPrivileges(delegate()
{
// do something
});

-------------------------------------------------------------------------------------------------------------
Check if list is of the type Document Library or Not
public bool CkechIfListisDocLib(SPList list) {
if (list is SPDocumentLibrary)
return true;
else
return false;
}