https://github.com/snipsco/Postal
  
  
    A Swift framework for working with emails 
    https://github.com/snipsco/Postal
  
mail-tech mailcore postal swift swift-framework
        Last synced: 3 months ago 
        JSON representation
    
A Swift framework for working with emails
- Host: GitHub
- URL: https://github.com/snipsco/Postal
- Owner: snipsco
- License: mit
- Created: 2016-05-18T10:51:25.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2019-05-22T13:44:32.000Z (over 6 years ago)
- Last Synced: 2024-09-16T13:31:37.483Z (about 1 year ago)
- Topics: mail-tech, mailcore, postal, swift, swift-framework
- Language: Swift
- Homepage:
- Size: 38.6 MB
- Stars: 653
- Watchers: 35
- Forks: 82
- Open Issues: 29
- 
            Metadata Files:
            - Readme: README.md
 
Awesome Lists containing this project
- awesome-ios - Postal - A swift framework providing simple access to common email providers. (Networking / Email)
- awesome-swift - Postal - Framework providing simple access to common email providers. (Libs / Network)
- awesome-swift - Postal - Framework providing simple access to common email providers. (Libs / Network)
- awesome-ios-star - Postal - A swift framework providing simple access to common email providers. (Networking / Email)
- fucking-awesome-swift - Postal - Framework providing simple access to common email providers. (Libs / Network)
- awesome-swift - Postal - A Swift framework for working with emails ` 📝 2 years ago ` (Network [🔝](#readme))
README
          

[](https://travis-ci.org/snipsco/Postal)
[](https://github.com/Carthage/Carthage)
[](https://cocoapods.org/)
[](https://swift.org/)

Postal is a swift framework providing simple access to common email providers.
## Example
### Connect
```swift
let postal = Postal(configuration: .icloud(login: "myemail@icloud.com", password: "mypassword"))
postal.connect { result in
    switch result {
    case .success:
        print("success")
    case .failure(let error):
        print("error: \(error)")
    }
}
```
### Search
```swift
let filter = .subject(value: "Foobar") && .from(value: "foo@bar.com")
postal.search("INBOX", filter: filter) { result in
    switch result {
    case .success(let indexes):
        print("success: \(indexes)")
    case .failure(let error):
        print("error: \(error)")
    }
}
```
### Fetch
```swift
let indexset = NSIndexSet(index: 42)
postal.fetchMessages("INBOX", uids: indexset, flags: [ .headers ], onMessage: { email in
    print("new email received: \(email)")
}, onComplete: error in
    if error = error {
        print("an error occured: \(error)")
    }
}
```
### Want to debug your IMAP session ?
```swift
postal.logger = { log in
    print(log)
}
```
### What about Mailcore ?
Postal does not address the same goal as MailCore. You can take a look at our thoughts in the [TechnicalNotes][] document.
### Provider quirks
Email protocol is standardized. However providers implementations often provides extension or variations of these standards.
We tried to build a document to synthesize working around these variations here: [ProviderQuirks][].
### Contributing
Postal has been a great effort and we could really use your help on many areas:
- Finding and reporting bugs.
- New feature suggestions.
- Answering questions on issues.
- Documentation improvements.
- Reviewing pull requests.
- Fixing bugs/new features.
- Improving tests.
- Contribute to elaborate the [Roadmap][].
If any of that sounds cool to you, please send a pull request!
Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms that you can find here: [CodeOfConduct][].
## Requirements
- Xcode 10
- OS X 10.10 or later
- iOS 8.0 or later
## Installation
### Carthage
Postal is [Carthage](https://github.com/Carthage/Carthage) compatible.
- Add `github "snipsco/Postal"` to your Cartfile.
- Run `carthage update`.
### CocoaPods
Postal also can be used by [CocoaPods](https://cocoapods.org/).
- Add the followings to your Podfile:
```ruby
use_frameworks!
pod 'Postal'
```
- Run `pod install`. 
### Manual
1. Add the Postal repository as a [submodule](https://git-scm.com/book/en/v2/Git-Tools-Submodules) of your application’s repository.
	
```bash
git submodule add https://github.com/snipsco/Postal.git
git submodule update --init --recursive
```
1. Drag and drop `Postal.xcodeproj` into your application’s Xcode project or workspace.
1. On the “General” tab of your application target’s settings, add `Postal.framework` to the “Embedded Binaries” section.
1. If your application target does not contain Swift code at all, you should also set the `EMBEDDED_CONTENT_CONTAINS_SWIFT` build setting to “Yes”.
## License
Postal is released under the [MIT License](LICENCE.md).
[Roadmap]: Documentation/Roadmap.md
[TechnicalNotes]: Documentation/TechnicalNotes.md
[ProviderQuirks]: Documentation/ProviderQuirks.md
[CodeOfConduct]: Documentation/CodeOfConduct.md