
Compartilhamento de arquivos fácil e rápido da linha de comando. Este código contém o servidor com tudo o que você precisa para criar sua própria instância.
Atualmente, o Transfer.Sh suporta os fornecedores S3 (Amazon S3), GDRIVE (Google Drive), Storj (STORJ) e sistema de arquivos local (local).
@stefanbenten é um mantenedor deste repositório e a pessoa que hospeda uma instalação pública bem conhecida do software no repositório.
De qualquer forma, os dois não estão relacionados, e o repositório não é o local para direcionar solicitações e problemas para qualquer instalação pubblica.
Nenhuma instalação pública de terceiros do software no repositório será anunciada ou mencionada no próprio repositório, por razões de segurança.
A posição oficial minha, @aspacca, como mantenedora do repositório, é que, se você deseja usar o software, deve hospedar sua própria instalação.
$ curl -v --upload-file ./hello.txt https://transfer.sh/hello.txt$ gpg --armor --symmetric --output - /tmp/hello.txt | curl --upload-file - https://transfer.sh/test.txt$ curl https://transfer.sh/1lDau/test.txt | gpg --decrypt --output /tmp/hello.txt$ curl -X PUT --upload-file nhgbhhj https://transfer.sh/test.txt/virustotal$ curl -X DELETE < X-Url-Delete Response Header URL > $ curl --upload-file ./hello.txt https://transfer.sh/hello.txt -H " Max-Downloads: 1 " # Limit the number of downloads$ curl --upload-file ./hello.txt https://transfer.sh/hello.txt -H " Max-Days: 1 " # Set the number of days before deletion$ curl --upload-file ./hello.txt https://your-transfersh-instance.tld/hello.txt -H " X-Encrypt-Password: test " # Encrypt the content sever side with AES265 using "test" as password$ curl https://your-transfersh-instance.tld/BAYh0/hello.txt -H " X-Decrypt-Password: test " # Decrypt the content sever side with AES265 using "test" as password O URL costumava solicitar a exclusão de um arquivo e retornou como cabeçalho de resposta.
curl -sD - --upload-file ./hello.txt https://transfer.sh/hello.txt | grep -i -E ' transfer.sh|x-url-delete '
x-url-delete: https://transfer.sh/hello.txt/BAYh0/hello.txt/PDw0NHPcqU
https://transfer.sh/hello.txt/BAYh0/hello.txtVeja bons exemplos de uso em exemplos.md
Crie link de download direto:
https://transfer.sh/1ldau/test.txt -> https://transfer.sh/get/1ldau/test.txt
Arquivo embutido:
https://transfer.sh/1ldau/test.txt -> https://transfer.sh/inline/1ldau/test.txt
| Parâmetro | Descrição | Valor | Env |
|---|---|---|---|
| ouvinte | Porta a ser usada para HTTP (: 80) | OUVINTE | |
| Listener de perfil | Porta a ser usada para o Profiler (: 6060) | Perfil_listener | |
| Force-https | redirecionar para https | falso | Force_https |
| TLS-Listener | Porta a ser usada para https (: 443) | Tls_listener | |
| TLS-Listener apenas | sinalizador para ativar apenas o ouvinte do TLS | Tls_listener_only | |
| TLS-CERT FILE | Caminho para o certificado TLS | TLS_CERT_FILE | |
| TLS-Private-Key | caminho para a chave privada do TLS | Tls_private_key | |
| Http-Auth-User | Usuário para Auth HTTP básico no upload | Http_auth_user | |
| Http-Auth-Pass | Passe para a auth http básica no upload | Http_auth_pass | |
| http-auth-htpasswd | Caminho do arquivo htpasswd para auth http básico no upload | Http_auth_htpasswd | |
| Http-Auth-ip-Whitelist | Lista de IPs separada por vírgula permitida sem ser desafiada uma autenticação HTTP | Http_auth_ip_whitelist | |
| IP-Whitelist | Lista de IPs separada por vírgula permitida para conectar -se ao serviço | Ip_whitelist | |
| Lista de IP-Black | Lista separada por vírgula de IPS não permissão para se conectar ao serviço | Ip_blacklist | |
| TEMP-PATH | Caminho para a pasta temporária | Temperatura do sistema | Temp_path |
| Web-Path | Caminho para arquivos da Web estática (para desenvolvimento ou front -end personalizado) | Web_path | |
| Path de proxy | prefixo de caminho quando o serviço é executado atrás de um proxy | Proxy_path | |
| port proxy | Porto do proxy quando o serviço é executado atrás de um proxy | Proxy_port | |
| Contato de email | Contato de e -mail para o front -end | Email_contact | |
| GA-KEY | Chave do Google Analytics para o front -end | Ga_key | |
| provedor | qual provedor de armazenamento usar | (S3, Storj, gdrive ou local) | |
| UserVoice-Key | Chave de voz do usuário para o front -end | Uservoice_key | |
| AWS-ACCESS-KEY | Chave de acesso da AWS | AWS_ACCESS_KEY | |
| Aws-secret-key | Chave de acesso da AWS | Aws_secret_key | |
| balde | Bucket da AWS | BALDE | |
| S3-EndPoint | Endpoint S3 personalizado. | S3_ENDPOINT | |
| S3-Region | região do balde S3 | Eu-West-1 | S3_region |
| S3-NO-MULTIPART | desativa o upload de múltiplas | falso | S3_NO_MULTIPART |
| S3-PATH-PATH | Força URLs de estilo de caminho, necessários para Minio. | falso | S3_Path_Style |
| Acesso Storj | Acesso para o projeto | Storj_access | |
| storj-bucket | Balde para usar no projeto | Storj_bucket | |
| baseado | Armazenamento de caminho para provedor local/de gdrive | Baseado | |
| GDRIVE-CLIENT-JSON-FILEPATH | Caminho para o OAuth Client JSON Config para provedor de gdrive | Gdrive_client_json_filepath | |
| GDRIVE-LOCAL-CONFIG-PATH | Caminho para armazenar cache de configuração de transferência local para provedor de gdrive | Gdrive_local_config_path | |
| tamanho de galinha de gdrive | O tamanho do pedaço para upload de gdrive em megabytes deve ser menor que a memória disponível (8 MB) | Gdrive_chunk_size | |
| Lets-Encrypt-Host | Hosts a serem usados para Certificados Lets Crypt (vírgula separada) | Anfitriões | |
| registro | Caminho para registrar o arquivo | REGISTRO | |
| cors-domina | Lista de domínios separados por vírgula | Cors_domains | |
| CLAMAV-HOST | Anfitrião para o recurso clamav | CLAMAV_HOST | |
| Perform-Clamav-Prescan | PrescAN todos os upload através do recurso CLAMAV (CLAMAV-HOST DEVE SER UM SOCKET LOCAL UNIX) | Perform_clamav_prescan | |
| limite de taxa | solicitação por minuto | Rate_limit | |
| Max-upload-size | tamanho máximo de upload em kilobytes | Max_upload_size | |
| Purge-dias | Número de dias após os uploads serem purgados automaticamente | Purge_Days | |
| intervalo de purga | intervalo em horas para executar a purga automática para (não aplicável a S3 e Storj) | Purge_Interval | |
| comprimento de toque aleatório | comprimento do token aleatório para o caminho de upload (o dobro do tamanho para excluir o caminho) | 6 | Random_token_length |
Se você deseja usar o TLS usando certificados Lets Crypt, defina o Lets-Encrypt-Host no seu domínio, defina o TLS-Listener como: 443 e ative o Force-Https.
Se você deseja usar o TLS usando seus próprios certificados, defina o TLS-Listener como: 443, Force-HTTPS, TLS-CERT-File e TLS-Private-Key.
Mudou para Go111module
go run main.go --provider=local --listener :8080 --temp-path=/tmp/ --basedir=/tmp/$ git clone [email protected]:dutchcoders/transfer.sh.git
$ cd transfer.sh
$ go build -o transfersh main.goPara facilitar a implantação, criamos um contêiner oficial do Docker. Existem duas variantes, diferindo apenas pelas quais o usuário executa o processo.
O padrão será executado como root :
docker run --publish 8080:8080 dutchcoders/transfer.sh:latest --provider local --basedir /tmp/ O marcado com o sufixo -noroot usará 5000 como UID e GID:
docker run --publish 8080:8080 dutchcoders/transfer.sh:latest-noroot --provider local --basedir /tmp/Você também pode construir o contêiner. Isso permite que você escolha qual UID/GID será usado, por exemplo, ao usar as montagens NFS:
# Build arguments:
# * RUNAS: If empty, the container will run as root.
# Set this to anything to enable UID/GID selection.
# * PUID: UID of the process. Needs RUNAS != "". Defaults to 5000.
# * PGID: GID of the process. Needs RUNAS != "". Defaults to 5000.
docker build -t transfer.sh-noroot --build-arg RUNAS=doesntmatter --build-arg PUID=1337 --build-arg PGID=1338 . Para o uso com um balde do AWS S3, você só precisa especificar as seguintes opções:
--provider s3AWS_ACCESS_KEY )AWS_SECRET_KEY )BUCKET variável de ambiente)S3_REGION )Se você especificar a região S3, não precisará definir o URL do ponto de extremidade, pois o terminal correto será usado automaticamente.
Para usar um provedor S3 não-AWS personalizado, você precisa especificar o terminal conforme definido no seu provedor de nuvem.
Para usar a rede STORJ como provedor de armazenamento, você precisa especificar os seguintes sinalizadores:
--provider storjVocê precisa criar uma concessão de acesso (ou copiá -la a partir da configuração Uplink) e um balde em preparação.
Para começar, faça login na sua conta e vá para o menu de concessão de acesso e inicie o assistente no canto superior direito.
Digite o nome da concessão de acesso, pressione a seguir e restrinja -o conforme necessário/preferido. Posteriormente, continue na CLI ou dentro do navegador. Em seguida, você será solicitado uma senha usada como chave de criptografia. Certifique -se de salvá -lo em um local seguro. Sem ele, você perderá a capacidade de descriptografar seus arquivos!
Posteriormente, você pode copiar a concessão de acesso e iniciar a inicialização do terminal de transferência.sh. Recomenda -se fornecer a concessão de acesso e o nome do balde como variáveis ENV para segurança aprimorada.
Exemplo:
export STORJ_BUCKET=<BUCKET NAME>
export STORJ_ACCESS=<ACCESS GRANT>
transfer.sh --provider storj
Para o uso no Google Drive, você precisa especificar as seguintes opções:
Você precisa criar um ID do cliente OAuth no console.cloud.google.com, baixar o arquivo e colocá -lo em um diretório seguro.
go run main.go --provider gdrive --basedir /tmp/ --gdrive-client-json-filepath /[credential_dir] --gdrive-local-config-path [directory_to_save_config]
transfer () (if [ $# -eq 0 ] ; then printf " No arguments specified.nUsage:n transfer <file|directory>n ... | transfer <file_name>n " >&2 ; return 1 ; fi ; file_name= $( basename " $1 " ) ; if [ -t 0 ] ; then file= " $1 " ; if [ ! -e " $file " ] ; then echo " $file : No such file or directory " >&2 ; return 1 ; fi ; if [ -d " $file " ] ; then cd " $file " || return 1 ; file_name= " $file_name .zip " ; set -- zip -r -q - . ; else set -- cat " $file " ; fi ; else set -- cat ; fi ; url= $( " $@ " | curl --silent --show-error --progress-bar --upload-file " - " " https://transfer.sh/ $file_name " ) ; echo " $url " ; ) $ transfer hello.txt
transfer ()
{
local file
declare -a file_array
file_array=( " ${ @ } " )
if [[ " ${file_array[@]} " == " " || " ${1} " == " --help " || " ${1} " == " -h " ]]
then
echo " ${0} - Upload arbitrary files to " transfer.sh " . "
echo " "
echo " Usage: ${0} [options] [<file>]... "
echo " "
echo " OPTIONS: "
echo " -h, --help "
echo " show this message "
echo " "
echo " EXAMPLES: "
echo " Upload a single file from the current working directory: "
echo " ${0} " image.img " "
echo " "
echo " Upload multiple files from the current working directory: "
echo " ${0} " image.img " " image2.img " "
echo " "
echo " Upload a file from a different directory: "
echo " ${0} " /tmp/some_file " "
echo " "
echo " Upload all files from the current working directory. Be aware of the webserver's rate limiting!: "
echo " ${0} * "
echo " "
echo " Upload a single file from the current working directory and filter out the delete token and download link: "
echo " ${0} " image.img " | awk --field-separator= " : " '/Delete token:/ { print $ 2 } /Download link:/ { print $ 2 }' "
echo " "
echo " Show help text from " transfer.sh " : "
echo " curl --request GET " https://transfer.sh " "
return 0
else
for file in " ${file_array[@]} "
do
if [[ ! -f " ${file} " ]]
then
echo -e " e[01;31m' ${file} ' could not be found or is not a file.e[0m " >&2
return 1
fi
done
unset file
fi
local upload_files
local curl_output
local awk_output
du -c -k -L " ${file_array[@]} " >&2
# be compatible with "bash"
if [[ " ${ZSH_NAME} " == " zsh " ]]
then
read $' upload_files? e [01;31mDo you really want to upload the above files ( ' " ${ # file_array[@]} " $' ) to "transfer.sh"? (Y/n): e [0m '
elif [[ " ${BASH} " == * " bash " * ]]
then
read -p $' e [01;31mDo you really want to upload the above files ( ' " ${ # file_array[@]} " $' ) to "transfer.sh"? (Y/n): e [0m ' upload_files
fi
case " ${upload_files :- y} " in
" y " | " Y " )
# for the sake of the progress bar, execute "curl" for each file.
# the parameters "--include" and "--form" will suppress the progress bar.
for file in " ${file_array[@]} "
do
# show delete link and filter out the delete token from the response header after upload.
# it is important to save "curl's" "stdout" via a subshell to a variable or redirect it to another command,
# which just redirects to "stdout" in order to have a sane output afterwards.
# the progress bar is redirected to "stderr" and is only displayed,
# if "stdout" is redirected to something; e.g. ">/dev/null", "tee /dev/null" or "| <some_command>".
# the response header is redirected to "stdout", so redirecting "stdout" to "/dev/null" does not make any sense.
# redirecting "curl's" "stderr" to "stdout" ("2>&1") will suppress the progress bar.
curl_output= $( curl --request PUT --progress-bar --dump-header - --upload-file " ${file} " " https://transfer.sh/ " )
awk_output= $( awk
' gsub("r", "", $0) && tolower($1) ~ /x-url-delete/
{
delete_link=$2;
print "Delete command: curl --request DELETE " """delete_link""";
gsub(".*/", "", delete_link);
delete_token=delete_link;
print "Delete token: " delete_token;
}
END{
print "Download link: " $0;
} ' <<< " ${curl_output} " )
# return the results via "stdout", "awk" does not do this for some reason.
echo -e " ${awk_output} n "
# avoid rate limiting as much as possible; nginx: too many requests.
if (( ${ # file_array[@]} > 4 ))
then
sleep 5
fi
done
;;
" n " | " N " )
return 1
;;
* )
echo -e " e[01;31mWrong input: ' ${upload_files} '.e[0m " >&2
return 1
esac
}$ ls -lh
total 20M
-rw-r--r-- 1 < some_username > < some_username > 10M Apr 4 21:08 image.img
-rw-r--r-- 1 < some_username > < some_username > 10M Apr 4 21:08 image2.img
$ transfer image *
10240K image2.img
10240K image.img
20480K total
Do you really want to upload the above files (2) to " transfer.sh " ? (Y/n):
# ####################################################################################################################################################################################################################################### 100.0%
Delete command: curl --request DELETE " https://transfer.sh/wJw9pz/image2.img/mSctGx7pYCId "
Delete token: mSctGx7pYCId
Download link: https://transfer.sh/wJw9pz/image2.img
# ####################################################################################################################################################################################################################################### 100.0%
Delete command: curl --request DELETE " https://transfer.sh/ljJc5I/image.img/nw7qaoiKUwCU "
Delete token: nw7qaoiKUwCU
Download link: https://transfer.sh/ljJc5I/image.img
$ transfer " image.img " | awk --field-separator= " : " ' /Delete token:/ { print $2 } /Download link:/ { print $2 } '
10240K image.img
10240K total
Do you really want to upload the above files (1) to " transfer.sh " ? (Y/n):
# ####################################################################################################################################################################################################################################### 100.0%
tauN5dE3fWJe
https://transfer.sh/MYkuqn/image.imgContribuições são bem -vindas.
Remco Verhoef
UVIS Grinfelds
Andrea Spacca
Stefan Benten
Código e documentação Copyright 2011-2018 Remco Verhoef. Código e documentação Copyright 2018-2020 Andrea Spacca. Código e documentação Copyright 2020- Andrea Spacca e Stefan Benten.
Código liberado sob a licença do MIT.