From 88a1ab65ce61bd94af0560980194d44affea45fb Mon Sep 17 00:00:00 2001 From: Karl MacMillan Date: Fri, 10 Aug 2007 07:09:16 -0400 Subject: [PATCH 1/4] Updates to build kpaswd and the slapi plugins. --- Makefile | 11 ++++++- ipa-server/Makefile | 2 +- ipa-server/freeipa-server.spec | 21 ++++++++++++-- ipa-server/freeipa-server.spec.in | 20 +++++++++++-- ipa-server/ipa-install/Makefile | 1 + ipa-server/ipa-kpasswd/Makefile | 23 +++++++++++++-- ipa-server/ipa-slapi-plugins/Makefile | 17 +++++++++++ .../ipa-slapi-plugins/ipa-pwd-extop/Makefile | 29 +++++++++++++++++-- 8 files changed, 110 insertions(+), 14 deletions(-) create mode 100644 ipa-server/ipa-slapi-plugins/Makefile diff --git a/Makefile b/Makefile index 5de0c5d3b..084c63e71 100644 --- a/Makefile +++ b/Makefile @@ -2,6 +2,9 @@ SUBDIRS=ipa-server ipa-admintools ipa-python PRJ_PREFIX=freeipa +# set to 1 to produce a debug build of all subprojects +#DEBUG=1 + # Version numbers - this is for the entire server. After # updating this you should run the version-update # target. @@ -26,12 +29,18 @@ PYTHON_VERSION=$(PYTHON_MAJOR).$(PYTHON_MINOR).$(PYTHON_RELEASE) PYTHON_TARBALL_PREFIX=$(PRJ_PREFIX)-python-$(PYTHON_VERSION) PYTHON_TARBALL=$(PYTHON_TARBALL_PREFIX).tgz +ifeq ($(DEBUG),1) + export CFLAGS = -g -Wall -Wshadow + export LDFLAGS = -g +endif + + all: @for subdir in $(SUBDIRS); do \ (cd $$subdir && $(MAKE) $@) || exit 1; \ done -install: +install: all @for subdir in $(SUBDIRS); do \ (cd $$subdir && $(MAKE) $@) || exit 1; \ done diff --git a/ipa-server/Makefile b/ipa-server/Makefile index dd3fa71ef..faee6e61c 100644 --- a/ipa-server/Makefile +++ b/ipa-server/Makefile @@ -1,4 +1,4 @@ -SUBDIRS=ipa-install xmlrpc-server +SUBDIRS=ipa-install xmlrpc-server ipa-kpasswd ipa-slapi-plugins PYTHONDIR=$(DESTDIR)/usr/share/ipa/ipaserver all: diff --git a/ipa-server/freeipa-server.spec b/ipa-server/freeipa-server.spec index 463db5893..85ddeb937 100755 --- a/ipa-server/freeipa-server.spec +++ b/ipa-server/freeipa-server.spec @@ -1,6 +1,6 @@ Name: freeipa-server Version: 0.1.0 -Release: 3%{?dist} +Release: %{?dist} Summary: FreeIPA authentication server Group: System Environment/Base @@ -8,11 +8,14 @@ License: GPL URL: http://www.freeipa.org Source0: %{name}-%{version}.tgz BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) -BuildArch: noarch +#BuildArch: -Requires: python fedora-ds-base krb5-server krb5-server-ldap nss-tools openldap-clients httpd mod_python mod_auth_kerb python-ldap freeipa-python ntpd cyrus-sasl-gssapi +BuildRequires: fedora-ds-base-devel openldap-devel krb5-devel nss-devel mozldap-devel openssl-devel mhash-devel + +Requires: python fedora-ds-base krb5-server krb5-server-ldap nss-tools openldap-clients httpd mod_python mod_auth_kerb python-ldap freeipa-python ntpd cyrus-sasl-gssapi nss %define httpd_conf /etc/httpd/conf.d +%define plugin_dir /usr/lib/fedora-ds/plugins %description FreeIPA is a server for identity, policy, and audit. @@ -20,9 +23,14 @@ FreeIPA is a server for identity, policy, and audit. %prep %setup -q +%build + +make DESTDIR=%{buildroot} + %install rm -rf %{buildroot} mkdir -p %{buildroot}%{_sbindir} +mkdir -p %{buildroot}%{plugin_dir} make install DESTDIR=%{buildroot} @@ -35,12 +43,19 @@ rm -rf %{buildroot} %defattr(-,root,root,-) %{_sbindir}/ipa-server-install %{_sbindir}/ipa-server-setupssl +%{_sbindir}/ipa_kpasswd + %dir %{_usr}/share/ipa %{_usr}/share/ipa/* +%{plugin_dir}/libipa_pwd_extop.so + %changelog +* Fri Aug 10 2007 Karl MacMillan - 0.1.0-3 +- Added support for ipa_kpasswd and ipa_pwd_extop + * Mon Aug 5 2007 Rob Crittenden - 0.1.0-3 - Abstracted client class to work directly or over RPC diff --git a/ipa-server/freeipa-server.spec.in b/ipa-server/freeipa-server.spec.in index 549afc979..e108da15a 100644 --- a/ipa-server/freeipa-server.spec.in +++ b/ipa-server/freeipa-server.spec.in @@ -1,6 +1,6 @@ Name: freeipa-server Version: VERSION -Release: 3%{?dist} +Release: %{?dist} Summary: FreeIPA authentication server Group: System Environment/Base @@ -8,11 +8,13 @@ License: GPL URL: http://www.freeipa.org Source0: %{name}-%{version}.tgz BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) -BuildArch: noarch -Requires: python fedora-ds-base krb5-server krb5-server-ldap nss-tools openldap-clients httpd mod_python mod_auth_kerb python-ldap freeipa-python ntpd cyrus-sasl-gssapi +BuildRequires: fedora-ds-base-devel openldap-devel krb5-devel nss-devel mozldap-devel openssl-devel mhash-devel + +Requires: python fedora-ds-base krb5-server krb5-server-ldap nss-tools openldap-clients httpd mod_python mod_auth_kerb python-ldap freeipa-python ntpd cyrus-sasl-gssapi nss %define httpd_conf /etc/httpd/conf.d +%define plugin_dir /usr/lib/fedora-ds/plugins %description FreeIPA is a server for identity, policy, and audit. @@ -20,9 +22,14 @@ FreeIPA is a server for identity, policy, and audit. %prep %setup -q +%build + +make DESTDIR=%{buildroot} + %install rm -rf %{buildroot} mkdir -p %{buildroot}%{_sbindir} +mkdir -p %{buildroot}%{plugin_dir} make install DESTDIR=%{buildroot} @@ -35,12 +42,19 @@ rm -rf %{buildroot} %defattr(-,root,root,-) %{_sbindir}/ipa-server-install %{_sbindir}/ipa-server-setupssl +%{_sbindir}/ipa_kpasswd + %dir %{_usr}/share/ipa %{_usr}/share/ipa/* +%{plugin_dir}/libipa_pwd_extop.so + %changelog +* Fri Aug 10 2007 Karl MacMillan - VERSION-3 +- Added support for ipa_kpasswd and ipa_pwd_extop + * Mon Aug 5 2007 Rob Crittenden - 0.1.0-3 - Abstracted client class to work directly or over RPC diff --git a/ipa-server/ipa-install/Makefile b/ipa-server/ipa-install/Makefile index 877ae09cc..2524baf31 100644 --- a/ipa-server/ipa-install/Makefile +++ b/ipa-server/ipa-install/Makefile @@ -3,6 +3,7 @@ SBINDIR=$(DESTDIR)/usr/sbin all: ; install: + -mkdir $(SBINDIR) install -m 755 ipa-server-install $(SBINDIR) install -m 755 ipa-server-setupssl $(SBINDIR) $(MAKE) -C share $@ diff --git a/ipa-server/ipa-kpasswd/Makefile b/ipa-server/ipa-kpasswd/Makefile index 4182b7705..11755a9a5 100644 --- a/ipa-server/ipa-kpasswd/Makefile +++ b/ipa-server/ipa-kpasswd/Makefile @@ -1,5 +1,22 @@ -all: - gcc ipa_kpasswd.c -I/usr/include -lkrb5 -llber -lldap -g -o ipa_kpasswd +PREFIX ?= $(DESTDIR)/usr +SBIN = $(PREFIX)/sbin + +LDFLAGS +=-lkrb5 -llber -lldap +CFLAGS ?= -Wall -Wshadow -O2 + +OBJS = $(patsubst %.c,%.o,$(wildcard *.c)) + +all: $(OBJS) + $(CC) $(LDFLAGS) $(OBJS) -o ipa_kpasswd + +%.o: %.c + $(CC) $(CFLAGS) -c -o $@ $< install: - cp -f ipa_kpasswd /usr/sbin/ + -mkdir -p $(SBIN) + install -m 755 ipa_kpasswd $(SBIN) + +clean: + rm -f *.o + rm -f ipa_kpasswd + rm -f *~ \ No newline at end of file diff --git a/ipa-server/ipa-slapi-plugins/Makefile b/ipa-server/ipa-slapi-plugins/Makefile new file mode 100644 index 000000000..95ed26c65 --- /dev/null +++ b/ipa-server/ipa-slapi-plugins/Makefile @@ -0,0 +1,17 @@ +SUBDIRS=ipa-pwd-extop + +all: + @for subdir in $(SUBDIRS); do \ + (cd $$subdir && $(MAKE) $@) || exit 1; \ + done + +install: + @for subdir in $(SUBDIRS); do \ + (cd $$subdir && $(MAKE) $@) || exit 1; \ + done + +clean: + @for subdir in $(SUBDIRS); do \ + (cd $$subdir && $(MAKE) $@) || exit 1; \ + done + rm -f *~ diff --git a/ipa-server/ipa-slapi-plugins/ipa-pwd-extop/Makefile b/ipa-server/ipa-slapi-plugins/ipa-pwd-extop/Makefile index 2a5646432..e89ca27ad 100644 --- a/ipa-server/ipa-slapi-plugins/ipa-pwd-extop/Makefile +++ b/ipa-server/ipa-slapi-plugins/ipa-pwd-extop/Makefile @@ -1,5 +1,28 @@ -all: - gcc ipa_pwd_extop.c -I/usr/include -I/usr/include/nss3 -I/usr/include/mozldap -I/usr/include/nspr4 -I/usr/include/fedora-ds -lkrb5 -lmhash -llber -lssl -shared -g -fPIC -DPIC -Wl,-soname -Wl,libipa_pwd_extop.so -o libipa_pwd_extop.so +PREFIX ?= $(DESTDIR)/usr +LIBDIR = $(PREFIX)/lib/fedora-ds/plugins +SHAREDIR = $(DESTDIR)/usr/share/ipa + +SONAME = libipa_pwd_extop.so +LDFLAGS += -lkrb5 -llber -lldap -lmhash -llber -lssl +CFLAGS ?= -Wall -Wshadow -O2 +CFLAGS += -I/usr/include/fedora-ds -I/usr/include/nss3 -I/usr/include/mozldap -I/usr/include/nspr4 -fPIC -DPIC + +OBJS = $(patsubst %.c,%.o,$(wildcard *.c)) + +all: $(OBJS) + $(CC) $(LDFLAGS) $(OBJS) -Wl,-soname -Wl,$(SONAME) -shared -o $(SONAME) + +%.o: %.c + $(CC) $(CFLAGS) -c -o $@ $< install: - cp -f libipa_pwd_extop.so /usr/lib/fedora-ds/plugins/ + -mkdir -p $(LIBDIR) + install -m 644 libipa_pwd_extop.so $(LIBDIR) + install -m 644 *.ldif $(SHAREDIR) + +clean: + rm -f *.o + rm -f $(SONAME) + rm -f *~ + + From 9a01f353cff7bdba3fdaa2aca2d29abf3c80c021 Mon Sep 17 00:00:00 2001 From: Karl MacMillan Date: Fri, 10 Aug 2007 07:17:53 -0400 Subject: [PATCH 2/4] Bump version numbers for release. --- Makefile | 6 +++--- ipa-python/freeipa-python.spec | 2 +- ipa-server/freeipa-server.spec | 9 ++++----- ipa-server/freeipa-server.spec.in | 6 +++--- 4 files changed, 11 insertions(+), 12 deletions(-) diff --git a/Makefile b/Makefile index 084c63e71..7068ec1d0 100644 --- a/Makefile +++ b/Makefile @@ -9,21 +9,21 @@ PRJ_PREFIX=freeipa # updating this you should run the version-update # target. SERV_MAJOR=0 -SERV_MINOR=1 +SERV_MINOR=2 SERV_RELEASE=0 SERV_VERSION=$(SERV_MAJOR).$(SERV_MINOR).$(SERV_RELEASE) SERV_TARBALL_PREFIX=$(PRJ_PREFIX)-server-$(SERV_VERSION) SERV_TARBALL=$(SERV_TARBALL_PREFIX).tgz ADMIN_MAJOR=0 -ADMIN_MINOR=1 +ADMIN_MINOR=2 ADMIN_RELEASE=0 ADMIN_VERSION=$(ADMIN_MAJOR).$(ADMIN_MINOR).$(ADMIN_RELEASE) ADMIN_TARBALL_PREFIX=$(PRJ_PREFIX)-admintools-$(ADMIN_VERSION) ADMIN_TARBALL=$(ADMIN_TARBALL_PREFIX).tgz PYTHON_MAJOR=0 -PYTHON_MINOR=1 +PYTHON_MINOR=2 PYTHON_RELEASE=0 PYTHON_VERSION=$(PYTHON_MAJOR).$(PYTHON_MINOR).$(PYTHON_RELEASE) PYTHON_TARBALL_PREFIX=$(PRJ_PREFIX)-python-$(PYTHON_VERSION) diff --git a/ipa-python/freeipa-python.spec b/ipa-python/freeipa-python.spec index e9b1e708d..d1a6b5db0 100755 --- a/ipa-python/freeipa-python.spec +++ b/ipa-python/freeipa-python.spec @@ -1,5 +1,5 @@ Name: freeipa-python -Version: 0.1.0 +Version: 0.2.0 Release: 3%{?dist} Summary: FreeIPA authentication server diff --git a/ipa-server/freeipa-server.spec b/ipa-server/freeipa-server.spec index 85ddeb937..cfd11d5ab 100755 --- a/ipa-server/freeipa-server.spec +++ b/ipa-server/freeipa-server.spec @@ -1,6 +1,6 @@ Name: freeipa-server -Version: 0.1.0 -Release: %{?dist} +Version: 0.2.0 +Release: 1%{?dist} Summary: FreeIPA authentication server Group: System Environment/Base @@ -8,7 +8,6 @@ License: GPL URL: http://www.freeipa.org Source0: %{name}-%{version}.tgz BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) -#BuildArch: BuildRequires: fedora-ds-base-devel openldap-devel krb5-devel nss-devel mozldap-devel openssl-devel mhash-devel @@ -53,7 +52,7 @@ rm -rf %{buildroot} %changelog -* Fri Aug 10 2007 Karl MacMillan - 0.1.0-3 +* Fri Aug 10 2007 Karl MacMillan - 0.2.0-1 - Added support for ipa_kpasswd and ipa_pwd_extop * Mon Aug 5 2007 Rob Crittenden - 0.1.0-3 @@ -67,7 +66,7 @@ rm -rf %{buildroot} - Create an ldif with a test user - Provide a certmap.conf for doing SSL client authentication -* Fri Jul 27 2007 Karl MacMillan - 0.1.0-1 +* Fri Jul 27 2007 Karl MacMillan - 0.1.0-1 - Initial rpm version diff --git a/ipa-server/freeipa-server.spec.in b/ipa-server/freeipa-server.spec.in index e108da15a..025c986b5 100644 --- a/ipa-server/freeipa-server.spec.in +++ b/ipa-server/freeipa-server.spec.in @@ -1,6 +1,6 @@ Name: freeipa-server Version: VERSION -Release: %{?dist} +Release: 1%{?dist} Summary: FreeIPA authentication server Group: System Environment/Base @@ -52,7 +52,7 @@ rm -rf %{buildroot} %changelog -* Fri Aug 10 2007 Karl MacMillan - VERSION-3 +* Fri Aug 10 2007 Karl MacMillan - 0.2.0-1 - Added support for ipa_kpasswd and ipa_pwd_extop * Mon Aug 5 2007 Rob Crittenden - 0.1.0-3 @@ -66,7 +66,7 @@ rm -rf %{buildroot} - Create an ldif with a test user - Provide a certmap.conf for doing SSL client authentication -* Fri Jul 27 2007 Karl MacMillan - 0.1.0-1 +* Fri Jul 27 2007 Karl MacMillan - 0.1.0-1 - Initial rpm version From cdaee95230322744be0a254b57832c5a35be4ca2 Mon Sep 17 00:00:00 2001 From: "kmccarth@redhat.com" Date: Sun, 12 Aug 2007 04:53:18 -0700 Subject: [PATCH 3/4] Addiing initial turbogears web gui. Contains simple user add, list, and view pages. --- ipa-server/ipa-gui/README.txt | 4 + ipa-server/ipa-gui/dev.cfg | 66 +++++++ ipa-server/ipa-gui/ipa_gui.egg-info/PKG-INFO | 15 ++ .../ipa-gui/ipa_gui.egg-info/SOURCES.txt | 21 +++ .../ipa_gui.egg-info/dependency_links.txt | 1 + .../ipa-gui/ipa_gui.egg-info/not-zip-safe | 1 + .../ipa_gui.egg-info/paster_plugins.txt | 2 + .../ipa-gui/ipa_gui.egg-info/requires.txt | 1 + .../ipa-gui/ipa_gui.egg-info/sqlobject.txt | 2 + .../ipa-gui/ipa_gui.egg-info/top_level.txt | 1 + ipa-server/ipa-gui/ipagui/config/app.cfg | 51 ++++++ ipa-server/ipa-gui/ipagui/config/log.cfg | 29 +++ ipa-server/ipa-gui/ipagui/controllers.py | 168 ++++++++++++++++++ ipa-server/ipa-gui/ipagui/forms/user.py | 67 +++++++ ipa-server/ipa-gui/ipagui/json.py | 10 ++ ipa-server/ipa-gui/ipagui/model.py | 9 + ipa-server/ipa-gui/ipagui/release.py | 14 ++ .../ipa-gui/ipagui/static/css/style.css | 146 +++++++++++++++ .../ipa-gui/ipagui/templates/groupindex.kid | 18 ++ .../ipa-gui/ipagui/templates/grouplayout.kid | 22 +++ ipa-server/ipa-gui/ipagui/templates/login.kid | 112 ++++++++++++ .../ipa-gui/ipagui/templates/master.kid | 48 +++++ .../ipa-gui/ipagui/templates/resindex.kid | 18 ++ .../ipa-gui/ipagui/templates/reslayout.kid | 22 +++ .../ipa-gui/ipagui/templates/useredit.kid | 13 ++ .../ipa-gui/ipagui/templates/userform.kid | 125 +++++++++++++ .../ipa-gui/ipagui/templates/userlayout.kid | 22 +++ .../ipa-gui/ipagui/templates/userlist.kid | 26 +++ .../ipa-gui/ipagui/templates/usernew.kid | 13 ++ .../ipa-gui/ipagui/templates/usershow.kid | 50 ++++++ .../ipa-gui/ipagui/templates/welcome.kid | 18 ++ .../ipa-gui/ipagui/tests/test_controllers.py | 32 ++++ ipa-server/ipa-gui/ipagui/tests/test_model.py | 22 +++ ipa-server/ipa-gui/sample-prod.cfg | 84 +++++++++ ipa-server/ipa-gui/setup.py | 62 +++++++ ipa-server/ipa-gui/start-ipagui.py | 25 +++ ipa-server/ipa-gui/test.cfg | 4 + 37 files changed, 1344 insertions(+) create mode 100644 ipa-server/ipa-gui/README.txt create mode 100644 ipa-server/ipa-gui/dev.cfg create mode 100644 ipa-server/ipa-gui/ipa_gui.egg-info/PKG-INFO create mode 100644 ipa-server/ipa-gui/ipa_gui.egg-info/SOURCES.txt create mode 100644 ipa-server/ipa-gui/ipa_gui.egg-info/dependency_links.txt create mode 100644 ipa-server/ipa-gui/ipa_gui.egg-info/not-zip-safe create mode 100644 ipa-server/ipa-gui/ipa_gui.egg-info/paster_plugins.txt create mode 100644 ipa-server/ipa-gui/ipa_gui.egg-info/requires.txt create mode 100644 ipa-server/ipa-gui/ipa_gui.egg-info/sqlobject.txt create mode 100644 ipa-server/ipa-gui/ipa_gui.egg-info/top_level.txt create mode 100644 ipa-server/ipa-gui/ipagui/config/app.cfg create mode 100644 ipa-server/ipa-gui/ipagui/config/log.cfg create mode 100644 ipa-server/ipa-gui/ipagui/controllers.py create mode 100644 ipa-server/ipa-gui/ipagui/forms/user.py create mode 100644 ipa-server/ipa-gui/ipagui/json.py create mode 100644 ipa-server/ipa-gui/ipagui/model.py create mode 100644 ipa-server/ipa-gui/ipagui/release.py create mode 100644 ipa-server/ipa-gui/ipagui/static/css/style.css create mode 100644 ipa-server/ipa-gui/ipagui/templates/groupindex.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/grouplayout.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/login.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/master.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/resindex.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/reslayout.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/useredit.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/userform.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/userlayout.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/userlist.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/usernew.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/usershow.kid create mode 100644 ipa-server/ipa-gui/ipagui/templates/welcome.kid create mode 100644 ipa-server/ipa-gui/ipagui/tests/test_controllers.py create mode 100644 ipa-server/ipa-gui/ipagui/tests/test_model.py create mode 100644 ipa-server/ipa-gui/sample-prod.cfg create mode 100644 ipa-server/ipa-gui/setup.py create mode 100644 ipa-server/ipa-gui/start-ipagui.py create mode 100644 ipa-server/ipa-gui/test.cfg diff --git a/ipa-server/ipa-gui/README.txt b/ipa-server/ipa-gui/README.txt new file mode 100644 index 000000000..876b880b1 --- /dev/null +++ b/ipa-server/ipa-gui/README.txt @@ -0,0 +1,4 @@ +ipa-gui + +This is a TurboGears (http://www.turbogears.org) project. It can be +started by running the start-ipagui.py script. \ No newline at end of file diff --git a/ipa-server/ipa-gui/dev.cfg b/ipa-server/ipa-gui/dev.cfg new file mode 100644 index 000000000..7bb0fd8c4 --- /dev/null +++ b/ipa-server/ipa-gui/dev.cfg @@ -0,0 +1,66 @@ +[global] +# This is where all of your settings go for your development environment +# Settings that are the same for both development and production +# (such as template engine, encodings, etc.) all go in +# ipagui/config/app.cfg + +# DATABASE + +# pick the form for your database +# sqlobject.dburi="postgres://username@hostname/databasename" +# sqlobject.dburi="mysql://username:password@hostname:port/databasename" +# sqlobject.dburi="sqlite:///file_name_and_path" + +# If you have sqlite, here's a simple default to get you started +# in development +sqlobject.dburi="sqlite://%(current_dir_uri)s/devdata.sqlite" + + +# if you are using a database or table type without transactions +# (MySQL default, for example), you should turn off transactions +# by prepending notrans_ on the uri +# sqlobject.dburi="notrans_mysql://username:password@hostname:port/databasename" + +# for Windows users, sqlite URIs look like: +# sqlobject.dburi="sqlite:///drive_letter:/path/to/file" + +# SERVER + +# Some server parameters that you may want to tweak +# server.socket_port=8080 + +# Enable the debug output at the end on pages. +# log_debug_info_filter.on = False + +server.environment="development" +autoreload.package="ipagui" + +# Auto-Reload after code modification +# autoreload.on = True + +# Set to True if you'd like to abort execution if a controller gets an +# unexpected parameter. False by default +tg.strict_parameters = True + +# LOGGING +# Logging configuration generally follows the style of the standard +# Python logging module configuration. Note that when specifying +# log format messages, you need to use *() for formatting variables. +# Deployment independent log configuration is in ipagui/config/log.cfg +[logging] + +[[loggers]] +[[[ipagui]]] +level='DEBUG' +qualname='ipagui' +handlers=['debug_out'] + +[[[allinfo]]] +level='INFO' +handlers=['debug_out'] + +[[[access]]] +level='INFO' +qualname='turbogears.access' +handlers=['access_out'] +propagate=0 diff --git a/ipa-server/ipa-gui/ipa_gui.egg-info/PKG-INFO b/ipa-server/ipa-gui/ipa_gui.egg-info/PKG-INFO new file mode 100644 index 000000000..544ba9f98 --- /dev/null +++ b/ipa-server/ipa-gui/ipa_gui.egg-info/PKG-INFO @@ -0,0 +1,15 @@ +Metadata-Version: 1.0 +Name: ipa-gui +Version: 1.0 +Summary: UNKNOWN +Home-page: UNKNOWN +Author: UNKNOWN +Author-email: UNKNOWN +License: UNKNOWN +Description: UNKNOWN +Platform: UNKNOWN +Classifier: Development Status :: 3 - Alpha +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Topic :: Software Development :: Libraries :: Python Modules +Classifier: Framework :: TurboGears diff --git a/ipa-server/ipa-gui/ipa_gui.egg-info/SOURCES.txt b/ipa-server/ipa-gui/ipa_gui.egg-info/SOURCES.txt new file mode 100644 index 000000000..49b7ce44d --- /dev/null +++ b/ipa-server/ipa-gui/ipa_gui.egg-info/SOURCES.txt @@ -0,0 +1,21 @@ +README.txt +setup.py +start-ipagui.py +ipa_gui.egg-info/PKG-INFO +ipa_gui.egg-info/SOURCES.txt +ipa_gui.egg-info/dependency_links.txt +ipa_gui.egg-info/not-zip-safe +ipa_gui.egg-info/paster_plugins.txt +ipa_gui.egg-info/requires.txt +ipa_gui.egg-info/sqlobject.txt +ipa_gui.egg-info/top_level.txt +ipagui/__init__.py +ipagui/controllers.py +ipagui/json.py +ipagui/model.py +ipagui/release.py +ipagui/config/__init__.py +ipagui/templates/__init__.py +ipagui/tests/__init__.py +ipagui/tests/test_controllers.py +ipagui/tests/test_model.py diff --git a/ipa-server/ipa-gui/ipa_gui.egg-info/dependency_links.txt b/ipa-server/ipa-gui/ipa_gui.egg-info/dependency_links.txt new file mode 100644 index 000000000..8b1378917 --- /dev/null +++ b/ipa-server/ipa-gui/ipa_gui.egg-info/dependency_links.txt @@ -0,0 +1 @@ + diff --git a/ipa-server/ipa-gui/ipa_gui.egg-info/not-zip-safe b/ipa-server/ipa-gui/ipa_gui.egg-info/not-zip-safe new file mode 100644 index 000000000..8b1378917 --- /dev/null +++ b/ipa-server/ipa-gui/ipa_gui.egg-info/not-zip-safe @@ -0,0 +1 @@ + diff --git a/ipa-server/ipa-gui/ipa_gui.egg-info/paster_plugins.txt b/ipa-server/ipa-gui/ipa_gui.egg-info/paster_plugins.txt new file mode 100644 index 000000000..14fec70ae --- /dev/null +++ b/ipa-server/ipa-gui/ipa_gui.egg-info/paster_plugins.txt @@ -0,0 +1,2 @@ +TurboGears +PasteScript diff --git a/ipa-server/ipa-gui/ipa_gui.egg-info/requires.txt b/ipa-server/ipa-gui/ipa_gui.egg-info/requires.txt new file mode 100644 index 000000000..aecc30960 --- /dev/null +++ b/ipa-server/ipa-gui/ipa_gui.egg-info/requires.txt @@ -0,0 +1 @@ +TurboGears >= 1.0.2.2 \ No newline at end of file diff --git a/ipa-server/ipa-gui/ipa_gui.egg-info/sqlobject.txt b/ipa-server/ipa-gui/ipa_gui.egg-info/sqlobject.txt new file mode 100644 index 000000000..cc84b8d00 --- /dev/null +++ b/ipa-server/ipa-gui/ipa_gui.egg-info/sqlobject.txt @@ -0,0 +1,2 @@ +db_module=ipagui.model +history_dir=$base/ipagui/sqlobject-history diff --git a/ipa-server/ipa-gui/ipa_gui.egg-info/top_level.txt b/ipa-server/ipa-gui/ipa_gui.egg-info/top_level.txt new file mode 100644 index 000000000..2ba21519d --- /dev/null +++ b/ipa-server/ipa-gui/ipa_gui.egg-info/top_level.txt @@ -0,0 +1 @@ +ipagui diff --git a/ipa-server/ipa-gui/ipagui/config/app.cfg b/ipa-server/ipa-gui/ipagui/config/app.cfg new file mode 100644 index 000000000..38d896f27 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/config/app.cfg @@ -0,0 +1,51 @@ +[global] +# The settings in this file should not vary depending on the deployment +# environment. dev.cfg and prod.cfg are the locations for +# the different deployment settings. Settings in this file will +# be overridden by settings in those other files. + +# The commented out values below are the defaults + +# VIEW + +# which view (template engine) to use if one is not specified in the +# template name +# tg.defaultview = "kid" + +# The following kid settings determine the settings used by the kid serializer. + +# One of (html|html-strict|xhtml|xhtml-strict|xml|json) +# kid.outputformat="html" + +# kid.encoding="utf-8" + +# The sitetemplate is used for overall styling of a site that +# includes multiple TurboGears applications +# tg.sitetemplate="" + +# Allow every exposed function to be called as json, +# tg.allow_json = False + +# List of Widgets to include on every page. +# for exemple ['turbogears.mochikit'] +# tg.include_widgets = [] + +# Set to True if the scheduler should be started +# tg.scheduler = False + +# Set session or cookie +# session_filter.on = True + + +# compress the data sends to the web browser +# [/] +# gzip_filter.on = True +# gzip_filter.mime_types = ["application/x-javascript", "text/javascript", "text/html", "text/css", "text/plain"] + +[/static] +static_filter.on = True +static_filter.dir = "%(top_level_dir)s/static" + +[/favicon.ico] +static_filter.on = True +static_filter.file = "%(top_level_dir)s/static/images/favicon.ico" diff --git a/ipa-server/ipa-gui/ipagui/config/log.cfg b/ipa-server/ipa-gui/ipagui/config/log.cfg new file mode 100644 index 000000000..ce776f850 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/config/log.cfg @@ -0,0 +1,29 @@ +# LOGGING +# Logging is often deployment specific, but some handlers and +# formatters can be defined here. + +[logging] +[[formatters]] +[[[message_only]]] +format='*(message)s' + +[[[full_content]]] +format='*(asctime)s *(name)s *(levelname)s *(message)s' + +[[handlers]] +[[[debug_out]]] +class='StreamHandler' +level='DEBUG' +args='(sys.stdout,)' +formatter='full_content' + +[[[access_out]]] +class='StreamHandler' +level='INFO' +args='(sys.stdout,)' +formatter='message_only' + +[[[error_out]]] +class='StreamHandler' +level='ERROR' +args='(sys.stdout,)' diff --git a/ipa-server/ipa-gui/ipagui/controllers.py b/ipa-server/ipa-gui/ipagui/controllers.py new file mode 100644 index 000000000..361a5cbdf --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/controllers.py @@ -0,0 +1,168 @@ +import cherrypy +import turbogears +from turbogears import controllers, expose, flash +from turbogears import validators, validate +from turbogears import widgets, paginate +from turbogears import error_handler +# from model import * +# import logging +# log = logging.getLogger("ipagui.controllers") +# import ipa.rpcclient +import ipa.config +import ipa.ipaclient +import ipa.user +import xmlrpclib +import forms.user + +ipa.config.init_config() +user_form = forms.user.UserFormWidget() + +client = ipa.ipaclient.IPAClient(True) +client.set_principal("test@FREEIPA.ORG") + +def restrict_post(): + if cherrypy.request.method != "POST": + turbogears.flash("This method only accepts posts") + raise turbogears.redirect("/") + +def user_to_hash(user): + return { + 'uid' : user.getValue('uid'), + 'givenName' : user.getValue('givenName'), + 'sn' : user.getValue('sn'), + 'mail' : user.getValue('mail'), + 'telephoneNumber': user.getValue('telephoneNumber'), + 'uidNumber': user.getValue('uidNumber'), + 'gidNumber': user.getValue('gidNumber'), + } + +class Root(controllers.RootController): + + @expose(template="ipagui.templates.welcome") + def index(self): + return dict() + + + ######## + # User # + ######## + + @expose("ipagui.templates.usernew") + def usernew(self, tg_errors=None): + """Displays the new user form""" + if tg_errors: + turbogears.flash("There was a problem with the form!") + + return dict(form=user_form) + + @expose() + def usercreate(self, **kw): + """Creates a new user""" + restrict_post() + if kw.get('submit') == 'Cancel': + turbogears.flash("Add user cancelled") + raise turbogears.redirect('/userlist') + + tg_errors, kw = self.uservalidate(**kw) + if tg_errors: + return dict(form=user_form, tg_template='ipagui.templates.usernew') + + try: + # rv = ipa.rpcclient.add_user(kw) + newuser = ipa.user.User(None) + newuser.setValue('uid', kw['uid']) + newuser.setValue('givenName', kw['givenName']) + newuser.setValue('sn', kw['sn']) + newuser.setValue('mail', kw['mail']) + newuser.setValue('telephoneNumber', kw['telephoneNumber']) + newuser2 = { + 'uid' : kw['uid'], + 'givenName' : kw['givenName'], + 'sn' : kw['sn'], + 'mail' : kw['mail'], + 'telephoneNumber': kw['telephoneNumber'] + } + rv = client.add_user(newuser2) + turbogears.flash("%s added!" % kw['uid']) + raise turbogears.redirect('/usershow', uid=kw['uid']) + except xmlrpclib.Fault, f: + turbogears.flash("User add failed: " + str(f.faultString)) + return dict(form=user_form, tg_template='ipagui.templates.usernew') + + + @expose("ipagui.templates.useredit") + def useredit(self, uid, tg_errors=None): + """Displays the edit user form""" + if tg_errors: + turbogears.flash("There was a problem with the form!") + + # user = ipa.rpcclient.get_user(uid) + user = client.get_user(uid) + return dict(form=user_form, user=user_to_hash(user)) + + @expose() + def userupdate(self, **kw): + """Updates an existing user""" + restrict_post() + if kw.get('submit') == 'Cancel': + turbogears.flash("Edit user cancelled") + raise turbogears.redirect('/usershow', uid=kw.get('uid')) + + tg_errors, kw = self.uservalidate(**kw) + if tg_errors: + return dict(form=user_form, user={}, tg_template='ipagui.templates.useredit') + + try: + # rv = ipa.rpcclient.add_user(kw) + turbogears.flash("%s updated!" % kw['uid']) + raise turbogears.redirect('/usershow', uid=kw['uid']) + except xmlrpclib.Fault, f: + turbogears.flash("User add failed: " + str(f.faultString)) + return dict(form=user_form, user={}, tg_template='ipagui.templates.useredit') + + + @expose("ipagui.templates.userlist") + @paginate('users', limit=3, allow_limit_override=True) + def userlist(self): + """Retrieve a list of all users and display them in one huge list""" + # users = ipa.rpcclient.get_all_users() + users = client.get_all_users() + return dict(users=users) + + + @expose("ipagui.templates.usershow") + def usershow(self, uid): + """Retrieve a single user for display""" + try: + # user = ipa.rpcclient.get_user(uid) + user = client.get_user(uid) + return dict(user=user_to_hash(user)) + except xmlrpclib.Fault, f: + turbogears.flash("User show failed: " + str(f.faultString)) + raise turbogears.redirect("/") + + @validate(form=user_form) + def uservalidate(self, tg_errors=None, **kw): + return tg_errors, kw + + @expose() + def userindex(self): + raise turbogears.redirect("/userlist") + + + ######### + # Group # + ######### + + @expose("ipagui.templates.groupindex") + def groupindex(self, tg_errors=None): + return dict() + + + ############ + # Resource # + ############ + + @expose("ipagui.templates.resindex") + def resindex(self, tg_errors=None): + return dict() diff --git a/ipa-server/ipa-gui/ipagui/forms/user.py b/ipa-server/ipa-gui/ipagui/forms/user.py new file mode 100644 index 000000000..3cb4aed49 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/forms/user.py @@ -0,0 +1,67 @@ +import turbogears +from turbogears import validators, widgets + +class UserFields(): + uid = widgets.TextField(name="uid", label="Login:") + userPassword = widgets.TextField(name="userPassword", label="Password:") + uidNumber = widgets.TextField(name="uidNumber", label="UID:") + gidNumber = widgets.TextField(name="gidNumber", label="GID:") + givenName = widgets.TextField(name="givenName", label="First name:") + sn = widgets.TextField(name="sn", label="Last name:") + mail = widgets.TextField(name="mail", label="E-mail address:") + telephoneNumber = widgets.TextField(name="telephoneNumber", label="Phone:") + + uid.validator = validators.PlainText(not_empty=True) + userPassword.validator = validators.String(not_empty=True) + givenName.validator = validators.String(not_empty=True) + sn.validator = validators.String(not_empty=True) + mail.validator = validators.Email(not_empty=True) + # validators.PhoneNumber may be a bit too picky, requiring an area code + telephoneNumber.validator = validators.PlainText(not_empty=True) + + +class UserFormWidget(widgets.Form): + params = ['user'] +# fields = [UserFields.uid, UserFields.userPassword, UserFields.givenName, +# UserFields.sn, UserFields.mail] + fields = [UserFields.uid, UserFields.givenName, + UserFields.uidNumber, UserFields.gidNumber, + UserFields.sn, UserFields.mail] + + def __init__(self, *args, **kw): + super(UserFormWidget,self).__init__(*args, **kw) + (self.template_c, self.template) = widgets.meta.load_kid_template("ipagui.templates.userform") + self.user = UserFields + + def update_params(self, params): + super(UserFormWidget,self).update_params(params) + params['has_foo'] = self.has_foo + + def has_foo(self): + return False + +# TODO - add dynamic field retrieval: +# myfields=[] +# schema = ipa.rpcclient.get_add_schema () +# +# # FIXME: What if schema is None or an error is thrown? +# +# for s in schema: +# required=False +# +# if (s['type'] == "text"): +# field = widgets.TextField(name=s['name'],label=s['label']) +# elif (s['type'] == "password"): +# field = widgets.PasswordField(name=s['name'],label=s['label']) +# +# if (s['required'] == "true"): +# required=True +# +# if (s['validator'] == "text"): +# field.validator=validators.PlainText(not_empty=required) +# elif (s['validator'] == "email"): +# field.validator=validators.Email(not_empty=required) +# elif (s['validator'] == "string"): +# field.validator=validators.String(not_empty=required) +# +# myfields.append(field) diff --git a/ipa-server/ipa-gui/ipagui/json.py b/ipa-server/ipa-gui/ipagui/json.py new file mode 100644 index 000000000..66d5cfb65 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/json.py @@ -0,0 +1,10 @@ +# A JSON-based API(view) for your app. +# Most rules would look like: +# @jsonify.when("isinstance(obj, YourClass)") +# def jsonify_yourclass(obj): +# return [obj.val1, obj.val2] +# @jsonify can convert your objects to following types: +# lists, dicts, numbers and strings + +from turbojson.jsonify import jsonify + diff --git a/ipa-server/ipa-gui/ipagui/model.py b/ipa-server/ipa-gui/ipagui/model.py new file mode 100644 index 000000000..244cfff70 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/model.py @@ -0,0 +1,9 @@ +from turbogears.database import PackageHub +from sqlobject import * + +hub = PackageHub('ipagui') +__connection__ = hub + +# class YourDataClass(SQLObject): +# pass + diff --git a/ipa-server/ipa-gui/ipagui/release.py b/ipa-server/ipa-gui/ipagui/release.py new file mode 100644 index 000000000..7be40c007 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/release.py @@ -0,0 +1,14 @@ +# Release information about ipa-gui + +version = "1.0" + +# description = "Your plan to rule the world" +# long_description = "More description about your plan" +# author = "Your Name Here" +# email = "YourEmail@YourDomain" +# copyright = "Vintage 2006 - a good year indeed" + +# if it's open source, you might want to specify these +# url = "http://yourcool.site/" +# download_url = "http://yourcool.site/download" +# license = "MIT" diff --git a/ipa-server/ipa-gui/ipagui/static/css/style.css b/ipa-server/ipa-gui/ipagui/static/css/style.css new file mode 100644 index 000000000..9cd7fe094 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/static/css/style.css @@ -0,0 +1,146 @@ +/* + * Quick mash-up of CSS for the TG quick start page. + */ + +html, body { + color: #000; + background:#fff; + margin: 0; + padding: 0; +} + +body { + min-width: 750px; +} + +#page { + background:#ccc; /* should be same as #sidebar */ + margin:0 auto; + width:100%; +} + + +#header { + background:#fff; +} + +#header h1 { + padding:5px; + margin:0; +} + + +#nav { + background:#cc0000; + color:#fff; + padding:5px; +} + +#nav ul { + margin:0; + padding:0; + list-style:none; +} + +#nav li { + display:inline; +} + +#nav a:visited { + color:#fff; +} +#nav a:link { + color:#fff; +} + + +#main_content { + background:#fff; + float:right; + width:85%; + border-left: 1px solid #000; + padding-left: 15px; + padding-bottom: 15px; +/* color: black; + font-size: 127%; + background-color: white; + margin: 0 auto 0 auto; + padding: 10px; + float: left; */ +} + + +#sidebar { + background:#ccc; /* should be same as #page */ + float:left; + width:10%; + /* border: 1px solid #aaa; + background-color: #eee; + margin: 0.5em; + padding: 1em; + float: left; + font-size: 88%; */ +} + +#sidebar h2 { + margin-top: 0; +} + +#sidebar ul { + margin-left: 1.5em; + padding-left: 0; +} + + +#footer { + background:#fff; + clear:both; + border-top: 1px solid #000; + /* color: #999; + background-color: white; + padding: 10px; + font-size: 80%; + text-align: center; + margin: 0 auto 1em auto; */ +} + + +.formsection { + color: #888888; + width: 90%; + font-weight: bold; + border-bottom: 1px solid; + margin: 20px 0px 20px 0px; +} + +.formtable { + width: 90%; +} + +.formtable th { + width: 15%; + text-align: right; +} + +#status_block { + margin: 0 auto 0.5em auto; + padding: 15px 10px 15px 55px; + background: #cec URL('../images/ok.png') left center no-repeat; + border: 1px solid #9c9; + width: 450px; + font-size: 120%; + font-weight: bolder; +} + +.notice { + margin: 0.5em auto 0.5em auto; + padding: 15px 10px 15px 55px; + width: 450px; + background: #eef URL('../images/info.png') left center no-repeat; + border: 1px solid #cce; +} + +.fielderror { + color: red; + font-weight: bold; +} diff --git a/ipa-server/ipa-gui/ipagui/templates/groupindex.kid b/ipa-server/ipa-gui/ipagui/templates/groupindex.kid new file mode 100644 index 000000000..0bb70ac9a --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/groupindex.kid @@ -0,0 +1,18 @@ + + + + +Group Listing + + + Groups go here. +
+
+
+
+
+
+
+ + diff --git a/ipa-server/ipa-gui/ipagui/templates/grouplayout.kid b/ipa-server/ipa-gui/ipagui/templates/grouplayout.kid new file mode 100644 index 000000000..af05a8082 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/grouplayout.kid @@ -0,0 +1,22 @@ + + + + + + +
+
+ +
+
+ + + + + diff --git a/ipa-server/ipa-gui/ipagui/templates/login.kid b/ipa-server/ipa-gui/ipagui/templates/login.kid new file mode 100644 index 000000000..a819cfc7a --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/login.kid @@ -0,0 +1,112 @@ + + + + + + Login + + + + +
+

