working commit

This commit is contained in:
2026-03-16 20:55:36 +02:00
parent 5c1da77f4c
commit 13b1905e05
31 changed files with 177 additions and 151 deletions
+31 -31
View File
@@ -30,7 +30,7 @@ type Referer struct {
}
func ParsePath(rawpath string) (*Referer, error) {
repo := &Referer{
ref := &Referer{
values: url.Values{},
}
if !strings.Contains(rawpath, "://") {
@@ -38,71 +38,71 @@ func ParsePath(rawpath string) (*Referer, error) {
}
urlobj, err := url.Parse(rawpath)
if err != nil {
return repo, err
return ref, err
}
if urlobj.User != nil {
repo.user = urlobj.User.Username()
repo.pass, _ = urlobj.User.Password()
ref.user = urlobj.User.Username()
ref.pass, _ = urlobj.User.Password()
urlobj.User = nil
}
repo.resource = path.Join("/", urlobj.Path)
ref.resource = path.Join("/", urlobj.Path)
urlobj.Path = "/"
repo.urlobj = urlobj
repo.values = urlobj.Query()
return repo, err
ref.urlobj = urlobj
ref.values = urlobj.Query()
return ref, err
}
func (repo *Referer) Raw() string {
res := path.Join(repo.urlobj.Host, repo.resource)
query := repo.values.Encode()
func (ref *Referer) Raw() string {
res := path.Join(ref.urlobj.Host, ref.resource)
query := ref.values.Encode()
if query != "" {
return res + "?" + query
}
return res
}
func (repo *Referer) SetResource(resource string) {
repo.resource = path.Join("/", resource)
func (ref *Referer) SetResource(resource string) {
ref.resource = path.Join("/", resource)
}
func (repo *Referer) JoinResource(resource string) {
repo.resource = path.Join("/", repo.resource, resource)
func (ref *Referer) JoinResource(resource string) {
ref.resource = path.Join("/", ref.resource, resource)
}
func (repo *Referer) PathType(typ string) {
repo.values.Set("pathType", typ)
func (ref *Referer) PathType(typ string) {
ref.values.Set("pathType", typ)
}
func (repo *Referer) DryRun(yesno bool) {
repo.values.Set("dryRun", strconv.FormatBool(yesno))
func (ref *Referer) DryRun(yesno bool) {
ref.values.Set("dryRun", strconv.FormatBool(yesno))
}
func (repo *Referer) FileEP() string {
curl := repo.urlobj.JoinPath("/v3/api/file/", repo.resource)
func (ref *Referer) FileEP() string {
curl := ref.urlobj.JoinPath("/v3/api/file/", ref.resource)
return curl.String()
}
func (repo *Referer) FilesEP() string {
curl := repo.urlobj.JoinPath("/v3/api/files/", repo.resource)
func (ref *Referer) FilesEP() string {
curl := ref.urlobj.JoinPath("/v3/api/files/", ref.resource)
return curl.String()
}
func (repo *Referer) CollectionEP() string {
curl := repo.urlobj.JoinPath("/v3/api/collection/", repo.resource)
func (ref *Referer) CollectionEP() string {
curl := ref.urlobj.JoinPath("/v3/api/collection/", ref.resource)
return curl.String()
}
func (repo *Referer) CollectionsEP() string {
curl := repo.urlobj.JoinPath("/v3/api/collections/", repo.resource)
func (ref *Referer) CollectionsEP() string {
curl := ref.urlobj.JoinPath("/v3/api/collections/", ref.resource)
return curl.String()
}
func (repo *Referer) Userinfo() (string, string) {
return repo.user, repo.pass
func (ref *Referer) Userinfo() (string, string) {
return ref.user, ref.pass
}
func (repo *Referer) SetUserinfo(user, pass string) {
func (ref *Referer) SetUserinfo(user, pass string) {
if user != "" && pass != "" {
repo.user, repo.pass = user, pass
ref.user, ref.pass = user, pass
}
}