File go-ipfs.spec of Package go-ipfs

# spec file for package go-ipfs
# Copyright (c) 2019 SUSE LINUX GmbH, Nuernberg, Germany.
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.

# Please submit bugfixes or comments via

%define debug_package %{nil}
%define repo
Name:           go-ipfs
Version:        0.4.22
Release:        0
Summary:        IPFS implementation in Go
License:        MIT
Group:          Productivity/Networking/Other
URL:            https://%{repo}
#Source0:        https://%{repo}/archive/v%{version}.tar.gz
# bundle with all deps from ./ and ./ :
Source0:        go-ipfs-min.tar

BuildRequires:  git
BuildRequires:  go >= 1.12
BuildRequires:  systemd-rpm-macros
Requires:       fuse

IPFS is a global, versioned, peer-to-peer filesystem. It combines good ideas from Git, BitTorrent, Kademlia, SFS, and the Web. It is like a single bittorrent swarm, exchanging git objects. IPFS provides an interface as simple as the HTTP web, but with permanence built in. You can also mount the world at /ipfs.

%setup -q -n mod
mkdir -p ../pkg/mod/ ; cp -al * ../pkg/mod/

export GO111MODULE=on
export GOPATH="$(cd ../ ; pwd)"
cd %{repo}@v%{version}
go build -buildmode=pie -o ./cmd/ipfs/ipfs ./cmd/ipfs

mkdir -p %{buildroot}%{_bindir}
mkdir -p %{buildroot}%{_userunitdir}
mkdir -p %{buildroot}%{_unitdir}
mkdir -p %{buildroot}%{_datadir}/bash-completion/completions/ipfs

cp %{repo}@v%{version}/cmd/ipfs/ipfs %{buildroot}%{_bindir}
cat << EOF >>  %{buildroot}%{_userunitdir}/ipfs.service
Description=InterPlanetary File System (IPFS) daemon

ExecStart=/usr/bin/ipfs daemon

cat << EOF >> %{buildroot}%{_unitdir}/ipfs@.service
Description=InterPlanetary File System (IPFS) daemon

ExecStart=/usr/bin/ipfs daemon

cp %{repo}@v%{version}/misc/completion/ipfs-completion.bash %{buildroot}%{_datadir}/bash-completion/completions/ipfs

%service_add_pre ipfs@.service

%service_add_post ipfs@.service

%service_del_preun ipfs@.service

%service_del_postun ipfs@.service

%license %{repo}@*/LICENSE*
%doc %{repo}@*/docs/*