Login

+

${message}

+
+ + + + + + + + + + + + +
+ + + +
+ + + +
+ +
+ + + + +
+
+ + diff --git a/ipa-server/ipa-gui/ipagui/templates/master.kid b/ipa-server/ipa-gui/ipagui/templates/master.kid new file mode 100644 index 000000000..464560d26 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/master.kid @@ -0,0 +1,48 @@ + + + + + + + Your title goes here + + + + + +
+ + Login + + + Welcome ${tg.identity.user.display_name}. + Logout + +
+ +
+ + + + +
+ + + +
+ + + + diff --git a/ipa-server/ipa-gui/ipagui/templates/resindex.kid b/ipa-server/ipa-gui/ipagui/templates/resindex.kid new file mode 100644 index 000000000..5cd06f7eb --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/resindex.kid @@ -0,0 +1,18 @@ + + + + +Resource Listing + + + Resources go here. +
+
+
+
+
+
+
+ + diff --git a/ipa-server/ipa-gui/ipagui/templates/reslayout.kid b/ipa-server/ipa-gui/ipagui/templates/reslayout.kid new file mode 100644 index 000000000..5b9b35c12 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/reslayout.kid @@ -0,0 +1,22 @@ + + + + + + +
+
+ +
+
+ + + + + diff --git a/ipa-server/ipa-gui/ipagui/templates/useredit.kid b/ipa-server/ipa-gui/ipagui/templates/useredit.kid new file mode 100644 index 000000000..781ff7ff1 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/useredit.kid @@ -0,0 +1,13 @@ + + + + +Edit a Person + + +

