blob: 61d2392d864b92f6096401d971c4ec7b04a3296f [file] [log] [blame]
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef SERVICES_DATA_DECODER_PUBLIC_CPP_SAFE_JSON_PARSER_H_
#define SERVICES_DATA_DECODER_PUBLIC_CPP_SAFE_JSON_PARSER_H_
#include <memory>
#include <string>
#include "base/callback.h"
namespace base {
class Value;
}
namespace service_manager {
class Connector;
}
namespace data_decoder {
// SafeJsonParser parses a given JSON safely via a platform-dependent mechanism
// (like parsing it in a utility process or in a memory-safe environment).
// Internally, an instance of this class is created when Parse() is called and
// is kept alive until one of the two callbacks is called, after which it
// deletes itself.
class SafeJsonParser {
public:
using SuccessCallback = base::Callback<void(std::unique_ptr<base::Value>)>;
using ErrorCallback = base::Callback<void(const std::string&)>;
using Factory = SafeJsonParser* (*)(const std::string& unsafe_json,
const SuccessCallback& success_callback,
const ErrorCallback& error_callback);
// Starts parsing the passed in |unsafe_json| and calls either
// |success_callback| or |error_callback| when finished.
// |connector| is the connector provided by the service manager and is used to
// retrieve the JSON decoder service. It's commonly retrieved from a service
// manager connection context object that the embedder provides.
// Note that on Android, this runs in process, the sanitizing of |unsafe_json|
// being performed in Java for safety. On other platforms the parsing happens
// in an isolated sandboxed utility process.
static void Parse(service_manager::Connector* connector,
const std::string& unsafe_json,
const SuccessCallback& success_callback,
const ErrorCallback& error_callback);
// Same as Parse, but allows clients to provide a |batch_id|, which the system
// may use to batch this parse request with other parse requests using the
// same |batch_id| in an effort to amortize the overhead of a single request.
// The trade-off is that batch requests may not be well-isolated from each
// other, so this should be used with appropriate caution.
static void ParseBatch(service_manager::Connector* connector,
const std::string& unsafe_json,
const SuccessCallback& success_callback,
const ErrorCallback& error_callback,
const std::string& batch_id);
static void SetFactoryForTesting(Factory factory);
protected:
virtual ~SafeJsonParser() {}
private:
virtual void Start() = 0;
};
} // namespace data_decoder
#endif // SERVICES_DATA_DECODER_PUBLIC_CPP_SAFE_JSON_PARSER_H_