%global _empty_manifest_terminate_build 0 Name: python-replitdb Version: 0.0.15 Release: 1 Summary: a client for replit db License: MIT License URL: https://github.com/Codemonkey51/replit-db-client Source0: https://mirrors.nju.edu.cn/pypi/web/packages/d7/1b/380e77275b7d57b0d4a37834de7e35dc8b2436f4c774abdb101e18db4ad9/replitdb-0.0.15.tar.gz BuildArch: noarch Requires: python3-requests-async %description # This package has been deprecated, I recommend you use the offical replit db client which can be found [here](https://pypi.org/p/replit). [![PyPI version](https://badge.fury.io/py/replitdb.svg)](https://pypi.org/project/replitdb) [![Run on Repl.it](https://repl.it/badge/github/codemonkey51/replit-db-client)](https://repl.it/github/codemonkey51/replit-db-client) [![Downloads](https://pepy.tech/badge/replitdb/week)](https://pepy.tech/project/replitdb) ## ReplitDB Client A Pythonic Client for use with the repl.it DataBase. Created by [Codemonkey51](https://repl.it/@codemonkey51). Documentation by [IreTheKID](https://repl.it/@irethekid). ## Installation There are many different methods of installing `replitdb` to your enviornment. `pip` is recommended as it is the most stable. + Pip: `pip install replitdb` + Easy Install: `easy_install replitdb` + Git: `$ git clone https://github.com/codemonkey51/replit-db-client replitdb` + Replit UPM: `python3 -m poetry init --no-interaction; python3 -m poetry add replitdb` ## Getting Started Once you have the package installed, simply import it and define the client to get started: ```py import replitdb client = replitdb.Client() ``` ## Using the Client The replitDB client can be used to write, delete, and edit keys/values within your database. Let's say you have your dictionary ready, like so: ```py import replitdb client = replitdb.Client() data = { "users" : { "name1" : {...}, "name2" : {...} }, "posts" : { "post1" : {...}, "post2" : {...} }, "codes" : [ 12345, 67890, ], "sessionID" : "837379829-2" } ``` You can write to the DB with either: ```py for key, value in data.items(): client.set(key=value) ``` or: ```py client.set_dict(data) ``` **Editor's Note:** Using the for loop will set 'key' equal to the variable value. Using `client.set_dict({key:value})` is recommended instead. After adding items to your DB, you may want to remove some. There are different methods to deleting values from the DB: ```py client.remove("codes") # Deletes the item the key "codes" client.remove_list(["users", "posts"]) # Deletes a list of items client.wipe # Wipes the whole DataBase clean ``` ## Client Functions ### Adding: + `client.set(name=value, name2=value2, ...)` Adds an item with it's name and value. + `client.set_dict({key:val})` Adds an item for every key/value pair in the dict. ### Removing: + `client.remove(name)` Removes an item by its name. + `client.remove_list([key])` Removes a list of items by name. + `client.wipe` Clears DB. (Caution: **Cannot Be Undone**) ### Viewing: + `client.view(name)` Returns the value of the name (tries to detect if it is a str or ddict/list and returns accordingly). + `client.view_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair found (tries to detect if it is a str or ddict/list and returns accordingly). + `client.view_multiple_list([key])` Returns a dictionary with each item being the key/value pair found in the list (tries to detect if it is a str or ddict/list and returns accordingly). + `client.all` Returns all key names. + `client.all_dict` Returns the entire DB as a dictionary. ### Viewing internals (async only) (recommended not to call directly) + `client._view_str(name)` Returns the value of the name as a string. + `client._view_str_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair as a string found. + `client._view_str_multiple_list([key])` Returns a dictionary with each item being the key/value pair found as a string in the list. + `client._view_json(name)` Returns the value of the name json decoded. + `client._view_json_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair json decoded found json decoded. + `client._view_json_multiple_list([key])` Returns a dictionary with each item being the key/value pair json decoded found in the list. ### Searching: + `client.list(prefix)` Returns lists of all keys found that start with the prefix. + `client.list_multiple(prefix, prefix2, ...)` Returns dict with each item being the prefix/key pair for all keys found that start each prefix. + `client.list_multiple_list([prefix])` Returns dict with each item being the prefix/key pair for all keys found that start each prefix in the list passed. ## Async Capabilities You can use asynchronous functions by defining your client with the `AsyncClient()` class. All functions will become coroutines that need to be awaited. Here are two examples: ```py import asyncio import replitdb client = AsyncClient() loop = asyncio.get_event_loop() data = { ... } loop.run_until_complete(client.set_dict(data)) ``` ```py import asyncio import replitdb client = AsyncClient() data = { ... } async def foo(): await client.set_dict(data) asyncio.run(foo()) ``` ## Known Issues + Repl.it UPM can't auto-detect package import. + Defualt client does not work in asynchronous enviornment. ## Deprecated Functions + `client.add(name)` is now `client.set(name)` + `client.add_dict({key:val})` is now `client.set_dict({key:val})` %package -n python3-replitdb Summary: a client for replit db Provides: python-replitdb BuildRequires: python3-devel BuildRequires: python3-setuptools BuildRequires: python3-pip %description -n python3-replitdb # This package has been deprecated, I recommend you use the offical replit db client which can be found [here](https://pypi.org/p/replit). [![PyPI version](https://badge.fury.io/py/replitdb.svg)](https://pypi.org/project/replitdb) [![Run on Repl.it](https://repl.it/badge/github/codemonkey51/replit-db-client)](https://repl.it/github/codemonkey51/replit-db-client) [![Downloads](https://pepy.tech/badge/replitdb/week)](https://pepy.tech/project/replitdb) ## ReplitDB Client A Pythonic Client for use with the repl.it DataBase. Created by [Codemonkey51](https://repl.it/@codemonkey51). Documentation by [IreTheKID](https://repl.it/@irethekid). ## Installation There are many different methods of installing `replitdb` to your enviornment. `pip` is recommended as it is the most stable. + Pip: `pip install replitdb` + Easy Install: `easy_install replitdb` + Git: `$ git clone https://github.com/codemonkey51/replit-db-client replitdb` + Replit UPM: `python3 -m poetry init --no-interaction; python3 -m poetry add replitdb` ## Getting Started Once you have the package installed, simply import it and define the client to get started: ```py import replitdb client = replitdb.Client() ``` ## Using the Client The replitDB client can be used to write, delete, and edit keys/values within your database. Let's say you have your dictionary ready, like so: ```py import replitdb client = replitdb.Client() data = { "users" : { "name1" : {...}, "name2" : {...} }, "posts" : { "post1" : {...}, "post2" : {...} }, "codes" : [ 12345, 67890, ], "sessionID" : "837379829-2" } ``` You can write to the DB with either: ```py for key, value in data.items(): client.set(key=value) ``` or: ```py client.set_dict(data) ``` **Editor's Note:** Using the for loop will set 'key' equal to the variable value. Using `client.set_dict({key:value})` is recommended instead. After adding items to your DB, you may want to remove some. There are different methods to deleting values from the DB: ```py client.remove("codes") # Deletes the item the key "codes" client.remove_list(["users", "posts"]) # Deletes a list of items client.wipe # Wipes the whole DataBase clean ``` ## Client Functions ### Adding: + `client.set(name=value, name2=value2, ...)` Adds an item with it's name and value. + `client.set_dict({key:val})` Adds an item for every key/value pair in the dict. ### Removing: + `client.remove(name)` Removes an item by its name. + `client.remove_list([key])` Removes a list of items by name. + `client.wipe` Clears DB. (Caution: **Cannot Be Undone**) ### Viewing: + `client.view(name)` Returns the value of the name (tries to detect if it is a str or ddict/list and returns accordingly). + `client.view_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair found (tries to detect if it is a str or ddict/list and returns accordingly). + `client.view_multiple_list([key])` Returns a dictionary with each item being the key/value pair found in the list (tries to detect if it is a str or ddict/list and returns accordingly). + `client.all` Returns all key names. + `client.all_dict` Returns the entire DB as a dictionary. ### Viewing internals (async only) (recommended not to call directly) + `client._view_str(name)` Returns the value of the name as a string. + `client._view_str_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair as a string found. + `client._view_str_multiple_list([key])` Returns a dictionary with each item being the key/value pair found as a string in the list. + `client._view_json(name)` Returns the value of the name json decoded. + `client._view_json_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair json decoded found json decoded. + `client._view_json_multiple_list([key])` Returns a dictionary with each item being the key/value pair json decoded found in the list. ### Searching: + `client.list(prefix)` Returns lists of all keys found that start with the prefix. + `client.list_multiple(prefix, prefix2, ...)` Returns dict with each item being the prefix/key pair for all keys found that start each prefix. + `client.list_multiple_list([prefix])` Returns dict with each item being the prefix/key pair for all keys found that start each prefix in the list passed. ## Async Capabilities You can use asynchronous functions by defining your client with the `AsyncClient()` class. All functions will become coroutines that need to be awaited. Here are two examples: ```py import asyncio import replitdb client = AsyncClient() loop = asyncio.get_event_loop() data = { ... } loop.run_until_complete(client.set_dict(data)) ``` ```py import asyncio import replitdb client = AsyncClient() data = { ... } async def foo(): await client.set_dict(data) asyncio.run(foo()) ``` ## Known Issues + Repl.it UPM can't auto-detect package import. + Defualt client does not work in asynchronous enviornment. ## Deprecated Functions + `client.add(name)` is now `client.set(name)` + `client.add_dict({key:val})` is now `client.set_dict({key:val})` %package help Summary: Development documents and examples for replitdb Provides: python3-replitdb-doc %description help # This package has been deprecated, I recommend you use the offical replit db client which can be found [here](https://pypi.org/p/replit). [![PyPI version](https://badge.fury.io/py/replitdb.svg)](https://pypi.org/project/replitdb) [![Run on Repl.it](https://repl.it/badge/github/codemonkey51/replit-db-client)](https://repl.it/github/codemonkey51/replit-db-client) [![Downloads](https://pepy.tech/badge/replitdb/week)](https://pepy.tech/project/replitdb) ## ReplitDB Client A Pythonic Client for use with the repl.it DataBase. Created by [Codemonkey51](https://repl.it/@codemonkey51). Documentation by [IreTheKID](https://repl.it/@irethekid). ## Installation There are many different methods of installing `replitdb` to your enviornment. `pip` is recommended as it is the most stable. + Pip: `pip install replitdb` + Easy Install: `easy_install replitdb` + Git: `$ git clone https://github.com/codemonkey51/replit-db-client replitdb` + Replit UPM: `python3 -m poetry init --no-interaction; python3 -m poetry add replitdb` ## Getting Started Once you have the package installed, simply import it and define the client to get started: ```py import replitdb client = replitdb.Client() ``` ## Using the Client The replitDB client can be used to write, delete, and edit keys/values within your database. Let's say you have your dictionary ready, like so: ```py import replitdb client = replitdb.Client() data = { "users" : { "name1" : {...}, "name2" : {...} }, "posts" : { "post1" : {...}, "post2" : {...} }, "codes" : [ 12345, 67890, ], "sessionID" : "837379829-2" } ``` You can write to the DB with either: ```py for key, value in data.items(): client.set(key=value) ``` or: ```py client.set_dict(data) ``` **Editor's Note:** Using the for loop will set 'key' equal to the variable value. Using `client.set_dict({key:value})` is recommended instead. After adding items to your DB, you may want to remove some. There are different methods to deleting values from the DB: ```py client.remove("codes") # Deletes the item the key "codes" client.remove_list(["users", "posts"]) # Deletes a list of items client.wipe # Wipes the whole DataBase clean ``` ## Client Functions ### Adding: + `client.set(name=value, name2=value2, ...)` Adds an item with it's name and value. + `client.set_dict({key:val})` Adds an item for every key/value pair in the dict. ### Removing: + `client.remove(name)` Removes an item by its name. + `client.remove_list([key])` Removes a list of items by name. + `client.wipe` Clears DB. (Caution: **Cannot Be Undone**) ### Viewing: + `client.view(name)` Returns the value of the name (tries to detect if it is a str or ddict/list and returns accordingly). + `client.view_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair found (tries to detect if it is a str or ddict/list and returns accordingly). + `client.view_multiple_list([key])` Returns a dictionary with each item being the key/value pair found in the list (tries to detect if it is a str or ddict/list and returns accordingly). + `client.all` Returns all key names. + `client.all_dict` Returns the entire DB as a dictionary. ### Viewing internals (async only) (recommended not to call directly) + `client._view_str(name)` Returns the value of the name as a string. + `client._view_str_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair as a string found. + `client._view_str_multiple_list([key])` Returns a dictionary with each item being the key/value pair found as a string in the list. + `client._view_json(name)` Returns the value of the name json decoded. + `client._view_json_multiple(name, name2, ...)` Returns a dictionary with each item being the name/value pair json decoded found json decoded. + `client._view_json_multiple_list([key])` Returns a dictionary with each item being the key/value pair json decoded found in the list. ### Searching: + `client.list(prefix)` Returns lists of all keys found that start with the prefix. + `client.list_multiple(prefix, prefix2, ...)` Returns dict with each item being the prefix/key pair for all keys found that start each prefix. + `client.list_multiple_list([prefix])` Returns dict with each item being the prefix/key pair for all keys found that start each prefix in the list passed. ## Async Capabilities You can use asynchronous functions by defining your client with the `AsyncClient()` class. All functions will become coroutines that need to be awaited. Here are two examples: ```py import asyncio import replitdb client = AsyncClient() loop = asyncio.get_event_loop() data = { ... } loop.run_until_complete(client.set_dict(data)) ``` ```py import asyncio import replitdb client = AsyncClient() data = { ... } async def foo(): await client.set_dict(data) asyncio.run(foo()) ``` ## Known Issues + Repl.it UPM can't auto-detect package import. + Defualt client does not work in asynchronous enviornment. ## Deprecated Functions + `client.add(name)` is now `client.set(name)` + `client.add_dict({key:val})` is now `client.set_dict({key:val})` %prep %autosetup -n replitdb-0.0.15 %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-replitdb -f filelist.lst %dir %{python3_sitelib}/* %files help -f doclist.lst %{_docdir}/* %changelog * Fri May 05 2023 Python_Bot - 0.0.15-1 - Package Spec generated