Edit User

+ + ${form.display(action="userupdate", value=user)} + + diff --git a/ipa-server/ipa-gui/ipagui/templates/userform.kid b/ipa-server/ipa-gui/ipagui/templates/userform.kid new file mode 100644 index 000000000..dd852865a --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/userform.kid @@ -0,0 +1,125 @@ +
+
+ +
Account Details
+ + + + + + + + + + + + + + + + + +
+ + + +
+ + + +
+ + + +
+ +
Identity Details
+ + + + + + + + + + +
+ + + + +
+ + + +
+ +
Contact Details
+ + + + + + + + + +
+ + + +
+ + + +
+ + + + + + + +
+
+ +
+
+ +
+ +
+
diff --git a/ipa-server/ipa-gui/ipagui/templates/userlayout.kid b/ipa-server/ipa-gui/ipagui/templates/userlayout.kid new file mode 100644 index 000000000..40ddcca39 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/userlayout.kid @@ -0,0 +1,22 @@ + + + + + + +
+
+ +
+
+ + + + + diff --git a/ipa-server/ipa-gui/ipagui/templates/userlist.kid b/ipa-server/ipa-gui/ipagui/templates/userlist.kid new file mode 100644 index 000000000..7b5667fb5 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/userlist.kid @@ -0,0 +1,26 @@ + + + + +User Listing + + +
+ People List +
+ Page: + + ${page} + ${page} + +

