diff options
author | CoprDistGit <infra@openeuler.org> | 2023-05-10 05:55:05 +0000 |
---|---|---|
committer | CoprDistGit <infra@openeuler.org> | 2023-05-10 05:55:05 +0000 |
commit | 7ee1d2589e46b93bc8d53d432e000d2396fcf94e (patch) | |
tree | e09cf51fb41f149b391cdb0bd362244a236c0c9f | |
parent | 6da79b02eb792f861f4b4c0843552e416c77e5a6 (diff) |
automatic import of python-georss-generic-client
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | python-georss-generic-client.spec | 292 | ||||
-rw-r--r-- | sources | 1 |
3 files changed, 294 insertions, 0 deletions
@@ -0,0 +1 @@ +/georss_generic_client-0.7.tar.gz diff --git a/python-georss-generic-client.spec b/python-georss-generic-client.spec new file mode 100644 index 0000000..c446ddb --- /dev/null +++ b/python-georss-generic-client.spec @@ -0,0 +1,292 @@ +%global _empty_manifest_terminate_build 0 +Name: python-georss-generic-client +Version: 0.7 +Release: 1 +Summary: A GeoRSS generic client library. +License: Apache-2.0 +URL: https://github.com/exxamalte/python-georss-generic-client +Source0: https://mirrors.nju.edu.cn/pypi/web/packages/00/ad/3c7fe11e7c962b1bcdaa54633f8c154b37e81f5af30ae22279c987ffaa85/georss_generic_client-0.7.tar.gz +BuildArch: noarch + +Requires: python3-georss-client + +%description +# python-georss-generic-client + +[](https://github.com/exxamalte/python-georss-generic-client/actions?workflow=CI) +[](https://codecov.io/gh/exxamalte/python-georss-generic-client) +[](https://pypi.python.org/pypi/georss-generic-client) +[](https://pypi.python.org/pypi/georss-generic-client) + +This library provides convenient generic access to [GeoRSS](http://www.georss.org/) feeds. + +## Installation +`pip install georss-generic-client` + +## Usage +See below for examples of how this library can be used for particular GeoRSS +feeds. After instantiating a particular class and supply the required +parameters, you can call `update` to retrieve the feed data. The return value +will be a tuple of a status code and the actual data in the form of a list of +feed entries specific to the selected feed. + +**Status Codes** +* _UPDATE_OK_: Update went fine and data was retrieved. The library may still return empty data, for example because no entries fulfilled the filter criteria. +* _UPDATE_OK_NO_DATA_: Update went fine but no data was retrieved, for example because the server indicated that there was not update since the last request. +* _UPDATE_ERROR_: Something went wrong during the update + +**Supported Filters** + +| Filter | | Description | +|------------|---------------------|-------------| +| Radius | `filter_radius` | Radius in kilometers around the home coordinates in which events from the feed are included. | +| Categories | `filter_categories` | Array of category names. Only events with a category matching any of these are included. | + +**Example** +```python +from georss_generic_client import GenericFeed +# Home Coordinates: Latitude: -27.5, Longitude: 153.0 +# Filter radius: 200 km +feed = GenericFeed((-27.5, 153.0), filter_radius=200, + url="https://www.qfes.qld.gov.au/data/alerts/bushfireAlert.xml") +status, entries = feed.update() +``` + +## Feed Manager + +The Feed Manager helps managing feed updates over time, by notifying the +consumer of the feed about new feed entries, updates and removed entries +compared to the last feed update. + +* If the current feed update is the first one, then all feed entries will be + reported as new. The feed manager will keep track of all feed entries' + external IDs that it has successfully processed. +* If the current feed update is not the first one, then the feed manager will + produce three sets: + * Feed entries that were not in the previous feed update but are in the + current feed update will be reported as new. + * Feed entries that were in the previous feed update and are still in the + current feed update will be reported as to be updated. + * Feed entries that were in the previous feed update but are not in the + current feed update will be reported to be removed. +* If the current update fails, then all feed entries processed in the previous + feed update will be reported to be removed. + +After a successful update from the feed, the feed manager will provide two +different dates: + +* `last_update` will be the timestamp of the last successful update from the + feed. This date may be useful if the consumer of this library wants to + treat intermittent errors from feed updates differently. +* `last_timestamp` will be the latest timestamp extracted from the feed data. + This requires that the underlying feed data actually contains a suitable + date. This date may be useful if the consumer of this library wants to + process feed entries differently if they haven't actually been updated. + + + + +%package -n python3-georss-generic-client +Summary: A GeoRSS generic client library. +Provides: python-georss-generic-client +BuildRequires: python3-devel +BuildRequires: python3-setuptools +BuildRequires: python3-pip +%description -n python3-georss-generic-client +# python-georss-generic-client + +[](https://github.com/exxamalte/python-georss-generic-client/actions?workflow=CI) +[](https://codecov.io/gh/exxamalte/python-georss-generic-client) +[](https://pypi.python.org/pypi/georss-generic-client) +[](https://pypi.python.org/pypi/georss-generic-client) + +This library provides convenient generic access to [GeoRSS](http://www.georss.org/) feeds. + +## Installation +`pip install georss-generic-client` + +## Usage +See below for examples of how this library can be used for particular GeoRSS +feeds. After instantiating a particular class and supply the required +parameters, you can call `update` to retrieve the feed data. The return value +will be a tuple of a status code and the actual data in the form of a list of +feed entries specific to the selected feed. + +**Status Codes** +* _UPDATE_OK_: Update went fine and data was retrieved. The library may still return empty data, for example because no entries fulfilled the filter criteria. +* _UPDATE_OK_NO_DATA_: Update went fine but no data was retrieved, for example because the server indicated that there was not update since the last request. +* _UPDATE_ERROR_: Something went wrong during the update + +**Supported Filters** + +| Filter | | Description | +|------------|---------------------|-------------| +| Radius | `filter_radius` | Radius in kilometers around the home coordinates in which events from the feed are included. | +| Categories | `filter_categories` | Array of category names. Only events with a category matching any of these are included. | + +**Example** +```python +from georss_generic_client import GenericFeed +# Home Coordinates: Latitude: -27.5, Longitude: 153.0 +# Filter radius: 200 km +feed = GenericFeed((-27.5, 153.0), filter_radius=200, + url="https://www.qfes.qld.gov.au/data/alerts/bushfireAlert.xml") +status, entries = feed.update() +``` + +## Feed Manager + +The Feed Manager helps managing feed updates over time, by notifying the +consumer of the feed about new feed entries, updates and removed entries +compared to the last feed update. + +* If the current feed update is the first one, then all feed entries will be + reported as new. The feed manager will keep track of all feed entries' + external IDs that it has successfully processed. +* If the current feed update is not the first one, then the feed manager will + produce three sets: + * Feed entries that were not in the previous feed update but are in the + current feed update will be reported as new. + * Feed entries that were in the previous feed update and are still in the + current feed update will be reported as to be updated. + * Feed entries that were in the previous feed update but are not in the + current feed update will be reported to be removed. +* If the current update fails, then all feed entries processed in the previous + feed update will be reported to be removed. + +After a successful update from the feed, the feed manager will provide two +different dates: + +* `last_update` will be the timestamp of the last successful update from the + feed. This date may be useful if the consumer of this library wants to + treat intermittent errors from feed updates differently. +* `last_timestamp` will be the latest timestamp extracted from the feed data. + This requires that the underlying feed data actually contains a suitable + date. This date may be useful if the consumer of this library wants to + process feed entries differently if they haven't actually been updated. + + + + +%package help +Summary: Development documents and examples for georss-generic-client +Provides: python3-georss-generic-client-doc +%description help +# python-georss-generic-client + +[](https://github.com/exxamalte/python-georss-generic-client/actions?workflow=CI) +[](https://codecov.io/gh/exxamalte/python-georss-generic-client) +[](https://pypi.python.org/pypi/georss-generic-client) +[](https://pypi.python.org/pypi/georss-generic-client) + +This library provides convenient generic access to [GeoRSS](http://www.georss.org/) feeds. + +## Installation +`pip install georss-generic-client` + +## Usage +See below for examples of how this library can be used for particular GeoRSS +feeds. After instantiating a particular class and supply the required +parameters, you can call `update` to retrieve the feed data. The return value +will be a tuple of a status code and the actual data in the form of a list of +feed entries specific to the selected feed. + +**Status Codes** +* _UPDATE_OK_: Update went fine and data was retrieved. The library may still return empty data, for example because no entries fulfilled the filter criteria. +* _UPDATE_OK_NO_DATA_: Update went fine but no data was retrieved, for example because the server indicated that there was not update since the last request. +* _UPDATE_ERROR_: Something went wrong during the update + +**Supported Filters** + +| Filter | | Description | +|------------|---------------------|-------------| +| Radius | `filter_radius` | Radius in kilometers around the home coordinates in which events from the feed are included. | +| Categories | `filter_categories` | Array of category names. Only events with a category matching any of these are included. | + +**Example** +```python +from georss_generic_client import GenericFeed +# Home Coordinates: Latitude: -27.5, Longitude: 153.0 +# Filter radius: 200 km +feed = GenericFeed((-27.5, 153.0), filter_radius=200, + url="https://www.qfes.qld.gov.au/data/alerts/bushfireAlert.xml") +status, entries = feed.update() +``` + +## Feed Manager + +The Feed Manager helps managing feed updates over time, by notifying the +consumer of the feed about new feed entries, updates and removed entries +compared to the last feed update. + +* If the current feed update is the first one, then all feed entries will be + reported as new. The feed manager will keep track of all feed entries' + external IDs that it has successfully processed. +* If the current feed update is not the first one, then the feed manager will + produce three sets: + * Feed entries that were not in the previous feed update but are in the + current feed update will be reported as new. + * Feed entries that were in the previous feed update and are still in the + current feed update will be reported as to be updated. + * Feed entries that were in the previous feed update but are not in the + current feed update will be reported to be removed. +* If the current update fails, then all feed entries processed in the previous + feed update will be reported to be removed. + +After a successful update from the feed, the feed manager will provide two +different dates: + +* `last_update` will be the timestamp of the last successful update from the + feed. This date may be useful if the consumer of this library wants to + treat intermittent errors from feed updates differently. +* `last_timestamp` will be the latest timestamp extracted from the feed data. + This requires that the underlying feed data actually contains a suitable + date. This date may be useful if the consumer of this library wants to + process feed entries differently if they haven't actually been updated. + + + + +%prep +%autosetup -n georss-generic-client-0.7 + +%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-georss-generic-client -f filelist.lst +%dir %{python3_sitelib}/* + +%files help -f doclist.lst +%{_docdir}/* + +%changelog +* Wed May 10 2023 Python_Bot <Python_Bot@openeuler.org> - 0.7-1 +- Package Spec generated @@ -0,0 +1 @@ +0ae398ed2f8af7dded6294436d716a0a georss_generic_client-0.7.tar.gz |