Accéder au contenu principal

SharePoint : Retrouver les items d’un sondage non validés par les utilisateurs

 SharePoint permet de créer des sondages simples, qui parfois peuvent s’afficher sur plusieurs pages. Dans ce cadre la, l’affichage du formulaire propose un bouton “Save” :

image

Le fait est que de nombreux utilisateurs ne passent pas sur la page suivante et cliquent sur “Save” en pensant valider ce formulaire.

Malheureusement, ce n’est pas le cas en interne, car la réponse est sauvegardée en base mais avec un status “Checked out” proche de celui des fichier Published/Checked Out.

D’ailleurs certains codes existent pour supprimer entèrement ce bouton, mais la n’est pas le sujet :

Un des effets visibles pour le créateur du sondage est la différence entre le nombre d’items visible dans les résultats et le nombre d’items dans la page de résumé :

image

Mais aussi, par le manque de certains numéros dans la suite des items des résultats (dans l’exemple, il manque le 1, le 11 & 12, …) :

image

De ce fait, le propriétaire du sondage veut pouvoir fermer ce sondage avec tous les résultats et souhaite pouvoir relancer uniquement ceux qui sont dans le cas “stand-by”. Il existe d’ailleurs une KB sur ce point qui ne fournit aucune solution.


Obtenir les informations en cours

Pour cela, il faut aller dans les bases de SharePoint, car il n’y a pas de moyen simple pour effectuer cela (pour des raisons évidentes de confidentialités). Il n’y a pas de possibilité de trouver ces informations directement via code/PowerShell.

En revanche, il nous faut connaître la base de données dans laquelle la collection se situe ainsi que l’ID (GUID) de la liste en question, sachant que nous avons l’URL et le nom de la liste. Pour le nom de la Base, on peut aller dans l’interface d’administration, mais le plus simple pour avoir les deux informations est de partir d’un petit script PowerShell :

function Get-AllSurveyItemOwners([string]$SurveyURL, [string]$SurveyName)
{
    [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint") > $null
    [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Administration") > $null

    $site = new-object Microsoft.SharePoint.SPSite($SurveyURL)
    Write-Host "SiteURL:", $SurveyURL

    $DBName = [Microsoft.SharePoint.Administration.SPContentDatabase].GetProperty("Name")

    $MyContentDatabase = $site.ContentDatabase
   
    Write-Host " ------------------------------ "
    $CurrentDBName = $DBName.GetValue($MyContentDatabase, $null)
    Write-Host " ---> ContentDB:", $CurrentDBName
   
    $web = $site.OpenWeb()

    Write-Host " ------------------------------ "
    $SurveyList = $web.Lists[$SurveyName];
    Write-Host " ---> Survey ListID:", $SurveyList.Id
    Write-Host " ------------------------------ "
   
    $web.Dispose()
    $site.Dispose()
}

cls
Get-AllSurveyItemOwners  “http://MyWebApp/sites/mysitecoll/lists/mysurvey”
 "MySurveyName"

image

Ainsi, nous avons à ce stade la base en question et le GUID de la liste Survey en question, il nous faut aller directement sur le serveur de bases de données et exécuter la requête :

USE [MyContentDB]

SELECT
    usrinf.tp_Login AS UsrLogin,
    usrinf.tp_Email AS UsrEmail,
    AllData.tp_Modified AS LastModified,
    AllData.tp_ID AS IDItem
FROM
    dbo.AllUserData AllData
INNER JOIN dbo.UserInfo usrinf
    ON AllData.tp_Author = usrinf.tp_ID
    AND AllData.tp_SiteID = usrinf.tp_SiteID
WHERE
    (tp_ListId = 'myGUID-myGUID-xxxxXXXX-XXXX)
AND
    (NOT tp_CheckoutUserId IS NULL)

Vous obtiendrez alors en résultat les informations nécessaires pour contacter les utilisateurs :

image

Il ne vous reste plus qu’à envoyer le résultat de cette requête au propriétaire du sondage.

Liens Annexes

Romelard Fabrice [MVP]

Commentaires

Posts les plus consultés de ce blog

Série de vidéos sur le montage d'une serre horticole ACD

 Episode 1: Préparation du terrain Episode 2: Montage de la serre en elle même Episode 3: Finalisation avec le montage électrique alimentant la serre Bon visionnage Fab

Présentation des outils utiles pour l'entretien de ses haies vives

Afin de gérer les haies vives, il est nécessaire d'avoir recourt à un matériel adapté. Les solutions à batteries sont bien adaptées pour un usage personnel avec des dimensions raisonnables. Ainsi dans mon cas précis, j'utilise les outils suivants de la Gamme Ryobi 18V ONE+ électroportatif: Petit taille-haies simple mais efficace -  RYOBI OHT1855R Un modèle plus puissant qui fonctionne très bien -  RYOBI RY18HTX60A Pour les parties hautes de vos haies, voici un outil très utile -  RYOBI OPT1845 Enfin lorsque vous devez élaguer certains arbres ou certaines partie hautes de vos haies, ce dernier outil est très utile -  RYOBI OPP1820 Ces outils font parti maintenant de mon arsenal de base pour maintenir notre maison chaque saison de taille. Fab

Série de Videos sur Home Assistant intégrant la production Photovoltaïque

 Un certain nombre de vidéos sont en ligne pour intégrer sa production photovoltaïque dans Home Assistant en partant de la base. Installation de Home Assistant: On peut ensuite intégrer les composant des Micro-Onduleurs Enphase, mais aussi les batteries Enphase: Ou encore le composant de contrôle Ecojoko: Ce qui permet alors de faire des comparaisons entre les valeurs capturées: Des videos seront encore publiés dans les prochaines semaines sur différents aspects de cette solution. Fab