Exemplo n.º 1
0
		private void OnBulkOperation(IHttpContext context, Func<string, IndexQuery, bool, RavenJArray> batchOperation)
		{
			var match = urlMatcher.Match(context.GetRequestUrl());
			var index = match.Groups[2].Value;
			if (string.IsNullOrEmpty(index))
			{
				context.SetStatusToBadRequest();
				return;
			}
			var allowStale = context.GetAllowStale();
			var indexQuery = context.GetIndexQueryFromHttpContext(maxPageSize: int.MaxValue);

		    var status = new BulkOperationStatus();
			var sp = Stopwatch.StartNew();
			long id = 0;

			var task = Task.Factory.StartNew(() =>
			{
				var array = batchOperation(index, indexQuery, allowStale);
			    status.State = array;
				status.Completed = true;

				context.Log(log => log.Debug("\tBatch Operation worked on {0:#,#;;0} documents in {1}, task #: {2}", array.Length, sp.Elapsed, id));
			});

			Database.AddTask(task, status, out id);

			context.WriteJson(new
			{
				OperationId = id
			});
		}
Exemplo n.º 2
0
        private void OnBulkOperation(IHttpContext context, Func <string, IndexQuery, bool, RavenJArray> batchOperation)
        {
            var match = urlMatcher.Match(context.GetRequestUrl());
            var index = match.Groups[2].Value;

            if (string.IsNullOrEmpty(index))
            {
                context.SetStatusToBadRequest();
                return;
            }
            var allowStale = context.GetAllowStale();
            var indexQuery = context.GetIndexQueryFromHttpContext(maxPageSize: int.MaxValue);

            var  status = new BulkOperationStatus();
            var  sp     = Stopwatch.StartNew();
            long id     = 0;

            var task = Task.Factory.StartNew(() =>
            {
                var array        = batchOperation(index, indexQuery, allowStale);
                status.State     = array;
                status.Completed = true;

                context.Log(log => log.Debug("\tBatch Operation worked on {0:#,#;;0} documents in {1}, task #: {2}", array.Length, sp.Elapsed, id));
            });

            Database.AddTask(task, status, out id);

            context.WriteJson(new
            {
                OperationId = id
            });
        }
Exemplo n.º 3
0
        private void OnBulkOperation(IHttpContext context, Func<string, IndexQuery, bool, JArray> batchOperation)
        {
            var match = urlMatcher.Match(context.GetRequestUrl());
            var index = match.Groups[2].Value;
            if (string.IsNullOrEmpty(index))
            {
                context.SetStatusToBadRequest();
                return;
            }
            var allowStale = context.GetAllowStale();
            var indexQuery = context.GetIndexQueryFromHttpContext(maxPageSize: int.MaxValue);

            var array = batchOperation(index, indexQuery, allowStale);

            context.WriteJson(array);
        }
Exemplo n.º 4
0
        private void OnBulkOperation(IHttpContext context, Func <string, IndexQuery, bool, JArray> batchOperation)
        {
            var match = urlMatcher.Match(context.GetRequestUrl());
            var index = match.Groups[2].Value;

            if (string.IsNullOrEmpty(index))
            {
                context.SetStatusToBadRequest();
                return;
            }
            var allowStale = context.GetAllowStale();
            var indexQuery = context.GetIndexQueryFromHttpContext(maxPageSize: int.MaxValue);

            var array = batchOperation(index, indexQuery, allowStale);

            context.WriteJson(array);
        }
Exemplo n.º 5
0
        private void OnBulkOperation(IHttpContext context, Func <string, TransactionInformation, object> batchOperation)
        {
            var match = urlMatcher.Match(context.GetRequestUrl());
            var index = match.Groups[2].Value;

            if (string.IsNullOrEmpty(index))
            {
                context.SetStatusToBadRequest();
                return;
            }
            var allowStale = context.GetAllowStale();

            Database.TransactionalStorage.Batch(actions =>
            {
                bool stale;
                var queryResults = Database.QueryDocumentIds(index, new IndexQuery
                {
                    Query         = context.Request.QueryString["query"],
                    Start         = context.GetStart(),
                    PageSize      = int.MaxValue,        // get all
                    Cutoff        = context.GetCutOff(),
                    FieldsToFetch = new[] { "__document_id" }
                }, out stale);

                if (stale)
                {
                    context.SetStatusToNonAuthoritativeInformation();
                    if (allowStale == false)
                    {
                        throw new InvalidOperationException(
                            "Bulk operation cancelled because the index is stale and allowStale is false");
                    }
                }

                var transactionInformation = GetRequestTransaction(context);
                var array = new JArray();
                foreach (var documentId in queryResults)
                {
                    var result = batchOperation(documentId, transactionInformation);
                    array.Add(JObject.FromObject(result, new JsonSerializer {
                        Converters = { new JsonEnumConverter() }
                    }));
                }
                context.WriteJson(array);
            });
        }
Exemplo n.º 6
0
    	private void OnBulkOperation(IHttpContext context, Func<string, TransactionInformation, object> batchOperation)
    	{
    		var match = urlMatcher.Match(context.GetRequestUrl());
    		var index = match.Groups[2].Value;
    		if (string.IsNullOrEmpty(index))
    		{
    			context.SetStatusToBadRequest();
    			return;
    		}
    		var allowStale = context.GetAllowStale();
    		Database.TransactionalStorage.Batch(actions =>
    		{
    			bool stale;
    			var queryResults = Database.QueryDocumentIds(index, new IndexQuery
    			{
    				Query = context.Request.QueryString["query"],
    				Start = context.GetStart(),
    				PageSize = int.MaxValue, // get all
    				Cutoff = context.GetCutOff(),
    				FieldsToFetch = new[] { "__document_id" }
    			}, out stale);

    			if (stale)
    			{
    				context.SetStatusToNonAuthoritativeInformation();
    				if (allowStale == false)
    				{
    					throw new InvalidOperationException(
    						"Bulk operation cancelled because the index is stale and allowStale is false");
    				}
    			}

				var transactionInformation = GetRequestTransaction(context);
    			var array = new JArray();
				foreach (var documentId in queryResults)
    			{
    				var result = batchOperation(documentId, transactionInformation);
					array.Add(JObject.FromObject(result, new JsonSerializer { Converters = { new JsonEnumConverter() } }));
    			}
    			context.WriteJson(array);
    		});
    	}