+ + ${user.cn} +
+
+

+
+ + diff --git a/ipa-server/ipa-gui/ipagui/templates/usernew.kid b/ipa-server/ipa-gui/ipagui/templates/usernew.kid new file mode 100644 index 000000000..84b6029ae --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/usernew.kid @@ -0,0 +1,13 @@ + + + + + Add a Person + + +

Add New User

+ + ${form.display(action="usercreate")} + + diff --git a/ipa-server/ipa-gui/ipagui/templates/usershow.kid b/ipa-server/ipa-gui/ipagui/templates/usershow.kid new file mode 100644 index 000000000..7fea76dbd --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/usershow.kid @@ -0,0 +1,50 @@ + + + + + View a Person + + +

View User

+ +
Account Details
+ + + + + + + + + + + + + +
User ID:${user.get("uid")}
UID:${user.get("uidNumber")}
GID:${user.get("gidNumber")}
+ +
Identity Details
+ + + + + +
Full Name:${user.get("givenName")} ${user.get("sn")}
+ +
Contact Details
+ + + + + + + + + +
Email:${user.get("mail")}
Telephone:${user.get("telephoneNumber")}
+ + edit + + + diff --git a/ipa-server/ipa-gui/ipagui/templates/welcome.kid b/ipa-server/ipa-gui/ipagui/templates/welcome.kid new file mode 100644 index 000000000..dc08c0b32 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/templates/welcome.kid @@ -0,0 +1,18 @@ + + + + +Welcome + + + +
+
+

