Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jnunemaker/httparty
:tada: Makes http fun again!
https://github.com/jnunemaker/httparty
http httparty ruby
Last synced: 6 days ago
JSON representation
:tada: Makes http fun again!
- Host: GitHub
- URL: https://github.com/jnunemaker/httparty
- Owner: jnunemaker
- License: mit
- Created: 2008-07-28T20:55:11.000Z (over 16 years ago)
- Default Branch: main
- Last Pushed: 2024-12-17T18:13:38.000Z (26 days ago)
- Last Synced: 2024-12-30T13:21:38.960Z (13 days ago)
- Topics: http, httparty, ruby
- Language: Ruby
- Homepage:
- Size: 1.48 MB
- Stars: 5,826
- Watchers: 65
- Forks: 961
- Open Issues: 43
-
Metadata Files:
- Readme: README.md
- Changelog: Changelog.md
- Contributing: CONTRIBUTING.md
- License: MIT-LICENSE
Awesome Lists containing this project
- awesome-ruby-toolbox - Httparty - Makes http fun! Also, makes consuming restful web services dead easy. (Web Apps, Services & Interaction / HTTP clients)
- awesome-ruby - httparty - Makes http fun again! (HTTP Clients and tools)
- awesome-rails-api-gems - Httparty - Makes http fun again! Ain't no party like a httparty, because a httparty don't stop. (HTTP Clients)
- awesome-rest - httparty - Makes HTTP fun again! (Clients / Ruby Clients)
- awesome-github-star - httparty
README
# httparty
[![CI](https://github.com/jnunemaker/httparty/actions/workflows/ci.yml/badge.svg)](https://github.com/jnunemaker/httparty/actions/workflows/ci.yml)
Makes http fun again! Ain't no party like a httparty, because a httparty don't stop.
## Install
```
gem install httparty
```## Requirements
- Ruby 2.7.0 or higher
- You like to party!## Examples
```ruby
# Use the class methods to get down to business quickly
response = HTTParty.get('http://api.stackexchange.com/2.2/questions?site=stackoverflow')puts response.body, response.code, response.message, response.headers.inspect
# Or wrap things up in your own class
class StackExchange
include HTTParty
base_uri 'api.stackexchange.com'def initialize(service, page)
@options = { query: { site: service, page: page } }
enddef questions
self.class.get("/2.2/questions", @options)
enddef users
self.class.get("/2.2/users", @options)
end
endstack_exchange = StackExchange.new("stackoverflow", 1)
puts stack_exchange.questions
puts stack_exchange.users
```See the [examples directory](http://github.com/jnunemaker/httparty/tree/master/examples) for even more goodies.
## Command Line Interface
httparty also includes the executable `httparty` which can be
used to query web services and examine the resulting output. By default
it will output the response as a pretty-printed Ruby object (useful for
grokking the structure of output). This can also be overridden to output
formatted XML or JSON. Execute `httparty --help` for all the
options. Below is an example of how easy it is.```
httparty "https://api.stackexchange.com/2.2/questions?site=stackoverflow"
```## Help and Docs
- [Docs](https://github.com/jnunemaker/httparty/tree/master/docs)
- https://github.com/jnunemaker/httparty/discussions
- https://www.rubydoc.info/github/jnunemaker/httparty## Contributing
- Fork the project.
- Run `bundle`
- Run `bundle exec rake`
- Make your feature addition or bug fix.
- Add tests for it. This is important so I don't break it in a future version unintentionally.
- Run `bundle exec rake` (No, REALLY :))
- Commit, do not mess with rakefile, version, or history. (if you want to have your own version, that is fine but bump version in a commit by itself in another branch so I can ignore when I pull)
- Send me a pull request. Bonus points for topic branches.