diff options
author | CoprDistGit <infra@openeuler.org> | 2023-04-12 02:46:04 +0000 |
---|---|---|
committer | CoprDistGit <infra@openeuler.org> | 2023-04-12 02:46:04 +0000 |
commit | 018a65786aec6a667fe4f06083f762060226dea2 (patch) | |
tree | 9779f510621f5392ea100b5b3641c89ac66d3c95 | |
parent | a648fd2ff80e05cd299f2d3257b409e4310595ab (diff) |
automatic import of python-fastapi-cache2
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | python-fastapi-cache2.spec | 212 | ||||
-rw-r--r-- | sources | 1 |
3 files changed, 214 insertions, 0 deletions
@@ -0,0 +1 @@ +/fastapi_cache2-0.2.1.tar.gz diff --git a/python-fastapi-cache2.spec b/python-fastapi-cache2.spec new file mode 100644 index 0000000..acf9722 --- /dev/null +++ b/python-fastapi-cache2.spec @@ -0,0 +1,212 @@ +%global _empty_manifest_terminate_build 0 +Name: python-fastapi-cache2 +Version: 0.2.1 +Release: 1 +Summary: Cache for FastAPI +License: Apache-2.0 +URL: https://github.com/long2ice/fastapi-cache +Source0: https://mirrors.nju.edu.cn/pypi/web/packages/98/a3/009315aa93cff6e45b01b435d67c354396ce48b936a3ca19d53ab517d73c/fastapi_cache2-0.2.1.tar.gz +BuildArch: noarch + +Requires: python3-aiobotocore +Requires: python3-aiohttp +Requires: python3-aiomcache +Requires: python3-fastapi +Requires: python3-pendulum +Requires: python3-redis +Requires: python3-typing-extensions +Requires: python3-uvicorn + +%description +expire | int, states a caching time in seconds +namespace | str, namespace to use to store certain cache items +coder | which coder to use, e.g. JsonCoder +key_builder | which key builder to use, default to builtin +You can also use `cache` as decorator like other cache tools to cache common function result. +### Custom coder +By default use `JsonCoder`, you can write custom coder to encode and decode cache result, just need +inherit `fastapi_cache.coder.Coder`. +```python +@app.get("/") +@cache(expire=60, coder=JsonCoder) +async def index(): + return dict(hello="world") +``` +### Custom key builder +By default use builtin key builder, if you need, you can override this and pass in `cache` or `FastAPICache.init` to +take effect globally. +```python +def my_key_builder( + func, + namespace: Optional[str] = "", + request: Request = None, + response: Response = None, + *args, + **kwargs, +): + prefix = FastAPICache.get_prefix() + cache_key = f"{prefix}:{namespace}:{func.__module__}:{func.__name__}:{args}:{kwargs}" + return cache_key +@app.get("/") +@cache(expire=60, coder=JsonCoder, key_builder=my_key_builder) +async def index(): + return dict(hello="world") +``` +### InMemoryBackend +`InMemoryBackend` store cache data in memory and use lazy delete, which mean if you don't access it after cached, it +will not delete automatically. +## Tests and coverage +```shell +coverage run -m pytest +coverage html +xdg-open htmlcov/index.html +``` +## License +This project is licensed under the [Apache-2.0](https://github.com/long2ice/fastapi-cache/blob/master/LICENSE) License. + +%package -n python3-fastapi-cache2 +Summary: Cache for FastAPI +Provides: python-fastapi-cache2 +BuildRequires: python3-devel +BuildRequires: python3-setuptools +BuildRequires: python3-pip +%description -n python3-fastapi-cache2 +expire | int, states a caching time in seconds +namespace | str, namespace to use to store certain cache items +coder | which coder to use, e.g. JsonCoder +key_builder | which key builder to use, default to builtin +You can also use `cache` as decorator like other cache tools to cache common function result. +### Custom coder +By default use `JsonCoder`, you can write custom coder to encode and decode cache result, just need +inherit `fastapi_cache.coder.Coder`. +```python +@app.get("/") +@cache(expire=60, coder=JsonCoder) +async def index(): + return dict(hello="world") +``` +### Custom key builder +By default use builtin key builder, if you need, you can override this and pass in `cache` or `FastAPICache.init` to +take effect globally. +```python +def my_key_builder( + func, + namespace: Optional[str] = "", + request: Request = None, + response: Response = None, + *args, + **kwargs, +): + prefix = FastAPICache.get_prefix() + cache_key = f"{prefix}:{namespace}:{func.__module__}:{func.__name__}:{args}:{kwargs}" + return cache_key +@app.get("/") +@cache(expire=60, coder=JsonCoder, key_builder=my_key_builder) +async def index(): + return dict(hello="world") +``` +### InMemoryBackend +`InMemoryBackend` store cache data in memory and use lazy delete, which mean if you don't access it after cached, it +will not delete automatically. +## Tests and coverage +```shell +coverage run -m pytest +coverage html +xdg-open htmlcov/index.html +``` +## License +This project is licensed under the [Apache-2.0](https://github.com/long2ice/fastapi-cache/blob/master/LICENSE) License. + +%package help +Summary: Development documents and examples for fastapi-cache2 +Provides: python3-fastapi-cache2-doc +%description help +expire | int, states a caching time in seconds +namespace | str, namespace to use to store certain cache items +coder | which coder to use, e.g. JsonCoder +key_builder | which key builder to use, default to builtin +You can also use `cache` as decorator like other cache tools to cache common function result. +### Custom coder +By default use `JsonCoder`, you can write custom coder to encode and decode cache result, just need +inherit `fastapi_cache.coder.Coder`. +```python +@app.get("/") +@cache(expire=60, coder=JsonCoder) +async def index(): + return dict(hello="world") +``` +### Custom key builder +By default use builtin key builder, if you need, you can override this and pass in `cache` or `FastAPICache.init` to +take effect globally. +```python +def my_key_builder( + func, + namespace: Optional[str] = "", + request: Request = None, + response: Response = None, + *args, + **kwargs, +): + prefix = FastAPICache.get_prefix() + cache_key = f"{prefix}:{namespace}:{func.__module__}:{func.__name__}:{args}:{kwargs}" + return cache_key +@app.get("/") +@cache(expire=60, coder=JsonCoder, key_builder=my_key_builder) +async def index(): + return dict(hello="world") +``` +### InMemoryBackend +`InMemoryBackend` store cache data in memory and use lazy delete, which mean if you don't access it after cached, it +will not delete automatically. +## Tests and coverage +```shell +coverage run -m pytest +coverage html +xdg-open htmlcov/index.html +``` +## License +This project is licensed under the [Apache-2.0](https://github.com/long2ice/fastapi-cache/blob/master/LICENSE) License. + +%prep +%autosetup -n fastapi-cache2-0.2.1 + +%build +%py3_build + +%install +%py3_install +install -d -m755 %{buildroot}/%{_pkgdocdir} +if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi +if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi +if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi +if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi +pushd %{buildroot} +if [ -d usr/lib ]; then + find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/lib64 ]; then + find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/bin ]; then + find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/sbin ]; then + find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst +fi +touch doclist.lst +if [ -d usr/share/man ]; then + find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst +fi +popd +mv %{buildroot}/filelist.lst . +mv %{buildroot}/doclist.lst . + +%files -n python3-fastapi-cache2 -f filelist.lst +%dir %{python3_sitelib}/* + +%files help -f doclist.lst +%{_docdir}/* + +%changelog +* Wed Apr 12 2023 Python_Bot <Python_Bot@openeuler.org> - 0.2.1-1 +- Package Spec generated @@ -0,0 +1 @@ +1de62809eaa8b7e38b407870bbce10af fastapi_cache2-0.2.1.tar.gz |