https://github.com/lucaslimapoa/NewsAPISwift
NewsAPISwift is a Swift client for News API V2, a service that provides breaking news headlines, and search for articles from over 30,000 news sources and blogs.
https://github.com/lucaslimapoa/NewsAPISwift
cocoapods ios newsapi swift
Last synced: 3 months ago
JSON representation
NewsAPISwift is a Swift client for News API V2, a service that provides breaking news headlines, and search for articles from over 30,000 news sources and blogs.
- Host: GitHub
- URL: https://github.com/lucaslimapoa/NewsAPISwift
- Owner: lucaslimapoa
- License: mit
- Created: 2017-05-31T01:36:14.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2018-06-28T16:19:10.000Z (over 6 years ago)
- Last Synced: 2024-09-02T17:46:25.321Z (6 months ago)
- Topics: cocoapods, ios, newsapi, swift
- Language: Swift
- Homepage:
- Size: 400 KB
- Stars: 24
- Watchers: 1
- Forks: 4
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- fucking-open-source-ios-apps - NewsAPISwift
README
# NewsAPISwift
[data:image/s3,"s3://crabby-images/54788/547887f568b5cb205917154befb73c3fdc1bc76a" alt="CI Status"](https://travis-ci.org/lucaslimapoa/NewsAPISwift)
[data:image/s3,"s3://crabby-images/2d180/2d1801ae7805458b91e18c5ac4d97d63da45be3a" alt="Carthage compatible"](https://github.com/Carthage/Carthage)
[data:image/s3,"s3://crabby-images/8b6bd/8b6bd3c581f81d468724d386b36d83d0a9f17211" alt="Version"](http://cocoapods.org/pods/NewsAPISwift)
[data:image/s3,"s3://crabby-images/7cc31/7cc3141d395998a5414a335af49c0e3d27ce31c3" alt="License"](http://cocoapods.org/pods/NewsAPISwift)
[data:image/s3,"s3://crabby-images/07838/07838936520c307f1d4e980bf6bf99b5dd4e267a" alt="Platform"](http://cocoapods.org/pods/NewsAPISwift)
[data:image/s3,"s3://crabby-images/976a7/976a7c60331bfd9ce5b6e6c2309a109dca659533" alt="codecov"](https://codecov.io/gh/lucaslimapoa/NewsAPISwift)
[data:image/s3,"s3://crabby-images/87a75/87a75dfa9063a74afc14edc72915e4a851ba2fd1" alt="codebeat badge"](https://codebeat.co/projects/github-com-lucaslimapoa-newsapiswift-master)NewsAPISwift is a Swift client for [News API V2](http://newsapi.org), a service that provides breaking news headlines, and search for articles from over 30,000 news sources and blogs.
## Usage
NewsAPISwift offers two functions to which sources and top headlines can be requested.
### Sources
The first functions is used for listing all available sources indexed by the service.
Three parameters can be passed in order to filter results.| Parameter | Description |
| --------- | ----------- |
| **Category** | The category you would like to get sources for. The possible values are: `business`, `entertainment`, `general`, `health`, `science`, `sports`, `technology`. *Default: all categories.*|
| **Language** | The language you would like to get sources for. The possible values are: `ar`, `de`, `en`, `es`, `fr`, `he`, `it`, `nl`, `no`, `pt`, `ru`, `se`, `ud`, `zh`. *Default: all languages.*|
| **Country** | The country you would like to get sources for. To get the full list of supported countries, please head to the official [documentation](https://newsapi.org/docs/endpoints/sources). *Default: all countries.*#### Example
```swift
import NewsAPISwiftlet newsAPI = NewsAPI(apiKey: "YourKeyHere")
newsAPI.getSources(category: .technology, language: .en, country: .us) { result in
switch result {
case .success(let sources):
// Do something with returned sources
case .failure(let error):
// Handle error
}
}
```### Top Headlines
The second function is used for listing top headlines. It is possible to request headlines for a specific country, a single or multiple sources, as well as keywords.To get a full list of supported parameters, check the official [documentation](https://newsapi.org/docs/endpoints/sources) for the service.
#### Example
Top Headlines about the weather:
```swift
import NewsAPISwiftlet newsAPI = NewsAPI(apiKey: "YourKeyHere")
newsAPI.getTopHeadlines(q: "weather") { result in
switch result {
case .success(let headlines):
// Do something with returned headlines
case .failure(let error):
// Handle error
}
}
```Top Headlines from BBC News:
```swift
newsAPI.getTopHeadlines(sources: ["bbc-news"]) { result in
switch result {
case .success(let headlines):
// Do something with returned headlines
case .failure(let error):
// Handle error
}
}```
Top Headlines from the US about technology:
```swift
newsAPI.getTopHeadlines(category: .technology, country: .us) { result in
switch result {
case .success(let headlines):
// Do something with returned headlines
case .failure(let error):
// Handle error
}
}```
It is also possible to limit the number of articles returned by passing the *pageSize* parameter. Since there could be more results, pagination is also possible.
```swift
newsAPI.getTopHeadlines(pageSize: 20, page: 1) { result in
switch result {
case .success(let headlines):
// Do something with returned headlines
case .failure(let error):
// Handle error
}
}```
## Example Application
To run the example project, clone the repo, and run `pod install` from the Example directory first. Then, open **Example.xcworkspace** and run the project.
## Installation
#### CocoaPods
CocoaPods is a dependency manager for Cocoa projects. You can install it with the following command:```
$ gem install cocoapods
```To integrate NewsAPISwift into your Xcode project using CocoaPods, specify it in your Podfile:
```ruby
platform :ios, '8.0'
use_frameworks!target '' do
pod 'NewsAPISwift', '~> 2.0'
end
```Then, run the following command:
```
$ pod install
````#### Carthage
Carthage is a decentralized dependency manager that builds your dependencies and provides you with binary frameworks.You can install Carthage with Homebrew using the following command:
```
$ brew update
$ brew install carthage
```To integrate NewsAPISwift into your Xcode project using Carthage, specify it in your Cartfile:
```
github "lucaslimapoa/NewsAPISwift"
```Run the following command to build the framework:
```
carthage update
```Then, drag the built NewsAPISwift.framework into your Xcode project.
## License
NewsAPISwift is available under the MIT license. See the LICENSE file for more info.
*NOTE: This library and its author are not endorsed by or affiliated with newsapi.org.*