Graph API предоставляет средство поиска , которое вы можете использовать, чтобы узнать, существует ли элемент. У вас есть возможность сначала запустить поиск, а затем создать элемент, если ничего не найдено, или вы можете сделать, как подсказывает @ Matt.G, и обойти nameAlreadyExists
исключение:
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
}
}
Текст запроса, используемый для поиска предметов. Значения могут совпадать в нескольких полях, включая имя файла, метаданные и содержимое файла.
Вы можете играть с поисковым запросом и делать что-то вроде filename=<yourName>
или, возможно, исследовать типы файлов (что, я думаю, не поможет в вашем конкретном случае, но я бы упомянул это для полноты картины)