-
-
Notifications
You must be signed in to change notification settings - Fork 14
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
define resource paths #220
Comments
A few minor thoughts, take 'em or leave 'em.
Overall this looks great to me, I do like the new API schema better than the old one. |
I agree with As for singular or plural in the routes, I suppose you may be referring to Ruby on Rails, where often the resources will maintain the plural form, such as
I figure, the base calendar is the General Roman Calendar. When retrieving a calendar resource you will always only retrieve a single calendar resource, and the "Calendar of calendars" is the General Roman Calendar which I'm thinking of making accessible simply at the path Another question that I'm not sure how to deal with, is calendars for different rites. For example, here in Italy in the area around Milan, they use the "Ambrosian calendar", which I personally know nothing about. I'll need to find a liturgist from Milan who's available to explain it to me sooner or later. While the General Roman Calendar is defined in the Latin edition of the Roman Missal, how is the Ambrosian calendar defined? How similar or different is it from the General Roman Calendar? Can it be considered as inheriting from the General Roman Calendar? Could it be considered as a local / diocesan calendar? What about other rites, such as the Melchite (Greek catholic) rite, or the Ruthenian catholic rite... Do they each have their own calendar? Do all eastern catholic rites inherit from a single calendar such as the "liturgy of John Chrysostom"? Since these rites are widespread over more than one country, I don't think they can be simply treated as "diocesan calendars", and I have no idea if they should descend hierarchically from the General Roman Calendar or if they are different enough that they should be treated in parallel to the General Roman Calendar. If they need to be treated in parallel, then we might have something like this:
In any case, I'm not very strongly opinionated about singular or plural. In a Ruby on Rails environment, you could use plural almost everywhere such that As for When it comes to liturgical celebration, the calendar for the local diocese is always used (or for the religious congregation; the Franciscans have their own specific calendar, the Dominicans have their own specific calendar... That's something else to think of, how should calendars for religious communities be dealt with in a project that would like to become as much of a service as possible throughout the Church). In any case, you wouldn't really use a "national calendar" in a liturgical celebration. However the "national calendar" determines the diocesan calendar: all the dioceses of a given nation will inherit the calendar from the Roman Missal language edition for the nation in which the diocese is situated. I wouldn't even say that it's necessarily known or called a "national" calendar (that sounds kind of patriotic, so has almost more of a political nuance to it), it's simply the calendar as defined by the Bishops Conference for a given nation based on the language edition of the Roman Missal in that nation. If we really wanted to respect the hierarchy of calendar data,
Only thing that will need some attention in this case, is avoiding conflicts between names of Dioceses. If more than one diocese throughout the world has the same name, more specificity will need to be added to the key that identifies one of these dioceses. For example, DIOCESISDECARTAGENA_ES and DIOCESISDECARTAGENA_CO to distinguish the diocese of Cartagena in Spain from the diocese of the same name in Colombia. |
Starting working on this on the So will be testing routes at the address: https://litcal.johnromanodorazio.com/api/v9/ . I have currently implemented the
The
You can also set the desired locale in the 'Accept-Language' header. Try in the devtools console (you will have to be on a page within the https://litcal.johnromanodorazio.com or https://litcal-staging.johnromanodorazio.com domains): fetch('https://litcal.johnromanodorazio.com/api/v9/events', { headers: {'Accept-Language': 'nl'} })
.then(response => response.json())
.then(data => console.log(data)); You can also request a response content type of either fetch('https://litcal.johnromanodorazio.com/api/v9/events', { headers: { 'Accept': 'application/yaml' } })
.then(response => response.blob())
.then(blob => blob.text())
.then(data => console.log(data)); You can also try invalid paths or parameters to see how the API responds to invalid data. |
I suppose another way of referring to the calendar for a given country, would be to refer to a Roman Missal. So rather than call it a "national calendar", seeing that the calendar in question is produced based on an edition of the Roman Missal as published in a certain country by the Bishops Conference (with the approval of the Congregation for Divine Worship), it could be referred to by the Missal, such as: |
I'm not going to use |
This has evolved so much now, and version 4 is coming to maturity. We even have multi-language national and diocesan calendars now (see issue #150). But I won't close this issue until all of the PUT / PATCH / DELETE requests are correctly implemented on the various routes. This is still going to require quite a bit of work... (see #265) |
We now have routing in place. We need to define a clear resource path strategy.
Current situation
Currently we have the following working paths:
/api/dev/
: will generate a calendar, whether General Roman, or a national calendar, or a diocesan calendar, based on params/api/dev/metadata/
: will generate the index of all the available calendars and related data/api/dev/testsindex/
: will generate the index of all available unit tests/api/dev/allevents/
: will generate a collection of all possible liturgical events that go to creating a given calendar (this is NOT the calendar, only the events that may be found in the calendar)/api/dev/regionaldata/
: will produce the data for a given national or diocesan calendar, that is used to generate the calendar; can also create new data / update existing data with PUT / PATCH requests/api/dev/easter/
: will generate all the dates of Easter from 1583 to 9999New Path schema
Proposed schema moving forward (RFC):
Calendars (
GET
,POST
) ✔️This is the true perpetual calendar endpoint, it will retrieve the actual calculated liturgical calendar for a given year
/api/dev/calendars/
: will generate the index of all the available calendars and related data/api/dev/calendar/{YEAR}/
: will generate the General Roman Calendar (aka Universal) for the year{YEAR}
(if year is omitted, will default to the current year)/api/dev/calendar/nation/{NATION}/{YEAR}/
: will generate the national calendar for{NATION}
for the year{YEAR}
(if year is omitted, will default to the current year)/api/dev/calendar/diocese/{DIOCESE}/{YEAR}/
: will generate the diocesan calendar for{DIOCESE}
for the year{YEAR}
(if year is omitted, will default to the current year)Roman Missals (
GET
,POST
,PUT
,PATCH
,DELETE
) ❗/api/dev/missals/
: will get the index of all Roman Missals for which data has been defined in the API/api/dev/missal/{YEAR}
: will get / update / create / delete sanctorale data for the Latin Roman Missal published in the year{YEAR}
(if{YEAR}
is omitted will get an array of all Latin Roman Missals published since 1969)/api/dev/missal/nation/{NATION}/{YEAR}
: will get / update / create / delete sanctorale data for the Missal of the nation{NATION}
published in the year{YEAR}
(if{YEAR}
is omitted will get an array of all Missals for the given{NATION}
published since 1969)Decrees of the Congregation for Divine Worship (
GET
,POST
,PUT
,PATCH
,DELETE
) ❗/api/dev/decrees/
: will get the data of Decrees of the Congregation for Divine Worship that add new festivities, or resolve coincidences between festivities; or create a new decree if one is issued (we shouldn't really have to update anything, but let's say a mistake was made when creating a new decree, perhaps we can allow toPATCH
it;DELETE
shouldn't really be needed here)Calendar data (
GET
,POST
,PUT
,PATCH
,DELETE
) ✔️This is data that goes to generating a National or Diocesan calendar, that cannot be handled in the Missals data; generally consists of particular operations, or liturgical events that have had changes since a Missal was published...
/api/dev/data/
: will get the index of all data files that have been defined for national or diocesan calendars/api/dev/data/nation/{NATION}/
: will get / update / create / delete the data that is used to generate the national calendar for{NATION}
(only data that will modify the sanctorale data from the relative Missal for the nation, or add new festivities for a given year that were not in the Missal, or move festivities etc.)/api/dev/data/diocese/{DIOCESE}
: will get / update / create / delete the data that is used to generate the diocesan calendar for{DIOCESE}
/api/dev/data/widerregion/{WIDERREGION}
: will get / update / create / delete the data that is used for the Wider Region that certain nations may belong to (e.g. "Europe" or "Americas"; this data will be included in the generation of a national calendar that belongs to the given Wider Region)Dates of Easter (
GET
,POST
) ✔️/api/dev/easter/
: will generate all the dates of Easter from 1583 to 9999Liturgical events (
GET
,POST
) ✔️/api/dev/events/
: will generate a collection of all possible liturgical events that go to creating the General Roman Calendar, whatever the year/api/dev/events/nation/{NATION}/
: will generate a collection of all possible liturgical events that go to creating the national calendar for{NATION}
, whatever the year/api/dev/events/diocese/{DIOCESE}
: will generate a collection of all possible liturgical events that go to creating the diocesan calendar for{DIOCESE}
, whatever the yearUnit Tests (
GET
,POST
,PUT
,PATCH
,DELETE
) ✔️/api/dev/tests/
: will generate the index of all available unit tests/api/dev/test/{TEST}/
: will get an existing test by ID, or create a new test / update / delete an existing test by IDPlease feel free to ask questions or contribute with ideas for better resource paths!
The text was updated successfully, but these errors were encountered: