1
0
Fork 0
mirror of https://github.com/ossrs/srs.git synced 2025-02-24 23:14:19 +00:00
srs/trunk/src/protocol/srs_protocol_json.hpp

173 lines
6.1 KiB
C++
Raw Normal View History

2017-03-25 09:21:39 +00:00
/**
* The MIT License (MIT)
*
2019-01-01 13:37:28 +00:00
* Copyright (c) 2013-2019 Winlin
2017-03-25 09:21:39 +00:00
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of
* this software and associated documentation files (the "Software"), to deal in
* the Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
* the Software, and to permit persons to whom the Software is furnished to do so,
* subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
2015-08-21 08:20:19 +00:00
#ifndef SRS_PROTOCOL_JSON_HPP
#define SRS_PROTOCOL_JSON_HPP
#include <srs_core.hpp>
#include <string>
#include <vector>
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
2019-04-23 00:06:50 +00:00
// JSON decode
// 1. SrsJsonAny: read any from str:char*
// SrsJsonAny* any = NULL;
// if ((any = SrsJsonAny::loads(str)) == NULL) {
// return -1;
// }
// srs_assert(pany); // if success, always valid object.
// 2. SrsJsonAny: convert to specifid type, for instance, string
// SrsJsonAny* any = ...
// if (any->is_string()) {
// string v = any->to_str();
// }
//
2019-04-23 00:06:50 +00:00
// For detail usage, see interfaces of each object.
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
// @see: https://github.com/udp/json-parser
class SrsAmf0Any;
class SrsJsonArray;
class SrsJsonObject;
class SrsJsonAny
{
public:
char marker;
2019-04-23 00:06:50 +00:00
// Don't directly create this object,
// please use SrsJsonAny::str() to create a concreated one.
protected:
SrsJsonAny();
public:
virtual ~SrsJsonAny();
public:
virtual bool is_string();
virtual bool is_boolean();
virtual bool is_integer();
virtual bool is_number();
virtual bool is_object();
virtual bool is_array();
virtual bool is_null();
public:
2019-04-23 00:06:50 +00:00
// Get the string of any when is_string() indicates true.
// user must ensure the type is a string, or assert failed.
virtual std::string to_str();
2019-04-23 00:06:50 +00:00
// Get the boolean of any when is_boolean() indicates true.
// user must ensure the type is a boolean, or assert failed.
virtual bool to_boolean();
2019-04-23 00:06:50 +00:00
// Get the integer of any when is_integer() indicates true.
// user must ensure the type is a integer, or assert failed.
virtual int64_t to_integer();
2019-04-23 00:06:50 +00:00
// Get the number of any when is_number() indicates true.
// user must ensure the type is a number, or assert failed.
virtual double to_number();
2019-04-23 00:06:50 +00:00
// Get the object of any when is_object() indicates true.
// user must ensure the type is a object, or assert failed.
virtual SrsJsonObject* to_object();
2019-04-23 00:06:50 +00:00
// Get the ecma array of any when is_ecma_array() indicates true.
// user must ensure the type is a ecma array, or assert failed.
virtual SrsJsonArray* to_array();
2015-09-19 04:27:31 +00:00
public:
2015-09-19 05:37:56 +00:00
virtual std::string dumps();
virtual SrsAmf0Any* to_amf0();
public:
2017-03-25 09:21:39 +00:00
static SrsJsonAny* str(const char* value = NULL);
static SrsJsonAny* str(const char* value, int length);
static SrsJsonAny* boolean(bool value = false);
static SrsJsonAny* integer(int64_t value = 0);
static SrsJsonAny* number(double value = 0.0);
static SrsJsonAny* null();
static SrsJsonObject* object();
static SrsJsonArray* array();
public:
2019-04-23 00:06:50 +00:00
// Read json tree from string.
// @return json object. NULL if error.
static SrsJsonAny* loads(const std::string& str);
};
class SrsJsonObject : public SrsJsonAny
{
private:
typedef std::pair<std::string, SrsJsonAny*> SrsJsonObjectPropertyType;
std::vector<SrsJsonObjectPropertyType> properties;
private:
2019-04-23 00:06:50 +00:00
// Use SrsJsonAny::object() to create it.
friend class SrsJsonAny;
SrsJsonObject();
public:
virtual ~SrsJsonObject();
public:
virtual int count();
// @remark: max index is count().
virtual std::string key_at(int index);
// @remark: max index is count().
virtual SrsJsonAny* value_at(int index);
2015-09-19 04:27:31 +00:00
public:
2015-09-19 05:37:56 +00:00
virtual std::string dumps();
virtual SrsAmf0Any* to_amf0();
public:
2018-02-15 12:55:34 +00:00
virtual SrsJsonObject* set(std::string key, SrsJsonAny* value);
virtual SrsJsonAny* get_property(std::string name);
virtual SrsJsonAny* ensure_property_string(std::string name);
2015-03-31 10:06:55 +00:00
virtual SrsJsonAny* ensure_property_integer(std::string name);
2015-12-07 10:22:55 +00:00
virtual SrsJsonAny* ensure_property_number(std::string name);
virtual SrsJsonAny* ensure_property_boolean(std::string name);
2015-09-17 05:36:02 +00:00
virtual SrsJsonAny* ensure_property_object(std::string name);
virtual SrsJsonAny* ensure_property_array(std::string name);
};
class SrsJsonArray : public SrsJsonAny
{
private:
std::vector<SrsJsonAny*> properties;
2017-03-25 09:21:39 +00:00
private:
2019-04-23 00:06:50 +00:00
// Use SrsJsonAny::array() to create it.
friend class SrsJsonAny;
SrsJsonArray();
public:
virtual ~SrsJsonArray();
public:
virtual int count();
// @remark: max index is count().
virtual SrsJsonAny* at(int index);
virtual void add(SrsJsonAny* value);
2015-09-19 04:27:31 +00:00
// alias to add.
2018-02-15 12:55:34 +00:00
virtual SrsJsonArray* append(SrsJsonAny* value);
2015-09-19 04:27:31 +00:00
public:
2015-09-19 05:37:56 +00:00
virtual std::string dumps();
virtual SrsAmf0Any* to_amf0();
};
2014-05-16 03:56:43 +00:00
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
2019-04-23 00:06:50 +00:00
// JSON encode, please use JSON.dumps() to encode json object.
2014-08-02 14:18:39 +00:00
#endif