Skip to content
Snippets Groups Projects
Unverified Commit a513c782 authored by roadscape's avatar roadscape Committed by GitHub
Browse files

Merge branch 'master' into netuoso-221-custom-json-validator

parents b82ff6e1 74a41ccb
No related branches found
No related tags found
No related merge requests found
{
"limits": {
"accounts_blacklist": [
"accounttoblock"
]
},
"upstreams": [
{
"name": "steemd",
"translate_to_appbase": true,
"urls": [
[
"steemd",
"https://your.steemd.url"
]
],
"ttls": [
[
"steemd",
3
]
],
"timeouts": [
[
"steemd",
3
]
]
},
{
"name": "appbase",
"urls": [
[
"appbase",
"https://your.steemd.url"
],
[
"appbase.account_history_api",
"https://your.account.history.steemd.url"
],
[
"appbase.condenser_api.get_account_history",
"https://your.account.history.steemd.url"
],
[
"appbase.condenser_api.get_ops_in_block",
"https://your.account.history.steemd.url"
],
[
"appbase.condenser_api.get_followers",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_following",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_follow_count",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_discussions_by_trending",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_discussions_by_hot",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_discussions_by_promoted",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_discussions_by_created",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_discussions_by_blog",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_discussions_by_feed",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_discussions_by_comments",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_replies_by_last_update",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_trending_tags",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_discussions_by_author_before_date",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_post_discussions_by_payout",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_comment_discussions_by_payout",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_blog",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_blog_entries",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_account_votes",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_state",
"https://your.hivemind.url"
],
[
"appbase.condenser_api.get_state.params=['witnesses']",
"https://your.account.history.steemd.url"
],
[
"appbase.condenser_api.get_state.params=['/witnesses']",
"https://your.account.history.steemd.url"
],
[
"appbase.condenser_api.get_state.params=['/~witnesses']",
"https://your.account.history.steemd.url"
],
[
"appbase.condenser_api.get_state.params=['~witnesses']",
"https://your.account.history.steemd.url"
],
[
"appbase.follow_api",
"https://your.hivemind.url"
],
[
"appbase.tags_api",
"https://your.hivemind.url"
]
],
"ttls": [
[
"appbase",
3
],
[
"appbase.login_api",
-1
],
[
"appbase.network_broadcast_api",
-1
],
[
"appbase.follow_api",
10
],
[
"appbase.market_history_api",
1
],
[
"appbase.condenser_api",
3
],
[
"appbase.condenser_api.get_block",
-2
],
[
"appbase.condenser_api.get_block_header",
-2
],
[
"appbase.condenser_api.get_content",
1
],
[
"appbase.condenser_api.get_state",
1
],
[
"appbase.condenser_api.get_state.params=['/trending']",
30
],
[
"appbase.condenser_api.get_state.params=['trending']",
30
],
[
"appbase.condenser_api.get_state.params=['/hot']",
30
],
[
"appbase.condenser_api.get_state.params=['/welcome']",
30
],
[
"appbase.condenser_api.get_state.params=['/promoted']",
30
],
[
"appbase.condenser_api.get_state.params=['/created']",
10
],
[
"appbase.condenser_api.get_dynamic_global_properties",
1
]
],
"timeouts": [
[
"appbase",
3
],
[
"appbase.network_broadcast_api",
0
],
[
"appbase.chain_api.push_block",
0
],
[
"appbase.chain_api.push_transaction",
0
],
[
"appbase.condenser_api.broadcast_block",
0
],
[
"appbase.condenser_api.broadcast_transaction",
0
],
[
"appbase.condenser_api.broadcast_transaction_synchronous",
0
],
[
"appbase.condenser_api.get_account_votes",
20
],
[
"appbase.condenser_api.get_ops_in_block.params=[2889020,false]",
20
],
[
"appbase.account_history_api.get_ops_in_block.params={\"block_num\":2889020,\"only_virtual\":false}",
20
]
]
},
{
"name": "hive",
"urls": [
[
"hive",
"https://your.hivemind.url"
]
],
"ttls": [
[
"hive",
-1
]
],
"timeouts": [
[
"hive",
30
]
]
}
]
}
......@@ -9,7 +9,7 @@ The easiest way to get up and running with jussi is by running it in a docker co
1) Copy the example `DEV_config.json` to a local directory and make any necessary edits.
2) Run this docker command (replace `/path/to/config.json` with the path to your config file):
```
docker run -it --env JUSSI_UPSTREAM_CONFIG_FILE=/app/config.json -v /path/to/config.json:/app/config.json -p 9000:9000 steemit/jussi:latest
docker run -it --env JUSSI_UPSTREAM_CONFIG_FILE=/app/config.json -v /path/to/config.json:/app/config.json -p 8080:8080 steemit/jussi:latest
```
You can build jussi using docker which will run it's full test suite with `docker build -t="myname/jussi:latest" .`
......@@ -147,4 +147,4 @@ Certain features of jussi can be configured using environment variables. If you
## Additional documentation
For more indepth documentation on jussi including examples, check out the section on it in the steem dev portal: https://developers.steem.io/services/#services-jussi
\ No newline at end of file
For more indepth documentation on jussi including examples, check out the section on it in the steem dev portal: https://developers.steem.io/services/#services-jussi
......@@ -33,7 +33,7 @@ from .utils import merge_cached_responses
logger = structlog.getLogger(__name__)
BATCH_IRREVERSIBLE_TTL_SET = frozenset([TTL.NO_EXPIRE_IF_IRREVERSIBLE])
BATCH_IRREVERSIBLE_TTL_SET = frozenset([TTL.DEFAULT_EXPIRE_IF_IRREVERSIBLE])
# types
CacheTTLValue = TypeVar('CacheTTL', int, float, type(None))
......@@ -188,7 +188,7 @@ class CacheGroup:
) -> None:
key = jsonrpc_cache_key(request)
ttl = ttl or request.upstream.ttl
if ttl == TTL.NO_EXPIRE_IF_IRREVERSIBLE:
if ttl == TTL.DEFAULT_EXPIRE_IF_IRREVERSIBLE:
last_irreversible_block_num = last_irreversible_block_num or \
self._memory_cache.gets('last_irreversible_block_num') or \
await self.get('last_irreversible_block_num')
......@@ -218,7 +218,7 @@ class CacheGroup:
else:
new_ttls = []
for i, ttl in enumerate(ttls):
if ttl == TTL.NO_EXPIRE_IF_IRREVERSIBLE:
if ttl == TTL.DEFAULT_EXPIRE_IF_IRREVERSIBLE:
ttl = irreversible_ttl(responses[i], last_irreversible_block_num)
new_ttls.append(ttl)
triplets = filter(lambda p: p[0] != TTL.NO_CACHE, zip(ttls, requests, responses))
......
......@@ -8,11 +8,11 @@ Method Settings
- TTL is an integer value in seconds. Integers <= 0 have special meaning
- A TTL of `0` won't expire
- A TTL of `-1` wont be cached
- A TTL of `-2` will be cached without expiration only if it is 'irreversible' in terms of blockchain consesus
- A TTL of `-2` will be cached with default expiration only if it is 'irreversible' in terms of blockchain consesus
- For readabilty/writabilty, there are shorthand variables for these 'special' TTL values:
- `NO_EXPIRE` == 0
- `NO_CACHE` == -1
- `NO_EXPIRE_IF_IRREVERSIBLE` == -2
- `DEFAULT_EXPIRE_IF_IRREVERSIBLE` == -2
"""
......@@ -23,7 +23,7 @@ class TTL(Enum):
DEFAULT_TTL = 3
NO_EXPIRE = None
NO_CACHE = -1
NO_EXPIRE_IF_IRREVERSIBLE = -2
DEFAULT_EXPIRE_IF_IRREVERSIBLE = -2
# pylint: disable=no-else-return
def __eq__(self, other: int) -> bool:
......
......@@ -30,8 +30,6 @@ def irreversible_ttl(jsonrpc_response: dict=None,
return TTL.NO_CACHE
try:
jrpc_block_num = block_num_from_jsonrpc_response(jsonrpc_response)
if jrpc_block_num and jrpc_block_num <= last_irreversible_block_num:
return TTL.NO_EXPIRE
return TTL.DEFAULT_TTL
except Exception as e:
logger.warning(
......
......@@ -18,7 +18,7 @@ from .errors import InvalidUpstreamURL
logger = structlog.get_logger(__name__)
ACCOUNT_TRANSFER_PATTERN = re.compile(r'^\/?(@([^\/\s]+)/transfers|~?witnesses)$')
ACCOUNT_TRANSFER_PATTERN = re.compile(r'^\/?(@([^\/\s]+)/transfers|~?witnesses|proposals)$')
# -------------------
......
......@@ -35,8 +35,8 @@ non_ttl_rpc_req = jsonrpc_from_request(dummy_request, 0, {"id": "1", "jsonrpc":
(ttl_rpc_req, rpc_resp, 999, TTL.DEFAULT_TTL),
# cache when last_block_num >= response block_num
(ttl_rpc_req, rpc_resp, 1000, TTL.NO_EXPIRE),
(ttl_rpc_req, rpc_resp, 1001, TTL.NO_EXPIRE),
(ttl_rpc_req, rpc_resp, 1000, TTL.DEFAULT_TTL),
(ttl_rpc_req, rpc_resp, 1001, TTL.DEFAULT_TTL),
# don't cache when bad/missing response block_num
(ttl_rpc_req, {}, 2000, TTL.NO_CACHE),
......@@ -54,7 +54,7 @@ def test_ttls(rpc_req, rpc_resp, last_block_num, expected):
(TTL.NO_CACHE, -1),
(TTL.DEFAULT_TTL, 3),
(TTL.NO_EXPIRE, None),
(TTL.NO_EXPIRE_IF_IRREVERSIBLE, -2),
(TTL.DEFAULT_EXPIRE_IF_IRREVERSIBLE, -2),
]
)
def test_ttl_eq(ttl, eq):
......@@ -65,7 +65,7 @@ def test_ttl_eq(ttl, eq):
@pytest.mark.parametrize('ttl', [
(TTL.NO_CACHE),
(TTL.DEFAULT_TTL),
(TTL.NO_EXPIRE_IF_IRREVERSIBLE)
(TTL.DEFAULT_EXPIRE_IF_IRREVERSIBLE)
]
)
def test_ttl_gt(ttl):
......@@ -75,7 +75,7 @@ def test_ttl_gt(ttl):
@pytest.mark.parametrize('ttl', [
(TTL.NO_CACHE),
(TTL.DEFAULT_TTL),
(TTL.NO_EXPIRE_IF_IRREVERSIBLE)
(TTL.DEFAULT_EXPIRE_IF_IRREVERSIBLE)
]
)
def test_ttl_ge(ttl):
......@@ -85,7 +85,7 @@ def test_ttl_ge(ttl):
@pytest.mark.parametrize('ttl', [
(TTL.NO_CACHE),
(TTL.DEFAULT_TTL),
(TTL.NO_EXPIRE_IF_IRREVERSIBLE)
(TTL.DEFAULT_EXPIRE_IF_IRREVERSIBLE)
]
)
def test_ttl_lt(ttl):
......@@ -95,7 +95,7 @@ def test_ttl_lt(ttl):
@pytest.mark.parametrize('ttl', [
(TTL.NO_CACHE),
(TTL.DEFAULT_TTL),
(TTL.NO_EXPIRE_IF_IRREVERSIBLE)
(TTL.DEFAULT_EXPIRE_IF_IRREVERSIBLE)
]
)
def test_ttl_le(ttl):
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment