1
    2
    3
    4
    5
    6
    7
    8
    9
   10
   11
   12
   13
   14
   15
   16
   17
   18
   19
   20
   21
   22
   23
   24
   25
   26
   27
   28
   29
   30
   31
   32
   33
   34
   35
   36
   37
   38
   39
   40
   41
   42
   43
   44
   45
   46
   47
   48
   49
   50
   51
   52
   53
   54
   55
   56
   57
   58
   59
   60
   61
   62
   63

content / browser / background_fetch / background_fetch_request_match_params.h [blame]

// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_REQUEST_MATCH_PARAMS_H_
#define CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_REQUEST_MATCH_PARAMS_H_

#include "content/common/content_export.h"
#include "third_party/blink/public/mojom/cache_storage/cache_storage.mojom.h"

namespace content {

class CONTENT_EXPORT BackgroundFetchRequestMatchParams {
 public:
  BackgroundFetchRequestMatchParams();
  BackgroundFetchRequestMatchParams(
      blink::mojom::FetchAPIRequestPtr request_to_match,
      blink::mojom::CacheQueryOptionsPtr cache_query_options,
      bool match_all);

  BackgroundFetchRequestMatchParams(const BackgroundFetchRequestMatchParams&) =
      delete;
  BackgroundFetchRequestMatchParams& operator=(
      const BackgroundFetchRequestMatchParams&) = delete;

  ~BackgroundFetchRequestMatchParams();

  bool FilterByRequest() const { return !request_to_match_.is_null(); }

  // Only call this method if a valid request_to_match was previously provided.
  const blink::mojom::FetchAPIRequestPtr& request_to_match() const {
    DCHECK(request_to_match_);
    return request_to_match_;
  }

  const blink::mojom::CacheQueryOptionsPtr& cache_query_options() const {
    return cache_query_options_;
  }

  blink::mojom::CacheQueryOptionsPtr cloned_cache_query_options() const {
    if (!cache_query_options_)
      return nullptr;
    return cache_query_options_->Clone();
  }

  bool match_all() const { return match_all_; }

 private:
  // If |request_to_match| is present, we get response(s) only for this request.
  // If not present, response(s) for all requests (contained in the fetch) will
  // be returned.
  blink::mojom::FetchAPIRequestPtr request_to_match_;

  // When nullptr, this has no effect on the response(s) returned.
  blink::mojom::CacheQueryOptionsPtr cache_query_options_;

  // Whether to return all matching responses from the cache storage.
  bool match_all_ = false;
};

}  // namespace content

#endif  // CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_REQUEST_MATCH_PARAMS_H_