Welcome to Free IPA

+
+ + + diff --git a/ipa-server/ipa-gui/ipagui/tests/test_controllers.py b/ipa-server/ipa-gui/ipagui/tests/test_controllers.py new file mode 100644 index 000000000..b9b4f5c5c --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/tests/test_controllers.py @@ -0,0 +1,32 @@ +import unittest +import turbogears +from turbogears import testutil +from ipagui.controllers import Root +import cherrypy + +cherrypy.root = Root() + +class TestPages(unittest.TestCase): + + def setUp(self): + turbogears.startup.startTurboGears() + + def tearDown(self): + """Tests for apps using identity need to stop CP/TG after each test to + stop the VisitManager thread. + See http://trac.turbogears.org/turbogears/ticket/1217 for details. + """ + turbogears.startup.stopTurboGears() + + def test_method(self): + "the index method should return a string called now" + import types + result = testutil.call(cherrypy.root.index) + assert type(result["now"]) == types.StringType + + def test_indextitle(self): + "The indexpage should have the right title" + testutil.createRequest("/") + response = cherrypy.response.body[0].lower() + assert "welcome to turbogears" in response + diff --git a/ipa-server/ipa-gui/ipagui/tests/test_model.py b/ipa-server/ipa-gui/ipagui/tests/test_model.py new file mode 100644 index 000000000..bd0db4c70 --- /dev/null +++ b/ipa-server/ipa-gui/ipagui/tests/test_model.py @@ -0,0 +1,22 @@ +# If your project uses a database, you can set up database tests +# similar to what you see below. Be sure to set the db_uri to +# an appropriate uri for your testing database. sqlite is a good +# choice for testing, because you can use an in-memory database +# which is very fast. + +from turbogears import testutil, database +# from ipagui.model import YourDataClass, User + +# database.set_db_uri("sqlite:///:memory:") + +# class TestUser(testutil.DBTest): +# def get_model(self): +# return User +# def test_creation(self): +# "Object creation should set the name" +# obj = User(user_name = "creosote", +# email_address = "spam@python.not", +# display_name = "Mr Creosote", +# password = "Wafer-thin Mint") +# assert obj.display_name == "Mr Creosote" + diff --git a/ipa-server/ipa-gui/sample-prod.cfg b/ipa-server/ipa-gui/sample-prod.cfg new file mode 100644 index 000000000..ffa684cc1 --- /dev/null +++ b/ipa-server/ipa-gui/sample-prod.cfg @@ -0,0 +1,84 @@ +[global] +# This is where all of your settings go for your production environment. +# You'll copy this file over to your production server and provide it +# as a command-line option to your start script. +# Settings that are the same for both development and production +# (such as template engine, encodings, etc.) all go in +# ipagui/config/app.cfg + +# DATABASE + +# pick the form for your database +# sqlobject.dburi="postgres://username@hostname/databasename" +# sqlobject.dburi="mysql://username:password@hostname:port/databasename" +# sqlobject.dburi="sqlite:///file_name_and_path" + +# If you have sqlite, here's a simple default to get you started +# in development +sqlobject.dburi="sqlite://%(current_dir_uri)s/devdata.sqlite" + + +# if you are using a database or table type without transactions +# (MySQL default, for example), you should turn off transactions +# by prepending notrans_ on the uri +# sqlobject.dburi="notrans_mysql://username:password@hostname:port/databasename" + +# for Windows users, sqlite URIs look like: +# sqlobject.dburi="sqlite:///drive_letter:/path/to/file" + + +# SERVER + +server.environment="production" + +# Sets the number of threads the server uses +# server.thread_pool = 1 + +# if this is part of a larger site, you can set the path +# to the TurboGears instance here +# server.webpath="" + +# Set to True if you are deploying your App behind a proxy +# e.g. Apache using mod_proxy +# base_url_filter.on = False + +# Set to True if your proxy adds the x_forwarded_host header +# base_url_filter.use_x_forwarded_host = True + +# If your proxy does not add the x_forwarded_host header, set +# the following to the *public* host url. +# (Note: This will be overridden by the use_x_forwarded_host option +# if it is set to True and the proxy adds the header correctly. +# base_url_filter.base_url = "http://www.example.com" + +# Set to True if you'd like to abort execution if a controller gets an +# unexpected parameter. False by default +# tg.strict_parameters = False + +# LOGGING +# Logging configuration generally follows the style of the standard +# Python logging module configuration. Note that when specifying +# log format messages, you need to use *() for formatting variables. +# Deployment independent log configuration is in ipagui/config/log.cfg +[logging] + +[[handlers]] + +[[[access_out]]] +# set the filename as the first argument below +args="('server.log',)" +class='FileHandler' +level='INFO' +formatter='message_only' + +[[loggers]] +[[[ipagui]]] +level='ERROR' +qualname='ipagui' +handlers=['error_out'] + +[[[access]]] +level='INFO' +qualname='turbogears.access' +handlers=['access_out'] +propagate=0 diff --git a/ipa-server/ipa-gui/setup.py b/ipa-server/ipa-gui/setup.py new file mode 100644 index 000000000..371325f6a --- /dev/null +++ b/ipa-server/ipa-gui/setup.py @@ -0,0 +1,62 @@ +from setuptools import setup, find_packages +from turbogears.finddata import find_package_data + +import os +execfile(os.path.join("ipagui", "release.py")) + +setup( + name="ipa-gui", + version=version, + + # uncomment the following lines if you fill them out in release.py + #description=description, + #author=author, + #author_email=email, + #url=url, + #download_url=download_url, + #license=license, + + install_requires = [ + "TurboGears >= 1.0.2.2", + ], + scripts = ["start-ipagui.py"], + zip_safe=False, + packages=find_packages(), + package_data = find_package_data(where='ipagui', + package='ipagui'), + keywords = [ + # Use keywords if you'll be adding your package to the + # Python Cheeseshop + + # if this has widgets, uncomment the next line + # 'turbogears.widgets', + + # if this has a tg-admin command, uncomment the next line + # 'turbogears.command', + + # if this has identity providers, uncomment the next line + # 'turbogears.identity.provider', + + # If this is a template plugin, uncomment the next line + # 'python.templating.engines', + + # If this is a full application, uncomment the next line + # 'turbogears.app', + ], + classifiers = [ + 'Development Status :: 3 - Alpha', + 'Operating System :: OS Independent', + 'Programming Language :: Python', + 'Topic :: Software Development :: Libraries :: Python Modules', + 'Framework :: TurboGears', + # if this is an application that you'll distribute through + # the Cheeseshop, uncomment the next line + # 'Framework :: TurboGears :: Applications', + + # if this is a package that includes widgets that you'll distribute + # through the Cheeseshop, uncomment the next line + # 'Framework :: TurboGears :: Widgets', + ], + test_suite = 'nose.collector', + ) + diff --git a/ipa-server/ipa-gui/start-ipagui.py b/ipa-server/ipa-gui/start-ipagui.py new file mode 100644 index 000000000..2165e110b --- /dev/null +++ b/ipa-server/ipa-gui/start-ipagui.py @@ -0,0 +1,25 @@ +#!/usr/bin/python +import pkg_resources +pkg_resources.require("TurboGears") + +from turbogears import update_config, start_server +import cherrypy +cherrypy.lowercase_api = True +from os.path import * +import sys + +# first look on the command line for a desired config file, +# if it's not on the command line, then +# look for setup.py in this directory. If it's not there, this script is +# probably installed +if len(sys.argv) > 1: + update_config(configfile=sys.argv[1], + modulename="ipagui.config") +elif exists(join(dirname(__file__), "setup.py")): + update_config(configfile="dev.cfg",modulename="ipagui.config") +else: + update_config(configfile="prod.cfg",modulename="ipagui.config") + +from ipagui.controllers import Root + +start_server(Root()) diff --git a/ipa-server/ipa-gui/test.cfg b/ipa-server/ipa-gui/test.cfg new file mode 100644 index 000000000..df909c99d --- /dev/null +++ b/ipa-server/ipa-gui/test.cfg @@ -0,0 +1,4 @@ +# You can place test-specific configuration options here (like test db uri, etc) + +sqlobject.dburi = "sqlite:///:memory:" + From 0d981af82098f14e5b9e1677be80f6553f90417d Mon Sep 17 00:00:00 2001 From: Karl MacMillan Date: Fri, 10 Aug 2007 07:31:29 -0400 Subject: [PATCH 4/4] Various build system fixes. --- Makefile | 2 +- ipa-admintools/freeipa-admintools.spec | 2 +- ipa-admintools/freeipa-admintools.spec.in | 2 +- ipa-server/freeipa-server.spec | 2 +- ipa-server/freeipa-server.spec.in | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/Makefile b/Makefile index 7068ec1d0..8a7f79092 100644 --- a/Makefile +++ b/Makefile @@ -97,7 +97,7 @@ tarballs: rpm-ipa-server: cp dist/$(SERV_TARBALL) ~/rpmbuild/SOURCES/. rpmbuild -ba ipa-server/freeipa-server.spec - cp ~/rpmbuild/RPMS/noarch/$(PRJ_PREFIX)-server-$(SERV_VERSION)-*.rpm dist/. + cp ~/rpmbuild/RPMS/*/$(PRJ_PREFIX)-server-$(SERV_VERSION)-*.rpm dist/. cp ~/rpmbuild/SRPMS/$(PRJ_PREFIX)-server-$(SERV_VERSION)-*.src.rpm dist/. rpm-ipa-admin: diff --git a/ipa-admintools/freeipa-admintools.spec b/ipa-admintools/freeipa-admintools.spec index 904a3b693..b7a9a5044 100755 --- a/ipa-admintools/freeipa-admintools.spec +++ b/ipa-admintools/freeipa-admintools.spec @@ -1,5 +1,5 @@ Name: freeipa-admintools -Version: 0.1.0 +Version: 0.2.0 Release: 3%{?dist} Summary: FreeIPA authentication server diff --git a/ipa-admintools/freeipa-admintools.spec.in b/ipa-admintools/freeipa-admintools.spec.in index 904a3b693..71d68bc6e 100755 --- a/ipa-admintools/freeipa-admintools.spec.in +++ b/ipa-admintools/freeipa-admintools.spec.in @@ -1,5 +1,5 @@ Name: freeipa-admintools -Version: 0.1.0 +Version: VERSION Release: 3%{?dist} Summary: FreeIPA authentication server diff --git a/ipa-server/freeipa-server.spec b/ipa-server/freeipa-server.spec index cfd11d5ab..2da36a96a 100755 --- a/ipa-server/freeipa-server.spec +++ b/ipa-server/freeipa-server.spec @@ -11,7 +11,7 @@ BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) BuildRequires: fedora-ds-base-devel openldap-devel krb5-devel nss-devel mozldap-devel openssl-devel mhash-devel -Requires: python fedora-ds-base krb5-server krb5-server-ldap nss-tools openldap-clients httpd mod_python mod_auth_kerb python-ldap freeipa-python ntpd cyrus-sasl-gssapi nss +Requires: python fedora-ds-base krb5-server krb5-server-ldap nss-tools openldap-clients httpd mod_python mod_auth_kerb python-ldap freeipa-python ntpd cyrus-sasl-gssapi nss TurboGears %define httpd_conf /etc/httpd/conf.d %define plugin_dir /usr/lib/fedora-ds/plugins diff --git a/ipa-server/freeipa-server.spec.in b/ipa-server/freeipa-server.spec.in index 025c986b5..aa75917da 100644 --- a/ipa-server/freeipa-server.spec.in +++ b/ipa-server/freeipa-server.spec.in @@ -11,7 +11,7 @@ BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) BuildRequires: fedora-ds-base-devel openldap-devel krb5-devel nss-devel mozldap-devel openssl-devel mhash-devel -Requires: python fedora-ds-base krb5-server krb5-server-ldap nss-tools openldap-clients httpd mod_python mod_auth_kerb python-ldap freeipa-python ntpd cyrus-sasl-gssapi nss +Requires: python fedora-ds-base krb5-server krb5-server-ldap nss-tools openldap-clients httpd mod_python mod_auth_kerb python-ldap freeipa-python ntpd cyrus-sasl-gssapi nss TurboGears %define httpd_conf /etc/httpd/conf.d %define plugin_dir /usr/lib/fedora-ds/plugins