summaryrefslogtreecommitdiff
path: root/python-simpleeval.spec
diff options
context:
space:
mode:
Diffstat (limited to 'python-simpleeval.spec')
-rw-r--r--python-simpleeval.spec135
1 files changed, 135 insertions, 0 deletions
diff --git a/python-simpleeval.spec b/python-simpleeval.spec
new file mode 100644
index 0000000..899cba5
--- /dev/null
+++ b/python-simpleeval.spec
@@ -0,0 +1,135 @@
+%global _empty_manifest_terminate_build 0
+Name: python-simpleeval
+Version: 0.9.13
+Release: 1
+Summary: A simple, safe single expression evaluator library.
+License: MIT License
+URL: https://github.com/danthedeckie/simpleeval
+Source0: https://mirrors.nju.edu.cn/pypi/web/packages/8f/fa/d2d5bbf9a03fe7b0956368ac5420cfcb072146be6e912a50747dc376133a/simpleeval-0.9.13.tar.gz
+BuildArch: noarch
+
+
+%description
+A single file library for easily adding evaluatable expressions into
+python projects. Say you want to allow a user to set an alarm volume, which
+could depend on the time of day, alarm level, how many previous alarms had gone
+off, and if there is music playing at the time.
+Or if you want to allow simple formulae in a web application, but don't want to
+give full eval() access, or don't want to run in javascript on the client side.
+It's deliberately trying to stay simple to use and not have millions of features,
+pull it in from PyPI (pip or easy_install), or even just a single file you can dump
+into a project.
+Internally, it's using the amazing python ``ast`` module to parse the
+expression, which allows very fine control of what is and isn't allowed. It
+should be completely safe in terms of what operations can be performed by the
+expression.
+The only issue I know to be aware of is that you can create an expression which
+takes a long time to evaluate, or which evaluating requires an awful lot of
+memory, which leaves the potential for DOS attacks. There is basic protection
+against this, and you can lock it down further if you desire. (see the
+Operators_ section below)
+You should be aware of this when deploying in a public setting.
+The defaults are pretty locked down and basic, and it's easy to add
+whatever extra specific functionality you need (your own functions,
+variable/name lookup, etc).
+
+%package -n python3-simpleeval
+Summary: A simple, safe single expression evaluator library.
+Provides: python-simpleeval
+BuildRequires: python3-devel
+BuildRequires: python3-setuptools
+BuildRequires: python3-pip
+%description -n python3-simpleeval
+A single file library for easily adding evaluatable expressions into
+python projects. Say you want to allow a user to set an alarm volume, which
+could depend on the time of day, alarm level, how many previous alarms had gone
+off, and if there is music playing at the time.
+Or if you want to allow simple formulae in a web application, but don't want to
+give full eval() access, or don't want to run in javascript on the client side.
+It's deliberately trying to stay simple to use and not have millions of features,
+pull it in from PyPI (pip or easy_install), or even just a single file you can dump
+into a project.
+Internally, it's using the amazing python ``ast`` module to parse the
+expression, which allows very fine control of what is and isn't allowed. It
+should be completely safe in terms of what operations can be performed by the
+expression.
+The only issue I know to be aware of is that you can create an expression which
+takes a long time to evaluate, or which evaluating requires an awful lot of
+memory, which leaves the potential for DOS attacks. There is basic protection
+against this, and you can lock it down further if you desire. (see the
+Operators_ section below)
+You should be aware of this when deploying in a public setting.
+The defaults are pretty locked down and basic, and it's easy to add
+whatever extra specific functionality you need (your own functions,
+variable/name lookup, etc).
+
+%package help
+Summary: Development documents and examples for simpleeval
+Provides: python3-simpleeval-doc
+%description help
+A single file library for easily adding evaluatable expressions into
+python projects. Say you want to allow a user to set an alarm volume, which
+could depend on the time of day, alarm level, how many previous alarms had gone
+off, and if there is music playing at the time.
+Or if you want to allow simple formulae in a web application, but don't want to
+give full eval() access, or don't want to run in javascript on the client side.
+It's deliberately trying to stay simple to use and not have millions of features,
+pull it in from PyPI (pip or easy_install), or even just a single file you can dump
+into a project.
+Internally, it's using the amazing python ``ast`` module to parse the
+expression, which allows very fine control of what is and isn't allowed. It
+should be completely safe in terms of what operations can be performed by the
+expression.
+The only issue I know to be aware of is that you can create an expression which
+takes a long time to evaluate, or which evaluating requires an awful lot of
+memory, which leaves the potential for DOS attacks. There is basic protection
+against this, and you can lock it down further if you desire. (see the
+Operators_ section below)
+You should be aware of this when deploying in a public setting.
+The defaults are pretty locked down and basic, and it's easy to add
+whatever extra specific functionality you need (your own functions,
+variable/name lookup, etc).
+
+%prep
+%autosetup -n simpleeval-0.9.13
+
+%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-simpleeval -f filelist.lst
+%dir %{python3_sitelib}/*
+
+%files help -f doclist.lst
+%{_docdir}/*
+
+%changelog
+* Thu Mar 09 2023 Python_Bot <Python_Bot@openeuler.org> - 0.9.13-1
+- Package Spec generated