c # - Microsoft Graph API - Sprawdź, czy folder istnieje


10

Korzystam z Microsoft Graph API i tworzę folder w następujący sposób:

var driveItem = new DriveItem
{
    Name = Customer_Name.Text + Customer_LName.Text,
    Folder = new Folder
    {
    },
    AdditionalData = new Dictionary<string, object>()
    {
        {"@microsoft.graph.conflictBehavior","rename"}
    }
};

var newFolder = await App.GraphClient
  .Me
  .Drive
  .Items["id-of-folder-I-am-putting-this-into"]
  .Children
  .Request()
  .AddAsync(driveItem);

Moje pytanie brzmi: jak sprawdzić, czy ten folder istnieje i czy otrzymuje identyfikator folderu?

Odpowiedzi:


4

Graph API zapewnia funkcję wyszukiwania , którą można wykorzystać, aby dowiedzieć się, czy element istnieje. Możesz albo najpierw uruchomić wyszukiwanie, a następnie utworzyć element, jeśli nic nie zostanie znalezione, lub możesz zrobić tak, jak sugeruje @ Matt.G i obejść nameAlreadyExistswyjątek:

        var driveItem = new DriveItem
        {
            Name = Customer_Name.Text + Customer_LName.Text,
            Folder = new Folder
            {
            },
            AdditionalData = new Dictionary<string, object>()
            {
                {"@microsoft.graph.conflictBehavior","fail"}
            }
        };

        try
        {
            driveItem = await graphserviceClient
                .Me
                .Drive.Root.Children
                .Items["id-of-folder-I-am-putting-this-into"]
                .Children
                .Request()
                .AddAsync(driveItem);
        }
        catch (ServiceException exception)
        {
            if (exception.StatusCode == HttpStatusCode.Conflict && exception.Error.Code == "nameAlreadyExists")
            {
                var newFolder = await graphserviceClient
                    .Me
                    .Drive.Root.Children
                    .Items["id-of-folder-I-am-putting-this-into"]
                    .Search(driveItem.Name) // the API lets us run searches https://docs.microsoft.com/en-us/graph/api/driveitem-search?view=graph-rest-1.0&tabs=csharp
                    .Request()
                    .GetAsync();
                // since the search is likely to return more results we should filter it further
                driveItem = newFolder.FirstOrDefault(f => f.Folder != null && f.Name == driveItem.Name); // Just to ensure we're finding a folder, not a file with this name
                Console.WriteLine(driveItem?.Id); // your ID here
            }
            else
            {
                Console.WriteLine("Other ServiceException");
                throw;// handle this
            }
        }

Tekst zapytania używany do wyszukiwania elementów. Wartości można dopasować w kilku polach, w tym w nazwie pliku, metadanych i zawartości pliku.

możesz grać z wyszukiwanym hasłem i robić rzeczy takie jak filename=<yourName>lub potencjalnie sprawdzać typy plików (co, jak sądzę, nie pomoże w twoim konkretnym przypadku, ale wspomnę o tym ze względu na kompletność)


1

Wyślij zapytanie dotyczące kontenera.

var existingItems = await graphServiceClient.Me.Drive
                          .Items["id-of-folder-I-am-putting-this-into"]
                          .Search("search")
                          .Request().GetAsync();

Następnie należy iterować existingItemskolekcję ( możliwe, że zawiera wiele stron ), aby ustalić, czy element istnieje.

Nie określasz kryteriów określania, czy element istnieje. Zakładając, że masz na myśli imię, możesz:

var exists = existingItems.CurrentPage
               .Any(i => i.Name.Equals(Customer_Name.Text + Customer_LName.Text);

Tak, ale jak mogę uzyskać identyfikator?
user979331,

Użyj Where () lub FirstOrDefault () lub odpowiedniego wyrażenia.
Paul Schaeflein,

1

Aby uzyskać folder o nazwie folderu:

wykres połączeń api Reference1 Reference2 :/me/drive/items/{item-id}:/path/to/file

to znaczy /drive/items/id-of-folder-I-am-putting-this-into:/{folderName}

  • Jeśli folder istnieje, zwraca odpowiedź driveItem , która ma identyfikator

  • Jeśli folder nie istnieje, zwraca 404 (NotFound)

Teraz, podczas tworzenia folderu, jeśli folder już istnieje, aby zakończyć połączenie, spróbuj ustawić dodatkowe dane w następujący sposób Odwołanie :

    AdditionalData = new Dictionary<string, object>
    {
        { "@microsoft.graph.conflictBehavior", "fail" }
    }
  • Zwróci to konflikt 409, jeśli folder istnieje

Ale jak mogę uzyskać identyfikator istniejącego folderu?
user979331,

1

Pod tym względem można rozważyć podejście oparte na zapytaniach . Ponieważ DriveItem.namewłaściwość według projektu jest unikalna w obrębie folderu, poniższe zapytanie pokazuje, jak filtrować driveItemwedług nazwy w celu ustalenia, czy element dysku istnieje:

https://graph.microsoft.com/v1.0/me/drive/items/{parent-item-id}/children?$filter=name eq '{folder-name}'

który może być reprezentowany w języku C # w ten sposób:

var items = await graphClient
            .Me
            .Drive
            .Items[parentFolderId]
            .Children
            .Request()
            .Filter($"name eq '{folderName}'")
            .GetAsync();

Biorąc pod uwagę podany punkt końcowy przepływ może składać się z następujących kroków:

  • prześlij żądanie, aby ustalić, czy folder o podanej nazwie już istnieje
  • prześlij drugi, jeśli folder nie został znaleziony (lub zwróć istniejący folder)

Przykład

Oto zaktualizowany przykład

//1.ensure drive item already exists (filtering by name) 
var items = await graphClient
            .Me
            .Drive
            .Items[parentFolderId]
            .Children
            .Request()
            .Filter($"name eq '{folderName}'")
            .GetAsync();



if (items.Count > 0) //found existing item (folder facet)
{
     Console.WriteLine(items[0].Id);  //<- gives an existing DriveItem Id (folder facet)  
}
else
{
     //2. create a folder facet
     var driveItem = new DriveItem
     {
         Name = folderName,
         Folder = new Folder
         {
         },
         AdditionalData = new Dictionary<string, object>()
         {
                    {"@microsoft.graph.conflictBehavior","rename"}
         }
     };

     var newFolder = await graphClient
                .Me
                .Drive
                .Items[parentFolderId]
                .Children
                .Request()
                .AddAsync(driveItem);

  }

-1

Można uzyskać identyfikator folderu, wywołując w ten sposób: https://graph.microsoft.com/v1.0/me/drive/root/children. Otrzymasz wszystkie elementy na dysku. Możesz użyć nazwy lub innej właściwości do filtrowania wyników, aby uzyskać identyfikator folderu, jeśli jeszcze go nie masz

public static bool isPropertyExist (dynamic d)
{
  try {
       string check = d.folder.childCount;
       return true;
  } catch {
       return false;
  }
}
var newFolder = await {https://graph.microsoft.com/v1.0/me/drive/items/{itemID}}


if (isPropertyExist(newFolder))
{
  //Your code goes here.
}

Jeśli typem elementu na dysku jest folder, otrzyma on folderwłaściwość. Możesz sprawdzić, czy ta właściwość istnieje i czy uruchamia kod, aby dodać element.

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.