Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
YottaChain
YTBP
提交
0313558e
Y
YTBP
项目概览
YottaChain
/
YTBP
通知
0
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Y
YTBP
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
0313558e
编写于
8月 26, 2017
作者:
M
Matias Romeo
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Implement get_table_rows for every table type #193
上级
8a8baeaa
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
104 addition
and
117 deletion
+104
-117
plugins/chain_api_plugin/chain_api_plugin.cpp
plugins/chain_api_plugin/chain_api_plugin.cpp
+1
-2
plugins/chain_plugin/chain_plugin.cpp
plugins/chain_plugin/chain_plugin.cpp
+18
-81
plugins/chain_plugin/include/eos/chain_plugin/chain_plugin.hpp
...ns/chain_plugin/include/eos/chain_plugin/chain_plugin.hpp
+85
-34
未找到文件。
plugins/chain_api_plugin/chain_api_plugin.cpp
浏览文件 @
0313558e
...
...
@@ -51,8 +51,7 @@ void chain_api_plugin::plugin_startup() {
CHAIN_RO_CALL
(
get_info
),
CHAIN_RO_CALL
(
get_block
),
CHAIN_RO_CALL
(
get_account
),
CHAIN_RO_CALL
(
get_table_rows_i64
),
CHAIN_RO_CALL
(
get_table_rows_i128i128_primary
),
CHAIN_RO_CALL
(
get_table_rows
),
CHAIN_RO_CALL
(
abi_json_to_bin
),
CHAIN_RO_CALL
(
abi_bin_to_json
),
CHAIN_RW_CALL
(
push_block
),
...
...
plugins/chain_plugin/chain_plugin.cpp
浏览文件 @
0313558e
...
...
@@ -11,7 +11,6 @@
#include <eos/native_contract/staked_balance_objects.hpp>
#include <eos/native_contract/balance_object.hpp>
#include <eos/native_contract/genesis_state.hpp>
#include <eos/types/AbiSerializer.hpp>
#include <fc/io/json.hpp>
#include <fc/variant.hpp>
...
...
@@ -26,6 +25,8 @@ using chain::block_log;
using
chain
::
chain_id_type
;
using
chain
::
account_object
;
using
chain
::
key_value_object
;
using
chain
::
key128x128_value_object
;
using
chain
::
key64x64x64_value_object
;
using
chain
::
by_name
;
using
chain
::
by_scope_primary
;
using
chain
::
uint128_t
;
...
...
@@ -223,87 +224,23 @@ read_only::get_info_results read_only::get_info(const read_only::get_info_params
};
}
read_only
::
get_table_rows_i64_result
read_only
::
get_table_rows_i64
(
const
read_only
::
get_table_rows_i64_params
&
p
)
const
{
read_only
::
get_table_rows_i64_result
result
;
const
auto
&
d
=
db
.
get_database
();
const
auto
&
code_account
=
d
.
get
<
account_object
,
by_name
>
(
p
.
code
);
types
::
AbiSerializer
abis
;
if
(
code_account
.
abi
.
size
()
>
4
)
{
/// 4 == packsize of empty Abi
eos
::
types
::
Abi
abi
;
fc
::
datastream
<
const
char
*>
ds
(
code_account
.
abi
.
data
(),
code_account
.
abi
.
size
()
);
fc
::
raw
::
unpack
(
ds
,
abi
);
abis
.
setAbi
(
abi
);
}
const
auto
&
idx
=
d
.
get_index
<
chain
::
key_value_index
,
by_scope_primary
>
();
auto
lower
=
idx
.
lower_bound
(
boost
::
make_tuple
(
p
.
scope
,
p
.
code
,
p
.
table
,
p
.
lower_bound
)
);
auto
upper
=
idx
.
upper_bound
(
boost
::
make_tuple
(
p
.
scope
,
p
.
code
,
p
.
table
,
p
.
upper_bound
)
);
vector
<
char
>
data
;
auto
start
=
fc
::
time_point
::
now
();
auto
end
=
fc
::
time_point
::
now
()
+
fc
::
microseconds
(
1000
*
10
);
/// 10ms max time
int
count
=
0
;
auto
itr
=
lower
;
for
(
itr
=
lower
;
itr
!=
upper
;
++
itr
)
{
data
.
resize
(
sizeof
(
uint64_t
)
+
itr
->
value
.
size
()
);
memcpy
(
data
.
data
(),
&
itr
->
primary_key
,
sizeof
(
itr
->
primary_key
)
);
memcpy
(
data
.
data
()
+
sizeof
(
uint64_t
),
itr
->
value
.
data
(),
itr
->
value
.
size
()
);
if
(
p
.
json
)
result
.
rows
.
emplace_back
(
abis
.
binaryToVariant
(
abis
.
getTableType
(
p
.
table
),
data
)
);
else
result
.
rows
.
emplace_back
(
fc
::
variant
(
data
)
);
if
(
++
count
==
p
.
limit
||
fc
::
time_point
::
now
()
>
end
)
break
;
read_only
::
get_table_rows_result
read_only
::
get_table_rows
(
const
read_only
::
get_table_rows_params
&
p
)
const
{
if
(
p
.
table_type
==
KEYi64
)
{
return
get_table_rows_ex
<
chain
::
key_value_index
,
chain
::
by_scope_primary
>
(
p
);
}
else
if
(
p
.
table_type
==
KEYi128i128
)
{
if
(
p
.
table_key
==
PRIMARY
)
return
get_table_rows_ex
<
chain
::
key128x128_value_index
,
chain
::
by_scope_primary
>
(
p
);
if
(
p
.
table_key
==
SECONDARY
)
return
get_table_rows_ex
<
chain
::
key128x128_value_index
,
chain
::
by_scope_secondary
>
(
p
);
}
else
if
(
p
.
table_type
==
KEYi64i64i64
)
{
if
(
p
.
table_key
==
PRIMARY
)
return
get_table_rows_ex
<
chain
::
key64x64x64_value_index
,
chain
::
by_scope_primary
>
(
p
);
if
(
p
.
table_key
==
SECONDARY
)
return
get_table_rows_ex
<
chain
::
key64x64x64_value_index
,
chain
::
by_scope_secondary
>
(
p
);
if
(
p
.
table_key
==
TERTIARY
)
return
get_table_rows_ex
<
chain
::
key64x64x64_value_index
,
chain
::
by_scope_tertiary
>
(
p
);
}
if
(
itr
!=
upper
)
result
.
more
=
true
;
return
result
;
}
read_only
::
get_table_rows_i128i128_primary_result
read_only
::
get_table_rows_i128i128_primary
(
const
read_only
::
get_table_rows_i128i128_primary_params
&
p
)
const
{
read_only
::
get_table_rows_i128i128_primary_result
result
;
const
auto
&
d
=
db
.
get_database
();
const
auto
&
code_account
=
d
.
get
<
account_object
,
by_name
>
(
p
.
code
);
types
::
AbiSerializer
abis
;
if
(
code_account
.
abi
.
size
()
>
4
)
{
/// 4 == packsize of empty Abi
eos
::
types
::
Abi
abi
;
fc
::
datastream
<
const
char
*>
ds
(
code_account
.
abi
.
data
(),
code_account
.
abi
.
size
()
);
fc
::
raw
::
unpack
(
ds
,
abi
);
abis
.
setAbi
(
abi
);
}
const
auto
&
idx
=
d
.
get_index
<
chain
::
key128x128_value_index
,
chain
::
by_scope_primary
>
();
auto
lower
=
idx
.
lower_bound
(
boost
::
make_tuple
(
p
.
scope
,
p
.
code
,
p
.
table
,
p
.
lower_bound
)
);
auto
upper
=
idx
.
upper_bound
(
boost
::
make_tuple
(
p
.
scope
,
p
.
code
,
p
.
table
,
p
.
upper_bound
)
);
vector
<
char
>
data
;
auto
start
=
fc
::
time_point
::
now
();
auto
end
=
fc
::
time_point
::
now
()
+
fc
::
microseconds
(
1000
*
10
);
/// 10ms max time
int
count
=
0
;
auto
itr
=
lower
;
for
(
itr
=
lower
;
itr
!=
upper
;
++
itr
)
{
data
.
resize
(
sizeof
(
uint128_t
)
*
2
+
itr
->
value
.
size
()
);
memcpy
(
data
.
data
(),
&
itr
->
primary_key
,
sizeof
(
itr
->
primary_key
)
);
memcpy
(
data
.
data
()
+
sizeof
(
uint128_t
),
&
itr
->
secondary_key
,
sizeof
(
itr
->
secondary_key
)
);
memcpy
(
data
.
data
()
+
sizeof
(
uint128_t
)
*
2
,
itr
->
value
.
data
(),
itr
->
value
.
size
()
);
if
(
p
.
json
)
result
.
rows
.
emplace_back
(
abis
.
binaryToVariant
(
abis
.
getTableType
(
p
.
table
),
data
)
);
else
result
.
rows
.
emplace_back
(
fc
::
variant
(
data
)
);
if
(
++
count
==
p
.
limit
||
fc
::
time_point
::
now
()
>
end
)
break
;
}
if
(
itr
!=
upper
)
result
.
more
=
true
;
return
result
;
FC_ASSERT
(
false
,
"invalid table type/key ${type}/${key}"
,
(
"type"
,
p
.
table_type
)(
"key"
,
p
.
table_key
));
}
read_only
::
get_block_results
read_only
::
get_block
(
const
read_only
::
get_block_params
&
params
)
const
{
...
...
plugins/chain_plugin/include/eos/chain_plugin/chain_plugin.hpp
浏览文件 @
0313558e
...
...
@@ -3,6 +3,7 @@
#include <eos/chain/chain_controller.hpp>
#include <eos/chain/key_value_object.hpp>
#include <eos/chain/account_object.hpp>
#include <eos/types/AbiSerializer.hpp>
#include <eos/database_plugin/database_plugin.hpp>
...
...
@@ -22,6 +23,13 @@ struct empty{};
class
read_only
{
const
chain_controller
&
db
;
const
string
KEYi64
=
"i64"
;
const
string
KEYi128i128
=
"i128i128"
;
const
string
KEYi64i64i64
=
"i64i64i64"
;
const
string
PRIMARY
=
"primary"
;
const
string
SECONDARY
=
"secondary"
;
const
string
TERTIARY
=
"tertiary"
;
public:
read_only
(
const
chain_controller
&
db
)
:
db
(
db
)
{}
...
...
@@ -105,39 +113,86 @@ public:
get_block_results
get_block
(
const
get_block_params
&
params
)
const
;
struct
get_table_rows_
i64_
params
{
struct
get_table_rows_params
{
bool
json
=
false
;
Name
scope
;
Name
code
;
Name
table
;
uint64_t
lower_bound
=
0
;
uint64_t
upper_bound
=
uint64_t
(
-
1
);
string
table_type
;
string
table_key
;
string
lower_bound
;
string
upper_bound
;
uint32_t
limit
=
10
;
};
struct
get_table_rows_i64_result
{
vector
<
fc
::
variant
>
rows
;
///< one row per item, either encoded as hex String or JSON object
bool
more
;
///< true if last element in data is not the end and sizeof data() < limit
};
get_table_rows_i64_result
get_table_rows_i64
(
const
get_table_rows_i64_params
&
params
)
const
;
struct
get_table_rows_i128i128_primary_params
{
bool
json
=
false
;
Name
scope
;
Name
code
;
Name
table
;
uint128_t
lower_bound
=
0
;
uint128_t
upper_bound
=
uint128_t
(
-
1
);
uint32_t
limit
=
10
;
};
};
struct
get_table_rows_
i128i128_primary_
result
{
struct
get_table_rows_result
{
vector
<
fc
::
variant
>
rows
;
///< one row per item, either encoded as hex String or JSON object
bool
more
;
///< true if last element in data is not the end and sizeof data() < limit
};
get_table_rows_i128i128_primary_result
get_table_rows_i128i128_primary
(
const
get_table_rows_i128i128_primary_params
&
params
)
const
;
get_table_rows_result
get_table_rows
(
const
get_table_rows_params
&
params
)
const
;
void
copy_row
(
const
chain
::
key_value_object
&
obj
,
vector
<
char
>&
data
)
const
{
data
.
resize
(
sizeof
(
uint64_t
)
+
obj
.
value
.
size
()
);
memcpy
(
data
.
data
(),
&
obj
.
primary_key
,
sizeof
(
uint64_t
)
);
memcpy
(
data
.
data
()
+
sizeof
(
uint64_t
),
obj
.
value
.
data
(),
obj
.
value
.
size
()
);
}
void
copy_row
(
const
chain
::
key128x128_value_object
&
obj
,
vector
<
char
>&
data
)
const
{
data
.
resize
(
2
*
sizeof
(
uint128_t
)
+
obj
.
value
.
size
()
);
memcpy
(
data
.
data
(),
&
obj
.
primary_key
,
sizeof
(
uint128_t
)
);
memcpy
(
data
.
data
()
+
sizeof
(
uint128_t
),
&
obj
.
secondary_key
,
sizeof
(
uint128_t
)
);
memcpy
(
data
.
data
()
+
2
*
sizeof
(
uint128_t
),
obj
.
value
.
data
(),
obj
.
value
.
size
()
);
}
void
copy_row
(
const
chain
::
key64x64x64_value_object
&
obj
,
vector
<
char
>&
data
)
const
{
data
.
resize
(
3
*
sizeof
(
uint64_t
)
+
obj
.
value
.
size
()
);
memcpy
(
data
.
data
(),
&
obj
.
primary_key
,
sizeof
(
uint64_t
)
);
memcpy
(
data
.
data
()
+
sizeof
(
uint64_t
),
&
obj
.
secondary_key
,
sizeof
(
uint64_t
)
);
memcpy
(
data
.
data
()
+
2
*
sizeof
(
uint64_t
),
&
obj
.
tertiary_key
,
sizeof
(
uint64_t
)
);
memcpy
(
data
.
data
()
+
3
*
sizeof
(
uint64_t
),
obj
.
value
.
data
(),
obj
.
value
.
size
()
);
}
template
<
typename
IndexType
,
typename
Scope
>
read_only
::
get_table_rows_result
get_table_rows_ex
(
const
read_only
::
get_table_rows_params
&
p
)
const
{
read_only
::
get_table_rows_result
result
;
const
auto
&
d
=
db
.
get_database
();
const
auto
&
code_account
=
d
.
get
<
chain
::
account_object
,
chain
::
by_name
>
(
p
.
code
);
types
::
AbiSerializer
abis
;
if
(
code_account
.
abi
.
size
()
>
4
)
{
/// 4 == packsize of empty Abi
eos
::
types
::
Abi
abi
;
fc
::
datastream
<
const
char
*>
ds
(
code_account
.
abi
.
data
(),
code_account
.
abi
.
size
()
);
fc
::
raw
::
unpack
(
ds
,
abi
);
abis
.
setAbi
(
abi
);
}
const
auto
&
idx
=
d
.
get_index
<
IndexType
,
Scope
>
();
auto
lower
=
idx
.
lower_bound
(
boost
::
make_tuple
(
p
.
scope
,
p
.
code
,
p
.
table
,
boost
::
lexical_cast
<
typename
IndexType
::
value_type
::
key_type
>
(
p
.
lower_bound
))
);
auto
upper
=
idx
.
upper_bound
(
boost
::
make_tuple
(
p
.
scope
,
p
.
code
,
p
.
table
,
boost
::
lexical_cast
<
typename
IndexType
::
value_type
::
key_type
>
(
p
.
upper_bound
))
);
vector
<
char
>
data
;
auto
start
=
fc
::
time_point
::
now
();
auto
end
=
fc
::
time_point
::
now
()
+
fc
::
microseconds
(
1000
*
10
);
/// 10ms max time
int
count
=
0
;
auto
itr
=
lower
;
for
(
itr
=
lower
;
itr
!=
upper
&&
itr
->
table
==
p
.
table
;
++
itr
)
{
copy_row
(
*
itr
,
data
);
if
(
p
.
json
)
result
.
rows
.
emplace_back
(
abis
.
binaryToVariant
(
abis
.
getTableType
(
p
.
table
),
data
)
);
else
result
.
rows
.
emplace_back
(
fc
::
variant
(
data
)
);
if
(
++
count
==
p
.
limit
||
fc
::
time_point
::
now
()
>
end
)
break
;
}
if
(
itr
!=
upper
)
result
.
more
=
true
;
return
result
;
}
};
class
read_write
{
...
...
@@ -198,20 +253,16 @@ private:
FC_REFLECT
(
eos
::
chain_apis
::
empty
,
)
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_info_results
,
(
head_block_num
)(
last_irreversible_block_num
)(
head_block_id
)(
head_block_time
)(
head_block_producer
)
(
recent_slots
)(
participation_rate
))
(
head_block_num
)(
last_irreversible_block_num
)(
head_block_id
)(
head_block_time
)(
head_block_producer
)
(
recent_slots
)(
participation_rate
))
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_block_params
,
(
block_num_or_id
))
FC_REFLECT_DERIVED
(
eos
::
chain_apis
::
read_only
::
get_block_results
,
(
eos
::
chain
::
signed_block
),
(
id
)(
block_num
)(
refBlockPrefix
)
);
FC_REFLECT
(
eos
::
chain_apis
::
read_write
::
push_transaction_results
,
(
transaction_id
)(
processed
)
)
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_table_rows_i64_params
,
(
json
)(
scope
)(
code
)(
table
)(
lower_bound
)(
upper_bound
)(
limit
)
);
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_table_rows_i64_result
,
(
rows
)(
more
)
);
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_table_rows_i128i128_primary_params
,
(
json
)(
scope
)(
code
)(
table
)(
lower_bound
)(
upper_bound
)(
limit
)
);
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_table_rows_i128i128_primary_result
,
(
rows
)(
more
)
);
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_table_rows_params
,
(
json
)(
table_type
)(
table_key
)(
scope
)(
code
)(
table
)(
lower_bound
)(
upper_bound
)(
limit
)
)
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_table_rows_result
,
(
rows
)(
more
)
);
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_account_results
,
(
name
)(
eos_balance
)(
staked_balance
)(
unstaking_balance
)(
last_unstaking_time
)(
producer
)(
abi
)
)
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
get_account_params
,
(
name
)
)
FC_REFLECT
(
eos
::
chain_apis
::
read_only
::
producer_info
,
(
name
)
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录