X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=admin%2Fsystempreferences.pl;h=f4069ae3bb3f067bbe825fa0bed44f88b92393e6;hb=e012957186426b9577bfc8498c5971990b258024;hp=1804a535a808be6293dfc92c0359cfb42a10ac74;hpb=5bb6d117c54034d86c5006e54b5125b0e6fb086e;p=koha.git diff --git a/admin/systempreferences.pl b/admin/systempreferences.pl index 1804a535a8..f4069ae3bb 100755 --- a/admin/systempreferences.pl +++ b/admin/systempreferences.pl @@ -17,13 +17,13 @@ # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR # A PARTICULAR PURPOSE. See the GNU General Public License for more details. # -# You should have received a copy of the GNU General Public License along with -# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place, -# Suite 330, Boston, MA 02111-1307 USA +# You should have received a copy of the GNU General Public License along +# with Koha; if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. =head1 systempreferences.pl -ALGO : +ALSO : this script use an $op to know what to do. if $op is empty or none of the above values, - the default screen is build (with all records, or filtered datas). @@ -41,360 +41,632 @@ ALGO : =cut use strict; +use warnings; + use CGI; +use MIME::Base64; use C4::Auth; use C4::Context; use C4::Koha; use C4::Languages qw(getTranslatedLanguages); use C4::ClassSource; +use C4::Log; use C4::Output; -use C4::Context; +use YAML::Syck qw( Dump LoadFile ); + # use Smart::Comments; +# FIXME, shouldnt we store this stuff in the systempreferences table? -# FIXME, shouldnt we store this stuff in the systempreferences table? +# FIXME: This uses hash in a backwards way. What we really want is: +# $tabsysprefs{key} = $array_ref; +# like +# $tabsysprefs{Cataloguing} = [qw(autoBarcode ISBD marc ...)]; +# +# Because some things *should* be on more than one tab. +# And the tabname is the unique part (the key). my %tabsysprefs; + # Acquisitions - $tabsysprefs{acquisitions}="Acquisitions"; $tabsysprefs{gist}="Acquisitions"; $tabsysprefs{emailPurchaseSuggestions}="Acquisitions"; + $tabsysprefs{RenewSerialAddsSuggestion}="Acquisitions"; + $tabsysprefs{AcqCreateItem}="Acquisitions"; + $tabsysprefs{OrderPdfFormat}="Acquisitions"; + $tabsysprefs{CurrencyFormat}="Acquisitions"; + $tabsysprefs{AcqViewBaskets}="Acquisitions"; # Admin - $tabsysprefs{singleBranchMode}="Admin"; - $tabsysprefs{staffClientBaseURL}="Admin"; - $tabsysprefs{Version}="Admin"; - $tabsysprefs{OpacMaintenance}="Admin"; - $tabsysprefs{FrameworksLoaded}="Admin"; - $tabsysprefs{libraryAddress}="Admin"; - $tabsysprefs{delimiter}="Admin"; - $tabsysprefs{IndependantBranches}="Admin"; - $tabsysprefs{insecure}="Admin"; - $tabsysprefs{KohaAdmin}="Admin"; - $tabsysprefs{KohaAdminEmailAddress}="Admin"; - $tabsysprefs{MIME}="Admin"; - $tabsysprefs{timeout}="Admin"; - $tabsysprefs{Intranet_includes}="Admin"; - $tabsysprefs{AutoLocation}="Admin"; - $tabsysprefs{DebugLevel}="Admin"; - $tabsysprefs{SessionStorage}="Admin"; - $tabsysprefs{noItemTypeImages}="Admin"; - $tabsysprefs{OPACBaseURL}="Admin"; +$tabsysprefs{singleBranchMode} = "Admin"; +$tabsysprefs{staffClientBaseURL} = "Admin"; +$tabsysprefs{Version} = "Admin"; +$tabsysprefs{OpacMaintenance} = "Admin"; +$tabsysprefs{FrameworksLoaded} = "Admin"; +$tabsysprefs{delimiter} = "Admin"; +$tabsysprefs{IndependantBranches} = "Admin"; +$tabsysprefs{insecure} = "Admin"; +$tabsysprefs{KohaAdmin} = "Admin"; +$tabsysprefs{KohaAdminEmailAddress} = "Admin"; +$tabsysprefs{timeout} = "Admin"; +$tabsysprefs{Intranet_includes} = "Admin"; +$tabsysprefs{AutoLocation} = "Admin"; +$tabsysprefs{DebugLevel} = "Admin"; +$tabsysprefs{SessionStorage} = "Admin"; + +# This script is depricated so all of these prefs are lumped here to avoid their being displayed in the local use prefs tab + +$tabsysprefs{noItemTypeImages} = "Admin"; +$tabsysprefs{OPACBaseURL} = "Admin"; +$tabsysprefs{AnonymousPatron} = "Admin"; +$tabsysprefs{casAuthentication} = "Admin"; +$tabsysprefs{casLogout} = "Admin"; +$tabsysprefs{casServerUrl} = "Admin"; +$tabsysprefs{Disable_Dictionary} = "Admin"; +$tabsysprefs{EnableOpacSearchHistory} = "Admin"; +$tabsysprefs{Intranetbookbag} = "Admin"; +$tabsysprefs{maxitemsinSearchResults} = "Admin"; +$tabsysprefs{noOPACUserLogin} = "Admin"; +$tabsysprefs{'OAI-PMH:ConfFile'} = "Admin"; +$tabsysprefs{OpacAddMastheadLibraryPulldown} = "Admin"; +$tabsysprefs{opaclargeimage} = "Admin"; +$tabsysprefs{OPACXSLTDetailsDisplay} = "Admin"; +$tabsysprefs{OPACXSLTResultsDisplay} = "Admin"; +$tabsysprefs{PDFFontType} = "Admin"; +$tabsysprefs{PrintNoticesMaxLines} = "Admin"; +$tabsysprefs{ReservesControlBranch} = "Admin"; +$tabsysprefs{ResultsDisplay} = "Admin"; +$tabsysprefs{NoReturnSetLost} = "Admin"; +$tabsysprefs{SearchURL} = "Admin"; +$tabsysprefs{ShowPictures} = "Admin"; +$tabsysprefs{soundon} = "Admin"; +$tabsysprefs{SpineLabelShowPrintOnBibDetails} = "Admin"; +$tabsysprefs{WebBasedSelfCheckHeader} = "Admin"; +$tabsysprefs{WebBasedSelfCheckTimeout} = "Admin"; # Authorities - $tabsysprefs{authoritysep}="Authorities"; - $tabsysprefs{AuthDisplayHierarchy}="Authorities"; - $tabsysprefs{dontmerge}="Authorities"; - $tabsysprefs{BiblioAddsAuthorities}="Authorities"; +$tabsysprefs{authoritysep} = "Authorities"; +$tabsysprefs{AuthDisplayHierarchy} = "Authorities"; +$tabsysprefs{dontmerge} = "Authorities"; +$tabsysprefs{BiblioAddsAuthorities} = "Authorities"; + # Cataloguing - $tabsysprefs{advancedMARCEditor}="Cataloguing"; - $tabsysprefs{autoBarcode}="Cataloguing"; - $tabsysprefs{hide_marc}="Cataloguing"; - $tabsysprefs{IntranetBiblioDefaultView} = "Cataloguing"; - $tabsysprefs{ISBD}="Cataloguing"; - $tabsysprefs{itemcallnumber}="Cataloguing"; - $tabsysprefs{LabelMARCView}="Cataloguing"; - $tabsysprefs{marc}="Cataloguing"; - $tabsysprefs{marcflavour}="Cataloguing"; - $tabsysprefs{serialsadditems}="Cataloguing"; - $tabsysprefs{MARCOrgCode}="Cataloguing"; - $tabsysprefs{z3950AuthorAuthFields}="Cataloguing"; - $tabsysprefs{z3950NormalizeAuthor}="Cataloguing"; - $tabsysprefs{Stemming}="Cataloguing"; - $tabsysprefs{WeightFields}="Cataloguing"; - $tabsysprefs{NoZebra}="Cataloguing"; - $tabsysprefs{NoZebraIndexes}="Cataloguing"; - $tabsysprefs{ReceiveBackIssues}="Cataloguing"; - $tabsysprefs{DefaultClassificationSource}="Cataloguing"; - $tabsysprefs{RoutingSerials}="Cataloguing"; - $tabsysprefs{'item-level_itypes'}="Cataloguing"; +$tabsysprefs{advancedMARCeditor} = "Cataloging"; +$tabsysprefs{autoBarcode} = "Cataloging"; +$tabsysprefs{hide_marc} = "Cataloging"; +$tabsysprefs{IntranetBiblioDefaultView} = "Cataloging"; +$tabsysprefs{ISBD} = "Cataloging"; +$tabsysprefs{itemcallnumber} = "Cataloging"; +$tabsysprefs{LabelMARCView} = "Cataloging"; +$tabsysprefs{marcflavour} = "Cataloging"; +$tabsysprefs{MARCOrgCode} = "Cataloging"; +$tabsysprefs{z3950AuthorAuthFields} = "Cataloging"; +$tabsysprefs{z3950NormalizeAuthor} = "Cataloging"; +$tabsysprefs{Stemming} = "Cataloging"; +$tabsysprefs{WeightFields} = "Cataloging"; +$tabsysprefs{NoZebra} = "Cataloging"; +$tabsysprefs{NoZebraIndexes} = "Cataloging"; +$tabsysprefs{ReceiveBackIssues} = "Cataloging"; +$tabsysprefs{DefaultClassificationSource} = "Cataloging"; +$tabsysprefs{RoutingSerials} = "Cataloging"; +$tabsysprefs{'item-level_itypes'} = "Cataloging"; +$tabsysprefs{OpacSuppression} = "Cataloging"; +$tabsysprefs{SpineLabelFormat} = "Cataloging"; +$tabsysprefs{SpineLabelAutoPrint} = "Cataloging"; # Circulation - $tabsysprefs{maxoutstanding}="Circulation"; - $tabsysprefs{maxreserves}="Circulation"; - $tabsysprefs{noissuescharge}="Circulation"; - $tabsysprefs{IssuingInProcess}="Circulation"; - $tabsysprefs{patronimages}="Circulation"; - $tabsysprefs{printcirculationslips}="Circulation"; - $tabsysprefs{ReturnBeforeExpiry}="Circulation"; - $tabsysprefs{SpecifyDueDate}="Circulation"; - $tabsysprefs{AutomaticItemReturn}="Circulation"; - $tabsysprefs{ReservesMaxPickUpDelay}="Circulation"; - $tabsysprefs{TransfersMaxDaysWarning}="Circulation"; - $tabsysprefs{useDaysMode}="Circulation"; - $tabsysprefs{ReservesNeedReturns}="Circulation"; - $tabsysprefs{CircAutocompl}="Circulation"; - $tabsysprefs{canreservefromotherbranches}="Circulation"; - $tabsysprefs{finesMode}="Circulation"; - $tabsysprefs{emailLibrarianWhenHoldIsPlaced}="Circulation"; - $tabsysprefs{globalDueDate}="Circulation"; - $tabsysprefs{holdCancelLength}="Circulation"; - $tabsysprefs{itemBarcodeInputFilter}="Circulation"; - $tabsysprefs{noOPACHolds}="Circulation"; - $tabsysprefs{WebBasedSelfCheck}="Circulation"; - $tabsysprefs{CircControl}="Circulation"; - $tabsysprefs{finesCalendar}="Circulation"; - $tabsysprefs{previousIssuesDefaultSortOrder}="Circulation"; - $tabsysprefs{todaysIssuesDefaultSortOrder}="Circulation"; - $tabsysprefs{HomeOrHoldingBranch}="Circulation"; +$tabsysprefs{maxoutstanding} = "Circulation"; +$tabsysprefs{maxreserves} = "Circulation"; +$tabsysprefs{noissuescharge} = "Circulation"; +$tabsysprefs{IssuingInProcess} = "Circulation"; +$tabsysprefs{patronimages} = "Circulation"; +$tabsysprefs{printcirculationslips} = "Circulation"; +$tabsysprefs{ReturnBeforeExpiry} = "Circulation"; +$tabsysprefs{SpecifyDueDate} = "Circulation"; +$tabsysprefs{AutomaticItemReturn} = "Circulation"; +$tabsysprefs{ReservesMaxPickUpDelay} = "Circulation"; +$tabsysprefs{TransfersMaxDaysWarning} = "Circulation"; +$tabsysprefs{useDaysMode} = "Circulation"; +$tabsysprefs{ReservesNeedReturns} = "Circulation"; +$tabsysprefs{CircAutocompl} = "Circulation"; +$tabsysprefs{AllowRenewalLimitOverride} = "Circulation"; +$tabsysprefs{canreservefromotherbranches} = "Circulation"; +$tabsysprefs{finesMode} = "Circulation"; +$tabsysprefs{numReturnedItemsToShow} = "Circulation"; +$tabsysprefs{emailLibrarianWhenHoldIsPlaced} = "Circulation"; +$tabsysprefs{itemBarcodeInputFilter} = "Circulation"; +$tabsysprefs{WebBasedSelfCheck} = "Circulation"; +$tabsysprefs{ShowPatronImageInWebBasedSelfCheck} = "Circulation"; +$tabsysprefs{CircControl} = "Circulation"; +$tabsysprefs{finesCalendar} = "Circulation"; +$tabsysprefs{previousIssuesDefaultSortOrder} = "Circulation"; +$tabsysprefs{todaysIssuesDefaultSortOrder} = "Circulation"; +$tabsysprefs{HomeOrHoldingBranch} = "Circulation"; +$tabsysprefs{HomeOrHoldingBranchReturn} = "Circulation"; +$tabsysprefs{RandomizeHoldsQueueWeight} = "Circulation"; +$tabsysprefs{StaticHoldsQueueWeight} = "Circulation"; +$tabsysprefs{AllowOnShelfHolds} = "Circulation"; +$tabsysprefs{AllowHoldsOnDamagedItems} = "Circulation"; +$tabsysprefs{UseBranchTransferLimits} = "Circulation"; +$tabsysprefs{AllowHoldPolicyOverride} = "Circulation"; +$tabsysprefs{BranchTransferLimitsType} = "Circulation"; +$tabsysprefs{AllowNotForLoanOverride} = "Circulation"; +$tabsysprefs{RenewalPeriodBase} = "Circulation"; +$tabsysprefs{FilterBeforeOverdueReport} = "Circulation"; +$tabsysprefs{AllowHoldDateInFuture} = "Circulation"; +$tabsysprefs{OPACFineNoRenewals} = "Circulation"; +$tabsysprefs{InProcessingToShelvingCart} = "Circulation"; +$tabsysprefs{NewItemsDefaultLocation} = "Circulation"; +$tabsysprefs{ReturnToShelvingCart} = "Circulation"; +$tabsysprefs{DisplayClearScreenButton} = "Circulation"; +$tabsysprefs{AllowAllMessageDeletion} = "Circulation"; +$tabsysprefs{OverdueNoticeBcc} = "Circulation"; +$tabsysprefs{OverduesBlockCirc} = "Circulation"; + # Staff Client - $tabsysprefs{TemplateEncoding}="StaffClient"; - $tabsysprefs{template}="StaffClient"; - $tabsysprefs{intranetstylesheet}="StaffClient"; - $tabsysprefs{IntranetNav}="StaffClient"; - $tabsysprefs{intranetcolorstylesheet}="StaffClient"; - $tabsysprefs{intranetuserjs}="StaffClient"; - $tabsysprefs{yuipath}="StaffClient"; - $tabsysprefs{IntranetmainUserblock}="StaffClient"; - +$tabsysprefs{template} = "StaffClient"; +$tabsysprefs{intranetstylesheet} = "StaffClient"; +$tabsysprefs{IntranetNav} = "StaffClient"; +$tabsysprefs{intranetcolorstylesheet} = "StaffClient"; +$tabsysprefs{intranetuserjs} = "StaffClient"; +$tabsysprefs{yuipath} = "StaffClient"; +$tabsysprefs{IntranetmainUserblock} = "StaffClient"; +$tabsysprefs{viewMARC} = "StaffClient"; +$tabsysprefs{viewLabeledMARC} = "StaffClient"; +$tabsysprefs{viewISBD} = "StaffClient"; + # Patrons - $tabsysprefs{automembernum}="Patrons"; - $tabsysprefs{checkdigit}="Patrons"; - $tabsysprefs{intranetreadinghistory}="Patrons"; - $tabsysprefs{NotifyBorrowerDeparture}="Patrons"; - $tabsysprefs{memberofinstitution}="Patrons"; - $tabsysprefs{ReadingHistory}="Patrons"; - $tabsysprefs{BorrowerMandatoryField}="Patrons"; - $tabsysprefs{borrowerRelationship}="Patrons"; - $tabsysprefs{BorrowersTitles}="Patrons"; - $tabsysprefs{patronimages}="Patrons"; - $tabsysprefs{MinPasswordLength}="Patrons"; - $tabsysprefs{uppercasesurnames}="Patrons"; - $tabsysprefs{NoReturnSetLost}="Patrons"; - $tabsysprefs{MaxFine}="Patrons"; - $tabsysprefs{NotifyBorrowerDeparture}="Patrons"; +$tabsysprefs{autoMemberNum} = "Patrons"; +$tabsysprefs{checkdigit} = "Patrons"; +$tabsysprefs{intranetreadinghistory} = "Patrons"; +$tabsysprefs{NotifyBorrowerDeparture} = "Patrons"; +$tabsysprefs{memberofinstitution} = "Patrons"; +$tabsysprefs{BorrowerMandatoryField} = "Patrons"; +$tabsysprefs{BorrowerUnwantedField} = "Patrons"; +$tabsysprefs{borrowerRelationship} = "Patrons"; +$tabsysprefs{BorrowersTitles} = "Patrons"; +$tabsysprefs{patronimages} = "Patrons"; +$tabsysprefs{minPasswordLength} = "Patrons"; +$tabsysprefs{uppercasesurnames} = "Patrons"; +$tabsysprefs{MaxFine} = "Patrons"; +$tabsysprefs{NotifyBorrowerDeparture} = "Patrons"; +$tabsysprefs{AddPatronLists} = "Patrons"; +$tabsysprefs{PatronsPerPage} = "Patrons"; +$tabsysprefs{ExtendedPatronAttributes} = "Patrons"; +$tabsysprefs{AutoEmailOpacUser} = "Patrons"; +$tabsysprefs{AutoEmailPrimaryAddress} = "Patrons"; +$tabsysprefs{EnhancedMessagingPreferences} = "Patrons"; +$tabsysprefs{'SMSSendDriver'} = 'Patrons'; +$tabsysprefs{HidePatronName} = "Patrons"; -# FRBR - $tabsysprefs{FRBRizeEditions}="FRBR"; - $tabsysprefs{XISBN}="FRBR"; - $tabsysprefs{OCLCAffiliateID}="FRBR"; - $tabsysprefs{XISBNDailyLimit}="FRBR"; - $tabsysprefs{PINESISBN}="FRBR"; - $tabsysprefs{ThingISBN}="FRBR"; - $tabsysprefs{OPACFRBRizeEditions}="FRBR"; - $tabsysprefs{XISBNAmazonSimilarItems}="FRBR"; # I18N/L10N - $tabsysprefs{dateformat}="I18N/L10N"; - $tabsysprefs{opaclanguages}="I18N/L10N"; - $tabsysprefs{opacthemes}="I18N/L10N"; - $tabsysprefs{language}="I18N/L10N"; +$tabsysprefs{dateformat} = "I18N/L10N"; +$tabsysprefs{opaclanguages} = "I18N/L10N"; +$tabsysprefs{opaclanguagesdisplay} = "I18N/L10N"; +$tabsysprefs{language} = "I18N/L10N"; # Searching - $tabsysprefs{defaultSortField}="Searching"; - $tabsysprefs{defaultSortOrder}="Searching"; - $tabsysprefs{maxItemsInSearchResults}="Searching"; - $tabsysprefs{numSearchResults}="Searching"; - $tabsysprefs{OPACdefaultSortField}="Searching"; - $tabsysprefs{OPACdefaultSortOrder}="Searching"; - $tabsysprefs{OPACItemsResultsDisplay}="Searching"; - $tabsysprefs{OPACnumSearchResults}="Searching"; - $tabsysprefs{QueryFuzzy}="Searching"; - $tabsysprefs{QueryStemming}="Searching"; - $tabsysprefs{QueryWeightFields}="Searching"; - $tabsysprefs{expandedSearchOption}="Searching"; - $tabsysprefs{sortbynonfiling}="Searching"; - $tabsysprefs{QueryAutoTruncate}="Searching"; - $tabsysprefs{QueryRemoveStopwords}="Searching"; +$tabsysprefs{defaultSortField} = "Searching"; +$tabsysprefs{defaultSortOrder} = "Searching"; +$tabsysprefs{numSearchResults} = "Searching"; +$tabsysprefs{OPACdefaultSortField} = "Searching"; +$tabsysprefs{OPACdefaultSortOrder} = "Searching"; +$tabsysprefs{OPACItemsResultsDisplay} = "Searching"; +$tabsysprefs{OPACnumSearchResults} = "Searching"; +$tabsysprefs{QueryFuzzy} = "Searching"; +$tabsysprefs{QueryStemming} = "Searching"; +$tabsysprefs{QueryWeightFields} = "Searching"; +$tabsysprefs{expandedSearchOption} = "Searching"; +$tabsysprefs{QueryAutoTruncate} = "Searching"; +$tabsysprefs{QueryRemoveStopwords} = "Searching"; +$tabsysprefs{AdvancedSearchTypes} = "Searching"; +$tabsysprefs{DisplayMultiPlaceHold} = "Searching"; + +# EnhancedContent +$tabsysprefs{AmazonEnabled} = "EnhancedContent"; +$tabsysprefs{OPACAmazonEnabled} = "EnhancedContent"; +$tabsysprefs{AmazonCoverImages} = "EnhancedContent"; +$tabsysprefs{OPACAmazonCoverImages} = "EnhancedContent"; +$tabsysprefs{AWSAccessKeyID} = "EnhancedContent"; +$tabsysprefs{AWSPrivateKey} = "EnhancedContent"; +$tabsysprefs{AmazonLocale} = "EnhancedContent"; +$tabsysprefs{AmazonAssocTag} = "EnhancedContent"; +$tabsysprefs{AmazonSimilarItems} = "EnhancedContent"; +$tabsysprefs{OPACAmazonSimilarItems} = "EnhancedContent"; +$tabsysprefs{AmazonReviews} = "EnhancedContent"; +$tabsysprefs{OPACAmazonReviews} = "EnhancedContent"; + +# Babelthèque +$tabsysprefs{Babeltheque} = "EnhancedContent"; + +# Baker & Taylor +$tabsysprefs{BakerTaylorBookstoreURL} = 'EnhancedContent'; +$tabsysprefs{BakerTaylorEnabled} = 'EnhancedContent'; +$tabsysprefs{BakerTaylorPassword} = 'EnhancedContent'; +$tabsysprefs{BakerTaylorUsername} = 'EnhancedContent'; + +# Library Thing for Libraries +$tabsysprefs{LibraryThingForLibrariesID} = "EnhancedContent"; +$tabsysprefs{LibraryThingForLibrariesEnabled} = "EnhancedContent"; +$tabsysprefs{LibraryThingForLibrariesTabbedView} = "EnhancedContent"; + +# Syndetics +$tabsysprefs{SyndeticsClientCode} = 'EnhancedContent'; +$tabsysprefs{SyndeticsEnabled} = 'EnhancedContent'; +$tabsysprefs{SyndeticsCoverImages} = 'EnhancedContent'; +$tabsysprefs{SyndeticsTOC} = 'EnhancedContent'; +$tabsysprefs{SyndeticsSummary} = 'EnhancedContent'; +$tabsysprefs{SyndeticsEditions} = 'EnhancedContent'; +$tabsysprefs{SyndeticsExcerpt} = 'EnhancedContent'; +$tabsysprefs{SyndeticsReviews} = 'EnhancedContent'; +$tabsysprefs{SyndeticsAuthorNotes} = 'EnhancedContent'; +$tabsysprefs{SyndeticsAwards} = 'EnhancedContent'; +$tabsysprefs{SyndeticsSeries} = 'EnhancedContent'; +$tabsysprefs{SyndeticsCoverImageSize} = 'EnhancedContent'; + + +# FRBR +$tabsysprefs{FRBRizeEditions} = "EnhancedContent"; +$tabsysprefs{XISBN} = "EnhancedContent"; +$tabsysprefs{OCLCAffiliateID} = "EnhancedContent"; +$tabsysprefs{XISBNDailyLimit} = "EnhancedContent"; +$tabsysprefs{ThingISBN} = "EnhancedContent"; +$tabsysprefs{OPACFRBRizeEditions} = "EnhancedContent"; + +# Tags +$tabsysprefs{TagsEnabled} = 'EnhancedContent'; +$tabsysprefs{TagsExternalDictionary} = 'EnhancedContent'; +$tabsysprefs{TagsInputOnDetail} = 'EnhancedContent'; +$tabsysprefs{TagsInputOnList} = 'EnhancedContent'; +$tabsysprefs{TagsShowOnDetail} = 'EnhancedContent'; +$tabsysprefs{TagsShowOnList} = 'EnhancedContent'; +$tabsysprefs{TagsModeration} = 'EnhancedContent'; +$tabsysprefs{GoogleJackets} = 'EnhancedContent'; +$tabsysprefs{AuthorisedValueImages} = "EnhancedContent"; # OPAC - $tabsysprefs{AmazonAssocTag}="OPAC"; - $tabsysprefs{AmazonSimilarItems}="OPAC"; - $tabsysprefs{AmazonContent}="OPAC"; - $tabsysprefs{OPACAmazonContent}="OPAC"; - $tabsysprefs{AmazonDevKey}="OPAC"; - $tabsysprefs{BiblioDefaultView}="OPAC"; - $tabsysprefs{LibraryName}="OPAC"; - $tabsysprefs{opaccolorstylesheet}="OPAC"; - $tabsysprefs{opaccredits}="OPAC"; - $tabsysprefs{opaclargeimage}="OPAC"; - $tabsysprefs{opaclayoutstylesheet}="OPAC"; - $tabsysprefs{OpacNav}="OPAC"; - $tabsysprefs{opacsmallimage}="OPAC"; - $tabsysprefs{opacstylesheet}="OPAC"; - $tabsysprefs{opacthemes}="OPAC"; - $tabsysprefs{opacuserjs}="OPAC"; - $tabsysprefs{SubscriptionHistory}="OPAC"; - $tabsysprefs{opacheader}="OPAC"; - $tabsysprefs{OPACAmazonSimilarItems}="OPAC"; - $tabsysprefs{OPACXISBNAmazonSimilarItems}="OPAC"; - - $tabsysprefs{hideBiblioNumber}="OPAC"; - $tabsysprefs{noOPACUserLogin}="OPAC"; - $tabsysprefs{OPACDisplayExtendedSubInfo}="OPAC"; - $tabsysprefs{OpacMainUserBlock}="OPAC"; - $tabsysprefs{OPACSubscriptionDisplay}="OPAC"; - $tabsysprefs{OPACURLOpenInNewWindow}="OPAC"; - $tabsysprefs{OPACUserCSS}="OPAC"; - $tabsysprefs{OPACHighlightedWords}="OPAC"; - $tabsysprefs{OPACViewOthersSuggestions}="OPAC"; - $tabsysprefs{URLLinkText}="OPAC"; - -# OPACFeatures - $tabsysprefs{SearchMyLibraryFirst}="OPACFeatures"; - $tabsysprefs{Disable_Dictionary}="OPACFeatures"; - $tabsysprefs{hidelostitems}="OPACFeatures"; - $tabsysprefs{opacbookbag}="OPACFeatures"; - $tabsysprefs{opaclanguagesdisplay}="OPACFeatures"; - $tabsysprefs{OpacPasswordChange}="OPACFeatures"; - $tabsysprefs{opacreadinghistory}="OPACFeatures"; - $tabsysprefs{virtualshelves}="OPACFeatures"; - $tabsysprefs{RequestOnOpac}="OPACFeatures"; - $tabsysprefs{reviewson}="OPACFeatures"; - $tabsysprefs{OpacTopissues}="OPACFeatures"; - $tabsysprefs{OpacAuthorities}="OPACFeatures"; - $tabsysprefs{OpacCloud}="OPACFeatures"; - $tabsysprefs{opacuserlogin}="OPACFeatures"; - $tabsysprefs{AnonSuggestions}="OPACFeatures"; - $tabsysprefs{suggestion}="OPACFeatures"; - $tabsysprefs{OpacTopissue}="OPACFeatures"; - $tabsysprefs{OpacBrowser}="OPACFeatures"; - $tabsysprefs{kohaspsuggest} = "OPACFeatures"; - $tabsysprefs{OpacRenewalAllowed} = "OPACFeatures"; +$tabsysprefs{BiblioDefaultView} = "OPAC"; +$tabsysprefs{LibraryName} = "OPAC"; +$tabsysprefs{opaccolorstylesheet} = "OPAC"; +$tabsysprefs{opaccredits} = "OPAC"; +$tabsysprefs{opaclayoutstylesheet} = "OPAC"; +$tabsysprefs{OpacNav} = "OPAC"; +$tabsysprefs{opacsmallimage} = "OPAC"; +$tabsysprefs{opacstylesheet} = "OPAC"; +$tabsysprefs{opacthemes} = "OPAC"; +$tabsysprefs{opacuserjs} = "OPAC"; +$tabsysprefs{opacheader} = "OPAC"; +$tabsysprefs{hideBiblioNumber} = "OPAC"; +$tabsysprefs{OpacMainUserBlock} = "OPAC"; +$tabsysprefs{OPACURLOpenInNewWindow} = "OPAC"; +$tabsysprefs{OPACUserCSS} = "OPAC"; +$tabsysprefs{OPACHighlightedWords} = "OPAC"; +$tabsysprefs{OPACViewOthersSuggestions} = "OPAC"; +$tabsysprefs{URLLinkText} = "OPAC"; +$tabsysprefs{OPACSearchForTitleIn} = "OPAC"; +$tabsysprefs{OPACShelfBrowser} = "OPAC"; +$tabsysprefs{OPACDisplayRequestPriority} = "OPAC"; +$tabsysprefs{OPACAllowHoldDateInFuture} = "OPAC"; +$tabsysprefs{OPACPatronDetails} = "OPAC"; +$tabsysprefs{OPACFinesTab} = "OPAC"; +$tabsysprefs{DisplayOPACiconsXSLT} = "OPAC"; +$tabsysprefs{AutoSelfCheckAllowed} = "OPAC"; +$tabsysprefs{AutoSelfCheckID} = "OPAC"; +$tabsysprefs{AutoSelfCheckPass} = "OPAC"; + +# OPAC +$tabsysprefs{SearchMyLibraryFirst} = "OPAC"; +$tabsysprefs{hidelostitems} = "OPAC"; +$tabsysprefs{opacbookbag} = "OPAC"; +$tabsysprefs{OpacPasswordChange} = "OPAC"; +$tabsysprefs{opacreadinghistory} = "OPAC"; +$tabsysprefs{virtualshelves} = "OPAC"; +$tabsysprefs{RequestOnOpac} = "OPAC"; +$tabsysprefs{reviewson} = "OPAC"; +$tabsysprefs{OpacTopissues} = "OPAC"; +$tabsysprefs{OpacAuthorities} = "OPAC"; +$tabsysprefs{OpacCloud} = "OPAC"; +$tabsysprefs{opacuserlogin} = "OPAC"; +$tabsysprefs{AnonSuggestions} = "OPAC"; +$tabsysprefs{suggestion} = "OPAC"; +$tabsysprefs{OpacTopissue} = "OPAC"; +$tabsysprefs{OpacBrowser} = "OPAC"; +$tabsysprefs{OpacRenewalAllowed} = "OPAC"; +$tabsysprefs{OPACItemHolds} = "OPAC"; +$tabsysprefs{OPACGroupResults} = "OPAC"; +$tabsysprefs{XSLTDetailsDisplay} = "OPAC"; +$tabsysprefs{XSLTResultsDisplay} = "OPAC"; +$tabsysprefs{OPACShowCheckoutName} = "OPAC"; +$tabsysprefs{AllowPurchaseSuggestionBranchChoice} = "OPAC"; + +# Serials +$tabsysprefs{RoutingListAddReserves} = "Serials"; +$tabsysprefs{OPACSerialIssueDisplayCount} = "Serials"; +$tabsysprefs{StaffSerialIssueDisplayCount} = "Serials"; +$tabsysprefs{RenewSerialAddsSuggestion} = "Serials"; +$tabsysprefs{SubscriptionHistory} = "Serials"; # LOGFeatures - $tabsysprefs{CataloguingLog} = "LOGFeatures"; - $tabsysprefs{BorrowersLog} = "LOGFeatures"; - $tabsysprefs{SubscriptionLog} = "LOGFeatures"; - $tabsysprefs{IssueLog} = "LOGFeatures"; - $tabsysprefs{ReturnLog} = "LOGFeatures"; - $tabsysprefs{LetterLog} = "LOGFeatures"; - $tabsysprefs{FinesLog} = "LOGFeatures"; - -sub StringSearch { - my ($searchstring,$type)=@_; +$tabsysprefs{CataloguingLog} = "Logs"; +$tabsysprefs{BorrowersLog} = "Logs"; +$tabsysprefs{SubscriptionLog} = "Logs"; +$tabsysprefs{IssueLog} = "Logs"; +$tabsysprefs{ReturnLog} = "Logs"; +$tabsysprefs{LetterLog} = "Logs"; +$tabsysprefs{FinesLog} = "Logs"; + +# OAI-PMH variables +$tabsysprefs{'OAI-PMH'} = "OAI-PMH"; +$tabsysprefs{'OAI-PMH:archiveID'} = "OAI-PMH"; +$tabsysprefs{'OAI-PMH:MaxCount'} = "OAI-PMH"; + +# ILS-DI variables +$tabsysprefs{'ILS-DI'} = "ILS-DI"; +$tabsysprefs{'ILS-DI:AuthorizedIPs'} = "Admin"; + +# Creator variables + +$tabsysprefs{'ImageLimit'} = "Creators"; + +sub StringSearch { + my ( $searchstring, $type ) = @_; my $dbh = C4::Context->dbh; - $searchstring=~ s/\'/\\\'/g; - my @data=split(' ',$searchstring); - my $count=@data; + $searchstring =~ s/\'/\\\'/g; + my @data = split( ' ', $searchstring ); + my $count = @data; my @results; - my $cnt=0; + my $cnt = 0; + my $sth; # used for doing a plain-old sys-pref search - if ($type eq 'all' ){ - my $sth=$dbh->prepare("SELECT * FROM systempreferences - WHERE variable LIKE ? OR explanation LIKE ? - ORDER BY VARIABLE"); - $sth->execute("%$searchstring%", "%$searchstring%"); - while (my $data=$sth->fetchrow_hashref){ - $data->{value} =~ s/{value} =~ s/>/>/g; - $data->{value}=substr($data->{value},0,100)."..." if length($data->{value}) >100; - push(@results,$data); - $cnt++; - } - $sth->finish; - - } elsif ($type){ - foreach my $syspref (sort { lc $a cmp lc $b } keys %tabsysprefs){ - if ($tabsysprefs{$syspref} eq $type){ - my $sth=$dbh->prepare("Select variable,value,explanation,type,options from systempreferences where (variable like ?) order by variable"); + if ( $type && $type ne 'all' ) { + foreach my $syspref ( sort { lc $a cmp lc $b } keys %tabsysprefs ) { + if ( $tabsysprefs{$syspref} eq $type ) { + my $sth = $dbh->prepare("Select variable,value,explanation,type,options from systempreferences where (variable like ?) order by variable"); $sth->execute($syspref); - while (my $data=$sth->fetchrow_hashref){ - $data->{value} =~ s/{value} =~ s/>/>/g; - $data->{value}=substr($data->{value},0,100)."..." if length($data->{value}) >100; - push(@results,$data); + while ( my $data = $sth->fetchrow_hashref ) { + $data->{shortvalue} = $data->{value}; + $data->{shortvalue} = substr( $data->{value}, 0, 60 ) . "..." if defined( $data->{value} ) and length( $data->{value} ) > 60; + push( @results, $data ); $cnt++; } $sth->finish; } } } else { - my $strsth ="Select variable,value,explanation,type,options from systempreferences where variable not in ("; - foreach my $syspref (keys %tabsysprefs){ - $strsth .= $dbh->quote($syspref).","; + my $sth; + + if ( $type and $type eq 'all' ) { + $sth = $dbh->prepare( " + SELECT * + FROM systempreferences + WHERE variable LIKE ? OR explanation LIKE ? + ORDER BY VARIABLE" ); + $sth->execute( "%$searchstring%", "%$searchstring%" ); + } else { + my $strsth = "Select variable,value,explanation,type,options from systempreferences where variable in ("; + my $first = 1; + for my $name ( get_local_prefs() ) { + $strsth .= ',' unless $first; + $strsth .= "'$name'"; + $first = 0; + } + $strsth .= ") order by variable"; + $sth = $dbh->prepare($strsth); + $sth->execute(); } - $strsth =~ s/,$/) /; - $strsth .= " order by variable"; - my $sth=$dbh->prepare($strsth); - $sth->execute(); - while (my $data=$sth->fetchrow_hashref){ - $data->{value}=substr($data->{value},0,100); - push(@results,$data); + + while ( my $data = $sth->fetchrow_hashref ) { + $data->{shortvalue} = $data->{value}; + $data->{shortvalue} = substr( $data->{value}, 0, 60 ) . "..." if length( $data->{value} ) > 60; + push( @results, $data ); $cnt++; } + $sth->finish; } - return ($cnt,\@results); + return ( $cnt, \@results ); } -my $input = new CGI; -my $searchfield=$input->param('searchfield'); -my $offset=$input->param('offset'); -my $script_name="/cgi-bin/koha/admin/systempreferences.pl"; - -my ($template, $borrowernumber, $cookie) - = get_template_and_user({template_name => "admin/systempreferences.tmpl", - query => $input, - type => "intranet", - authnotrequired => 0, - flagsrequired => {parameters => 1}, - debug => 1, - }); -my $pagesize=100; -my $op = $input->param('op'); -$searchfield=~ s/\,//g; +sub GetPrefParams { + my $data = shift; + my $params = $data; + my @options; + + if ( defined $data->{'options'} ) { + foreach my $option ( split( /\|/, $data->{'options'} ) ) { + my $selected = '0'; + defined( $data->{'value'} ) and $option eq $data->{'value'} and $selected = 1; + push @options, { option => $option, selected => $selected }; + } + } + + $params->{'prefoptions'} = $data->{'options'}; + + if ( not defined( $data->{'type'} ) ) { + $params->{'type_free'} = 1; + $params->{'fieldlength'} = ( defined( $data->{'options'} ) and $data->{'options'} and $data->{'options'} > 0 ); + } elsif ( $data->{'type'} eq 'Upload' ) { + $params->{'type_upload'} = 1; + } elsif ( $data->{'type'} eq 'Choice' ) { + $params->{'type_choice'} = 1; + } elsif ( $data->{'type'} eq 'YesNo' ) { + $params->{'type_yesno'} = 1; + $data->{'value'} = C4::Context->boolean_preference( $data->{'variable'} ); + if ( defined( $data->{'value'} ) and $data->{'value'} eq '1' ) { + $params->{'value_yes'} = 1; + } else { + $params->{'value_no'} = 1; + } + } elsif ( $data->{'type'} eq 'Integer' || $data->{'type'} eq 'Float' ) { + $params->{'type_free'} = 1; + $params->{'fieldlength'} = ( defined( $data->{'options'} ) and $data->{'options'} and $data->{'options'} > 0 ) ? $data->{'options'} : 10; + } elsif ( $data->{'type'} eq 'Textarea' ) { + $params->{'type_textarea'} = 1; + $data->{options} =~ /(.*)\|(.*)/; + $params->{'cols'} = $1; + $params->{'rows'} = $2; + } elsif ( $data->{'type'} eq 'Themes' ) { + $params->{'type_choice'} = 1; + my $type = ''; + ( $data->{'variable'} =~ m#opac#i ) ? ( $type = 'opac' ) : ( $type = 'intranet' ); + @options = (); + my $currently_selected_themes; + my $counter = 0; + foreach my $theme ( split /\s+/, $data->{'value'} ) { + push @options, { option => $theme, counter => $counter }; + $currently_selected_themes->{$theme} = 1; + $counter++; + } + foreach my $theme ( getallthemes($type) ) { + my $selected = '0'; + next if $currently_selected_themes->{$theme}; + push @options, { option => $theme, counter => $counter }; + $counter++; + } + } elsif ( $data->{'type'} eq 'ClassSources' ) { + $params->{'type_choice'} = 1; + my $type = ''; + @options = (); + my $sources = GetClassSources(); + my $counter = 0; + foreach my $cn_source ( sort keys %$sources ) { + if ( $cn_source eq $data->{'value'} ) { + push @options, { option => $cn_source, counter => $counter, selected => 1 }; + } else { + push @options, { option => $cn_source, counter => $counter }; + } + $counter++; + } + } elsif ( $data->{'type'} eq 'Languages' ) { + my $currently_selected_languages; + foreach my $language ( split /\s+/, $data->{'value'} ) { + $currently_selected_languages->{$language} = 1; + } + + # current language + my $lang = $params->{'lang'}; + my $theme; + my $interface; + if ( $data->{'variable'} =~ /opac/ ) { + + # this is the OPAC + $interface = 'opac'; + $theme = C4::Context->preference('opacthemes'); + } else { + + # this is the staff client + $interface = 'intranet'; + $theme = C4::Context->preference('template'); + } + my $languages_loop = getTranslatedLanguages( $interface, $theme, $lang, $currently_selected_languages ); + + $params->{'languages_loop'} = $languages_loop; + $params->{'type_langselector'} = 1; + } else { + $params->{'type_free'} = 1; + $params->{'fieldlength'} = ( defined( $data->{'options'} ) and $data->{'options'} and $data->{'options'} > 0 ) ? $data->{'options'} : 30; + } + + if ( $params->{'type_choice'} || $params->{'type_free'} || $params->{'type_yesno'} ) { + $params->{'oneline'} = 1; + } + + $params->{'preftype'} = $data->{'type'}; + $params->{'options'} = \@options; + + return $params; +} + +my $input = new CGI; +my $searchfield = $input->param('searchfield') || ''; +my $Tvalue = $input->param('Tvalue'); +my $offset = $input->param('offset') || 0; +my $script_name = "/cgi-bin/koha/admin/systempreferences.pl"; + +my ( $template, $borrowernumber, $cookie ) = get_template_and_user( + { template_name => "admin/systempreferences.tmpl", + query => $input, + type => "intranet", + authnotrequired => 0, + flagsrequired => { parameters => 1 }, + debug => 1, + } +); +my $pagesize = 100; +my $op = $input->param('op') || ''; +$searchfield =~ s/\,//g; if ($op) { -$template->param(script_name => $script_name, - $op => 1); # we show only the TMPL_VAR names $op + $template->param( + script_name => $script_name, + $op => 1 + ); # we show only the TMPL_VAR names $op } else { -$template->param(script_name => $script_name, - else => 1); # we show only the TMPL_VAR names $op + $template->param( + script_name => $script_name, + else => 1 + ); # we show only the TMPL_VAR names $op } -if ($op eq 'update_and_reedit') { - foreach ($input->param) { +if ( $op eq 'update_and_reedit' ) { + foreach ( $input->param ) { } - my $value=''; - if (my $currentorder=$input->param('currentorder')) { - my @currentorder=split /\|/, $currentorder; - my $orderchanged=0; - foreach my $param ($input->param) { - if ($param=~m#up-(\d+).x#) { - my $temp=$currentorder[$1]; - $currentorder[$1]=$currentorder[$1-1]; - $currentorder[$1-1]=$temp; - $orderchanged=1; + my $value = ''; + if ( my $currentorder = $input->param('currentorder') ) { + my @currentorder = split /\|/, $currentorder; + my $orderchanged = 0; + foreach my $param ( $input->param ) { + if ( $param =~ m#up-(\d+).x# ) { + my $temp = $currentorder[$1]; + $currentorder[$1] = $currentorder[ $1 - 1 ]; + $currentorder[ $1 - 1 ] = $temp; + $orderchanged = 1; last; - } elsif ($param=~m#down-(\d+).x#) { - my $temp=$currentorder[$1]; - $currentorder[$1]=$currentorder[$1+1]; - $currentorder[$1+1]=$temp; - $orderchanged=1; + } elsif ( $param =~ m#down-(\d+).x# ) { + my $temp = $currentorder[$1]; + $currentorder[$1] = $currentorder[ $1 + 1 ]; + $currentorder[ $1 + 1 ] = $temp; + $orderchanged = 1; last; } } - $value=join ' ', @currentorder; + $value = join ' ', @currentorder; if ($orderchanged) { - $op='add_form'; - $template->param(script_name => $script_name, - $op => 1); # we show only the TMPL_VAR names $op + $op = 'add_form'; + $template->param( + script_name => $script_name, + $op => 1 + ); # we show only the TMPL_VAR names $op } else { - $op=''; - $searchfield=''; - $template->param(script_name => $script_name, - else => 1); # we show only the TMPL_VAR names $op + $op = ''; + $searchfield = ''; + $template->param( + script_name => $script_name, + else => 1 + ); # we show only the TMPL_VAR names $op } } - my $dbh = C4::Context->dbh; - my $query="select * from systempreferences where variable=?"; - my $sth=$dbh->prepare($query); - $sth->execute($input->param('variable')); - if ($sth->rows) { - unless (C4::Context->config('demo') eq 1) { - my $sth=$dbh->prepare("update systempreferences set value=?,explanation=?,type=?,options=? where variable=?"); - $sth->execute($value, $input->param('explanation'), $input->param('variable'), $input->param('preftype'), $input->param('prefoptions')); + my $dbh = C4::Context->dbh; + my $query = "select * from systempreferences where variable=?"; + my $sth = $dbh->prepare($query); + $sth->execute( $input->param('variable') ); + if ( $sth->rows ) { + unless ( C4::Context->config('demo') ) { + my $sth = $dbh->prepare("update systempreferences set value=?,explanation=?,type=?,options=? where variable=?"); + $sth->execute( $value, $input->param('explanation'), $input->param('variable'), $input->param('preftype'), $input->param('prefoptions') ); $sth->finish; + logaction( 'SYSTEMPREFERENCE', 'MODIFY', undef, $input->param('variable') . " | " . $value ); } } else { - unless (C4::Context->config('demo') eq 1) { - my $sth=$dbh->prepare("insert into systempreferences (variable,value,explanation) values (?,?,?,?,?)"); - $sth->execute($input->param('variable'), $input->param('value'), $input->param('explanation'), $input->param('preftype'), $input->param('prefoptions')); + unless ( C4::Context->config('demo') ) { + my $sth = $dbh->prepare("insert into systempreferences (variable,value,explanation) values (?,?,?,?,?)"); + $sth->execute( $input->param('variable'), $input->param('value'), $input->param('explanation'), $input->param('preftype'), $input->param('prefoptions') ); $sth->finish; + logaction( 'SYSTEMPREFERENCE', 'ADD', undef, $input->param('variable') . " | " . $input->param('value') ); } } $sth->finish; @@ -404,198 +676,204 @@ if ($op eq 'update_and_reedit') { ################## ADD_FORM ################################## # called by default. Used to create form to add or modify a record -if ($op eq 'add_form') { +if ( $op eq 'add_form' ) { + #---- if primkey exists, it's a modify action, so read values to modify... my $data; if ($searchfield) { my $dbh = C4::Context->dbh; - my $sth=$dbh->prepare("select variable,value,explanation,type,options from systempreferences where variable=?"); + my $sth = $dbh->prepare("select variable,value,explanation,type,options from systempreferences where variable=?"); $sth->execute($searchfield); - $data=$sth->fetchrow_hashref; + $data = $sth->fetchrow_hashref; $sth->finish; - $template->param(modify => 1); + $template->param( modify => 1 ); + # save tab to return to if user cancels edit - $template->param(return_tab => $tabsysprefs{$searchfield}); + $template->param( return_tab => $tabsysprefs{$searchfield} ); } - my @options; - foreach my $option (split(/\|/, $data->{'options'})) { - my $selected='0'; - $option eq $data->{'value'} and $selected=1; - push @options, { option => $option, selected => $selected }; - } - if ($data->{'type'} eq 'Choice') { - $template->param('type-choice' => 1); - } elsif ($data->{'type'} eq 'YesNo') { - $template->param('type-yesno' => 1); - $data->{'value'}=C4::Context->boolean_preference($data->{'variable'}); - ($data->{'value'} eq '1') ? ($template->param('value-yes'=>1)) : ($template->param('value-no'=>1)); - } elsif ($data->{'type'} eq 'Integer') { - $template->param('type-free' => 1); - $template->param('fieldlength' => $data->{'options'}); - } elsif ($data->{'type'} eq 'Textarea') { - $template->param('type-textarea' => 1); - $data->{options} =~ /(.*)\|(.*)/; - $template->param('cols' => $1, 'rows' => $2);; - } elsif ($data->{'type'} eq 'Float') { - $template->param('type-free' => 1); - $template->param('fieldlength' => $data->{'options'}); - } elsif ($data->{'type'} eq 'Themes') { - $template->param('type-choice' => 1); - my $type=''; - ($data->{'variable'}=~m#opac#i) ? ($type='opac') : ($type='intranet'); - @options=(); - my $currently_selected_themes; - my $counter=0; - foreach my $theme (split /\s+/, $data->{'value'}) { - push @options, { option => $theme, counter => $counter }; - $currently_selected_themes->{$theme}=1; - $counter++; - } - foreach my $theme (getallthemes($type)) { - my $selected='0'; - next if $currently_selected_themes->{$theme}; - push @options, { option => $theme, counter => $counter }; - $counter++; - } - } elsif ($data->{'type'} eq 'ClassSources') { - $template->param('type-choice' => 1); - my $type=''; - @options=(); - my $sources = GetClassSources(); - my $counter=0; - foreach my $cn_source (sort keys %$sources) { - if ($cn_source eq $data->{'value'}) { - push @options, { option => $cn_source, counter => $counter, selected => 1 }; - } else { - push @options, { option => $cn_source, counter => $counter }; - } - $counter++; - } - } elsif ($data->{'type'} eq 'Languages') { - my $currently_selected_languages; - foreach my $language (split /\s+/, $data->{'value'}) { - $currently_selected_languages->{$language}=1; - } - # current language - my $lang = $template->param('lang'); - my $theme; - my $interface; - if ($data->{'variable'} =~ /opac/) { - # this is the OPAC - $interface = 'opac'; - $theme = C4::Context->preference('opacthemes'); - } - else { - # this is the staff client - $interface = 'intranet'; - $theme = C4::Context->preference('template'); - } - my $languages_loop = getTranslatedLanguages($interface,$theme,$lang,$currently_selected_languages); - - $template->param('languages_loop' => $languages_loop); - $template->param('type-langselector' => 1); - } else { - $template->param('type-free' => 1); - $template->param('fieldlength' => $data->{'options'}>0?$data->{'options'}:60); - } - $template->param(explanation => $data->{'explanation'}, - value => $data->{'value'}, - type => $data->{'type'}, - options => \@options, - preftype => $data->{'type'}, - prefoptions => $data->{'options'}, - searchfield => $searchfield); + $data->{'lang'} = $template->param('lang'); + + $template->param( GetPrefParams($data) ); + + $template->param( searchfield => $searchfield ); ################## ADD_VALIDATE ################################## -# called by add_form, used to insert/modify data in DB -} elsif ($op eq 'add_validate') { + # called by add_form, used to insert/modify data in DB +} elsif ( $op eq 'add_validate' ) { my $dbh = C4::Context->dbh; - my $sth=$dbh->prepare("select * from systempreferences where variable=?"); - $sth->execute($input->param('variable')); + my $sth = $dbh->prepare("select * from systempreferences where variable=?"); + $sth->execute( $input->param('variable') ); + # to handle multiple values my $value; + # handle multiple value strings (separated by ',') my $params = $input->Vars; - my @values = split("\0",$params->{'value'}) if $params->{'value'}; - for my $vl (@values) { - $value .= "$vl,"; + if ( defined $params->{'value'} ) { + my @values = (); + @values = split( "\0", $params->{'value'} ) if defined( $params->{'value'} ); + if (@values) { + $value = ""; + for my $vl (@values) { + $value .= "$vl,"; + } + $value =~ s/,$//; + } else { + $value = $params->{'value'}; + } } - $value =~ s/,$//; - if ($sth->rows) { - unless (C4::Context->config('demo') eq 1) { - my $sth=$dbh->prepare("update systempreferences set value=?,explanation=?,type=?,options=? where variable=?"); - $sth->execute($value, $input->param('explanation'), $input->param('preftype'), $input->param('prefoptions'), $input->param('variable')); + + if ( $input->param('preftype') eq 'Upload' ) { + my $lgtfh = $input->upload('value'); + $value = join '', <$lgtfh>; + $value = encode_base64($value); + } + + if ( $sth->rows ) { + unless ( C4::Context->config('demo') ) { + my $sth = $dbh->prepare("update systempreferences set value=?,explanation=?,type=?,options=? where variable=?"); + $sth->execute( $value, $input->param('explanation'), $input->param('preftype'), $input->param('prefoptions'), $input->param('variable') ); $sth->finish; + logaction( 'SYSTEMPREFERENCE', 'MODIFY', undef, $input->param('variable') . " | " . $value ); } } else { - unless (C4::Context->config('demo') eq 1) { - my $sth=$dbh->prepare("insert into systempreferences (variable,value,explanation,type,options) values (?,?,?,?,?)"); - $sth->execute($input->param('variable'), $value, $input->param('explanation'), $input->param('preftype'), $input->param('prefoptions')); + unless ( C4::Context->config('demo') ) { + my $sth = $dbh->prepare("insert into systempreferences (variable,value,explanation,type,options) values (?,?,?,?,?)"); + $sth->execute( $input->param('variable'), $value, $input->param('explanation'), $input->param('preftype'), $input->param('prefoptions') ); $sth->finish; + logaction( 'SYSTEMPREFERENCE', 'ADD', undef, $input->param('variable') . " | " . $value ); } } $sth->finish; - print "Content-Type: text/html\n\nparam('variable')}."\">"; + print "Content-Type: text/html\n\nparam('variable') } . "\">"; exit; ################## DELETE_CONFIRM ################################## -# called by default form, used to confirm deletion of data in DB -} elsif ($op eq 'delete_confirm') { + # called by default form, used to confirm deletion of data in DB +} elsif ( $op eq 'delete_confirm' ) { my $dbh = C4::Context->dbh; - my $sth=$dbh->prepare("select variable,value,explanation,type,options from systempreferences where variable=?"); + my $sth = $dbh->prepare("select variable,value,explanation,type,options from systempreferences where variable=?"); $sth->execute($searchfield); - my $data=$sth->fetchrow_hashref; + my $data = $sth->fetchrow_hashref; $sth->finish; - $template->param(searchfield => $searchfield, - Tvalue => $data->{'value'}, - ); + $template->param( + searchfield => $searchfield, + Tvalue => $data->{'value'}, + ); - # END $OP eq DELETE_CONFIRM + # END $OP eq DELETE_CONFIRM ################## DELETE_CONFIRMED ################################## -# called by delete_confirm, used to effectively confirm deletion of data in DB -} elsif ($op eq 'delete_confirmed') { + # called by delete_confirm, used to effectively confirm deletion of data in DB +} elsif ( $op eq 'delete_confirmed' ) { my $dbh = C4::Context->dbh; - my $sth=$dbh->prepare("delete from systempreferences where variable=?"); + my $sth = $dbh->prepare("delete from systempreferences where variable=?"); $sth->execute($searchfield); + my $logstring = $searchfield . " | " . $Tvalue; + logaction( 'SYSTEMPREFERENCE', 'DELETE', undef, $logstring ); $sth->finish; - # END $OP eq DELETE_CONFIRMED + # END $OP eq DELETE_CONFIRMED ################## DEFAULT ################################## -} else { # DEFAULT - #Adding tab management for system preferences - my $tab=$input->param('tab'); - $template->param($tab => 1); - my ($count,$results)=StringSearch($searchfield,$tab); - my $toggle=0; +} else { # DEFAULT + #Adding tab management for system preferences + my $tab = $input->param('tab'); + $template->param( $tab => 1 ); + my ( $count, $results ) = StringSearch( $searchfield, $tab ); my @loop_data = (); - for (my $i=$offset; $i < ($offset+$pagesize<$count?$offset+$pagesize:$count); $i++){ - if ($toggle eq 0){ - $toggle=1; - } else { - $toggle=0; - } - my %row_data; # get a fresh hash for the row data - $row_data{variable} = $results->[$i]{'variable'}; - $row_data{value} = $results->[$i]{'value'}; - $row_data{yes} = 1 if ($results->[$i]{'value'} == 1); - $row_data{yesno} = 1 if ($results->[$i]{'type'} eq 'YesNo'); - $row_data{explanation} = $results->[$i]{'explanation'}; - $row_data{toggle} = $toggle; - $row_data{edit} = "$script_name?op=add_form&searchfield=".$results->[$i]{'variable'}; - $row_data{delete} = "$script_name?op=delete_confirm&searchfield=".$results->[$i]{'variable'}; - push(@loop_data, \%row_data); + for ( my $i = $offset ; $i < ( $offset + $pagesize < $count ? $offset + $pagesize : $count ) ; $i++ ) { + my $row_data = $results->[$i]; + $row_data->{'lang'} = $template->param('lang'); + $row_data = GetPrefParams($row_data); # get a fresh hash for the row data + $row_data->{edit} = "$script_name?op=add_form&searchfield=" . $results->[$i]{'variable'}; + $row_data->{delete} = "$script_name?op=delete_confirm&searchfield=" . $results->[$i]{'variable'}; + push( @loop_data, $row_data ); } - $tab=($tab?$tab:"Local Use"); - $template->param(loop => \@loop_data, $tab => 1); - if ($offset>0) { - my $prevpage = $offset-$pagesize; - $template->param("'); + $tab = ( $tab ? $tab : "local_use" ); + $template->param( loop => \@loop_data, $tab => 1 ); + if ( $offset > 0 ) { + my $prevpage = $offset - $pagesize; + $template->param( "' ); } - if ($offset+$pagesize<$count) { - my $nextpage =$offset+$pagesize; - $template->param("a href=$script_name?offset=".$nextpage.'Next >>'); + if ( $offset + $pagesize < $count ) { + my $nextpage = $offset + $pagesize; + $template->param( "a href=$script_name?offset=" . $nextpage . 'Next >>' ); } - $template->param( tab => $tab, - ); -} #---- END $OP eq DEFAULT + $template->param( tab => $tab, ); +} #---- END $OP eq DEFAULT output_html_with_http_headers $input, $cookie, $template->output; + + +# Return an array containing all preferences defined in current Koha instance +# .pref files. + +sub get_prefs_from_files { + my $context = C4::Context->new(); + my $path_pref_en = $context->config('intrahtdocs') . + '/prog/en/modules/admin/preferences'; + # Get all .pref file names + opendir ( my $fh, $path_pref_en ); + my @pref_files = grep { /.pref/ } readdir($fh); + close $fh; + + my @names = (); + my $append = sub { + my $prefs = shift; + for my $pref ( @$prefs ) { + for my $element ( @$pref ) { + if ( ref( $element) eq 'HASH' ) { + my $name = $element->{pref}; + next unless $name; + push @names, $name; + next; + } + } + } + }; + for my $file (@pref_files) { + my $pref = LoadFile( "$path_pref_en/$file" ); + for my $tab ( keys %$pref ) { + my $content = $pref->{$tab}; + if ( ref($content) eq 'ARRAY' ) { + $append->($content); + next; + } + for my $section ( keys %$content ) { + my $syspref = $content->{$section}; + $append->($syspref); + } + } + } + return @names; +} + + +# Return an array containg all preferences defined in DB + +sub get_prefs_from_db { + my $dbh = C4::Context->dbh; + my $sth = $dbh->prepare("SELECT variable FROM systempreferences"); + $sth->execute; + my @names = (); + while ( (my $name) = $sth->fetchrow_array ) { + push @names, $name if $name; + } + return @names; +} + + +# Return an array containing all local preferences: those which are defined in +# DB and not defined in Koha .pref files. + +sub get_local_prefs { + my @prefs_file = get_prefs_from_files(); + my @prefs_db = get_prefs_from_db(); + + my %prefs_file = map { $_ => 1 } @prefs_file; + my @names = (); + foreach my $name (@prefs_db) { + push @names, $name unless $prefs_file{$name}; + } + + return @names; +} +