annotate jamendo/sparql-archived/SeRQL/jrn_export.pl @ 27:d95e683fbd35 tip

Enable CORS on urispace redirects as well
author Chris Cannam
date Tue, 20 Feb 2018 14:52:02 +0000
parents df9685986338
children
rev   line source
Chris@0 1 /* $Id$
Chris@0 2
Chris@0 3 Part of SWI-Prolog
Chris@0 4
Chris@0 5 Author: Jan Wielemaker
Chris@0 6 E-mail: wielemak@science.uva.nl
Chris@0 7 WWW: http://www.swi-prolog.org
Chris@0 8 Copyright (C): 1985-2005, University of Amsterdam
Chris@0 9
Chris@0 10 This program is free software; you can redistribute it and/or
Chris@0 11 modify it under the terms of the GNU General Public License
Chris@0 12 as published by the Free Software Foundation; either version 2
Chris@0 13 of the License, or (at your option) any later version.
Chris@0 14
Chris@0 15 This program is distributed in the hope that it will be useful,
Chris@0 16 but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@0 17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@0 18 GNU General Public License for more details.
Chris@0 19
Chris@0 20 You should have received a copy of the GNU Lesser General Public
Chris@0 21 License along with this library; if not, write to the Free Software
Chris@0 22 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Chris@0 23
Chris@0 24 As a special exception, if you link this library with other files,
Chris@0 25 compiled with a Free Software compiler, to produce an executable, this
Chris@0 26 library does not by itself cause the resulting executable to be covered
Chris@0 27 by the GNU General Public License. This exception does not however
Chris@0 28 invalidate any other reasons why the executable file might be covered by
Chris@0 29 the GNU General Public License.
Chris@0 30 */
Chris@0 31
Chris@0 32 :- module(rdf_jrn_export, []).
Chris@0 33 :- use_module(library('semweb/rdf_persistency')).
Chris@0 34 :- use_module(user_db).
Chris@0 35 :- use_module(http_admin).
Chris@0 36 :- use_module(http_user).
Chris@0 37 :- use_module(library('http/http_parameters')).
Chris@0 38 :- use_module(library('http/mimetype')).
Chris@0 39 :- use_module(library('http/http_dispatch')).
Chris@0 40
Chris@0 41 /* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Chris@0 42 This module exports the journal files defined in rdf_persistency. This
Chris@0 43 is will be used to synchronise servers.
Chris@0 44 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
Chris@0 45
Chris@0 46 :- http_handler('/SeRQL/list_journals', list_journals, []).
Chris@0 47 :- http_handler('/SeRQL/journal', journal, []).
Chris@0 48
Chris@0 49 %% list_journals
Chris@0 50 %
Chris@0 51 % HTTP handler to list the available journals from the persistent
Chris@0 52 % store.
Chris@0 53
Chris@0 54 list_journals(_Request) :- !,
Chris@0 55 authorized(read(default, list_journals)),
Chris@0 56 format('Content-type: text/xml~n~n'),
Chris@0 57 format('<journals>~n'),
Chris@0 58 forall(rdf_journal_file(DB, _File),
Chris@0 59 format(' <journal db="~w"/>~n', [DB])),
Chris@0 60 format('</journals>~n').
Chris@0 61
Chris@0 62 %% journal
Chris@0 63 %
Chris@0 64 % HTTP handler that serves the journal for an RDF named graph.
Chris@0 65
Chris@0 66 journal(Request) :- !,
Chris@0 67 http_parameters(Request,
Chris@0 68 [ 'DB'(DB, [])
Chris@0 69 ],
Chris@0 70 [
Chris@0 71 ]),
Chris@0 72 authorized(read(DB, read_journal)),
Chris@0 73 rdf_journal_file(DB, Path),
Chris@0 74 throw(http_reply(file(text/'x-prolog', Path))).