Nuta
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować się zalogować lub zmienić katalog.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
Pokazy
W tym przykładzie przedstawiono minimalną implementację ogólnego wtyczki dostawcy danych tabeli wirtualnej Microsoft Dataverse, DropboxRetrieveMultiplePlugin dla usługi udostępniania plików Dropbox . Używa podejścia "bare metal", tłumacząc QueryExpression przez utworzenie niestandardowej klasy odwiedzającej, DropBoxExpressionVisitor. Zwraca kolekcję plików, które spełniają kryteria wyszukiwania jako EntityCollection.
Uwaga / Notatka
Ten przykład wymaga użycia funkcji ILMERGE do łączenia wtyczki i zestawów Dropbox przed zarejestrowaniem zestawu w usłudze Dataverse. Korzystanie z ILMERGE nie jest wspierane formalnie. Przyszła aktualizacja tego przykładu spowoduje usunięcie konieczności użycia funkcji ILMERGE.
Wprowadzenie
Aby skompilować ten przykład, należy najpierw zainstalować pakiety NuGet Dropbox.Api i Microsoft.CrmSdk.Data. Będziesz również potrzebować konta Dropbox i podać rzeczywisty token dostępu podczas tworzenia instancji DropboxClient.
Dodaj następujące instrukcje using do kodu:
using Microsoft.Xrm.Sdk;
using Microsoft.Xrm.Sdk.Query;
using Dropbox.Api;
using Dropbox.Api.Files;
Przykładowy kod
public class DropBoxExpressionVisitor : QueryExpressionVisitorBase
{
public string SearchKeyWords { get; private set; }
public override QueryExpression Visit(QueryExpression query)
{
// Very simple visitor that extracts search keywords
var filter = query.Criteria;
if (filter.Conditions.Count > 0)
{
foreach (ConditionExpression condition in filter.Conditions)
{
if (condition.Operator == ConditionOperator.Like && condition.Values.Count > 0)
{
string exprVal = (string)condition.Values[0];
if (exprVal.Length > 2)
{
this.SearchKeyWords += " " + exprVal.Substring(1, exprVal.Length - 2);
}
}
}
return query;
}
}
}
public class DropboxRetrieveMultiplePlugin : IPlugin
{
public void Execute(IServiceProvider serviceProvider)
{
var context = (IPluginExecutionContext)serviceProvider.GetService(typeof(IPluginExecutionContext));
var qe = (QueryExpression)context.InputParameters["Query"];
if (qe != null)
{
var visitor = new DropBoxExpressionVisitor();
qe.Accept(visitor);
using (var dbx = new DropboxClient(AccessToken))
{
if (visitor.SearchKeyWords != string.Empty)
{
var searchCriteria = new SearchArg(string.Empty, visitor.SearchKeyWords);
var task = Task.Run(() => this.SearchFile(dbx, searchCriteria));
context.OutputParameters["BusinessEntityCollection"] = task.Result;
}
}
}
}
public async Task<EntityCollection> SearchFile(DropboxClient dbx, SearchArg arg)
{
EntityCollection ec = new EntityCollection();
var list = await dbx.Files.SearchAsync(arg);
foreach (var item in list.Matches)
{
if (item.Metadata.IsFile)
{
Entity e = new Entity("new_dropbox");
e.Attributes.Add("new_dropboxid", Guid.NewGuid());
e.Attributes.Add("new_filename", item.Metadata.AsFile.Name);
e.Attributes.Add("new_filesize", item.Metadata.AsFile.Size);
e.Attributes.Add("new_modifiedon", item.Metadata.AsFile.ServerModified);
ec.Entities.Add(e);
}
}
return ec;
}
}
Zobacz także
Rozpoczynanie pracy z tabelami wirtualnymi
Zagadnienia dotyczące interfejsu API tabel wirtualnych
Niestandardowi dostawcy danych tabel wirtualnych