Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/johnsonandjohnson/Guppy-iOS
iOS pod about a curious fish named Guppy
https://github.com/johnsonandjohnson/Guppy-iOS
guppy ios network-monitoring networking swift urlsession
Last synced: 13 days ago
JSON representation
iOS pod about a curious fish named Guppy
- Host: GitHub
- URL: https://github.com/johnsonandjohnson/Guppy-iOS
- Owner: johnsonandjohnson
- License: apache-2.0
- Created: 2019-04-12T13:45:28.000Z (almost 6 years ago)
- Default Branch: main
- Last Pushed: 2022-02-03T20:25:07.000Z (almost 3 years ago)
- Last Synced: 2024-12-30T22:22:08.026Z (about 1 month ago)
- Topics: guppy, ios, network-monitoring, networking, swift, urlsession
- Language: Swift
- Homepage:
- Size: 2.87 MB
- Stars: 40
- Watchers: 12
- Forks: 3
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- top-pharma50 - **johnsonandjohnson/Guppy-iOS** - monitoring`, `networking`, `swift`, `urlsession`<br><img src='https://github.com/HubTou/topgh/blob/main/icons/gstars.png'> 40 <img src='https://github.com/HubTou/topgh/blob/main/icons/forks.png'> 3 <img src='https://github.com/HubTou/topgh/blob/main/icons/code.png'> Swift <img src='https://github.com/HubTou/topgh/blob/main/icons/license.png'> Apache License 2.0 <img src='https://github.com/HubTou/topgh/blob/main/icons/last.png'> 2022-02-03 20:25:07 | (Ranked by starred repositories)
- top-pharma50 - **johnsonandjohnson/Guppy-iOS** - monitoring`, `networking`, `swift`, `urlsession`<br><img src='https://github.com/HubTou/topgh/blob/main/icons/gstars.png'> 40 <img src='https://github.com/HubTou/topgh/blob/main/icons/forks.png'> 3 <img src='https://github.com/HubTou/topgh/blob/main/icons/code.png'> Swift <img src='https://github.com/HubTou/topgh/blob/main/icons/license.png'> Apache License 2.0 <img src='https://github.com/HubTou/topgh/blob/main/icons/last.png'> 2022-02-03 20:25:07 | (Ranked by starred repositories)
README
![Guppy](https://user-images.githubusercontent.com/4382161/149004565-ffeba0bd-c863-4165-b417-78c1350e2c6b.png)
[![Platform](https://img.shields.io/badge/platform-iOS-green.svg?style=flat)](https://img.shields.io/badge/platform-iOS-blue.svg?style=flat)
[![Swift Version](https://img.shields.io/badge/Swift-5.0+-F16D39.svg?style=flat)](https://developer.apple.com/swift)
[![CocoaPods](https://img.shields.io/cocoapods/v/Guppy.svg?style=flat)](https://cocoapods.org/pods/Guppy)
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/Carthage/Carthage)
[![codecov](https://codecov.io/gh/johnsonandjohnson/Guppy-iOS/branch/main/graph/badge.svg)](https://codecov.io/gh/johnsonandjohnson/Guppy-iOS)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)Do you want to know what's tedious? Debugging network requests and responses if you don't have the right tools. Guppy is a logging tool focused on HTTP requests that can be easily plugged into any iOS application. Guppy will intercept and log each network request sent from the app. You can access any Guppy log and share it with the rest of your team effortlessly.
## Usage
While in the simulator you can use: `^ + ⌘ + z` to bring up Guppy or shake your phone.
![Routes](https://user-images.githubusercontent.com/4382161/149004398-df4c8c40-eaa1-432a-b2f4-86fdf0e4a806.png)
You can dig deep into the details of your network logs and share them with your team or yourself.
![Details](https://user-images.githubusercontent.com/4382161/149004684-37d3196d-473f-4fb3-8cde-0eee954d6ae4.png)
## Example
To run the example project, clone the repo, and run `pod install` from the Example directory first.
### URLSession
```swift
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
Guppy.registerURLProtocol()
return true
}
}
```### URLSession with Custom Protocols
```swift
class Session: URLSession {
init() {
let configuration = URLSessionConfiguration.default
configuration.urlCache = nil
// Protocols are evaluated in reverse order
// If GuppyURLProtocol is not the last protocol it is not guaranteed to be executed
configuration.protocolClasses = [MyCustomProtocol, GuppyURLProtocol.self]
super.init(configuration: configuration)
}
}```
### Alamofire
```swift
class SessionManager: Alamofire.SessionManager {init() {
let configuration = URLSessionConfiguration.defaultconfiguration.urlCache = nil
configuration.protocolClasses = [GuppyURLProtocol.self]
super.init(configuration: configuration)
}
}
```## Requirements
* Xcode 12.0+
* iOS 13.0+## Installation
Guppy is best used in non-production environments. By default, installing the Guppy framework will automatically make it available when the user shakes their device. To avoid this do any combination of the following:
* If you are using multiple targets for different environments, only include the Guppy framework in the non-production targets
* If you are using one target with multiple configurations for different environments, only include the Guppy framework in the non-production configuration
* Set `Guppy.shared.showOnShake = false` in your `didFinishLaunchingWithOptions` for the specific times where Guppy should not be available### [Swift Package Manager](https://swift.org/package-manager/)
```
https://github.com/johnsonandjohnson/Guppy-iOS.git
```### [CocoaPods](https://cocoapods.org)
```ruby
pod 'Guppy'
```### [Carthage](https://github.com/Carthage/Carthage)
```
github "johnsonandjohnson/Guppy-iOS"
```## License
Guppy is released under the Apache 2.0 license. See [LICENSE](https://github.com/johnsonandjohnson/Guppy-iOS/blob/main/LICENSE) for details.