phoebe 0.1.0.pre.alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.ignore +2 -0
- data/CHANGELOG.md +52 -0
- data/README.md +235 -0
- data/SECURITY.md +27 -0
- data/lib/phoebe/client.rb +80 -0
- data/lib/phoebe/errors.rb +228 -0
- data/lib/phoebe/file_part.rb +58 -0
- data/lib/phoebe/internal/transport/base_client.rb +573 -0
- data/lib/phoebe/internal/transport/pooled_net_requester.rb +208 -0
- data/lib/phoebe/internal/type/array_of.rb +168 -0
- data/lib/phoebe/internal/type/base_model.rb +531 -0
- data/lib/phoebe/internal/type/base_page.rb +55 -0
- data/lib/phoebe/internal/type/boolean.rb +77 -0
- data/lib/phoebe/internal/type/converter.rb +327 -0
- data/lib/phoebe/internal/type/enum.rb +131 -0
- data/lib/phoebe/internal/type/file_input.rb +111 -0
- data/lib/phoebe/internal/type/hash_of.rb +188 -0
- data/lib/phoebe/internal/type/request_parameters.rb +42 -0
- data/lib/phoebe/internal/type/union.rb +237 -0
- data/lib/phoebe/internal/type/unknown.rb +81 -0
- data/lib/phoebe/internal/util.rb +915 -0
- data/lib/phoebe/internal.rb +20 -0
- data/lib/phoebe/models/data/observation.rb +107 -0
- data/lib/phoebe/models/data/observations/geo/recent/notable_list_params.rb +95 -0
- data/lib/phoebe/models/data/observations/geo/recent/notable_list_response.rb +16 -0
- data/lib/phoebe/models/data/observations/geo/recent/specie_list_params.rb +84 -0
- data/lib/phoebe/models/data/observations/geo/recent/specie_list_response.rb +16 -0
- data/lib/phoebe/models/data/observations/geo/recent_list_params.rb +126 -0
- data/lib/phoebe/models/data/observations/geo/recent_list_response.rb +14 -0
- data/lib/phoebe/models/data/observations/nearest/geo_specie_list_params.rb +82 -0
- data/lib/phoebe/models/data/observations/nearest/geo_specie_list_response.rb +14 -0
- data/lib/phoebe/models/data/observations/recent/historic_list_params.rb +144 -0
- data/lib/phoebe/models/data/observations/recent/historic_list_response.rb +14 -0
- data/lib/phoebe/models/data/observations/recent/notable_list_params.rb +79 -0
- data/lib/phoebe/models/data/observations/recent/notable_list_response.rb +14 -0
- data/lib/phoebe/models/data/observations/recent/specie_retrieve_params.rb +75 -0
- data/lib/phoebe/models/data/observations/recent/specie_retrieve_response.rb +14 -0
- data/lib/phoebe/models/data/observations/recent_list_params.rb +91 -0
- data/lib/phoebe/models/data/observations/recent_list_response.rb +12 -0
- data/lib/phoebe/models/product/checklist_view_params.rb +16 -0
- data/lib/phoebe/models/product/checklist_view_response.rb +291 -0
- data/lib/phoebe/models/product/list_retrieve_params.rb +24 -0
- data/lib/phoebe/models/product/list_retrieve_response.rb +295 -0
- data/lib/phoebe/models/product/lists/historical_retrieve_params.rb +66 -0
- data/lib/phoebe/models/product/lists/historical_retrieve_response.rb +297 -0
- data/lib/phoebe/models/product/species_list_list_params.rb +16 -0
- data/lib/phoebe/models/product/species_list_list_response.rb +10 -0
- data/lib/phoebe/models/product/stat_retrieve_params.rb +34 -0
- data/lib/phoebe/models/product/stat_retrieve_response.rb +30 -0
- data/lib/phoebe/models/product/top100_retrieve_params.rb +64 -0
- data/lib/phoebe/models/product/top100_retrieve_response.rb +51 -0
- data/lib/phoebe/models/ref/hotspot/geo_retrieve_params.rb +67 -0
- data/lib/phoebe/models/ref/hotspot/geo_retrieve_response.rb +71 -0
- data/lib/phoebe/models/ref/hotspot/info_retrieve_params.rb +18 -0
- data/lib/phoebe/models/ref/hotspot/info_retrieve_response.rb +92 -0
- data/lib/phoebe/models/ref/hotspot_list_params.rb +43 -0
- data/lib/phoebe/models/ref/hotspot_list_response.rb +69 -0
- data/lib/phoebe/models/ref/region/adjacent_list_params.rb +18 -0
- data/lib/phoebe/models/ref/region/adjacent_list_response.rb +29 -0
- data/lib/phoebe/models/ref/region/info_retrieve_params.rb +49 -0
- data/lib/phoebe/models/ref/region/info_retrieve_response.rb +55 -0
- data/lib/phoebe/models/ref/region/list_list_params.rb +44 -0
- data/lib/phoebe/models/ref/region/list_list_response.rb +29 -0
- data/lib/phoebe/models/ref/taxonomy/ebird_retrieve_params.rb +69 -0
- data/lib/phoebe/models/ref/taxonomy/ebird_retrieve_response.rb +89 -0
- data/lib/phoebe/models/ref/taxonomy/form_list_params.rb +18 -0
- data/lib/phoebe/models/ref/taxonomy/form_list_response.rb +12 -0
- data/lib/phoebe/models/ref/taxonomy/locale_list_params.rb +24 -0
- data/lib/phoebe/models/ref/taxonomy/locale_list_response.rb +35 -0
- data/lib/phoebe/models/ref/taxonomy/species_group_list_params.rb +41 -0
- data/lib/phoebe/models/ref/taxonomy/species_group_list_response.rb +37 -0
- data/lib/phoebe/models/ref/taxonomy/version_list_params.rb +18 -0
- data/lib/phoebe/models/ref/taxonomy/version_list_response.rb +29 -0
- data/lib/phoebe/models.rb +47 -0
- data/lib/phoebe/request_options.rb +77 -0
- data/lib/phoebe/resources/data/observations/geo/recent/notable.rb +62 -0
- data/lib/phoebe/resources/data/observations/geo/recent/species.rb +78 -0
- data/lib/phoebe/resources/data/observations/geo/recent.rb +75 -0
- data/lib/phoebe/resources/data/observations/geo.rb +22 -0
- data/lib/phoebe/resources/data/observations/nearest/geo_species.rb +64 -0
- data/lib/phoebe/resources/data/observations/nearest.rb +22 -0
- data/lib/phoebe/resources/data/observations/recent/historic.rb +84 -0
- data/lib/phoebe/resources/data/observations/recent/notable.rb +57 -0
- data/lib/phoebe/resources/data/observations/recent/species.rb +74 -0
- data/lib/phoebe/resources/data/observations/recent.rb +72 -0
- data/lib/phoebe/resources/data/observations.rb +28 -0
- data/lib/phoebe/resources/data.rb +18 -0
- data/lib/phoebe/resources/product/checklist.rb +38 -0
- data/lib/phoebe/resources/product/lists/historical.rb +66 -0
- data/lib/phoebe/resources/product/lists.rb +44 -0
- data/lib/phoebe/resources/product/species_list.rb +42 -0
- data/lib/phoebe/resources/product/stats.rb +58 -0
- data/lib/phoebe/resources/product/top100.rb +79 -0
- data/lib/phoebe/resources/product.rb +34 -0
- data/lib/phoebe/resources/ref/hotspot/geo.rb +49 -0
- data/lib/phoebe/resources/ref/hotspot/info.rb +40 -0
- data/lib/phoebe/resources/ref/hotspot.rb +50 -0
- data/lib/phoebe/resources/ref/region/adjacent.rb +40 -0
- data/lib/phoebe/resources/ref/region/info.rb +58 -0
- data/lib/phoebe/resources/ref/region/list.rb +51 -0
- data/lib/phoebe/resources/ref/region.rb +28 -0
- data/lib/phoebe/resources/ref/taxonomy/ebird.rb +51 -0
- data/lib/phoebe/resources/ref/taxonomy/forms.rb +39 -0
- data/lib/phoebe/resources/ref/taxonomy/locales.rb +44 -0
- data/lib/phoebe/resources/ref/taxonomy/species_groups.rb +47 -0
- data/lib/phoebe/resources/ref/taxonomy/versions.rb +37 -0
- data/lib/phoebe/resources/ref/taxonomy.rb +36 -0
- data/lib/phoebe/resources/ref.rb +26 -0
- data/lib/phoebe/version.rb +5 -0
- data/lib/phoebe.rb +139 -0
- data/manifest.yaml +17 -0
- data/rbi/phoebe/client.rbi +55 -0
- data/rbi/phoebe/errors.rbi +205 -0
- data/rbi/phoebe/file_part.rbi +37 -0
- data/rbi/phoebe/internal/transport/base_client.rbi +297 -0
- data/rbi/phoebe/internal/transport/pooled_net_requester.rbi +82 -0
- data/rbi/phoebe/internal/type/array_of.rbi +104 -0
- data/rbi/phoebe/internal/type/base_model.rbi +299 -0
- data/rbi/phoebe/internal/type/base_page.rbi +42 -0
- data/rbi/phoebe/internal/type/boolean.rbi +58 -0
- data/rbi/phoebe/internal/type/converter.rbi +204 -0
- data/rbi/phoebe/internal/type/enum.rbi +82 -0
- data/rbi/phoebe/internal/type/file_input.rbi +59 -0
- data/rbi/phoebe/internal/type/hash_of.rbi +104 -0
- data/rbi/phoebe/internal/type/request_parameters.rbi +29 -0
- data/rbi/phoebe/internal/type/union.rbi +126 -0
- data/rbi/phoebe/internal/type/unknown.rbi +58 -0
- data/rbi/phoebe/internal/util.rbi +484 -0
- data/rbi/phoebe/internal.rbi +16 -0
- data/rbi/phoebe/models/data/observation.rbi +175 -0
- data/rbi/phoebe/models/data/observations/geo/recent/notable_list_params.rbi +172 -0
- data/rbi/phoebe/models/data/observations/geo/recent/notable_list_response.rbi +19 -0
- data/rbi/phoebe/models/data/observations/geo/recent/specie_list_params.rbi +124 -0
- data/rbi/phoebe/models/data/observations/geo/recent/specie_list_response.rbi +19 -0
- data/rbi/phoebe/models/data/observations/geo/recent_list_params.rbi +270 -0
- data/rbi/phoebe/models/data/observations/geo/recent_list_response.rbi +17 -0
- data/rbi/phoebe/models/data/observations/nearest/geo_specie_list_params.rbi +122 -0
- data/rbi/phoebe/models/data/observations/nearest/geo_specie_list_response.rbi +17 -0
- data/rbi/phoebe/models/data/observations/recent/historic_list_params.rbi +324 -0
- data/rbi/phoebe/models/data/observations/recent/historic_list_response.rbi +17 -0
- data/rbi/phoebe/models/data/observations/recent/notable_list_params.rbi +158 -0
- data/rbi/phoebe/models/data/observations/recent/notable_list_response.rbi +17 -0
- data/rbi/phoebe/models/data/observations/recent/specie_retrieve_params.rbi +116 -0
- data/rbi/phoebe/models/data/observations/recent/specie_retrieve_response.rbi +17 -0
- data/rbi/phoebe/models/data/observations/recent_list_params.rbi +192 -0
- data/rbi/phoebe/models/data/observations/recent_list_response.rbi +15 -0
- data/rbi/phoebe/models/product/checklist_view_params.rbi +32 -0
- data/rbi/phoebe/models/product/checklist_view_response.rbi +556 -0
- data/rbi/phoebe/models/product/list_retrieve_params.rbi +48 -0
- data/rbi/phoebe/models/product/list_retrieve_response.rbi +565 -0
- data/rbi/phoebe/models/product/lists/historical_retrieve_params.rbi +130 -0
- data/rbi/phoebe/models/product/lists/historical_retrieve_response.rbi +576 -0
- data/rbi/phoebe/models/product/species_list_list_params.rbi +32 -0
- data/rbi/phoebe/models/product/species_list_list_response.rbi +13 -0
- data/rbi/phoebe/models/product/stat_retrieve_params.rbi +53 -0
- data/rbi/phoebe/models/product/stat_retrieve_response.rbi +61 -0
- data/rbi/phoebe/models/product/top100_retrieve_params.rbi +122 -0
- data/rbi/phoebe/models/product/top100_retrieve_response.rbi +96 -0
- data/rbi/phoebe/models/ref/hotspot/geo_retrieve_params.rbi +127 -0
- data/rbi/phoebe/models/ref/hotspot/geo_retrieve_response.rbi +125 -0
- data/rbi/phoebe/models/ref/hotspot/info_retrieve_params.rbi +34 -0
- data/rbi/phoebe/models/ref/hotspot/info_retrieve_response.rbi +153 -0
- data/rbi/phoebe/models/ref/hotspot_list_params.rbi +81 -0
- data/rbi/phoebe/models/ref/hotspot_list_response.rbi +123 -0
- data/rbi/phoebe/models/ref/region/adjacent_list_params.rbi +34 -0
- data/rbi/phoebe/models/ref/region/adjacent_list_response.rbi +47 -0
- data/rbi/phoebe/models/ref/region/info_retrieve_params.rbi +132 -0
- data/rbi/phoebe/models/ref/region/info_retrieve_response.rbi +117 -0
- data/rbi/phoebe/models/ref/region/list_list_params.rbi +95 -0
- data/rbi/phoebe/models/ref/region/list_list_response.rbi +47 -0
- data/rbi/phoebe/models/ref/taxonomy/ebird_retrieve_params.rbi +139 -0
- data/rbi/phoebe/models/ref/taxonomy/ebird_retrieve_response.rbi +152 -0
- data/rbi/phoebe/models/ref/taxonomy/form_list_params.rbi +34 -0
- data/rbi/phoebe/models/ref/taxonomy/form_list_response.rbi +15 -0
- data/rbi/phoebe/models/ref/taxonomy/locale_list_params.rbi +48 -0
- data/rbi/phoebe/models/ref/taxonomy/locale_list_response.rbi +61 -0
- data/rbi/phoebe/models/ref/taxonomy/species_group_list_params.rbi +90 -0
- data/rbi/phoebe/models/ref/taxonomy/species_group_list_response.rbi +71 -0
- data/rbi/phoebe/models/ref/taxonomy/version_list_params.rbi +34 -0
- data/rbi/phoebe/models/ref/taxonomy/version_list_response.rbi +51 -0
- data/rbi/phoebe/models.rbi +9 -0
- data/rbi/phoebe/request_options.rbi +55 -0
- data/rbi/phoebe/resources/data/observations/geo/recent/notable.rbi +58 -0
- data/rbi/phoebe/resources/data/observations/geo/recent/species.rbi +70 -0
- data/rbi/phoebe/resources/data/observations/geo/recent.rbi +76 -0
- data/rbi/phoebe/resources/data/observations/geo.rbi +19 -0
- data/rbi/phoebe/resources/data/observations/nearest/geo_species.rbi +56 -0
- data/rbi/phoebe/resources/data/observations/nearest.rbi +21 -0
- data/rbi/phoebe/resources/data/observations/recent/historic.rbi +72 -0
- data/rbi/phoebe/resources/data/observations/recent/notable.rbi +54 -0
- data/rbi/phoebe/resources/data/observations/recent/species.rbi +63 -0
- data/rbi/phoebe/resources/data/observations/recent.rbi +68 -0
- data/rbi/phoebe/resources/data/observations.rbi +23 -0
- data/rbi/phoebe/resources/data.rbi +15 -0
- data/rbi/phoebe/resources/product/checklist.rbi +30 -0
- data/rbi/phoebe/resources/product/lists/historical.rbi +52 -0
- data/rbi/phoebe/resources/product/lists.rbi +34 -0
- data/rbi/phoebe/resources/product/species_list.rbi +32 -0
- data/rbi/phoebe/resources/product/stats.rbi +40 -0
- data/rbi/phoebe/resources/product/top100.rbi +63 -0
- data/rbi/phoebe/resources/product.rbi +27 -0
- data/rbi/phoebe/resources/ref/hotspot/geo.rbi +43 -0
- data/rbi/phoebe/resources/ref/hotspot/info.rbi +32 -0
- data/rbi/phoebe/resources/ref/hotspot.rbi +40 -0
- data/rbi/phoebe/resources/ref/region/adjacent.rbi +34 -0
- data/rbi/phoebe/resources/ref/region/info.rbi +51 -0
- data/rbi/phoebe/resources/ref/region/list.rbi +41 -0
- data/rbi/phoebe/resources/ref/region.rbi +23 -0
- data/rbi/phoebe/resources/ref/taxonomy/ebird.rbi +47 -0
- data/rbi/phoebe/resources/ref/taxonomy/forms.rbi +31 -0
- data/rbi/phoebe/resources/ref/taxonomy/locales.rbi +33 -0
- data/rbi/phoebe/resources/ref/taxonomy/species_groups.rbi +41 -0
- data/rbi/phoebe/resources/ref/taxonomy/versions.rbi +26 -0
- data/rbi/phoebe/resources/ref/taxonomy.rbi +29 -0
- data/rbi/phoebe/resources/ref.rbi +21 -0
- data/rbi/phoebe/version.rbi +5 -0
- data/sig/phoebe/client.rbs +30 -0
- data/sig/phoebe/errors.rbs +117 -0
- data/sig/phoebe/file_part.rbs +21 -0
- data/sig/phoebe/internal/transport/base_client.rbs +133 -0
- data/sig/phoebe/internal/transport/pooled_net_requester.rbs +48 -0
- data/sig/phoebe/internal/type/array_of.rbs +48 -0
- data/sig/phoebe/internal/type/base_model.rbs +102 -0
- data/sig/phoebe/internal/type/base_page.rbs +24 -0
- data/sig/phoebe/internal/type/boolean.rbs +26 -0
- data/sig/phoebe/internal/type/converter.rbs +79 -0
- data/sig/phoebe/internal/type/enum.rbs +32 -0
- data/sig/phoebe/internal/type/file_input.rbs +25 -0
- data/sig/phoebe/internal/type/hash_of.rbs +48 -0
- data/sig/phoebe/internal/type/request_parameters.rbs +17 -0
- data/sig/phoebe/internal/type/union.rbs +52 -0
- data/sig/phoebe/internal/type/unknown.rbs +26 -0
- data/sig/phoebe/internal/util.rbs +185 -0
- data/sig/phoebe/internal.rbs +9 -0
- data/sig/phoebe/models/data/observation.rbs +129 -0
- data/sig/phoebe/models/data/observations/geo/recent/notable_list_params.rbs +94 -0
- data/sig/phoebe/models/data/observations/geo/recent/notable_list_response.rbs +15 -0
- data/sig/phoebe/models/data/observations/geo/recent/specie_list_params.rbs +81 -0
- data/sig/phoebe/models/data/observations/geo/recent/specie_list_response.rbs +15 -0
- data/sig/phoebe/models/data/observations/geo/recent_list_params.rbs +133 -0
- data/sig/phoebe/models/data/observations/geo/recent_list_response.rbs +13 -0
- data/sig/phoebe/models/data/observations/nearest/geo_specie_list_params.rbs +79 -0
- data/sig/phoebe/models/data/observations/nearest/geo_specie_list_response.rbs +13 -0
- data/sig/phoebe/models/data/observations/recent/historic_list_params.rbs +151 -0
- data/sig/phoebe/models/data/observations/recent/historic_list_response.rbs +13 -0
- data/sig/phoebe/models/data/observations/recent/notable_list_params.rbs +82 -0
- data/sig/phoebe/models/data/observations/recent/notable_list_response.rbs +13 -0
- data/sig/phoebe/models/data/observations/recent/specie_retrieve_params.rbs +74 -0
- data/sig/phoebe/models/data/observations/recent/specie_retrieve_response.rbs +13 -0
- data/sig/phoebe/models/data/observations/recent_list_params.rbs +101 -0
- data/sig/phoebe/models/data/observations/recent_list_response.rbs +11 -0
- data/sig/phoebe/models/product/checklist_view_params.rbs +17 -0
- data/sig/phoebe/models/product/checklist_view_response.rbs +367 -0
- data/sig/phoebe/models/product/list_retrieve_params.rbs +27 -0
- data/sig/phoebe/models/product/list_retrieve_response.rbs +372 -0
- data/sig/phoebe/models/product/lists/historical_retrieve_params.rbs +67 -0
- data/sig/phoebe/models/product/lists/historical_retrieve_response.rbs +374 -0
- data/sig/phoebe/models/product/species_list_list_params.rbs +17 -0
- data/sig/phoebe/models/product/species_list_list_response.rbs +9 -0
- data/sig/phoebe/models/product/stat_retrieve_params.rbs +34 -0
- data/sig/phoebe/models/product/stat_retrieve_response.rbs +38 -0
- data/sig/phoebe/models/product/top100_retrieve_params.rbs +65 -0
- data/sig/phoebe/models/product/top100_retrieve_response.rbs +64 -0
- data/sig/phoebe/models/ref/hotspot/geo_retrieve_params.rbs +69 -0
- data/sig/phoebe/models/ref/hotspot/geo_retrieve_response.rbs +87 -0
- data/sig/phoebe/models/ref/hotspot/info_retrieve_params.rbs +19 -0
- data/sig/phoebe/models/ref/hotspot/info_retrieve_response.rbs +110 -0
- data/sig/phoebe/models/ref/hotspot_list_params.rbs +47 -0
- data/sig/phoebe/models/ref/hotspot_list_response.rbs +85 -0
- data/sig/phoebe/models/ref/region/adjacent_list_params.rbs +19 -0
- data/sig/phoebe/models/ref/region/adjacent_list_response.rbs +28 -0
- data/sig/phoebe/models/ref/region/info_retrieve_params.rbs +62 -0
- data/sig/phoebe/models/ref/region/info_retrieve_response.rbs +70 -0
- data/sig/phoebe/models/ref/region/list_list_params.rbs +50 -0
- data/sig/phoebe/models/ref/region/list_list_response.rbs +28 -0
- data/sig/phoebe/models/ref/taxonomy/ebird_retrieve_params.rbs +73 -0
- data/sig/phoebe/models/ref/taxonomy/ebird_retrieve_response.rbs +108 -0
- data/sig/phoebe/models/ref/taxonomy/form_list_params.rbs +19 -0
- data/sig/phoebe/models/ref/taxonomy/form_list_response.rbs +11 -0
- data/sig/phoebe/models/ref/taxonomy/locale_list_params.rbs +30 -0
- data/sig/phoebe/models/ref/taxonomy/locale_list_response.rbs +37 -0
- data/sig/phoebe/models/ref/taxonomy/species_group_list_params.rbs +41 -0
- data/sig/phoebe/models/ref/taxonomy/species_group_list_response.rbs +47 -0
- data/sig/phoebe/models/ref/taxonomy/version_list_params.rbs +19 -0
- data/sig/phoebe/models/ref/taxonomy/version_list_response.rbs +28 -0
- data/sig/phoebe/models.rbs +7 -0
- data/sig/phoebe/request_options.rbs +34 -0
- data/sig/phoebe/resources/data/observations/geo/recent/notable.rbs +27 -0
- data/sig/phoebe/resources/data/observations/geo/recent/species.rbs +28 -0
- data/sig/phoebe/resources/data/observations/geo/recent.rbs +31 -0
- data/sig/phoebe/resources/data/observations/geo.rbs +13 -0
- data/sig/phoebe/resources/data/observations/nearest/geo_species.rbs +26 -0
- data/sig/phoebe/resources/data/observations/nearest.rbs +13 -0
- data/sig/phoebe/resources/data/observations/recent/historic.rbs +29 -0
- data/sig/phoebe/resources/data/observations/recent/notable.rbs +24 -0
- data/sig/phoebe/resources/data/observations/recent/species.rbs +25 -0
- data/sig/phoebe/resources/data/observations/recent.rbs +29 -0
- data/sig/phoebe/resources/data/observations.rbs +15 -0
- data/sig/phoebe/resources/data.rbs +9 -0
- data/sig/phoebe/resources/product/checklist.rbs +14 -0
- data/sig/phoebe/resources/product/lists/historical.rbs +21 -0
- data/sig/phoebe/resources/product/lists.rbs +17 -0
- data/sig/phoebe/resources/product/species_list.rbs +14 -0
- data/sig/phoebe/resources/product/stats.rbs +17 -0
- data/sig/phoebe/resources/product/top100.rbs +19 -0
- data/sig/phoebe/resources/product.rbs +17 -0
- data/sig/phoebe/resources/ref/hotspot/geo.rbs +20 -0
- data/sig/phoebe/resources/ref/hotspot/info.rbs +16 -0
- data/sig/phoebe/resources/ref/hotspot.rbs +20 -0
- data/sig/phoebe/resources/ref/region/adjacent.rbs +16 -0
- data/sig/phoebe/resources/ref/region/info.rbs +18 -0
- data/sig/phoebe/resources/ref/region/list.rbs +18 -0
- data/sig/phoebe/resources/ref/region.rbs +15 -0
- data/sig/phoebe/resources/ref/taxonomy/ebird.rbs +20 -0
- data/sig/phoebe/resources/ref/taxonomy/forms.rbs +16 -0
- data/sig/phoebe/resources/ref/taxonomy/locales.rbs +16 -0
- data/sig/phoebe/resources/ref/taxonomy/species_groups.rbs +17 -0
- data/sig/phoebe/resources/ref/taxonomy/versions.rbs +15 -0
- data/sig/phoebe/resources/ref/taxonomy.rbs +19 -0
- data/sig/phoebe/resources/ref.rbs +13 -0
- data/sig/phoebe/version.rbs +3 -0
- metadata +380 -0
|
@@ -0,0 +1,531 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Phoebe
|
|
4
|
+
module Internal
|
|
5
|
+
module Type
|
|
6
|
+
# @abstract
|
|
7
|
+
class BaseModel
|
|
8
|
+
extend Phoebe::Internal::Type::Converter
|
|
9
|
+
extend Phoebe::Internal::Util::SorbetRuntimeSupport
|
|
10
|
+
|
|
11
|
+
class << self
|
|
12
|
+
# @api private
|
|
13
|
+
#
|
|
14
|
+
# Assumes superclass fields are totally defined before fields are accessed /
|
|
15
|
+
# defined on subclasses.
|
|
16
|
+
#
|
|
17
|
+
# @param child [Class<Phoebe::Internal::Type::BaseModel>]
|
|
18
|
+
def inherited(child)
|
|
19
|
+
super
|
|
20
|
+
child.known_fields.replace(known_fields.dup)
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
# @api private
|
|
24
|
+
#
|
|
25
|
+
# @return [Hash{Symbol=>Hash{Symbol=>Object}}]
|
|
26
|
+
def known_fields = @known_fields ||= {}
|
|
27
|
+
|
|
28
|
+
# @api private
|
|
29
|
+
#
|
|
30
|
+
# @return [Hash{Symbol=>Hash{Symbol=>Object}}]
|
|
31
|
+
def fields
|
|
32
|
+
known_fields.transform_values do |field|
|
|
33
|
+
{**field.except(:type_fn), type: field.fetch(:type_fn).call}
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
# @api private
|
|
38
|
+
#
|
|
39
|
+
# @param name_sym [Symbol]
|
|
40
|
+
#
|
|
41
|
+
# @param required [Boolean]
|
|
42
|
+
#
|
|
43
|
+
# @param type_info [Hash{Symbol=>Object}, Proc, Phoebe::Internal::Type::Converter, Class]
|
|
44
|
+
#
|
|
45
|
+
# @param spec [Hash{Symbol=>Object}] .
|
|
46
|
+
#
|
|
47
|
+
# @option spec [NilClass, TrueClass, FalseClass, Integer, Float, Symbol] :const
|
|
48
|
+
#
|
|
49
|
+
# @option spec [Proc] :enum
|
|
50
|
+
#
|
|
51
|
+
# @option spec [Proc] :union
|
|
52
|
+
#
|
|
53
|
+
# @option spec [Boolean] :"nil?"
|
|
54
|
+
private def add_field(name_sym, required:, type_info:, spec:)
|
|
55
|
+
meta = Phoebe::Internal::Type::Converter.meta_info(type_info, spec)
|
|
56
|
+
type_fn, info =
|
|
57
|
+
case type_info
|
|
58
|
+
in Proc | Phoebe::Internal::Type::Converter | Class
|
|
59
|
+
[Phoebe::Internal::Type::Converter.type_info({**spec, union: type_info}), spec]
|
|
60
|
+
in Hash
|
|
61
|
+
[Phoebe::Internal::Type::Converter.type_info(type_info), type_info]
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
setter = :"#{name_sym}="
|
|
65
|
+
api_name = info.fetch(:api_name, name_sym)
|
|
66
|
+
nilable = info.fetch(:nil?, false)
|
|
67
|
+
const = required && !nilable ? info.fetch(:const, Phoebe::Internal::OMIT) : Phoebe::Internal::OMIT
|
|
68
|
+
|
|
69
|
+
[name_sym, setter].each { undef_method(_1) } if known_fields.key?(name_sym)
|
|
70
|
+
|
|
71
|
+
known_fields[name_sym] =
|
|
72
|
+
{
|
|
73
|
+
mode: @mode,
|
|
74
|
+
api_name: api_name,
|
|
75
|
+
required: required,
|
|
76
|
+
nilable: nilable,
|
|
77
|
+
const: const,
|
|
78
|
+
type_fn: type_fn,
|
|
79
|
+
meta: meta
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
define_method(setter) do |value|
|
|
83
|
+
target = type_fn.call
|
|
84
|
+
state = Phoebe::Internal::Type::Converter.new_coerce_state(translate_names: false)
|
|
85
|
+
coerced = Phoebe::Internal::Type::Converter.coerce(target, value, state: state)
|
|
86
|
+
status = @coerced.store(name_sym, state.fetch(:error) || true)
|
|
87
|
+
stored =
|
|
88
|
+
case [target, status]
|
|
89
|
+
in [Phoebe::Internal::Type::Converter | Symbol, true]
|
|
90
|
+
coerced
|
|
91
|
+
else
|
|
92
|
+
value
|
|
93
|
+
end
|
|
94
|
+
@data.store(name_sym, stored)
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
# rubocop:disable Style/CaseEquality
|
|
98
|
+
# rubocop:disable Metrics/BlockLength
|
|
99
|
+
define_method(name_sym) do
|
|
100
|
+
target = type_fn.call
|
|
101
|
+
|
|
102
|
+
case @coerced[name_sym]
|
|
103
|
+
in true | false if Phoebe::Internal::Type::Converter === target
|
|
104
|
+
@data.fetch(name_sym)
|
|
105
|
+
in ::StandardError => e
|
|
106
|
+
raise Phoebe::Errors::ConversionError.new(
|
|
107
|
+
on: self.class,
|
|
108
|
+
method: __method__,
|
|
109
|
+
target: target,
|
|
110
|
+
value: @data.fetch(name_sym),
|
|
111
|
+
cause: e
|
|
112
|
+
)
|
|
113
|
+
else
|
|
114
|
+
Kernel.then do
|
|
115
|
+
value = @data.fetch(name_sym) { const == Phoebe::Internal::OMIT ? nil : const }
|
|
116
|
+
state = Phoebe::Internal::Type::Converter.new_coerce_state(translate_names: false)
|
|
117
|
+
if (nilable || !required) && value.nil?
|
|
118
|
+
nil
|
|
119
|
+
else
|
|
120
|
+
Phoebe::Internal::Type::Converter.coerce(
|
|
121
|
+
target, value, state: state
|
|
122
|
+
)
|
|
123
|
+
end
|
|
124
|
+
rescue StandardError => e
|
|
125
|
+
raise Phoebe::Errors::ConversionError.new(
|
|
126
|
+
on: self.class,
|
|
127
|
+
method: __method__,
|
|
128
|
+
target: target,
|
|
129
|
+
value: value,
|
|
130
|
+
cause: e
|
|
131
|
+
)
|
|
132
|
+
end
|
|
133
|
+
end
|
|
134
|
+
end
|
|
135
|
+
# rubocop:enable Metrics/BlockLength
|
|
136
|
+
# rubocop:enable Style/CaseEquality
|
|
137
|
+
end
|
|
138
|
+
|
|
139
|
+
# @api private
|
|
140
|
+
#
|
|
141
|
+
# @param name_sym [Symbol]
|
|
142
|
+
#
|
|
143
|
+
# @param type_info [Hash{Symbol=>Object}, Proc, Phoebe::Internal::Type::Converter, Class]
|
|
144
|
+
#
|
|
145
|
+
# @param spec [Hash{Symbol=>Object}] .
|
|
146
|
+
#
|
|
147
|
+
# @option spec [NilClass, TrueClass, FalseClass, Integer, Float, Symbol] :const
|
|
148
|
+
#
|
|
149
|
+
# @option spec [Proc] :enum
|
|
150
|
+
#
|
|
151
|
+
# @option spec [Proc] :union
|
|
152
|
+
#
|
|
153
|
+
# @option spec [Boolean] :"nil?"
|
|
154
|
+
def required(name_sym, type_info, spec = {})
|
|
155
|
+
add_field(name_sym, required: true, type_info: type_info, spec: spec)
|
|
156
|
+
end
|
|
157
|
+
|
|
158
|
+
# @api private
|
|
159
|
+
#
|
|
160
|
+
# @param name_sym [Symbol]
|
|
161
|
+
#
|
|
162
|
+
# @param type_info [Hash{Symbol=>Object}, Proc, Phoebe::Internal::Type::Converter, Class]
|
|
163
|
+
#
|
|
164
|
+
# @param spec [Hash{Symbol=>Object}] .
|
|
165
|
+
#
|
|
166
|
+
# @option spec [NilClass, TrueClass, FalseClass, Integer, Float, Symbol] :const
|
|
167
|
+
#
|
|
168
|
+
# @option spec [Proc] :enum
|
|
169
|
+
#
|
|
170
|
+
# @option spec [Proc] :union
|
|
171
|
+
#
|
|
172
|
+
# @option spec [Boolean] :"nil?"
|
|
173
|
+
def optional(name_sym, type_info, spec = {})
|
|
174
|
+
add_field(name_sym, required: false, type_info: type_info, spec: spec)
|
|
175
|
+
end
|
|
176
|
+
|
|
177
|
+
# @api private
|
|
178
|
+
#
|
|
179
|
+
# `request_only` attributes not excluded from `.#coerce` when receiving responses
|
|
180
|
+
# even if well behaved servers should not send them
|
|
181
|
+
#
|
|
182
|
+
# @param blk [Proc]
|
|
183
|
+
private def request_only(&blk)
|
|
184
|
+
@mode = :dump
|
|
185
|
+
blk.call
|
|
186
|
+
ensure
|
|
187
|
+
@mode = nil
|
|
188
|
+
end
|
|
189
|
+
|
|
190
|
+
# @api private
|
|
191
|
+
#
|
|
192
|
+
# `response_only` attributes are omitted from `.#dump` when making requests
|
|
193
|
+
#
|
|
194
|
+
# @param blk [Proc]
|
|
195
|
+
private def response_only(&blk)
|
|
196
|
+
@mode = :coerce
|
|
197
|
+
blk.call
|
|
198
|
+
ensure
|
|
199
|
+
@mode = nil
|
|
200
|
+
end
|
|
201
|
+
|
|
202
|
+
# @api public
|
|
203
|
+
#
|
|
204
|
+
# @param other [Object]
|
|
205
|
+
#
|
|
206
|
+
# @return [Boolean]
|
|
207
|
+
def ==(other)
|
|
208
|
+
other.is_a?(Class) && other <= Phoebe::Internal::Type::BaseModel && other.fields == fields
|
|
209
|
+
end
|
|
210
|
+
|
|
211
|
+
# @api public
|
|
212
|
+
#
|
|
213
|
+
# @return [Integer]
|
|
214
|
+
def hash = fields.hash
|
|
215
|
+
end
|
|
216
|
+
|
|
217
|
+
# @api public
|
|
218
|
+
#
|
|
219
|
+
# @param other [Object]
|
|
220
|
+
#
|
|
221
|
+
# @return [Boolean]
|
|
222
|
+
def ==(other) = self.class == other.class && @data == other.to_h
|
|
223
|
+
|
|
224
|
+
# @api public
|
|
225
|
+
#
|
|
226
|
+
# @return [Integer]
|
|
227
|
+
def hash = [self.class, @data].hash
|
|
228
|
+
|
|
229
|
+
class << self
|
|
230
|
+
# @api private
|
|
231
|
+
#
|
|
232
|
+
# @param value [Phoebe::Internal::Type::BaseModel, Hash{Object=>Object}, Object]
|
|
233
|
+
#
|
|
234
|
+
# @param state [Hash{Symbol=>Object}] .
|
|
235
|
+
#
|
|
236
|
+
# @option state [Boolean] :translate_names
|
|
237
|
+
#
|
|
238
|
+
# @option state [Boolean] :strictness
|
|
239
|
+
#
|
|
240
|
+
# @option state [Hash{Symbol=>Object}] :exactness
|
|
241
|
+
#
|
|
242
|
+
# @option state [Class<StandardError>] :error
|
|
243
|
+
#
|
|
244
|
+
# @option state [Integer] :branched
|
|
245
|
+
#
|
|
246
|
+
# @return [self, Object]
|
|
247
|
+
def coerce(value, state:)
|
|
248
|
+
exactness = state.fetch(:exactness)
|
|
249
|
+
|
|
250
|
+
if value.is_a?(self)
|
|
251
|
+
exactness[:yes] += 1
|
|
252
|
+
return value
|
|
253
|
+
end
|
|
254
|
+
|
|
255
|
+
unless (val = Phoebe::Internal::Util.coerce_hash(value)).is_a?(Hash)
|
|
256
|
+
exactness[:no] += 1
|
|
257
|
+
state[:error] = TypeError.new("#{value.class} can't be coerced into #{Hash}")
|
|
258
|
+
return value
|
|
259
|
+
end
|
|
260
|
+
exactness[:yes] += 1
|
|
261
|
+
|
|
262
|
+
keys = val.keys.to_set
|
|
263
|
+
instance = new
|
|
264
|
+
data = instance.to_h
|
|
265
|
+
status = instance.instance_variable_get(:@coerced)
|
|
266
|
+
|
|
267
|
+
# rubocop:disable Metrics/BlockLength
|
|
268
|
+
fields.each do |name, field|
|
|
269
|
+
mode, required, target = field.fetch_values(:mode, :required, :type)
|
|
270
|
+
api_name, nilable, const = field.fetch_values(:api_name, :nilable, :const)
|
|
271
|
+
src_name = state.fetch(:translate_names) ? api_name : name
|
|
272
|
+
|
|
273
|
+
unless val.key?(src_name)
|
|
274
|
+
if required && mode != :dump && const == Phoebe::Internal::OMIT
|
|
275
|
+
exactness[nilable ? :maybe : :no] += 1
|
|
276
|
+
else
|
|
277
|
+
exactness[:yes] += 1
|
|
278
|
+
end
|
|
279
|
+
next
|
|
280
|
+
end
|
|
281
|
+
|
|
282
|
+
item = val.fetch(src_name)
|
|
283
|
+
keys.delete(src_name)
|
|
284
|
+
|
|
285
|
+
state[:error] = nil
|
|
286
|
+
converted =
|
|
287
|
+
if item.nil? && (nilable || !required)
|
|
288
|
+
exactness[nilable ? :yes : :maybe] += 1
|
|
289
|
+
nil
|
|
290
|
+
else
|
|
291
|
+
coerced = Phoebe::Internal::Type::Converter.coerce(target, item, state: state)
|
|
292
|
+
case target
|
|
293
|
+
in Phoebe::Internal::Type::Converter | Symbol
|
|
294
|
+
coerced
|
|
295
|
+
else
|
|
296
|
+
item
|
|
297
|
+
end
|
|
298
|
+
end
|
|
299
|
+
|
|
300
|
+
status.store(name, state.fetch(:error) || true)
|
|
301
|
+
data.store(name, converted)
|
|
302
|
+
end
|
|
303
|
+
# rubocop:enable Metrics/BlockLength
|
|
304
|
+
|
|
305
|
+
keys.each { data.store(_1, val.fetch(_1)) }
|
|
306
|
+
instance
|
|
307
|
+
end
|
|
308
|
+
|
|
309
|
+
# @api private
|
|
310
|
+
#
|
|
311
|
+
# @param value [self, Object]
|
|
312
|
+
#
|
|
313
|
+
# @param state [Hash{Symbol=>Object}] .
|
|
314
|
+
#
|
|
315
|
+
# @option state [Boolean] :can_retry
|
|
316
|
+
#
|
|
317
|
+
# @return [Hash{Object=>Object}, Object]
|
|
318
|
+
def dump(value, state:)
|
|
319
|
+
unless (coerced = Phoebe::Internal::Util.coerce_hash(value)).is_a?(Hash)
|
|
320
|
+
return super
|
|
321
|
+
end
|
|
322
|
+
|
|
323
|
+
acc = {}
|
|
324
|
+
|
|
325
|
+
coerced.each do |key, val|
|
|
326
|
+
name = key.is_a?(String) ? key.to_sym : key
|
|
327
|
+
case (field = known_fields[name])
|
|
328
|
+
in nil
|
|
329
|
+
acc.store(name, super(val, state: state))
|
|
330
|
+
else
|
|
331
|
+
api_name, mode, type_fn = field.fetch_values(:api_name, :mode, :type_fn)
|
|
332
|
+
case mode
|
|
333
|
+
in :coerce
|
|
334
|
+
next
|
|
335
|
+
else
|
|
336
|
+
target = type_fn.call
|
|
337
|
+
acc.store(api_name, Phoebe::Internal::Type::Converter.dump(target, val, state: state))
|
|
338
|
+
end
|
|
339
|
+
end
|
|
340
|
+
end
|
|
341
|
+
|
|
342
|
+
known_fields.each_value do |field|
|
|
343
|
+
api_name, mode, const = field.fetch_values(:api_name, :mode, :const)
|
|
344
|
+
next if mode == :coerce || acc.key?(api_name) || const == Phoebe::Internal::OMIT
|
|
345
|
+
acc.store(api_name, const)
|
|
346
|
+
end
|
|
347
|
+
|
|
348
|
+
acc
|
|
349
|
+
end
|
|
350
|
+
|
|
351
|
+
# @api private
|
|
352
|
+
#
|
|
353
|
+
# @return [Object]
|
|
354
|
+
def to_sorbet_type
|
|
355
|
+
self
|
|
356
|
+
end
|
|
357
|
+
end
|
|
358
|
+
|
|
359
|
+
class << self
|
|
360
|
+
# @api private
|
|
361
|
+
#
|
|
362
|
+
# @param model [Phoebe::Internal::Type::BaseModel]
|
|
363
|
+
# @param convert [Boolean]
|
|
364
|
+
#
|
|
365
|
+
# @return [Hash{Symbol=>Object}]
|
|
366
|
+
def recursively_to_h(model, convert:)
|
|
367
|
+
rec = ->(x) do
|
|
368
|
+
case x
|
|
369
|
+
in Phoebe::Internal::Type::BaseModel
|
|
370
|
+
if convert
|
|
371
|
+
fields = x.class.known_fields
|
|
372
|
+
x.to_h.to_h do |key, val|
|
|
373
|
+
[key, rec.call(fields.key?(key) ? x.public_send(key) : val)]
|
|
374
|
+
rescue Phoebe::Errors::ConversionError
|
|
375
|
+
[key, rec.call(val)]
|
|
376
|
+
end
|
|
377
|
+
else
|
|
378
|
+
rec.call(x.to_h)
|
|
379
|
+
end
|
|
380
|
+
in Hash
|
|
381
|
+
x.transform_values(&rec)
|
|
382
|
+
in Array
|
|
383
|
+
x.map(&rec)
|
|
384
|
+
else
|
|
385
|
+
x
|
|
386
|
+
end
|
|
387
|
+
end
|
|
388
|
+
rec.call(model)
|
|
389
|
+
end
|
|
390
|
+
end
|
|
391
|
+
|
|
392
|
+
# @api public
|
|
393
|
+
#
|
|
394
|
+
# Returns the raw value associated with the given key, if found. Otherwise, nil is
|
|
395
|
+
# returned.
|
|
396
|
+
#
|
|
397
|
+
# It is valid to lookup keys that are not in the API spec, for example to access
|
|
398
|
+
# undocumented features. This method does not parse response data into
|
|
399
|
+
# higher-level types. Lookup by anything other than a Symbol is an ArgumentError.
|
|
400
|
+
#
|
|
401
|
+
# @param key [Symbol]
|
|
402
|
+
#
|
|
403
|
+
# @return [Object, nil]
|
|
404
|
+
def [](key)
|
|
405
|
+
unless key.instance_of?(Symbol)
|
|
406
|
+
raise ArgumentError.new("Expected symbol key for lookup, got #{key.inspect}")
|
|
407
|
+
end
|
|
408
|
+
|
|
409
|
+
@data[key]
|
|
410
|
+
end
|
|
411
|
+
|
|
412
|
+
# @api public
|
|
413
|
+
#
|
|
414
|
+
# Returns a Hash of the data underlying this object. O(1)
|
|
415
|
+
#
|
|
416
|
+
# Keys are Symbols and values are the raw values from the response. The return
|
|
417
|
+
# value indicates which values were ever set on the object. i.e. there will be a
|
|
418
|
+
# key in this hash if they ever were, even if the set value was nil.
|
|
419
|
+
#
|
|
420
|
+
# This method is not recursive. The returned value is shared by the object, so it
|
|
421
|
+
# should not be mutated.
|
|
422
|
+
#
|
|
423
|
+
# @return [Hash{Symbol=>Object}]
|
|
424
|
+
def to_h = @data
|
|
425
|
+
|
|
426
|
+
alias_method :to_hash, :to_h
|
|
427
|
+
|
|
428
|
+
# @api public
|
|
429
|
+
#
|
|
430
|
+
# In addition to the behaviour of `#to_h`, this method will recursively call
|
|
431
|
+
# `#to_h` on nested models.
|
|
432
|
+
#
|
|
433
|
+
# @return [Hash{Symbol=>Object}]
|
|
434
|
+
def deep_to_h = self.class.recursively_to_h(@data, convert: false)
|
|
435
|
+
|
|
436
|
+
# @param keys [Array<Symbol>, nil]
|
|
437
|
+
#
|
|
438
|
+
# @return [Hash{Symbol=>Object}]
|
|
439
|
+
#
|
|
440
|
+
# @example
|
|
441
|
+
# # `observation` is a `Phoebe::Data::Observation`
|
|
442
|
+
# observation => {
|
|
443
|
+
# id: id,
|
|
444
|
+
# com_name: com_name,
|
|
445
|
+
# firstname: firstname
|
|
446
|
+
# }
|
|
447
|
+
def deconstruct_keys(keys)
|
|
448
|
+
(keys || self.class.known_fields.keys)
|
|
449
|
+
.filter_map do |k|
|
|
450
|
+
unless self.class.known_fields.key?(k)
|
|
451
|
+
next
|
|
452
|
+
end
|
|
453
|
+
|
|
454
|
+
[k, public_send(k)]
|
|
455
|
+
end
|
|
456
|
+
.to_h
|
|
457
|
+
end
|
|
458
|
+
|
|
459
|
+
# @api public
|
|
460
|
+
#
|
|
461
|
+
# @param a [Object]
|
|
462
|
+
#
|
|
463
|
+
# @return [String]
|
|
464
|
+
def to_json(*a) = Phoebe::Internal::Type::Converter.dump(self.class, self).to_json(*a)
|
|
465
|
+
|
|
466
|
+
# @api public
|
|
467
|
+
#
|
|
468
|
+
# @param a [Object]
|
|
469
|
+
#
|
|
470
|
+
# @return [String]
|
|
471
|
+
def to_yaml(*a) = Phoebe::Internal::Type::Converter.dump(self.class, self).to_yaml(*a)
|
|
472
|
+
|
|
473
|
+
# Create a new instance of a model.
|
|
474
|
+
#
|
|
475
|
+
# @param data [Hash{Symbol=>Object}, self]
|
|
476
|
+
def initialize(data = {})
|
|
477
|
+
@data = {}
|
|
478
|
+
@coerced = {}
|
|
479
|
+
Phoebe::Internal::Util.coerce_hash!(data).each do
|
|
480
|
+
if self.class.known_fields.key?(_1)
|
|
481
|
+
public_send(:"#{_1}=", _2)
|
|
482
|
+
else
|
|
483
|
+
@data.store(_1, _2)
|
|
484
|
+
@coerced.store(_1, false)
|
|
485
|
+
end
|
|
486
|
+
end
|
|
487
|
+
end
|
|
488
|
+
|
|
489
|
+
class << self
|
|
490
|
+
# @api private
|
|
491
|
+
#
|
|
492
|
+
# @param depth [Integer]
|
|
493
|
+
#
|
|
494
|
+
# @return [String]
|
|
495
|
+
def inspect(depth: 0)
|
|
496
|
+
return super() if depth.positive?
|
|
497
|
+
|
|
498
|
+
depth = depth.succ
|
|
499
|
+
deferred = fields.transform_values do |field|
|
|
500
|
+
type, required, nilable = field.fetch_values(:type, :required, :nilable)
|
|
501
|
+
inspected = [
|
|
502
|
+
Phoebe::Internal::Type::Converter.inspect(type, depth: depth),
|
|
503
|
+
!required || nilable ? "nil" : nil
|
|
504
|
+
].compact.join(" | ")
|
|
505
|
+
-> { inspected }.tap { _1.define_singleton_method(:inspect) { call } }
|
|
506
|
+
end
|
|
507
|
+
|
|
508
|
+
"#{name}[#{deferred.inspect}]"
|
|
509
|
+
end
|
|
510
|
+
end
|
|
511
|
+
|
|
512
|
+
# @api public
|
|
513
|
+
#
|
|
514
|
+
# @return [String]
|
|
515
|
+
def to_s = deep_to_h.to_s
|
|
516
|
+
|
|
517
|
+
# @api private
|
|
518
|
+
#
|
|
519
|
+
# @return [String]
|
|
520
|
+
def inspect
|
|
521
|
+
converted = self.class.recursively_to_h(self, convert: true)
|
|
522
|
+
"#<#{self.class}:0x#{object_id.to_s(16)} #{converted}>"
|
|
523
|
+
end
|
|
524
|
+
|
|
525
|
+
define_sorbet_constant!(:KnownField) do
|
|
526
|
+
T.type_alias { {mode: T.nilable(Symbol), required: T::Boolean, nilable: T::Boolean} }
|
|
527
|
+
end
|
|
528
|
+
end
|
|
529
|
+
end
|
|
530
|
+
end
|
|
531
|
+
end
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Phoebe
|
|
4
|
+
module Internal
|
|
5
|
+
module Type
|
|
6
|
+
# @api private
|
|
7
|
+
#
|
|
8
|
+
# @generic Elem
|
|
9
|
+
#
|
|
10
|
+
# This module provides a base implementation for paginated responses in the SDK.
|
|
11
|
+
module BasePage
|
|
12
|
+
# rubocop:disable Lint/UnusedMethodArgument
|
|
13
|
+
|
|
14
|
+
# @api public
|
|
15
|
+
#
|
|
16
|
+
# @return [Boolean]
|
|
17
|
+
def next_page? = (raise NotImplementedError)
|
|
18
|
+
|
|
19
|
+
# @api public
|
|
20
|
+
#
|
|
21
|
+
# @raise [Phoebe::Errors::APIError]
|
|
22
|
+
# @return [self]
|
|
23
|
+
def next_page = (raise NotImplementedError)
|
|
24
|
+
|
|
25
|
+
# @api public
|
|
26
|
+
#
|
|
27
|
+
# @param blk [Proc]
|
|
28
|
+
#
|
|
29
|
+
# @yieldparam [generic<Elem>]
|
|
30
|
+
# @return [void]
|
|
31
|
+
def auto_paging_each(&blk) = (raise NotImplementedError)
|
|
32
|
+
|
|
33
|
+
# @return [Enumerable<generic<Elem>>]
|
|
34
|
+
def to_enum = super(:auto_paging_each)
|
|
35
|
+
|
|
36
|
+
alias_method :enum_for, :to_enum
|
|
37
|
+
|
|
38
|
+
# @api private
|
|
39
|
+
#
|
|
40
|
+
# @param client [Phoebe::Internal::Transport::BaseClient]
|
|
41
|
+
# @param req [Hash{Symbol=>Object}]
|
|
42
|
+
# @param headers [Hash{String=>String}]
|
|
43
|
+
# @param page_data [Object]
|
|
44
|
+
def initialize(client:, req:, headers:, page_data:)
|
|
45
|
+
@client = client
|
|
46
|
+
@req = req
|
|
47
|
+
@model = req.fetch(:model)
|
|
48
|
+
super()
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
# rubocop:enable Lint/UnusedMethodArgument
|
|
52
|
+
end
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
end
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Phoebe
|
|
4
|
+
module Internal
|
|
5
|
+
module Type
|
|
6
|
+
# @api private
|
|
7
|
+
#
|
|
8
|
+
# @abstract
|
|
9
|
+
#
|
|
10
|
+
# Ruby has no Boolean class; this is something for models to refer to.
|
|
11
|
+
class Boolean
|
|
12
|
+
extend Phoebe::Internal::Type::Converter
|
|
13
|
+
extend Phoebe::Internal::Util::SorbetRuntimeSupport
|
|
14
|
+
|
|
15
|
+
private_class_method :new
|
|
16
|
+
|
|
17
|
+
# @api public
|
|
18
|
+
#
|
|
19
|
+
# @param other [Object]
|
|
20
|
+
#
|
|
21
|
+
# @return [Boolean]
|
|
22
|
+
def self.===(other) = other == true || other == false
|
|
23
|
+
|
|
24
|
+
# @api public
|
|
25
|
+
#
|
|
26
|
+
# @param other [Object]
|
|
27
|
+
#
|
|
28
|
+
# @return [Boolean]
|
|
29
|
+
def self.==(other) = other.is_a?(Class) && other <= Phoebe::Internal::Type::Boolean
|
|
30
|
+
|
|
31
|
+
class << self
|
|
32
|
+
# @api private
|
|
33
|
+
#
|
|
34
|
+
# Coerce value to Boolean if possible, otherwise return the original value.
|
|
35
|
+
#
|
|
36
|
+
# @param value [Boolean, Object]
|
|
37
|
+
#
|
|
38
|
+
# @param state [Hash{Symbol=>Object}] .
|
|
39
|
+
#
|
|
40
|
+
# @option state [Boolean] :translate_names
|
|
41
|
+
#
|
|
42
|
+
# @option state [Boolean] :strictness
|
|
43
|
+
#
|
|
44
|
+
# @option state [Hash{Symbol=>Object}] :exactness
|
|
45
|
+
#
|
|
46
|
+
# @option state [Class<StandardError>] :error
|
|
47
|
+
#
|
|
48
|
+
# @option state [Integer] :branched
|
|
49
|
+
#
|
|
50
|
+
# @return [Boolean, Object]
|
|
51
|
+
def coerce(value, state:)
|
|
52
|
+
state.fetch(:exactness)[value == true || value == false ? :yes : :no] += 1
|
|
53
|
+
value
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
# @!method dump(value, state:)
|
|
57
|
+
# @api private
|
|
58
|
+
#
|
|
59
|
+
# @param value [Boolean, Object]
|
|
60
|
+
#
|
|
61
|
+
# @param state [Hash{Symbol=>Object}] .
|
|
62
|
+
#
|
|
63
|
+
# @option state [Boolean] :can_retry
|
|
64
|
+
#
|
|
65
|
+
# @return [Boolean, Object]
|
|
66
|
+
|
|
67
|
+
# @api private
|
|
68
|
+
#
|
|
69
|
+
# @return [Object]
|
|
70
|
+
def to_sorbet_type
|
|
71
|
+
T::Boolean
|
|
72
|
+
end
|
|
73
|
+
end
|
|
74
|
+
end
|
|
75
|
+
end
|
|
76
|
+
end
|
|
77
|
+
end
|