1
0
mirror of https://github.com/seejohnrun/haste-client.git synced 2025-12-16 16:51:29 +00:00

14 Commits

Author SHA1 Message Date
Filipe Chagas
6170ad7de6 Fix codeowners 2022-06-02 11:58:55 -03:00
Adam Dubnytskyy
06d4afb1ca add codeowners (#51) 2022-06-02 16:57:59 +03:00
Filipe Chagas
eeede13a3c Add GHA workflow to mark and close inactive PRs and Issues 2022-03-08 11:46:12 -03:00
Nick Otter
6e9801e547 Basic Authentication (#28)
* adding basic http authentication

* updating ruby style

* SSL support, variable name corrections
2022-02-14 14:25:49 -03:00
Konstantin Rybakov
fb77a2e9f5 Merge pull request #38 from xenithorb/patch-1
Haste lite-client improvement
2022-01-12 16:36:36 +03:00
Mike Goodwin
baeeb2874a Haste lite-client improvement
- Easily change variables for scheme, host, port, language
- Specify language on execution 
- Closes #30
2017-10-21 12:21:38 -04:00
John Crepezzi
32c4523e1c Update travis to reflect rubies actually used in the real world 2017-07-19 17:30:45 -04:00
John Crepezzi
c307e8c904 Remove transpec dependency 2017-07-19 17:27:06 -04:00
John Crepezzi
1037d899b9 Bump version to 0.2.3
For #27
2017-07-19 17:23:07 -04:00
John Crepezzi
b5aa8fbacc Added some tests for #27 2017-07-19 17:22:04 -04:00
John Crepezzi
1f3318adeb Merge pull request #27 from vaibhav92/master
Fix issue #26
2017-07-19 17:13:43 -04:00
John Crepezzi
4c0e5f311d Merge pull request #34 from seejohnrun/move_readme_to_https
Move README to HTTPS
2017-03-24 11:24:40 -04:00
John Crepezzi
dab2d08f42 Move README to HTTPS
Also remove a trailing whitespace
2017-03-24 11:23:53 -04:00
vajain21
0ea5e5c61c Fix issue #26 2015-01-21 14:59:06 +05:30
9 changed files with 139 additions and 14 deletions

1
.github/CODEOWNERS vendored Normal file
View File

@@ -0,0 +1 @@
* @toptal/site-acquisition-eng

30
.github/workflows/close-inactive.yaml vendored Normal file
View File

@@ -0,0 +1,30 @@
name: Close inactive issues and PRs
on:
workflow_dispatch:
schedule:
- cron: "30 1 * * *"
jobs:
close-stale:
runs-on: ubuntu-latest
permissions:
issues: write
pull-requests: write
steps:
- uses: actions/stale@v3
with:
days-before-stale: 30
days-before-close: 14
stale-issue-label: "stale"
stale-pr-label: "stale"
exempt-issue-labels: backlog,triage,nostale
exempt-pr-labels: backlog,triage,nostale
stale-pr-message: "This PR is stale because it has been open for 30 days with no activity."
close-pr-message: "This PR was closed because it has been inactive for 14 days since being marked as stale."
stale-issue-message: "This issue is stale because it has been open for 30 days with no activity."
close-issue-message: "This issue was closed because it has been inactive for 14 days since being marked as stale."
repo-token: ${{ secrets.GITHUB_TOKEN }}

View File

@@ -4,6 +4,6 @@ branches:
- master
rvm:
- 1.8.7
- 1.9.2
- 1.9.3
- 2.0.0
- 2.4.0

View File

@@ -1,3 +1,2 @@
source 'https://rubygems.org'
gemspec
gem 'transpec'

View File

@@ -10,7 +10,7 @@ And once the output makes it to the server, it will print the URL to STDOUT.
This can be really really cool in combination with `pbcopy`, like:
* mac osx: `cat file | haste | pbcopy`
* mac osx: `cat file | haste | pbcopy`
* linux: `cat file | haste | xsel`
after which the contents of `file` will be accessible at a URL which has been copied to your pasteboard.
@@ -42,14 +42,30 @@ haste file --raw
## Changing the location of your haste server
By default, haste will point at `http://hastebin.com`. You can change this by setting the value of `ENV['HASTE_SERVER']` to the URL of your haste server. You can also use `alias` to make easy shortcuts if you commonly use a few hastes intermingled with each other. To do that, you'd put something like this into ~.bash_profile:
By default, haste will point at `https://hastebin.com`. You can change this by setting the value of `ENV['HASTE_SERVER']` to the URL of your haste server. You can also use `alias` to make easy shortcuts if you commonly use a few hastes intermingled with each other. To do that, you'd put something like this into ~.bash_profile:
``` bash
alias work_haste="HASTE_SERVER=http://something.com haste"
alias work_haste="HASTE_SERVER=https://something.com haste"
```
After which you can use `work_haste` to send hastes to that server instead.
### Authentication
If your haste installation requires http authentication,
add the following to your ~.bash_profile:
```bash
export HASTE_USER="myusername"
export HASTE_PASS="mypassword"
```
if you are using SSL, you will need to supply your certs path
```bash
export HASTE_SSL_CERTS="/System/Library/OpenSSL/certs"
```
## Use as a library
You can also use `Haste` as a library to upload hastes:
@@ -70,13 +86,22 @@ If you'd like an alternative on Windows that supports functionality similar to `
Han Boetes and @nickthename have contributed a simple shell-script alternative for those not interested in installing a RubyGem:
``` bash
haste() { a=$(cat); curl -X POST -s -d "$a" http://hastebin.com/documents | awk -F '"' '{print "http://hastebin.com/"$4}'; }
haste() {
local S="https" H="hastebin.com" P="" L="$1"
local SHP="${S}://${H}${P}/"
curl -X POST -s --data-binary @- "${SHP}documents" \
| awk -F '"' 'b{ b="."b }; {print a$4b}' a="${SHP}" b="${L}"
}
```
Where `S` is the scheme, `H` is the host, `P` is the port, and `L` is the language. Requires `curl`
Usage:
``` bash
cat file.txt | haste
cat file.txt | haste # cat file into hate, output url
haste sh < script.sh # Same as above, but ensure shell syntax highlighting
xsel -b | haste txt # Output clipboard buffer into haste, ensure no highlighting
```
And a more expansive BASH option by @diethnis can be found at:

View File

@@ -4,7 +4,11 @@ module Haste
# Create a new uploader
def initialize
@uploader = Uploader.new ENV['HASTE_SERVER']
@uploader = Uploader.new(
ENV['HASTE_SERVER'],
ENV['HASTE_USER'],
ENV['HASTE_PASS'],
ENV['HASTE_SSL_CERTS'])
end
# And then handle the basic usage

View File

@@ -1,5 +1,6 @@
require 'json'
require 'faraday'
require 'uri'
module Haste
@@ -7,12 +8,16 @@ module Haste
class Uploader
attr_reader :server_url
attr_reader :server_url, :server_user, :server_pass, :ssl_certs
def initialize(server_url = nil)
def initialize(server_url = nil, server_user = nil, server_pass = nil, ssl_certs = nil)
@server_url = server_url || Haste::DEFAULT_URL
@server_url = @server_url.dup
@server_url = @server_url.chop if @server_url.end_with?('/')
@server_user = server_user
@server_pass = server_pass
@ssl_certs = ssl_certs
end
# Take in a path and return a key
@@ -40,16 +45,41 @@ module Haste
private
def post_path
parsed_uri = URI.parse(server_url)
"#{parsed_uri.path}/documents"
end
def do_post(data)
connection.post('/documents', data)
connection.post(post_path, data)
end
def connection
@connection ||= Faraday.new(:url => server_url) do |c|
c.adapter Faraday.default_adapter
@connection ||= connection_set
end
def connection_set
return connection_https if @ssl_certs
connection_http
end
def connection_http
Faraday.new(:url => server_url) do |c|
connection_config(c)
end
end
def connection_https
Faraday.new(:url => server_url, :ssl => { :ca_path => @ssl_certs }) do |c|
connection_config(c)
end
end
def connection_config(config)
config.basic_auth(@server_user, @server_pass) if @server_user
config.adapter Faraday.default_adapter
end
def fail_with(msg)
raise Exception.new(msg)
end

View File

@@ -1,5 +1,5 @@
module Haste
VERSION = '0.2.2'
VERSION = '0.2.3'
end

View File

@@ -126,6 +126,42 @@ describe Haste::Uploader do
end
describe :post_path do
let(:post_path) { uploader.send(:post_path) }
context "when the server URL doesn't have a path" do
let(:base) { 'http://example.com/' }
it 'should return /documents' do
expect(post_path).to eq('/documents')
end
end
context "when the server URL has a path" do
let(:base) { 'http://example.com/friend' }
it 'should return /documents' do
expect(post_path).to eq('/friend/documents')
end
end
context "when the server URL has a path that ends with slash" do
let(:base) { 'http://example.com/friend/' }
it 'should return /documents appended to the path without a duplicate slash' do
expect(post_path).to eq('/friend/documents')
end
end
end
describe :server_url do
let(:server_url) { uploader.server_url }