from datetime import date
from django.conf import settings
from conifer.libsystems.evergreen.support import initialize, E1
-from conifer.libsystems.z3950 import marcxml as M
+from conifer.libsystems import marcxml as M
from conifer.libsystems.evergreen import item_status as I
from conifer.libsystems.z3950 import pyz3950_search as PZ
from xml.etree import ElementTree as ET
--- /dev/null
+from xml.etree import ElementTree
+
+# Note: the 'record' parameters passed to these functions must be
+# Unicode strings, not plain Python strings; or ElementTree instances.
+
+def _to_tree(unicode_or_etree):
+ if isinstance(unicode_or_etree, unicode):
+ tree = ElementTree.fromstring(unicode_or_etree.encode('utf-8'))
+ elif isinstance(unicode_or_etree, ElementTree._ElementInterface):
+ tree = unicode_or_etree
+ else:
+ raise Exception('Bad parameter', unicode_or_etree)
+ return tree
+
+def marcxml_to_records(rec):
+ tree = _to_tree(rec)
+ if tree.tag == '{http://www.loc.gov/MARC21/slim}collection':
+ # then we may have multiple records
+ records = tree.findall('{http://www.loc.gov/MARC21/slim}record')
+ elif tree.tag == '{http://www.loc.gov/MARC21/slim}record':
+ records = [tree]
+ else:
+ return []
+ return records
+
+def record_to_dictionary(rec, multiples=True):
+ tree = _to_tree(rec)
+ dct = {}
+ for df in tree.findall('{http://www.loc.gov/MARC21/slim}datafield'):
+ t = df.attrib['tag']
+ for sf in df.findall('{http://www.loc.gov/MARC21/slim}subfield'):
+ c = sf.attrib['code']
+ v = sf.text or ''
+ dct.setdefault(t+c, []).append(v)
+ dct = dict((k,'\n'.join(v or [])) for k,v in dct.items())
+ return dct
+
+def marcxml_to_dictionary(rec, multiples=False):
+ tree = _to_tree(rec)
+ if tree.tag == '{http://www.loc.gov/MARC21/slim}collection':
+ # then we may have multiple records
+ records = tree.findall('{http://www.loc.gov/MARC21/slim}record')
+ elif tree.tag == '{http://www.loc.gov/MARC21/slim}record':
+ records = [tree]
+ else:
+ return []
+ out = []
+ for r in records:
+ dct = {}
+ for df in r.findall('{http://www.loc.gov/MARC21/slim}datafield'):
+ t = df.attrib['tag']
+ for sf in df.findall('{http://www.loc.gov/MARC21/slim}subfield'):
+ c = sf.attrib['code']
+ v = sf.text or ''
+ dct.setdefault(t+c, []).append(v)
+ dct = dict((k,'\n'.join(v or [])) for k,v in dct.items())
+ out.append(dct)
+ if multiples is False:
+ return out and out[0] or None
+ else:
+ return out
+
+def marcxml_dictionary_to_dc(dct):
+ """Take a dictionary generated by marcxml_to_dictionary, and
+ extract some Dublin Core elements from it. Fixme, I'm sure this
+ could be way improved."""
+ out = {}
+ meta = [('245a', 'dc:title'),
+ ('260c', 'dc:date'),
+ ('700a', 'dc:contributor')]
+ for marc, dc in meta:
+ value = dct.get(marc)
+ if value:
+ out[dc] = value
+
+ pub = [v.strip() for k,v in sorted(dct.items()) if k.startswith('260')]
+ if pub:
+ out['dc:publisher'] = strip_punct(' '.join(pub))
+
+ title = [v.strip() for k,v in sorted(dct.items()) if k in ('245a', '245b')]
+ if title:
+ out['dc:title'] = strip_punct(' '.join(title))
+
+ for k in ('100a', '110a', '700a', '710a'):
+ if dct.get(k):
+ out['dc:creator'] = strip_punct(dct[k])
+ break
+
+ return out
+
+
+def strip_punct(s):
+ # strip whitespace and trailing single punctuation characters
+ s = s.strip()
+ if s and (s[-1] in ',.;:/'):
+ s = s[:-1]
+ return s.strip()
+++ /dev/null
-from xml.etree import ElementTree
-
-# Note: the 'record' parameters passed to these functions must be
-# Unicode strings, not plain Python strings; or ElementTree instances.
-
-def _to_tree(unicode_or_etree):
- if isinstance(unicode_or_etree, unicode):
- tree = ElementTree.fromstring(unicode_or_etree.encode('utf-8'))
- elif isinstance(unicode_or_etree, ElementTree._ElementInterface):
- tree = unicode_or_etree
- else:
- raise Exception('Bad parameter', unicode_or_etree)
- return tree
-
-def marcxml_to_records(rec):
- tree = _to_tree(rec)
- if tree.tag == '{http://www.loc.gov/MARC21/slim}collection':
- # then we may have multiple records
- records = tree.findall('{http://www.loc.gov/MARC21/slim}record')
- elif tree.tag == '{http://www.loc.gov/MARC21/slim}record':
- records = [tree]
- else:
- return []
- return records
-
-def record_to_dictionary(rec, multiples=True):
- tree = _to_tree(rec)
- dct = {}
- for df in tree.findall('{http://www.loc.gov/MARC21/slim}datafield'):
- t = df.attrib['tag']
- for sf in df.findall('{http://www.loc.gov/MARC21/slim}subfield'):
- c = sf.attrib['code']
- v = sf.text or ''
- dct.setdefault(t+c, []).append(v)
- dct = dict((k,'\n'.join(v or [])) for k,v in dct.items())
- return dct
-
-def marcxml_to_dictionary(rec, multiples=False):
- tree = _to_tree(rec)
- if tree.tag == '{http://www.loc.gov/MARC21/slim}collection':
- # then we may have multiple records
- records = tree.findall('{http://www.loc.gov/MARC21/slim}record')
- elif tree.tag == '{http://www.loc.gov/MARC21/slim}record':
- records = [tree]
- else:
- return []
- out = []
- for r in records:
- dct = {}
- for df in r.findall('{http://www.loc.gov/MARC21/slim}datafield'):
- t = df.attrib['tag']
- for sf in df.findall('{http://www.loc.gov/MARC21/slim}subfield'):
- c = sf.attrib['code']
- v = sf.text or ''
- dct.setdefault(t+c, []).append(v)
- dct = dict((k,'\n'.join(v or [])) for k,v in dct.items())
- out.append(dct)
- if multiples is False:
- return out and out[0] or None
- else:
- return out
-
-def marcxml_dictionary_to_dc(dct):
- """Take a dictionary generated by marcxml_to_dictionary, and
- extract some Dublin Core elements from it. Fixme, I'm sure this
- could be way improved."""
- out = {}
- meta = [('245a', 'dc:title'),
- ('260c', 'dc:date'),
- ('700a', 'dc:contributor')]
- for marc, dc in meta:
- value = dct.get(marc)
- if value:
- out[dc] = value
-
- pub = [v.strip() for k,v in sorted(dct.items()) if k.startswith('260')]
- if pub:
- out['dc:publisher'] = strip_punct(' '.join(pub))
-
- title = [v.strip() for k,v in sorted(dct.items()) if k in ('245a', '245b')]
- if title:
- out['dc:title'] = strip_punct(' '.join(title))
-
- for k in ('100a', '110a', '700a', '710a'):
- if dct.get(k):
- out['dc:creator'] = strip_punct(dct[k])
- break
-
- return out
-
-
-def strip_punct(s):
- # strip whitespace and trailing single punctuation characters
- s = s.strip()
- if s and (s[-1] in ',.;:/'):
- s = s[:-1]
- return s.strip()
import warnings
import re
import sys
-from marcxml import marcxml_to_dictionary
+from ..marcxml import marcxml_to_dictionary
from xml.etree import ElementTree as ET
try:
import re
import pexpect
import sys
-from marcxml import marcxml_to_dictionary
+from ..marcxml import marcxml_to_dictionary
LOG = None # for pexpect debugging, try LOG = sys.stderr
YAZ_CLIENT = 'yaz-client'
import os
from here import HERE
+DEBUG = False
+
#----------------------------------------------------------------------
# You may need to set the PYTHON_EGG_CACHE directory, depending on how
# you installed Syrup.
DATABASE_PORT = '' # Set to empty string for default. Not used with sqlite3.
#----------------------------------------------------------------------
-DEBUG = False
ADMINS = (
# ('Your Name', 'your_email@domain.com'),
#----------------------------------------------------------------------
-EVERGREEN_AUTHENTICATION = False
-
-#----------------------------------------------------------------------
-#Campus integration
-
-CAMPUS_INTEGRATION_MODULE = 'conifer.integration.default'
+EVERGREEN_AUTHENTICATION = False # Evergreen ILS authentication
+LINKTOOL_AUTHENTICATION = False # Sakai LMS Linktool authentication
#----------------------------------------------------------------------
# Stuff that probably belongs in a config table in the database, with
EVERGREEN_GATEWAY_SERVER = 'www.concat.ca'
Z3950_CONFIG = ('zed.concat.ca', 210, 'OWA') #OWA,OSUL,CONIFER
-SIP_HOST = ('localhost', 8080)
-SIP_CREDENTIALS = ('sipclient', 'c0n1fi3', 'graham home workstation')
+
+#----------------------------------------------------------------------
+# INTEGRATION_MODULE: name of a module to import after the database
+# models have been initialized. This can be used for defining 'hook'
+# functions, and other late initializations.
+# See the 'conifer.syrup.integration' module for more information.
+
+INTEGRATION_MODULE = 'name.of.our.integration.module'
'django.contrib.auth.backends.ModelBackend'
]
-CAMPUS_INTEGRATION_MODULE = 'conifer.integration.default'
-
#---------------------------------------------------------------------------
# local_settings.py
#----------
-try:
- exec 'import %s as CAMPUS_INTEGRATION' % CAMPUS_INTEGRATION_MODULE
-except:
- raise Exception('There is an error in your campus integration module (%s)! '
- 'Please investigate and repair.' % CAMPUS_INTEGRATION_MODULE,
- sys.exc_value)
-
-#----------
-
-import re
import random
+import re
-from django.db import models as m
-from django.db.models import Q
-from django.contrib.auth.models import User
-from django.contrib.auth.models import AnonymousUser
-from datetime import datetime
-from genshi import Markup
-from django.utils.translation import ugettext as _
-from django.utils import simplejson
+from conifer.libsystems import marcxml as MX
from conifer.plumbing.genshi_support import get_request
-
-# campus and library integration
from conifer.plumbing.hooksystem import *
+from datetime import datetime
from django.conf import settings
-campus = settings.CAMPUS_INTEGRATION
-import conifer.libsystems.z3950.marcxml as MX
+from django.contrib.auth.models import AnonymousUser, User
+from django.db import models as m
+from django.db.models import Q
from django.utils import simplejson as json
+from django.utils.translation import ugettext as _
+from genshi import Markup
#----------------------------------------------------------------------
(r'^$', 'welcome'),
(r'^site/$', 'my_sites'),
(r'^site/new/$', 'add_new_site'),
- (r'^site/new/ajax_title$', 'add_new_site_ajax_title'),
(r'^site/invitation/$', 'site_invitation'),
(r'^browse/$', 'browse'),
(r'^browse/(?P<browse_option>.*)/$', 'browse'),
import warnings
import pdb
+from conifer.integration.hooksystem import gethook, callhook, callhook_required
from conifer.syrup import models
from datetime import datetime
from django.contrib.auth import authenticate, login, logout
from django.utils.translation import ugettext as _
from _generics import * # TODO: should not import-star
-from conifer.libsystems.z3950.marcxml import (marcxml_to_dictionary,
- marcxml_dictionary_to_dc)
+from conifer.libsystems.marcxml import (marcxml_to_dictionary,
+ marcxml_dictionary_to_dc)
#-----------------------------------------------------------------------------
from _common import *
from django.utils.translation import ugettext as _
-from conifer.plumbing.hooksystem import *
from datetime import date
#-----------------------------------------------------------------------------
-# genshi_namespace
+# genshi_namespace: toplevel definitions in this module will be
+# available when rendering a Genshi template. In addition, the Genshi
+# template will have access to:
-# Toplevel definitions in this module will be available in when
-# rendering a Genshi template.
+# request: the current request object
+# user: the current user
+# ROOT: the SCRIPT_NAME of the root directory of this application.
+# errors: either None, or a list of errors related to the current page.
-from conifer.integration._hooksystem import gethook, callhook
-import itertools
-from itertools import cycle
-from conifer.syrup import models
import django.forms
-from django.utils import translation
-
-_ = translation.ugettext
-
-# this probably ought to be a method on User, or another model class.
-def instructor_url(instructor, suffix=''):
- return '/instructor/%d/%s' % (instructor.id, suffix)
-
-# added to make department browse
-def department_url(department, suffix=''):
- return '/department/%d/%s' % (department.id, suffix)
-
-
-def call_or_value(obj, dflt=None):
- # This is used by the generics templates.
- if callable(obj):
- return obj() or dflt
- else:
- return obj or dflt
+import itertools
+from conifer.integration.hooksystem import gethook, callhook
+from conifer.syrup import models
+from django.utils import translation
-def instructs(user, site):
- try:
- mbr = models.Member.objects.get(user=user, site=site)
- return mbr.role in ('INSTR', 'PROXY')
- except:
- return False
-
+_ = translation.ugettext
-from _common import *
+from _common import *
+from conifer.syrup import integration
from django.utils.translation import ugettext as _
-from xml.etree import ElementTree as ET
-from conifer.syrup import integration
-from conifer.plumbing.hooksystem import *
-
+from xml.etree import ElementTree as ET
@members_only
def item_detail(request, site_id, item_id):
site_filter = Q(site=for_site) if for_site else Q()
_items = models.Item.objects.select_related()
- print (term_filter & user_filter &
- site_filter & owner_filter)
items = _items.filter(term_filter & user_filter &
site_filter & owner_filter)
this instructor.
'''
- print("in_site is %s" % in_site)
- print("for_owner is %s" % for_owner)
-
query_string = request.GET.get('q', '').strip()
if not query_string: # empty query?
def clean_code(self):
v = (self.cleaned_data.get('code') or '').strip()
- is_valid_func = models.campus.course_code_is_valid
+ is_valid_func = gethook('course_code_is_valid')
if (not is_valid_func) or is_valid_func(v):
return v
else:
super(NewSiteForm, self).__init__(*args, **kwargs)
-# if we have course-code lookup, hack lookup support into the new-course form.
-
-COURSE_CODE_LIST = bool(models.campus.course_code_list)
-COURSE_CODE_LOOKUP_TITLE = bool(models.campus.course_code_lookup_title)
-
-# if COURSE_CODE_LIST:
-# from django.forms import Select
-# course_list = models.campus.course_code_list()
-# choices = [(a,a) for a in course_list]
-# choices.sort()
-# empty_label = u'---------'
-# choices.insert(0, ('', empty_label))
-# NewSiteForm.base_fields['code'].widget = Select(
-# choices = choices)
-# NewSiteForm.base_fields['code'].empty_label = empty_label
-
#--------------------
@login_required
if is_add:
instance = models.Site()
current_access_level = not is_add and instance.access or None
- example = models.campus.course_code_example
if request.method != 'POST':
form = NewSiteForm(instance=instance)
return g.render('edit_site.xhtml', **locals())
else:
return HttpResponseRedirect('../') # back to main view.
-# no access-control needed to protect title lookup.
-def add_new_site_ajax_title(request):
- course_code = request.GET['course_code']
- title = models.campus.course_code_lookup_title(course_code)
- return HttpResponse(simplejson.dumps({'title':title}))
-
@instructors_only
def edit_site_permissions(request, site_id):
site = get_object_or_404(models.Site, pk=site_id)
(u'STUDT', _(u'Students in my course -- I will provide section numbers')),
(u'INVIT', _(u'Students in my course -- I will share an Invitation Code with them')),
(u'LOGIN', _(u'All Reserves patrons'))]
+ # TODO: fixme, campus module no longer exists.
if models.campus.sections_tuple_delimiter is None:
# no course-sections support? Then STUDT cannot be an option.
del choices[1]
<?python
-title = _('Please log in')
+title = _('Please log in.')
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
</script>
</head>
<body>
- <h1>Please log in.</h1>
+ <h1>${title}</h1>
+ <p>You must log in to access this resource.</p>
<form action="." method="post">
<input type="hidden" name="next" value="${next}"/>
<div class="errors" py:if="defined('err')">${err}</div>
<?python
index = form.Index
title = index.title
+def call_or_value(obj, dflt=None):
+ if callable(obj):
+ return obj() or dflt
+ else:
+ return obj or dflt
?>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:xi="http://www.w3.org/2001/XInclude"
<?python
from django.utils.simplejson import dumps
from xml.etree import ElementTree as ET
-from conifer.libsystems.z3950.marcxml import record_to_dictionary
-from conifer.libsystems.z3950.marcxml import marcxml_dictionary_to_dc as to_dublin
+from conifer.libsystems.marcxml import record_to_dictionary
+from conifer.libsystems.marcxml import marcxml_dictionary_to_dc as to_dublin
title = _('Add physical or electronic item, by catalogue search')
helptext = _('Use keywords or CCL syntax for searching, for example: ti="detroit river" and au="wilgus"')
dc_keys = ['dc:title', 'dc:creator', 'dc:publisher', 'dc:date']
py:strip="">
<div py:def="pagetable(paginator, count, pagerow, pagehead=None, query=None, target=None)"
py:with="page = paginator.page(page_num)">
- <table class="pagetable" py:with="cls = cycle(('odd', 'even'))">
+ <table class="pagetable" py:with="cls = itertools.cycle(('odd', 'even'))">
<thead py:if="pagehead">
${pagehead()}
</thead>
<?python
title = _('Wanted items: %s') % term
-from conifer.libsystems.z3950.marcxml import marcxml_dictionary_to_dc as to_dublin
+from conifer.libsystems.marcxml import marcxml_dictionary_to_dc as to_dublin
dc_keys = ['dc:title', 'dc:creator', 'dc:publisher', 'dc:date']
from django.conf import settings
lang = settings.LANGUAGE_CODE.replace('_','-')