# Changelog All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ## 6.0.4 (2024-05-29) Various fixes - please see the commit-details. ### Commit Statistics - 8 commits contributed to the release over the course of 36 calendar days. - 78 days passed between releases. - 0 commits were understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Prepare changelog of `google-apis-common` ([`1c42538`](https://github.com/Byron/google-apis-rs/commit/1c42538333d6fd0cec554c977d9894080829c808)) - Merge pull request #493 from serprex/base64v22 ([`ce47a46`](https://github.com/Byron/google-apis-rs/commit/ce47a46ca4e80dfbb2ead94037169bc5257c306e)) - 6.0.4 ([`4b23b5a`](https://github.com/Byron/google-apis-rs/commit/4b23b5a0c6b267f0fc1213b2c401bd156abfdb1e)) - Base64 0.22, serde_with 3, url 2 ([`0fca3a9`](https://github.com/Byron/google-apis-rs/commit/0fca3a944a27a548a8d21508bfb67ba7828ab94f)) - Merge pull request #491 from IvanUkhov/oauth2 ([`6f44ce8`](https://github.com/Byron/google-apis-rs/commit/6f44ce870262de0536879d1fb93f66faa78da95c)) - Update yup-oauth2 to version 9 ([`8d47fd5`](https://github.com/Byron/google-apis-rs/commit/8d47fd501085f07cbf99419b527968a612657fc2)) - Merge pull request #490 from IvanUkhov/oauth2 ([`764857a`](https://github.com/Byron/google-apis-rs/commit/764857a3cf3092f599cc97a773a69e8f6fb87cb0)) - Update yup-oauth2 in google-apis-common ([`ba52472`](https://github.com/Byron/google-apis-rs/commit/ba52472c9f83f89651f735ac0781c45214ee13ae))
## 6.0.3 (2024-03-11) ### Bug Fixes - update `chrono` dependency version It now requires a minimal version that introduced `try_seconds()`, which is now being used instead of `seconds()`. ### Commit Statistics - 3 commits contributed to the release. - 1 commit was understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v6.0.3 ([`b117649`](https://github.com/Byron/google-apis-rs/commit/b1176493d6d1b08362def61f4b686387c73817ad)) - Release google-apis-common v6.0.2 ([`5c047b7`](https://github.com/Byron/google-apis-rs/commit/5c047b7e9132269494fcc96b090925cf6d32678c)) - Update `chrono` dependency version ([`fa7f7b1`](https://github.com/Byron/google-apis-rs/commit/fa7f7b13fb07aa64be95a1d6fc42906f4d14a13c))
## 6.0.2 (2024-03-11) Fix deprecation warnings in latest version of the `chrono` crate. ### Bug Fixes - update `chrono` dependency version It now requires a minimal version that introduced `try_seconds()`, which is now being used instead of `seconds()`. ### Commit Statistics - 11 commits contributed to the release over the course of 65 calendar days. - 65 days passed between releases. - 0 commits were understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v6.0.2 ([`b5c33a9`](https://github.com/Byron/google-apis-rs/commit/b5c33a9dce79e65e3ddca825fc468870350fcc40)) - Prepare changelog prior to release of google-apis-common ([`7ecead7`](https://github.com/Byron/google-apis-rs/commit/7ecead753cddcd890626e465f95d7fc9dee594db)) - Merge branch 'docker' ([`292a86e`](https://github.com/Byron/google-apis-rs/commit/292a86ee5a44a41533bbc3cde66c8739766b46a5)) - Fix lints by avoiding deprecated methods with latest chrono ([`36f78cd`](https://github.com/Byron/google-apis-rs/commit/36f78cdebfa1c9dc8ac7b58ceb1f3f889a14b20c)) - Merge pull request #471 from ytanay/fix-base64-deserialization-borrowed ([`b74056b`](https://github.com/Byron/google-apis-rs/commit/b74056b4b7e4e573e83e0fa2237b622be9655195)) - Use Cow for reading base64 strings ([`a8d7356`](https://github.com/Byron/google-apis-rs/commit/a8d735628215d13d736447e919d0bd57767135c5)) - Add failing test case for reading base64 string via reader ([`f990fd0`](https://github.com/Byron/google-apis-rs/commit/f990fd0589bb7f5d904c4ef613cd004c4883bcc1)) - Merge pull request #465 from andrewbaxter/field-mask-pub-value ([`00a3e18`](https://github.com/Byron/google-apis-rs/commit/00a3e18145c9163a314253a62a4d28d5606c2944)) - Add docstring ([`d09893e`](https://github.com/Byron/google-apis-rs/commit/d09893e9212be1f346f6fe8ca61d39ff6c8b8232)) - Add FieldMask new method instead of making internals public ([`157b45f`](https://github.com/Byron/google-apis-rs/commit/157b45f6064b9d2c95c2b7057c60875312530103)) - Make field mask inner public ([`1ee4014`](https://github.com/Byron/google-apis-rs/commit/1ee401408c6c5ec78b229f9cea556dbb583d296b))
## 6.0.1 (2024-01-05) Added another encoding/decoding wrapper for base64. ### Commit Statistics - 4 commits contributed to the release over the course of 100 calendar days. - 135 days passed between releases. - 0 commits were understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v6.0.1 ([`5a190c7`](https://github.com/Byron/google-apis-rs/commit/5a190c7e20cd8f4160e88d91d3c5c375a6f2bf94)) - Prepare changelog prior to google-apis-common release. ([`3e0829c`](https://github.com/Byron/google-apis-rs/commit/3e0829caf73a3bb2f7430bb2fc8109d43d5b61d9)) - Merge pull request #464 from andrewbaxter/standard-base64 ([`23aecc3`](https://github.com/Byron/google-apis-rs/commit/23aecc38e8b03ab3d50641e5581aca63dde76cb3)) - Attempt to add 'standard' base64 bytes support ([`ee4ed07`](https://github.com/Byron/google-apis-rs/commit/ee4ed07af102f7ae5f685b78327737b233a4023e))
## 6.0.0 (2023-08-23) A maintenance release with updated yup-oauth2 dependency ### Commit Statistics - 3 commits contributed to the release over the course of 126 calendar days. - 126 days passed between releases. - 0 commits were understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v6.0.0 ([`573d543`](https://github.com/Byron/google-apis-rs/commit/573d5437a379c19b9c13be1f8b1251ad135a2e9e)) - Update changelog prior to common crate releases ([`0cf81f1`](https://github.com/Byron/google-apis-rs/commit/0cf81f1df4fa79b8eaffdb56d892d392dc580812)) - Bump yup-oauth2 to the latest version, bringing in `hyper-rustls` v0.24. ([`58189b3`](https://github.com/Byron/google-apis-rs/commit/58189b31498fb324175721ab5bb46e8e12379636))
## 5.0.4 (2023-04-19) ### Bug Fixes - pin `yup-oauth2` to the latest known working version of yup-oauth2. It comes with hyper-rustls 0.23 which the currently released batch of google crates requires. ### Commit Statistics - 2 commits contributed to the release. - 1 commit was understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v5.0.4 ([`343b479`](https://github.com/Byron/google-apis-rs/commit/343b4792088e3eaa4562050ee5a7c56f9ed26268)) - Pin `yup-oauth2` to the latest known working version of yup-oauth2. ([`f5b37c3`](https://github.com/Byron/google-apis-rs/commit/f5b37c3f71989c25bff9d7954ede21c3455e56cb))
## 5.0.3 (2023-04-19) ### Bug Fixes - update `hyper-rustls` to latest version for compatibility with latest `yup-oauth2`. This works with `yup-oauth2` v8.2. Please let me know if it breaks again and we can keep following it with patch releases. ### Commit Statistics - 5 commits contributed to the release over the course of 55 calendar days. - 136 days passed between releases. - 1 commit was understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v5.0.3 ([`843f3dc`](https://github.com/Byron/google-apis-rs/commit/843f3dcf1f1fae352613d9a256f11e58e535498c)) - Update `hyper-rustls` to latest version for compatibility with latest `yup-oauth2`. ([`0be367a`](https://github.com/Byron/google-apis-rs/commit/0be367a4c116959ba9391679b0859d0b8985b7cc)) - Chore: update google-apis-common Cargo.toml ([`d9ce1ea`](https://github.com/Byron/google-apis-rs/commit/d9ce1eaf969d27a63c8d43aeabfebde54273733e)) - Replace a few unwraps() with `?` where possible ([`6e0caa3`](https://github.com/Byron/google-apis-rs/commit/6e0caa3b220df3939d0b2cd2b4789219f9e8fcfd)) - Fix clippy ([`ad51cb9`](https://github.com/Byron/google-apis-rs/commit/ad51cb96a5bbc72df38b3202b7a69aeed42bcb88))
## 5.0.2 (2022-12-03) ### Bug Fixes - remove old time dependency from API. Chrono currently depends on an old version of time with a reported vulnerability: https://rustsec.org/advisories/RUSTSEC-2020-0159 While it does not use any vulnerable code, the dependency may show up in code vulnerability scans, etc. This removes the "oldtime" feature from chrono, to remove that. Also removes the "std" feature because it doesn't seem to be in use in this code. ### Commit Statistics - 5 commits contributed to the release over the course of 3 calendar days. - 44 days passed between releases. - 1 commit was understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v5.0.2 ([`ce4d51f`](https://github.com/Byron/google-apis-rs/commit/ce4d51fb99cc957f58b9effce00072851497d1a9)) - Remove old time dependency from API. ([`a657448`](https://github.com/Byron/google-apis-rs/commit/a6574486ba7cae72951f9d8c2c555b38d7279306)) - Remove old time dependency from API. ([`80ba514`](https://github.com/Byron/google-apis-rs/commit/80ba5140331fecd75dc46debded09166aca812c4)) - Merge branch 'update_yup_oauth' ([`5f601f8`](https://github.com/Byron/google-apis-rs/commit/5f601f89074d9f944aa1bc0db26ae14a0808d265)) - Update yup-oauth2 to 8.0.0. ([`c6039c0`](https://github.com/Byron/google-apis-rs/commit/c6039c085db68835757bc5c9c09000ef5b18164a))
## 5.0.1 (2022-10-20) ### Documentation - min 1 try + retries in example ### Commit Statistics - 20 commits contributed to the release over the course of 2 calendar days. - 10 days passed between releases. - 1 commit was understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v5.0.1 ([`ca8ad69`](https://github.com/Byron/google-apis-rs/commit/ca8ad69d91f189355a6303730ac464501c945112)) - Merge branch 'refactor' ([`d202c95`](https://github.com/Byron/google-apis-rs/commit/d202c95aa4b6ed4c159b4b3e2f754bf176234f5c)) - Cargo fmt ([`4bdd77a`](https://github.com/Byron/google-apis-rs/commit/4bdd77a52ffa57c6cf6649f7973f5f1eee9e9d6e)) - Impl std::fmt::Display for FieldMask ([`9285942`](https://github.com/Byron/google-apis-rs/commit/9285942f3d06039f85be8d60a19fcff12e5efdf2)) - Cargo clippy --fix google-clis-common ([`f4317a2`](https://github.com/Byron/google-apis-rs/commit/f4317a2968238eb0837bb88e65de4cee387d500f)) - Apply cargo clippy --fix ([`4cca633`](https://github.com/Byron/google-apis-rs/commit/4cca633f9236dc3cc1a799f562931c9f12026c9f)) - Add FromStr impl for FieldMask ([`63793b5`](https://github.com/Byron/google-apis-rs/commit/63793b55a69a30aea17d87b29ab8b19d6d43ebdd)) - Refactor Params into external struct ([`0ad3b12`](https://github.com/Byron/google-apis-rs/commit/0ad3b1258f55318cbfa9c4fc121291471cb65dca)) - Add UploadProtocol enum to remove string types ([`cfa6958`](https://github.com/Byron/google-apis-rs/commit/cfa6958aa09b2e7ae9ad7da551abc011f38ccd79)) - Merge pull request #384 from philippeitis/update-mime ([`b20e630`](https://github.com/Byron/google-apis-rs/commit/b20e63072317775e239b2400099ce1705f1c076c)) - Make MultiPartReader::mime_type associated fn ([`f6b195d`](https://github.com/Byron/google-apis-rs/commit/f6b195df4f52bc13f711cadb236cba56890080ff)) - Update mime ([`616b324`](https://github.com/Byron/google-apis-rs/commit/616b324a7796173534f97302fcdae6bae0381ad2)) - Merge branch 'auth-refactor' ([`fb884e1`](https://github.com/Byron/google-apis-rs/commit/fb884e193a191a671602562ae8d82cd9fb6026ac)) - Update documentation ([`7a114a6`](https://github.com/Byron/google-apis-rs/commit/7a114a6d1c8808abff3fc2dc9817d4ca89222450)) - Min 1 try + retries in example ([`4d30072`](https://github.com/Byron/google-apis-rs/commit/4d30072c9152d105034eb121a89c79410933cc92)) - Use Result, _> ([`a375b71`](https://github.com/Byron/google-apis-rs/commit/a375b710b1debaef08583bfc3160c120076d0ebe)) - More correct GetToken docs ([`1132b54`](https://github.com/Byron/google-apis-rs/commit/1132b542d2590e0bccf588691d95e47148bc059d)) - Make yup-oauth2 optional ([`7ca7f1c`](https://github.com/Byron/google-apis-rs/commit/7ca7f1cafda0292e888e8faff296ab1c3c4400bb)) - Document auth.rs ([`50dd53a`](https://github.com/Byron/google-apis-rs/commit/50dd53a87716547ae6bf829e1baef5500b218cef)) - Return Option from GetToken::get_token instead of Result<...> ([`32110d6`](https://github.com/Byron/google-apis-rs/commit/32110d6970ae9c16d6889fc5c1fe65556fa3d469))
## 5.0.0 (2022-10-10) ### New Features - apis-common for the 5.0 line of google crates. It aids with better type decoding support. ### Commit Statistics - 18 commits contributed to the release over the course of 2 calendar days. - 8 days passed between releases. - 1 commit was understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v5.0.0 ([`1855e44`](https://github.com/Byron/google-apis-rs/commit/1855e44a9509f47ada83c49e0b1262fbb4e1eace)) - Apis-common for the 5.0 line of google crates. ([`3625188`](https://github.com/Byron/google-apis-rs/commit/3625188eb5dac9f6dfe8e672a65e75dcb0810081)) - Merge branch 'format_types' ([`ed5dab2`](https://github.com/Byron/google-apis-rs/commit/ed5dab2dbd1aa8d126b1253e8020bcf964f0ee34)) - Use correct string impls for http headers ([`1c04f66`](https://github.com/Byron/google-apis-rs/commit/1c04f662d17fd131c9342bb4ccccb728e03b9376)) - Support serde for arbitrary field types ([`f6cced9`](https://github.com/Byron/google-apis-rs/commit/f6cced960594d680c2335c5740c331b99e46bdcc)) - Fix cargo check w.r.t. FieldMask ([`8cc2707`](https://github.com/Byron/google-apis-rs/commit/8cc27075638e005448defd31fbf8ec3e445dd7b0)) - Add #[serde(default)] for Option parsing ([`ddac761`](https://github.com/Byron/google-apis-rs/commit/ddac761e06dd2bd6c544bfafc8f058871aa3ec04)) - Add base64 round trip test ([`8809ec4`](https://github.com/Byron/google-apis-rs/commit/8809ec4807385e2c90fa2093885e67567f21a94f)) - Add FieldMask and serde impl ([`afb96bd`](https://github.com/Byron/google-apis-rs/commit/afb96bd264c91372b9900360d9d060ea38c7a31e)) - Add serde test cases ([`928c602`](https://github.com/Byron/google-apis-rs/commit/928c6027e65aed1fb71269571fecdf20e5b0a57c)) - Serde cleanup ([`7662741`](https://github.com/Byron/google-apis-rs/commit/76627413a34ff335a74750ba3f2cbc8999d4c6f3)) - Refactor serde functionality into separate module ([`5398dc6`](https://github.com/Byron/google-apis-rs/commit/5398dc6f7945ee08071c8131ed3fb02163342a60)) - Fix type signatures ([`477be5d`](https://github.com/Byron/google-apis-rs/commit/477be5d76c1f33a1df6796684b4a29b59bd0ccfd)) - Use chrono::Duration directly with serde attributes ([`05df68d`](https://github.com/Byron/google-apis-rs/commit/05df68de324561773b9867f143bf7dbb4381f603)) - Add proper error handling for parsing Duration ([`444b610`](https://github.com/Byron/google-apis-rs/commit/444b610ddc62af31c9c95e6865b8e58452afb10f)) - Clean up duration parsing code ([`fc78001`](https://github.com/Byron/google-apis-rs/commit/fc780014d4e94b7a01c5237feb21999c86474cc1)) - Use appropriate types for date-time, duration, bytes ([`29aa8df`](https://github.com/Byron/google-apis-rs/commit/29aa8df15b0ee08b7dea83f9a25cd9d6c2304b99)) - Add support for duration and base64 serde ([`66c535e`](https://github.com/Byron/google-apis-rs/commit/66c535e4d67b2ebcb726eaad4cb6daf24c650ecc))
## 4.0.1 (2022-10-02) `+Send` trait bound for `GetToken`. ### Commit Statistics - 13 commits contributed to the release over the course of 3 calendar days. - 6 days passed between releases. - 0 commits were understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v4.0.1 ([`93c8601`](https://github.com/Byron/google-apis-rs/commit/93c8601fdca62f92f164957d9e86220f4f1b10f7)) - Prepare release of google-apis-common ([`dc0686e`](https://github.com/Byron/google-apis-rs/commit/dc0686ea0b4cf6984992930ba531407a3e9e2666)) - Merge branch 'patch-2' ([`fe1e972`](https://github.com/Byron/google-apis-rs/commit/fe1e97299f5cb025d6e4d18a1864356bcb6f5244)) - Merge branch 'patch-1' ([`6548d38`](https://github.com/Byron/google-apis-rs/commit/6548d384837316a6b40c2f02f581c89dc400181a)) - Replace std::thread::sleep with tokio::thread::sleep ([`811ed3d`](https://github.com/Byron/google-apis-rs/commit/811ed3d016c7465e95628b91c0828837aeef2f88)) - Make remove_json_null_values O(n) instead of O(n^2) ([`276324a`](https://github.com/Byron/google-apis-rs/commit/276324ae09f4fa60c65518991cf89ce6bd7900ac)) - Add additional send/sync bounds ([`dad761d`](https://github.com/Byron/google-apis-rs/commit/dad761d3f8278e014cf51271ef0ab45495f5d86a)) - Update lib.rs ([`5a5d476`](https://github.com/Byron/google-apis-rs/commit/5a5d476317d6491d9c23bc8c9e5740f392bec7c0)) - Add Send bound to GetToken ([`b10bdda`](https://github.com/Byron/google-apis-rs/commit/b10bddab08e3ae42a23600235e09d35a71e547bd)) - Merge branch 'common-cli-crate' ([`4c4d96d`](https://github.com/Byron/google-apis-rs/commit/4c4d96d3c2028497de2b2e86f94f79a9d6b371bb)) - Fix compile warnings ([`3b4fae9`](https://github.com/Byron/google-apis-rs/commit/3b4fae994e82ba48c4cc809a668516f44a367e5e)) - Run only tests that are actually used/implemented ([`a1e6496`](https://github.com/Byron/google-apis-rs/commit/a1e6496ccdeaa8a0d799c53ed3b95fca5b7fc7c9)) - Move client.rs to common dependency ([`9142859`](https://github.com/Byron/google-apis-rs/commit/9142859612e00fd81a3644f587f6abb9a8d837a9))
## 4.0.0 (2022-09-25) The initial release of the crate that is shared among all google-api crates. This allows trait-implementations to be re-used as they are not unique to their respective crate. If the google-api crate you are looking at doesn't seem to use it, make sure you have `4.0.2` or higher, or ask in the source repository for a release of the crates you need. ### Chore - clean up after failed wget Wget leaves empty files when getting a 404. This causes JSON parse errors later on instead of the expected file not found message. - add photoslibrary v1 code - Add support for adding unlisted APIs The photoslibrary API is not listed however is still available. This adds a method of manually adding APIs to the shared.yaml and adds the photoslibary API info. - Update virtualenv Update virtualenv from 12.0.7 to 16.0.0 - Pin hyper and mime crates to fix compilation. - adds all missing apis With recent changes in the generator and or rust a bunch of api are now working that were blacklisted. This commit adds the generated files for those apis. - remove working apis from blacklist With recent changes to rust and or the generator a bunch of api are now working. This commit removes them from the blacklist. - added compute1 - remove compute1 from blacklist - added sheets - removed sheets from blacklist - regenerate apis without leading slashes - v1.0.5 - regen all source [skip ci] - upgrade patch level It seems crates.io has inconsistent version information, making a few CLIs pull outdated crates. [skip CI] - all api+cli However, it appears some APIs changed without updating their respective version number. Thus newer CLIs pull outdated APIs? Something is wrong. [skip CI] - Update examples - update all apis And bring in 5 new ones, including cloudkms. Also update dependencies to make things compile again. - remaining publishes - more crates published - intermediate publish cargo cannot connect to github anymore for some reason [skip ci] - regen all apis/clis for v1.0.4 - v1.0.4 - serde upgrade - remove local override Should not have been committed in the first place - one step closer to getting it compiled - fix error handling - latest release - regen all cli for new version - patch bump to v1.0.3 To bring in support for hyper v0.10 - Update hyper for generated crates to ^0.10 You guessed it, again related to the openssl upgrade in dermesser/yup-oauth2#51. As long as the API crates depend on openssl 0.7 via hyper 0.9, any client using the APIs won't build :( For example, examples/drive_example/ in dermesser/yup-oauth2. Please regenerate and publish afterwards, if possible. - published all v1.0.2 For the sole purpose of getting the documentation onto docs.rs after applying a bugfix. - v1.0.2 - v1.0.2 - cli - all api - update code to latest version required before publishing - update - api-cli lock-step; depend on specific version As they are usually meant to work hand-in-hand anyway. This simplifies the way this works a lot, and is probably more correct as well. - v1.0.1 * cli: now refers to just version 1 of API * api: updates the documentation URLs in cargo.toml - DS_Store [skip ci] - get fixes into README This will provide a proper link to the readme. - re-publish as much as possible - fetch latest json and re-gen all code - remove .DS_Store files - update - all CLIs and APIs are available in v1.0 now! - all clis except for one google-serviceregistryalpha for some reason can't be found in version 1.0.0 even though it is there. - ignore cloudtrace - keep state It uses timestamp files to remember which crates have already been published. - add api publish notes That way already published crates will not be retried. - keep things stable in v1.0 I think the current API is quite useable, therefore there is no need to keep it below v1 artificially. - allow failure on nightly It appears someone in the dependency chain is pulling in a failing aster. Ideally, we review this or try to make a PR to fix this in our upstream dependencies. For now though, I want this badge green. - use serde_derive - use yup-oauth2 1.0 Celebrations ! - use latest of yup-oauth2 Seems to work just fine. - Regenerate APIs - publish remaining cli Seems there are a few inconsistencies that needed to be ironed out manually. - all cli Some could not be uploaded as we went out-of-memory. Will redo those on a stronger system - prepare cli for publish - latest APIs The only difference to the previous version is that they are referring to the latest versions of serde. - specify version to allow cli publishing Let's see if we can actually get away with a '*' ... . - publish all APIs only compute1 didn't publish due to the typical ring-buffer error that really wants a dynamic buffer, instead of a static one. - update to latest version Which is to be published - to latest Using `make update-json`, all json descriptions have been update. Quite interesting to see that there are plenty of new ones which are giving 404 when queried. An actual bug, or something I should look into ? - version-update Use latest serde to make nightly builds work. - one more down Even though docs work on this one, compilation does not. [skip ci] - v0.3.6 With simpler authentication flow. - rustc version no longer needed It now just works, and hopefully will keep doing so for a while. [skip ci] - update to latest version [skip ci] - update with latest troublemakers Those don't compile, usually for trivial reason, which means they come up with duplicate types, or have name-clashes. If there is the need, this can be fixed. - latest version to crates.io Also update the latest source-code, which is just a cleanup. - remove workaround marker ... and some left-over comments. The workaround code is actually more readable than the previous version, so it may as well stay. - update code to latest version - increment versions ... ... in preparation for new publish. Latest flows, and all should work out of the box with the latest serde. - license year Wow, didn't know the makefile could do that :) ! - `make regen-apis` - split doc and test to handle features Previously it would fail as the built-in doc target in make doesn't handle features at all. Now these need to be taken into consideration though for it to have a chance. - add last known working rustc version For now, just nighly. - use features for cli-dependency That way, we respect the API features when pulling it in via the CLI. Also make it compatible to the latest serde-json version. - let's be sure to get the matrix right It's also done that way in yup-oauth2, and I forgot it previously. It's like a pre-emptive fix. - Travis CI support Travis should now be able to use nightly as well. - update to latest version + nightly support Nightly is now supported, in theory, to allow not to use serde_codegen, which currently has trouble to build thanks to an assertion error. Nightly on the other hand suffers from being build with incorrect feature-flags, which makes quasi_macros fail to build ... . - pin `url` crate The latest one needs some modifications, that will be done in time. - publish state This helps make keep track of what was successfully published to crates.io - to latest schema version - all jsons; version-up As we are now back to serde 0.6, the patch-level was upped too. - use compatible yup-oauth It seems all these serde versions interact with each other in unforseen ways, so they will have to be in sync for it to work. Its a shaky card-house I am building here, and I don't like it at all. - first bunch of publishes Many don't work due to https://github.com/serde-rs/syntex/issues/33 - update after version-up - api version 0.1.12 - update code matching latest jsons This was particularly interesting as APIs went away - fetch latest json api-list.yaml was updated manually to push out APIs which are just empty or plain incompatible with what we are doing - upgrade to 0.7 Desired feature: ignore unknown fields, which is now on by default. - added custom client secret to allow operation - update generated code This seems to be just a remainder, two APIs were missed last time I updated the code. I guess. - remove unimplemented option - update all crates - update remaining APIs Missed them in the first run - update - updated to latest state - increment versions of API + CLI - update with latest changes - no wildcards in dependencies Also version specifications in dependencies were chosen to provide maximum flexibility for users of the libraries. CLIs on the other hand specify last known-to-work major and minor versions to prevent breakage - support for latest hyper - test on nightly, and run cargo test related to #132 - of latest API versions ... no functional change - update everything to latest google API versions - update to latest version - code compiles with rust 1.3/serde 0.6 - re-publish lib crates at latest version - add source at latest version - latest json files This also adds a usable version of the genomics API, which was empty previously (and if I recall correctly). - upgrade to latest hyper+clap - configure to use wait-lock This allows to build everything concurrently without failure provided the latest cargo is used. - latest version of v0.3.1 code * also fixed OSX deployment utility to deal with target folder as primary location for build-artifacts [skip ci] - CLI v0.3.1 - update json and regen all code - adjust to build.target-dir Thanks to the latest cargo 0.3.0, it's possible to keep everything in the stanard doc output directory, which essentially collects everything for us. This creatly reduces the space required to hold all documentation, and is in fact quite beatiful. - one target dir for all projects Starting from cargo 0.3.0, one can override the target-directory to be an absolute path, forcing all output to be dumped into one and the same target dir. That way, all dependencies are shared among the projects, saving 4 to 7 minutes per project in debug and release mode respectively. - cli code update - published latest versions - added latest version of api+cli APIs have additional files thanks to the build-script requirement. CLI has just seen minor changes though, making it usable with a stable compiler. - api+cli increment CLI was incremented to 0.3.0, just to signal usage of the latest clap-rs as well as the update of the used API implememtation. In that moment we also got rid of the json-tools dependency - it required unstable features, and I was not willing to enforce making it stable just yet. - explicitly use stable rust This would be the default, but I want to be sure everyone sees stable is what we need. - bump hyper dep to 0.5.0 google-apis-rs no longer builds with hyper 0.4.0, due to the use of a now-undefined macro - compilation without local overrides Also checked in code for groupsmigration to allow others to test it simply by checking out the right commit. - fix tar-handling Previously it would fail as '*' was in fact not substituted by the subshell. Now I just take the brutal route, using find. [skip ci] - typo + fixed yaml references [skip ci] - change wording [skip ci] - updated for cli v0.2.0 [skip ci] - move all scripts into src/bash That way, they are more official than hidden scripts dumped in the project root. [skip ci] - script to deploy for download A fully untested utility script allows to unpack a tar file previously created from `*-depoly.sh` scripts to a suitable location to be compatible with the downloads links we generate in the documentation index. Related to #107 [skip ci] - publish APIs @v0.1.7 * keep track of publish through version files * updated clog configuration and changelog (automatic) [skip ci] - latest version of all code - remove special clap configuration In latest clap, it's all fixed - special clap configuration Turn off default features to disable overly red first version of otherwise very promising ascii-coloring support. It's good to see that thanks to yaml, that flexibility is easily achieved without altering any generator code. - added dev diary episode 2 link - added information about imp - add support for 'imp' 'imp' will resolve to 'improvements' in the changelog. A new feature supported in clog v0.5.0 - added changelog Powered by [clog](http://goo.gl/QUpyeL) [skip ci] - disabled rust linter,but configured it It's usually too slow to run it, but besides that it's very practical to have ! [skip ci] - to reflect recent changes And to be sure we don't forget to publish new crates when the new CLI hits the road. - using docker Allow building all dependencies using docker - prepare dep generation to use suffix That way, we can have multiple deps files, one per program 'type' - make publish We will now keep marker files to remember which crates we have published successfully. These files are checked in to make this information persist. - add latest version * json takes delegate errors - removed generated go file It shouldn't have been committed - after all, these are just there for my own reference. - generate doc index It contains links to all generated API docs, in a style similar to the standard rust API docs. Thank you, shared CSS ! - api-list is now in separte file This file is completely generated, and allows us to easily bring in new versions after each json update. To make that work, we simple merge all data handed to mako-render, inside of it. That way, we can put 'api/list' data in any yaml. - update-json and all APIs It's about time we finish up this part, to make it even easier to test against more APIs, and keep them up-to-date - cargo calls for any API That way, it's so much easier to parallelize doc and test generation, just to be sure it's truly working. ### Documentation - add lang attribute to docs index Use the W3 standard "lang" attribute on the "html" tag to provide context for browsers and screen readers. - fix build errors Rustdoc assumes indented code is Rust code, but when it isn't, the docs fail to build. The Sheets API has Java, Objective-C, and JavaScript examples in its descripiton. Wrap these examples in language-tagged triple-backticks to prevent rustdoc from trying to compile them. - fix typo - Add dependencies to README In the section that describes setting up the Cargo.toml, add the required dependencies, and note that `hyper` and `hyper-rustls` are not the latest versions. This helps new users get started quicker and easier. - fix body and footer headers - information about unstable rustc Explicitly state that a nightly or beta rust toolchain is required for successful builds. - added dev-diary episode 3 [skip ci] - added Download information That way, it's easy to obtain the respective precompiled binary, as well as seeing the source-code. Overall, it makes promoting the tools easier as the CLI docs can be linked directly. - detailed deployment instructions Related to #107 [skip ci] - `after_help` url for method scmds That way, whenever the extended help of a method (e.g. apis get-rest) is queried, you can easily jump to the online docs to get details about required data-structures or parameters for instance. [skip ci] - update STRUCT_FLAG and UPLOAD flags * adjust documentation to resemble actual upload flag semantics. It was still using the one previously used in docopt. * Make -m optional, defaulting to 'application/octet-stream' * put program type inforamtion into shared.yaml to allow accessing it from the index.html.mako template. * Instead of writing pod-types, we generate a random value of the required type. * Fully document how cursors can be set, which is all that's usually demonstrated in more complex dynamic structure documentation * just for show, use absolute cursors in the top-level structure * indicate you are setting an array or hashmap in the details * add method listing for various categories, like 'downloads' and 'uploads' * add general information on how to do downloads and uploads using various protocols ### New Features - Support custom connectors Switch the constraints on Hub types to use public traits based on tower::service, as recommended by Hyper. This enables support for custom connectors beyond hyper_rustls::HttpsConnector - bump yup-oauth2 to next major version - Allow overriding rootUrl and baseUrl Allow the hub to override `rootUrl` and `baseUrl` for the service. This is useful for pointing at localhost for testing or a proxy. - remove download information - can now be published This works as the API version is now explicitly specified, allowing cargo-publish to work as usual. - Use flow for installed apps That way, more complex APIs like drive and calendars will work without any (sometimes non-existing) workarounds. - updated API descriptions - clap-rs v1.5 -> 2.0 - improved structure setter code We save about 30% of CLI code just because we offload the work of settings structures into serde, building a generic `json::Value` to contain all the data, and then let serde do the deserialization for us. All we need for that is some information we let the generator provide and translate it into the runtime. - basis for simplified value setting Previously we would set static structures manully, using complex cases and utility functions. Now we setup the foundation to allow setting a generic `json::value::Value` instead, which can later be deserialized into the target structure. Related to #111 - added download links (osx,ubuntu) All assets are configured via shared.yaml and are located elsewhere in the web. This could lead to broken assets at some point, but I am just risking it for know, knowing that it's easily done to have local resources. - added back-link to crates.io * url is created per-API and features a nice crates image coming from githubusercontent. * functionality is cursor-aware, and fixes the actual string the user passed in. That way, it is made very clear how the suggested value is to be used. * it's a known weakness of the implementation that it operates on a flattened list of field names, and thus may make nonsensical suggestions. * added punctuation to all errors * As `possible_values()` applies to all arguments, we cannot use it anymore but have to check the UploadProtocol type ourselves. Besides that, switching to the latest `clap` simplified our lives a little. * ajusted docs to not enforce using `-r` all the time * More detailed error type for JsonTokenStorage * removed all traces of rustc_serialize * use pretty-printers everywhere to allow writing human-readable json files for secretes and for tokens * added simple script to build tar archive with all debug/release binaries. * slightly improved docker script, even though it would need additional work. For now, I use the cloud VM anyway * with native support for type conversion and error handling * improved hash-map key-value parsing to at least state that it knows it's dealing with a hashmap. Error text is still not what it should be because we don't know at runtime (initially) what type we handle. * Seem to work for docopt, mkdocs and code itself * mkdocs now show type of required params * some code which deals with converting elements to their target types is totally untested right now. * Allow to see all authentication related communication, similar to --debug flag otherwise. * fixed broken generator when handling request value parsing. * If `--debug` is set, we will output all server communication to stderr. That way, we can compare our requests to what is expected by ush based on official docs. * `discovery` now doesn't use the API key anymore - this is specified using a custom override. * set globally shared parameters (which includes 'alt') * track if 'alt' is set to 'media' at runtime to do the right thing when outputting the result. There is still an issue to be fixed though * support for encoding response schemas to json * support for simple downloads (without alt=media) * improved documentation about error handling, it's less verbose yet explains what you can do. * ArgumentError -> ClIError - seems more fitting * if there is no secret file in json format, we write a default one that we will then read in a second iteration of the loop. That way, the user has an example of how such a file must look like. * Only supports one level of directory * full error handling, and uses memory efficiently * allow usage of cmn.rs for common types (like Error types) * instantiate an engine and handle errors, in an initial quick and dirty way. * allow to rename executables, for now just brute-force using a boolean flag. If we have more binaries at some point, we might want to be more elaborate. * everything related to docopts functionality is now in the docopts module. Related to #45 * crate version: code gen version * + (build-metadata): exact version of API schema * MultiPartReader is using match to handle state, reducing unnecessary calls to 0 in that regard. * Fixed seek() calls on readers, assuring they are reset to start each time the loop is done. * both media-parameters now use `ReadSeek` streams. * Use `seek()` to figure out size, simplifying the interface. * reserve_exact(X) where possible (params, multi-part-reader) * `if let` used whereever possible to prevent duplicate checks * outer frame of `MultiPartReader` to allow using it in `doit()` * restructured `doit()` to get content-types right * Added filters for rust doc string * fixed .PHONY * multiple outputs per template/command invocation * NICE embedding of code (like GSL can) * CI * documentation * basic cargo ### Bug Fixes - teach remove_json_null_values arrays change `remove_json_null_values()` to properly remove nulls from and recurse in to arrays google_firestore1_beta1's `CommitRequest` contains an array of `Write` objects which can ultimately contain `Value` members that need to have nulls removed to avoid sending multiple types of values which generates a 400 response fixes calls to google_firestore1_beta1's `hub.projects().databases_documents_commit()` - iteration over dicts with 'values' key Sheets api has a 'values' key in resources.spreadsheets.resources which collides with values(). - strip leading slashes from urls - kgsearch doesn't work out of the box [skip CI] - Example now uses hyper_rustls It's already done by the CLI, but the docs still showed code that would only work in older hyper versions that still shipped with HTTPS. - for now allow nightly to fail I don't know what it is except for it pulling a more recent version of serde when in nighly mode. I don't even know if I set it up that way, but would say that is not too relevant right now. - more idiomatic swapping of values - use latest gen/ from origin/master that fixes a conflict when merging - Added an assert to detect when docs need updating - Finished adjustments to index.html template (fixes #166) Summary of changes: - Converted from using span + br tags for formatting to using tables * `SubCommand::new(...)` was renamed to `SubCommand::with_name(...)` which actually is now consistent with everything else (e.g. `Arg::with_name(...)`) * Signature of `client::Response` changed and now requires a `hyper::Url` as well. * Mime crate must be used in the same version hyper uses * made attempted move a borrow * Vec::add was removed ... which forces me to write 4 lines instead of one very readable one :(. Not everything is to the better here, even though I can imagine they did it to prevent people from thinking this is a cheap operation. * Use `Result` everywhere, instead of Option or tuples * Properly handle error occurring after the dry-run. We do it in an extensible way, in case we need to do more than handle invalid output files at some point. Output files that could not be opened will now result in a nice error message with all the information we have. * CallType now represents either Upload or Standard calls, whereas the Upload variant is represented by the UploadProtocol enum. That way it's clear what happens, and we don't mix orthogonal concepts in one enumeration just for convenience. * upload * download * request structures * parameters * scopes * config-dir * debug[-auth] * mkdoc docs grammar is now hierarchical, making the command structure more obvious and easier to understand. It's a nice addition to the auto-generated, hierachical usage of clap. * UploadProtocol enum is now CallType, to ease handling the different ways the Call has to be executed. It looks quite clean, even though combining upload protocols and the calltype is a bit hacky. * `--version` now includes the API revision we embody (using crate_version()) * Allow multiple scopes to be specified, instead of just one. Previously this was problemantic due to argument parsing of docopt being greedy. However, this also means we have to specify the `-r` flag for each invocation. See https://github.com/kbknapp/clap-rs/issues/89 . * Adapted to new signature of `Arg::possible_values()` and used the previously orphaned `UploadProtocol` enum. * Deduplicated code a little by adding the new `opt_values()` generator function. * also includes publishing tag files * now the cursor will only be set permanently if the -r flag is used in 'cursor' mode. In 'cursor=value' mode, the cursor change doesn't persist among the flags. That way, one can easily distinguish between setting the cursor, and setting a field. However, '...sublevel.level=value' will still work as it did previously, yet the cursor change will not persist. * Documentation was adjusted to represent the new cursor style. * fixed boundary syntax of multi-part message. Was --BOUNDARY, now is --BOUNDARY-- * Fixed ContentRange parsing and serialization. We actually managed to break it last time we tried to update it to match the Go implementation. * fixed uploadType header parameter. It's based on chosen protocol and whether or not the method supports multipart operation for the given protocol. * implement custom scopes - previously they could be set, but were ignored during the API call * api-overrides are not yaml files for convenience. Existing ones were updated as needed. * add new APIs * remove old ones * add latest json files * updated all json API descriptions * enabled 'pretty' printing of response structures. However, currently there is no way to get rid of all the NULL fields without external filtering * all structure fields are now optional - there seems to be no way around it. * exclude dataflow API - it doesn't have a single method as long as it's in B4. See https://github.com/Byron/google-apis-rs/issues/78 * assure ARRAY branch can be hit * API-docs now adjust depending on where 'alt' is set (either as global parameter, or as method-parameter) * CLI: download tracking now works for 'alt' as method-parameter * CLI: global parameter remapping allows them to be named consistently, but map to the name required by the google API. * Thanks to a generic function, we save a lot of code within main.rs * more effcient signature for ParseError * refactored errors into a hierarchy * implemented `Display` trait for all error types, including some 'hierarchy-aware' printing. * in APIs, scopes will now be per-method, and if no scope is given, we will assume only the API key has to be set. Previously there was a wild mix between globally mentioned scopes and method scopes. * assure CLI generation works so far, for all avaialable APIs * update all APIs to contain said change. It's not worth a republish though. * catchier title for dev diary episode 1 * fixed target name for clean, which was 'clean-api', but should have been 'clean-all-api' * fix documentation link in Cargo.toml * adjust to latest hyper. It's not even out yet, but people can't build the APIs anyway. * deal with hyper client not using a type-parameter anymore * fix incorrect documentation link (use '_' instead of '-') * added crate publish tag files * `docs` is `docs-all` now. On travis, this should only build one API * macro 'alias' was renamed to 'rename' * fixed `cargo test` on main project * keywords are no longer than 20 characters, which is a restriction cargo imposes * don't use 'homepage' link in cargo.toml unless the homepage is non-empty * Added all publish-results to mark the respective crate version * builds with latest beta/nightly * using std::convert * update to latest hyper (and other dependencies) * `ResourceMethodsBuilder` -> `MethodsBuilder`. This is now precise enough. Previously it was just to similar to what's now a `CallBuilder` * Fixed whitespace issue in `doit()` * Added all APIs to source control * upped crate version * renamed `*MethodsBuilder` type to `*Methods` type * renamed `*CallBuilder` type to `*Call` type * greatly simplified `doit()` signature if uploads are involved * pass `auth` to upload helper * do not emit unused types. Sometimes though, rustc doesn't seem to detect that attributses are actually used * ToParts trait is used and implemented only when needed. * complete list of reserved words (keywords in Rust) * use namespace for otherwise clashing types in cmn::, io:: ### Other - Make new_context dict-compatible This is an incremental change towards a strongly-typed util module, aimed at reducing dependency on the DictObject class. The rough idea is to annotate everything as Dict, add some tests to codify the existing behavior, and then start defining dataclasses for the dischovery schema. We also remove some unused logic & params. - :iter not needed - blacklist versions that do not exist - Fix version of Python used on Travis mkdocs depends on tornado that fails to compile on Python before 2.7.9. When running in Travis not using the Python language a very old version of Python is used. This commit adds pyenv and uses it to ensure Travis Python is viable and stable. - update toc [skip CI] - remove obsolete notes about linux We use cargo now as installation method, no need to provide binaries anymore. [skip ci] - upgrade to v0.9 This provides proc macros, greatly simplifying the build projects. - use hyper-rustls instead of openssl The only openssl dependency left would be coming from yup-oauth2! - don't use relative links Instead we link to the absolute location. tech debt: we now use http://byron.github.io/google-apis-rs multiple times and thus duplicate that information. - improve UX Better help alert when copying an installation script to clipboard. Better looks. - better install script + blacklist We now consider the blacklist, which is probably what the previous implementation achieved as it checked for existence of files on disk. We do the same, but more directly. A complete installation script is provided for those who don't yet have rustup installed. - link to doc.rs for APIs We also link more specifically to crates.io. Some debt was taken on as the build_version is special and duplicated right now. - button to copy install-script - remove all download links Instead refer to cargo install for installation. [skip ci] - use docs.rs for library documentation We will still need to host the CLI docs though. - multirust is deprecated - use rustup :) - badges for issue stats [skip ci] - inform about nightly builds [skip ci] - need Rust 1.6 now [skip ci] - rever to multirust-rs - fix error from no trailing newline - stackshare.io badge I like it ! It's super useful, especially when deciding which tools to use in a new project. - pretty-print errors in debug mode - update info about rust stable Yes, it's fully supported now. - disallow empty values explicitly [skip ci] - download links to `tar.gz` files That way, we save bandwidth and preserve the executable bit of the respective program. - DL title contains os-name That way, it's clearer, besides the icons themselves, which OS you are downloading for. Related to #106 [skip ci] - improved display of BadRequest Previously you would only see "BadRequest ... " without the information that would actually help you to understand what the cause of the issue is. Now we will print all the information we have, accordingly, which greatly improves usability. - remove null in pretty-printed json Without all that clutter, it's so much more enjoyable to read the output. The implementation is based on a suggestion of @erickt, which is converts into a json::Value (able to represent any json structure), on which the filtering is applied. If we should ever implement pretty-printing in json-tools, we might still consider using these capabilities instead, as we would avoid building potentially large datastructures, all we would need is a sufficiently large destination buffer which is a single alloc and a consecutive region in memory. - faster null-value removal Previously reserialization of token streams with removed null values was performed on a byte-per-byte basis, which was quite inefficient to say the least. Now it uses `io::copy` to copy in chunks of 65kb, which makes out our throughput and should deliver about 150MB/s at least. ### Refactor - Added bootstrap to make things pretty - Cleaned up a lot of the link logic - Converted data to a table - OK version of json value setter However, we don't set the correct field names yet, and are lacking a remapping of CLI field names to struct field names before any testing makes sense. - handle recursive mut json values * recurively drill down a mutable, recursive enumeration, without borrow checker issues. The obvious solution doesn't work, but should. Stackoverflow ? * infrastructure to set actual value, with support for ararys, pods and hashmaps - bring in all required field data Previously we only knew the type as string, now we have enums and additional type information, like whether or not it's a POD. However, borrow-checker doesn't like the current code, will need more work. - non-redundant data access Previously we would define information about the program types in two places, once for the index, and once per program type. Now within the index.html, we just load the respective program type information to have access to the latest at all times. - use `json_tools::IteratorExt` That way, we can invert the flow and produce more idiomatic code. [skip ci] - use `arg_enum!` clap-rs macro That way, we get a better (case-insensitive) implementation of `FromStr` which reduces the amount of code we have to maintain. - better vector building Instead of using multiple lines to add vectors up involving iterators, I just add slices together. This should produce less, and possibly faster machine code, with less ascii code. Downloads tested with drive2, and are verified to be working ! - move global params to runtime Global params were repeated per method, even though they were global, per API. Now they are kept in vectors and used at runtime, accordingly. We save a little bit of code, have simple matches, and less repition. It's unclear if this reduces the size of the binary though ... or the compile times, as the extra loop is an extra loop after all ;). Still need to test the download mode using drive1 Related to #97 [skip ci] - use raw strings for argparser That way, we should be save from contained '"' characters, and whatever else. - request-value parsing;Default * Default::default() optimized to use T::default() if possible * deduplicated special type handling ('Count' strings -> int64) * put request value parsing into own private function - put API relevant stuff into subdir This is the first of many changes to come. We try to leverage our ability to merge multiple data source into one to abstract away what we are actually doing, and of course, to allow sharing the majority of the code, were applicable. - remove map!, better dlg call * map! wasn't used. * improved delegate calls, using `match` or `delegate.is_some()` to get the nicest looking, shortest-possible code - deduplicate object creation code Everything is still working ... maybe it will all work now ? - into own def Was rather easy, and shows that plenty of complexity arose from the usage example. Implementing the action will probably be quite something ... . Can't wait to have an auto-generated sample program ! - methods useful for mbuild as too It's vital to be able to traverse parameters easily and consistently :) - new _setter method Just to make things a little easier to read. Don't expect it to grow much larger though. - move resource builder into own lib As the code is likely to grow far more complex, it's required to move it as long as it is easy to do so. ### Style - Fixed up indenting and line length ### Test - initial test Implementation has to follow next ### Refactor (BREAKING) - remove various errors structs ### Commit Statistics - 5 commits contributed to the release. - 0 commits were understood as [conventional](https://www.conventionalcommits.org). - 0 issues like '(#ID)' were seen in commit messages ### Commit Details
view details * **Uncategorized** - Release google-apis-common v4.0.0 ([`64705a7`](https://github.com/Byron/google-apis-rs/commit/64705a75b6ece818c1a5c3c55ff686ea155c856b)) - Prepare changelog ([`ecb10a2`](https://github.com/Byron/google-apis-rs/commit/ecb10a2ff500a1d10add9be336393a10e51ec050)) - Merge branch 'common-crate' ([`96b3d72`](https://github.com/Byron/google-apis-rs/commit/96b3d728a3b3d76c64fa0e48198d09b2d3c023bd)) - Prepare google-apis-common for release ([`716c4c2`](https://github.com/Byron/google-apis-rs/commit/716c4c263a278c334feacf57c3eabbed09251a9e)) - Rename `google-api-client` to `google-apis-common` ([`8d7309b`](https://github.com/Byron/google-apis-rs/commit/8d7309b78c3bc909b794d447115328cfb0f41649))