Skip to content

Commit

Permalink
fix: fix Redis issues
Browse files Browse the repository at this point in the history
  • Loading branch information
ninoseki committed Feb 4, 2024
1 parent 5128690 commit 65ec1cd
Show file tree
Hide file tree
Showing 6 changed files with 15 additions and 10 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ Alternatively you can set values through `.env` file. Values in `.env` file will
| ---------------------- | ----------------------------------------------- | ----------- |
| `INQUEST_API_KEY` | InQuest API key | - |
| `REDIS_EXPIRE` | Redis cache expiration time (in seconds) | 3600 |
| `REDIS_HSET_KEY` | Redis HSET key | `analysis` |
| `REDIS_KEY_PREFIX` | Redis key prefix | `analysis` |
| `REDIS_URL` | Redis URL | - |
| `SPAMASSASSIN_HOST` | SpamAssassin host | `127.0.0.1` |
| `SPAMASSASSIN_PORT` | SpamAssassin port | 783 |
Expand Down
8 changes: 3 additions & 5 deletions backend/api/endpoints/analyze.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,12 +40,10 @@ def cache_response(
redis: Redis,
response: schemas.Response,
expire: int = settings.REDIS_EXPIRE,
name: str = settings.REDIS_HSET_KEY,
key_prefix: str = settings.REDIS_KEY_PREFIX,
):
redis.hset(name=name, key=response.id, value=response.model_dump_json())

if expire > 0:
redis.expire(name=response.id, time=expire)
ex = expire if expire > 0 else None
redis.set(f"{key_prefix}:{response.id}", value=response.model_dump_json(), ex=ex)


@router.post(
Expand Down
6 changes: 5 additions & 1 deletion backend/api/endpoints/cache.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,4 +18,8 @@ async def cache_keys(optional_redis: deps.OptionalRedis) -> list[str]:
detail="Redis cache is not enabled",
)

return optional_redis.hkeys(settings.REDIS_HSET_KEY) # type: ignore
byte_keys: list[bytes] = optional_redis.keys(f"{settings.REDIS_KEY_PREFIX}:*") # type: ignore
return [
byte_key.decode().removeprefix(f"{settings.REDIS_KEY_PREFIX}:")
for byte_key in byte_keys
]
2 changes: 1 addition & 1 deletion backend/api/endpoints/lookup.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ async def lookup(id: str, *, optional_redis: deps.OptionalRedis) -> schemas.Resp
detail="Redis cache is not enabled",
)

got: bytes | None = optional_redis.hget(name=id, key=settings.REDIS_HSET_KEY) # type: ignore
got: bytes | None = optional_redis.get(f"{settings.REDIS_KEY_PREFIX}:{id}") # type: ignore
if got is None:
raise HTTPException(
status_code=status.HTTP_404_NOT_FOUND,
Expand Down
2 changes: 1 addition & 1 deletion backend/settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
# Redis
REDIS_URL: DatabaseURL | None = config("REDIS_URL", cast=DatabaseURL, default=None)
REDIS_EXPIRE: int = config("REDIS_EXPIRE", cast=int, default=3600)
REDIS_HSET_KEY: str = config("REDIS_HSET_KEY", cast=str, default="analysis")
REDIS_KEY_PREFIX: str = config("REDIS_KEY_PREFIX", cast=str, default="analysis")

# 3rd party API keys
VIRUSTOTAL_API_KEY: Secret | None = config(
Expand Down
5 changes: 4 additions & 1 deletion frontend/src/components/Cache.vue
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
<Loading v-if="getCacheKeysTask.isRunning"></Loading>
<ErrorMessage :error="getCacheKeysTask.last?.error" v-if="getCacheKeysTask.isError" />
<div class="block" v-if="getCacheKeysTask.last?.value && !getCacheKeysTask.last.isRunning">
<div class="buttons">
<div class="buttons" v-if="getCacheKeysTask.last.value.length > 0">
<router-link
class="button is-link is-light"
:to="{ name: 'Lookup', params: { id: key } }"
Expand All @@ -13,6 +13,9 @@
>{{ key }}</router-link
>
</div>
<article class="message is-info" v-else>
<div class="message-body">There is no cache.</div>
</article>
</div>
</div>
</template>
Expand Down

0 comments on commit 65ec1cd

Please sign in to comment.