Class: AtlasRb::Community
- Defined in:
- lib/atlas_rb/community.rb
Overview
A top-level grouping in the Atlas hierarchy.
Communities are organizational containers — they hold Collections and, optionally, sub-Communities. Most institutional structure (departments, programs, projects) is modeled as a tree of Communities with Collections at the leaves.
See also: Collection, Work.
Constant Summary collapse
- ROUTE =
This constant is part of a private API. You should avoid using this constant if possible, as it may be removed or be changed in the future.
Atlas REST endpoint prefix for this resource.
"/communities/"
Class Method Summary collapse
-
.children(id, nuid: nil) ⇒ Array<String>
List the immediate children (sub-Communities and Collections) of a Community.
-
.create(id = nil, xml_path = nil, nuid: nil) ⇒ Hash
Create a new Community, optionally seeded with MODS metadata.
-
.destroy(id, nuid: nil) ⇒ Faraday::Response
Delete a Community.
-
.find(id, nuid: nil) ⇒ Hash
Fetch a single Community by ID.
-
.metadata(id, values, nuid: nil) ⇒ Hash
Patch individual descriptive-metadata fields without uploading a full MODS document.
-
.mods(id, kind = nil, nuid: nil) ⇒ String
Fetch the Community's MODS representation in the requested format.
-
.restore(id, nuid:) ⇒ Faraday::Response
Restore a previously tombstoned Community.
-
.set_thumbnails(id, thumbnail: nil, thumbnail_2x: nil, preview: nil, nuid: nil) ⇒ AtlasRb::Mash
Attach the three thumbnail/preview Delegate URIs to a Community.
-
.tombstone(id, nuid:) ⇒ Faraday::Response
Tombstone (withdraw) a Community.
-
.update(id, xml_path, nuid: nil) ⇒ Hash
Replace a Community's metadata by uploading a MODS XML document.
Methods inherited from Resource
Methods included from FaradayHelper
Class Method Details
.children(id, nuid: nil) ⇒ Array<String>
List the immediate children (sub-Communities and Collections) of a Community.
The endpoint returns just the noids; resolve each through Resource.find (which dispatches by type) when richer payloads are needed.
126 127 128 |
# File 'lib/atlas_rb/community.rb', line 126 def self.children(id, nuid: nil) JSON.parse(connection({}, nuid).get(ROUTE + id + '/children')&.body) end |
.create(id = nil, xml_path = nil, nuid: nil) ⇒ Hash
Create a new Community, optionally seeded with MODS metadata.
Pass id = nil to create a top-level Community; pass a Community ID to
nest the new Community beneath an existing one.
54 55 56 57 58 59 60 |
# File 'lib/atlas_rb/community.rb', line 54 def self.create(id = nil, xml_path = nil, nuid: nil) result = AtlasRb::Mash.new(JSON.parse(connection({ parent_id: id }, nuid).post(ROUTE)&.body))["community"] return result unless xml_path.present? update(result["id"], xml_path, nuid: nuid) find(result["id"], nuid: nuid) end |
.destroy(id, nuid: nil) ⇒ Faraday::Response
Delete a Community.
72 73 74 |
# File 'lib/atlas_rb/community.rb', line 72 def self.destroy(id, nuid: nil) connection({}, nuid).delete(ROUTE + id) end |
.find(id, nuid: nil) ⇒ Hash
Fetch a single Community by ID.
29 30 31 |
# File 'lib/atlas_rb/community.rb', line 29 def self.find(id, nuid: nil) AtlasRb::Mash.new(JSON.parse(connection({}, nuid).get(ROUTE + id)&.body))["community"] end |
.metadata(id, values, nuid: nil) ⇒ Hash
Patch individual descriptive-metadata fields without uploading a full MODS document.
Scoped to user-authored descriptive metadata only. Programmatic writes of machine-set Delegate URIs (thumbnails) have their own purpose-specific endpoint — see set_thumbnails.
165 166 167 |
# File 'lib/atlas_rb/community.rb', line 165 def self.(id, values, nuid: nil) AtlasRb::Mash.new(JSON.parse(connection({ metadata: values }, nuid).patch(ROUTE + id)&.body)) end |
.mods(id, kind = nil, nuid: nil) ⇒ String
Fetch the Community's MODS representation in the requested format.
213 214 215 216 217 218 |
# File 'lib/atlas_rb/community.rb', line 213 def self.mods(id, kind = nil, nuid: nil) # json default, html, xml connection({}, nuid).get( ROUTE + id + '/mods' + (kind.present? ? ".#{kind}" : '') )&.body end |
.restore(id, nuid:) ⇒ Faraday::Response
Restore a previously tombstoned Community.
Operator-only. Restoration is intentionally not exposed in any end-user UI; call this from a Rails console session (or a future admin panel) when the library has decided an object should come back.
107 108 109 |
# File 'lib/atlas_rb/community.rb', line 107 def self.restore(id, nuid:) connection({}, nuid).post(ROUTE + id + '/restore') end |
.set_thumbnails(id, thumbnail: nil, thumbnail_2x: nil, preview: nil, nuid: nil) ⇒ AtlasRb::Mash
Attach the three thumbnail/preview Delegate URIs to a Community.
Community-level mirror of Work.set_thumbnails. Atlas dispatches
each non-blank URI to its matching Delegate role
(thumbnail_image / thumbnail_image_2x / preview_image) via
DelegateUpdater. Missing keys are left untouched.
192 193 194 195 196 197 |
# File 'lib/atlas_rb/community.rb', line 192 def self.set_thumbnails(id, thumbnail: nil, thumbnail_2x: nil, preview: nil, nuid: nil) body = { thumbnail: thumbnail, thumbnail_2x: thumbnail_2x, preview: preview }.compact AtlasRb::Mash.new(JSON.parse( connection({}, nuid).patch(ROUTE + id + '/thumbnails', JSON.dump(body))&.body )) end |
.tombstone(id, nuid:) ⇒ Faraday::Response
Tombstone (withdraw) a Community.
The Community remains in Atlas storage but is marked as withdrawn:
search and show pages return a withdrawn stub for every user. Atlas
rejects the request with 422 has_live_children if the Community
still has live (non-tombstoned) members.
91 92 93 |
# File 'lib/atlas_rb/community.rb', line 91 def self.tombstone(id, nuid:) connection({}, nuid).post(ROUTE + id + '/tombstone') end |
.update(id, xml_path, nuid: nil) ⇒ Hash
Replace a Community's metadata by uploading a MODS XML document.
141 142 143 144 145 146 |
# File 'lib/atlas_rb/community.rb', line 141 def self.update(id, xml_path, nuid: nil) payload = { binary: Faraday::Multipart::FilePart.new(File.open(xml_path), "application/xml", File.basename(xml_path)) } AtlasRb::Mash.new(JSON.parse(multipart(nuid).patch(ROUTE + id, payload)&.body)) end |