Headless CMS and Content Managment Hub
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

128 lines
4.5 KiB

// ==========================================================================
// Squidex Headless CMS
// ==========================================================================
// Copyright (c) Squidex UG (haftungsbeschraenkt)
// All rights reserved. Licensed under the MIT license.
// ==========================================================================
using System;
using System.Collections.ObjectModel;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Squidex.Hosting;
using Squidex.Infrastructure.Json;
using Index = Microsoft.Azure.Documents.Index;
namespace Squidex.Infrastructure.EventSourcing
{
public sealed partial class CosmosDbEventStore : DisposableObjectBase, IEventStore, IInitializable
{
private readonly DocumentClient documentClient;
private readonly Uri collectionUri;
private readonly Uri databaseUri;
public IJsonSerializer JsonSerializer { get; }
public string DatabaseId { get; }
public string MasterKey { get; }
public Uri ServiceUri
{
get { return documentClient.ServiceEndpoint; }
}
public CosmosDbEventStore(DocumentClient documentClient, string masterKey, string database, IJsonSerializer jsonSerializer)
{
Guard.NotNull(documentClient, nameof(documentClient));
Guard.NotNull(jsonSerializer, nameof(jsonSerializer));
Guard.NotNullOrEmpty(masterKey, nameof(masterKey));
Guard.NotNullOrEmpty(database, nameof(database));
this.documentClient = documentClient;
databaseUri = UriFactory.CreateDatabaseUri(database);
DatabaseId = database;
collectionUri = UriFactory.CreateDocumentCollectionUri(database, Constants.Collection);
MasterKey = masterKey;
JsonSerializer = jsonSerializer;
}
protected override void DisposeObject(bool disposing)
{
if (disposing)
{
documentClient.Dispose();
}
}
public async Task InitializeAsync(CancellationToken ct = default)
{
await documentClient.CreateDatabaseIfNotExistsAsync(new Database { Id = DatabaseId });
await documentClient.CreateDocumentCollectionIfNotExistsAsync(databaseUri,
new DocumentCollection
{
PartitionKey = new PartitionKeyDefinition
{
Paths = new Collection<string>
{
"/id"
}
},
Id = Constants.LeaseCollection
});
await documentClient.CreateDocumentCollectionIfNotExistsAsync(databaseUri,
new DocumentCollection
{
PartitionKey = new PartitionKeyDefinition
{
Paths = new Collection<string>
{
"/eventStream"
}
},
IndexingPolicy = new IndexingPolicy
{
IncludedPaths = new Collection<IncludedPath>
{
new IncludedPath
{
Path = "/*",
Indexes = new Collection<Index>
{
Index.Range(DataType.Number),
Index.Range(DataType.String)
}
}
}
},
UniqueKeyPolicy = new UniqueKeyPolicy
{
UniqueKeys = new Collection<UniqueKey>
{
new UniqueKey
{
Paths = new Collection<string>
{
"/eventStream",
"/eventStreamOffset"
}
}
}
},
Id = Constants.Collection
},
new RequestOptions
{
PartitionKey = new PartitionKey("/eventStream")
});
}
}
}