Class: Mangadex::Manga
- Inherits:
-
MangadexObject
- Object
- MangadexObject
- Mangadex::Manga
- Defined in:
- lib/mangadex/manga.rb
Instance Attribute Summary
Attributes included from Internal::WithAttributes
#attributes, #id, #related_type, #relationships, #type
Class Method Summary collapse
- .all_reading_status(status = nil) ⇒ Object
- .attributes_to_inspect ⇒ Object
- .create(**args) ⇒ Object
- .delete(id) ⇒ Object
- .feed(id, **args) ⇒ Object
- .follow(id) ⇒ Object
- .list(**args) ⇒ Object
- .random(**args) ⇒ Object
- .read_markers(id, grouped: false) ⇒ Object
- .reading_status(id) ⇒ Object
- .tag_list ⇒ Object
- .unfollow(id) ⇒ Object
- .update(id, **args) ⇒ Object (also: edit)
- .update_reading_status(id, status) ⇒ Object
- .view(id, **args) ⇒ Object (also: get)
- .volumes_and_chapters(id, **args) ⇒ Object (also: aggregate)
Instance Method Summary collapse
Methods inherited from MangadexObject
#eq?, #hash, #initialize, #inspect
Methods included from Concern
#append_features, #class_methods, extended, #included, #prepend_features, #prepended
Constructor Details
This class inherits a constructor from Mangadex::MangadexObject
Class Method Details
.all_reading_status(status = nil) ⇒ Object
134 135 136 137 138 139 140 141 142 143 144 145 146 |
# File 'lib/mangadex/manga.rb', line 134 def self.all_reading_status(status = nil) args = { status: status } if status.present? Mangadex::Internal::Request.get( '/manga/status', Mangadex::Internal::Definition.validate(args, { status: { accepts: %w(reading on_hold dropped plan_to_read re_reading completed), converts: :to_s, }, }) ) end |
.attributes_to_inspect ⇒ Object
202 203 204 |
# File 'lib/mangadex/manga.rb', line 202 def self.attributes_to_inspect [:id, :type, :title, :content_rating, :original_language, :year] end |
.create(**args) ⇒ Object
198 199 200 |
# File 'lib/mangadex/manga.rb', line 198 def self.create(**args) Mangadex::Internal::Request.post('/manga', payload: args) end |
.delete(id) ⇒ Object
190 191 192 193 194 195 196 |
# File 'lib/mangadex/manga.rb', line 190 def self.delete(id) Mangadex::Internal::Definition.must(id) Mangadex::Internal::Request.delete( '/manga/%{id}' % {id: id}, ) end |
.feed(id, **args) ⇒ Object
105 106 107 108 109 110 111 112 113 |
# File 'lib/mangadex/manga.rb', line 105 def self.feed(id, **args) Mangadex::Internal::Definition.must(id) Mangadex::Internal::Request.get( '/manga/%{id}/feed' % {id: id}, Mangadex::Internal::Definition.chapter_list(args), content_rating: true, ) end |
.follow(id) ⇒ Object
96 97 98 99 100 101 102 |
# File 'lib/mangadex/manga.rb', line 96 def self.follow(id) Mangadex::Internal::Definition.must(id) Mangadex::Internal::Request.post( '/manga/%{id}/follow' % {id: id}, ) end |
.list(**args) ⇒ Object
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
# File 'lib/mangadex/manga.rb', line 28 def self.list(**args) to_a = Mangadex::Internal::Definition.converts(:to_a) Mangadex::Internal::Request.get( '/manga', Mangadex::Internal::Definition.validate(args, { limit: { accepts: Integer }, offset: { accepts: Integer }, title: { accepts: String }, authors: { accepts: [String] }, artists: { accepts: [String] }, year: { accepts: Integer }, included_tags: { accepts: [String] }, included_tags_mode: { accepts: %w(OR AND), converts: to_a }, excluded_tags: { accepts: [String] }, excluded_tags_mode: { accepts: %w(OR AND), converts: to_a }, status: { accepts: %w(ongoing completed hiatus cancelled), converts: to_a }, original_language: { accepts: [String] }, excluded_original_language: { accepts: [String] }, available_translated_language: { accepts: [String] }, publication_demographic: { accepts: %w(shounen shoujo josei seinen none), converts: to_a }, ids: { accepts: Array }, content_rating: { accepts: %w(safe suggestive erotica pornographic), converts: to_a }, created_at_since: { accepts: %r{^\d{4}-[0-1]\d-([0-2]\d|3[0-1])T([0-1]\d|2[0-3]):[0-5]\d:[0-5]\d$} }, updated_at_since: { accepts: %r{^\d{4}-[0-1]\d-([0-2]\d|3[0-1])T([0-1]\d|2[0-3]):[0-5]\d:[0-5]\d$} }, order: { accepts: Hash }, includes: { accepts: Array, converts: to_a }, has_available_chapters: { accepts: ['0', '1', 'true', 'false'] }, group: { accepts: String }, }), content_rating: true, ) end |
.random(**args) ⇒ Object
116 117 118 119 120 121 122 123 124 |
# File 'lib/mangadex/manga.rb', line 116 def self.random(**args) Mangadex::Internal::Request.get( '/manga/random', Mangadex::Internal::Definition.validate(args, { includes: { accepts: Array }, content_rating: { accepts: %w(safe suggestive erotica pornographic), converts: to_a }, }) ) end |
.read_markers(id, grouped: false) ⇒ Object
173 174 175 176 177 178 179 |
# File 'lib/mangadex/manga.rb', line 173 def self.read_markers(id, grouped: false) Mangadex::Internal::Request.get( '/manga/read', { ids: Array(id), grouped: grouped }, auth: true, ) end |
.reading_status(id) ⇒ Object
149 150 151 152 153 154 155 |
# File 'lib/mangadex/manga.rb', line 149 def self.reading_status(id) Mangadex::Internal::Definition.must(id) Mangadex::Internal::Request.get( '/manga/%{id}/status' % {id: id}, ) end |
.tag_list ⇒ Object
127 128 129 130 131 |
# File 'lib/mangadex/manga.rb', line 127 def self.tag_list Mangadex::Internal::Request.get( '/manga/tag' ) end |
.unfollow(id) ⇒ Object
87 88 89 90 91 92 93 |
# File 'lib/mangadex/manga.rb', line 87 def self.unfollow(id) Mangadex::Internal::Definition.must(id) Mangadex::Internal::Request.delete( '/manga/%{id}/follow' % {id: id}, ) end |
.update(id, **args) ⇒ Object Also known as: edit
183 184 185 186 187 |
# File 'lib/mangadex/manga.rb', line 183 def self.update(id, **args) Mangadex::Internal::Definition.must(id) Mangadex::Internal::Request.put('/manga/%{id}' % {id: id}, payload: args) end |
.update_reading_status(id, status) ⇒ Object
158 159 160 161 162 163 164 165 166 167 168 169 170 |
# File 'lib/mangadex/manga.rb', line 158 def self.update_reading_status(id, status) Mangadex::Internal::Definition.must(id) Mangadex::Internal::Request.post( '/manga/%{id}/status' % {id: id}, payload: Mangadex::Internal::Definition.validate({status: status}, { status: { accepts: %w(reading on_hold dropped plan_to_read re_reading completed), required: true, }, }) ) end |
.view(id, **args) ⇒ Object Also known as: get
74 75 76 77 78 79 80 81 82 83 84 |
# File 'lib/mangadex/manga.rb', line 74 def self.view(id, **args) to_a = Mangadex::Internal::Definition.converts(:to_a) Mangadex::Internal::Definition.must(id) Mangadex::Internal::Request.get( '/manga/%{id}' % {id: id}, Mangadex::Internal::Definition.validate(args, { includes: { accepts: Array, converts: to_a }, }) ) end |
.volumes_and_chapters(id, **args) ⇒ Object Also known as: aggregate
63 64 65 66 67 68 69 70 71 |
# File 'lib/mangadex/manga.rb', line 63 def self.volumes_and_chapters(id, **args) Mangadex::Internal::Request.get( '/manga/%{id}/aggregate' % {id: id}, Mangadex::Internal::Definition.validate(args, { translated_language: { accepts: Array }, groups: { accepts: Array }, }), ) end |
Instance Method Details
#chapters(**args) ⇒ Object
220 221 222 223 |
# File 'lib/mangadex/manga.rb', line 220 def chapters(**args) chapter_args = args.merge({manga: id}) Chapter.list(**chapter_args) end |
#content_rating ⇒ Object
213 214 215 216 217 |
# File 'lib/mangadex/manga.rb', line 213 def return unless attributes&..present? ContentRating.new(attributes.) end |