¿Cómo actualizar sub sitios existentes cuando modifiqué la plantilla?

Esta pregunta fue realizada en sharepoint.stackexchange.com y me pareció importante compartir un enfoque que he tomado en una situación similar. Comparto la respuesta que dejé en el foro. Pueden verla en:

Transcripción de mi respuesta
Hola.
Estoy trabajando en un proyecto similar:
– Sitio raíz
– Sitios de proyecto
– Plantillas de sitios de proyecto
Es un proyecto de más de un año bastante complejo.
Me he encontrado con el mismo problema y he analizado diferentes alternativas.
No hay forma de resolver eso automáticamente. Para ello deberías usar definiciones de sitios en lugar de plantillas de sitios. Pero es un enfoque excesivamente complejo y muy poco utilizado.
Has hecho muy bien en utilizar tipos de contenido ya que eso resuelve gran parte del problema.
En mi caso he optado por utilizar el modelo de objetos del servidor para hacer los cambios en los sitios de proyecto ya existentes. Me refiero a C# con Visual Studio. Este modelo es muy poderoso y te permite modificar cosas que uno nunca hubiese imaginado.
Resumen del enfoque:
1) Creas un programa en C# para hacer los cambios mediante código. No utilizas configuración.
2) Ese programa posee un LOOP para recorrer todos los sitios de proyecto y aplicar los cambios
Luego de usar este enfoque, he tomado la decisión de hacer todos los cambios en forma programática. Esto facilita mucho el pasaje entre ambientes de prueba y producción.
Entonces el enfoque pasa a ser crear un programa que:
1) Modifique programaticamente tipos de contenido y columnas de sitio
2) Modifique programáticamente los sitios de proyecto (incluso la plantilla). Me refiero a vistas, elementos web, etc.
3) Crea una nueva plantilla basada en el sitio base y elimine la anterior
Con este enfoque el pasaje entre desarrollo y prueba / producción es limpio y rápido. Es muy robusto. Y actualiza automáticamente los sitios existentes. Garantizando al mismo tiempo que los sitios futuros se creen con los nuevos cambios de la plantilla.
Cualquier consulta avisame. 
Tengo muchísimos ejemplos de código para compartir.

¿Cómo listar las alertas de usuario en una lista en SharePoint con c#?

El objetivo es lista para una lista específica las alertas de diferentes usuarios.

En este ejemplo, a modo de prueba, he configurado una alerta sobre la lista Hitos:
El siguiente código permite listar los usuarios con alertas sobre Hitos:
        public static string listarAlertasLista(SPWeb web, string listaInternalName)
        {
            string alerts = “”;
            string listUrl = web.ServerRelativeUrl + “/Lists/” + listaInternalName;
            listUrl = listUrl.Replace(“//”, “/”);
            
            SPList list = web.GetList(listUrl);
            SPAlertCollection alertsColl = web.Alerts;

            alerts += “<span style=’color: blue’>Alertas de la lista ” + listaInternalName + “</span><br>”;
            foreach (SPAlert alert in alertsColl)
            {
                if (alert.ListID == list.ID)
                {
                    alerts += “Usuario: ” + alert.User.LoginName + “<br>”;
                    alerts += “Tipo: ” + alert.AlertType + “<br>”;
                    alerts += “Canales: ” + alert.DeliveryChannels.ToString() + “<br>”;
                }
            }

            return alerts;
        }
El resultado:

¿Cómo listar los adjuntos de un ítem de lista en c# en SharePoint?

El resultado





El código


        public static string htmlAdjuntos(string lista, int id, int total)
        {
            string html = “”;
            if (total > 0)
            {
                using (SPWeb web = SPContext.Current.Web)
                {

                    // Busco el ítem            
                    string listaURL = web.ServerRelativeUrl + “/Lists/” + lista;
                    listaURL = listaURL.Replace(“//”, “/”);
                    SPList listaAdjuntos = web.GetList(listaURL);
                    SPListItem item = listaAdjuntos.GetItemById(id);

                    // Busco adjuntos
                    SPAttachmentCollection adjuntos = item.Attachments;
                    foreach (string adjunto in adjuntos)
                    {
                        string urlAdjunto = SPUrlUtility.CombineUrl(item.Attachments.UrlPrefix, adjunto);
                        SPFile archivoAdjunto = web.GetFile(urlAdjunto);
                        string nombreAdjunto = archivoAdjunto.Name;
                        html += “&nbsp;<a style=’border:none;’ href='” + urlAdjunto + “‘>” + iconoAdjunto(nombreAdjunto) + “</a>”;
                    }

                }

            }

            return html;
        }
        public static string iconoAdjunto(string hint)
        {
            string extension = Path.GetExtension(hint).ToLower();
            if (extension != “.doc” && extension != “.docx” && extension != “.xls” && extension != “.xlsx” && extension != “.ppt” && extension != “.pptx” && extension != “.txt” && extension != “.zip” && extension != “.bmp” && extension != “.jpg” && extension != “.jpeg” && extension != “.png”)
                extension = “gen”;
            if (extension != null) extension = extension.Split(‘.’)[1];
            return icono(hint, “ic” + extension + “.gif”);
        }

        public static string icono(string hint, string img)
        {
                return “<img title='” + hint + “‘ border=’none’ src=’/_layouts/images/” + img + “‘/>”;
        }

¿Cómo crear una vista de hoja de datos y ocultarla en c# en SharePoint 2010?

SPList listaRiesgos = oWebsite.Lists.TryGetList(“Issues y riesgos”);
System.Collections.Specialized.StringCollection columnas = new System.Collections.Specialized.StringCollection();
columnas.Add(“Title”);
columnas.Add(“Observaciones”);
string query = “<Where><And><Neq><FieldRef Name=’Estado_Cumplimiento_Riesgo’/><Value Type=’Text’>Cerrado</Value></Neq><Neq><FieldRef Name=’Estado_Cumplimiento_Riesgo’/><Value Type=’Text’>Desestimado</Value></Neq></And></Where><OrderBy><FieldRef Name=’Tipo_Riesgo’ Ascending=’False’/></OrderBy>”;
SPView vista = listaRiesgos.Views.Add(“mivista”, columnas, query, 100, true, false, SPViewCollection.SPViewType.Grid, false);
vista.Hidden = true;
vista.Update();