blob: c4ed2bc5980bf996edde610e37f06c23eb7c02a7 [file] [log] [blame]
// Copyright 2016 The LUCI Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// Package viewer is a support library to interact with the LogDog web app and
// log stream viewer.
package viewer
import (
"fmt"
"net/url"
"go.chromium.org/luci/logdog/common/types"
)
// LogDogViewerURLTag is a special LogDog tag that is recognized by the LogDog
// viewer as a link back to the source of the log stream (usually a build page).
const LogDogViewerURLTag = "logdog.viewer_url"
// GetURL generates a LogDog app viewer URL for the specified streams.
// Uses the plain-text endpoint for single stream paths, and the client-side endpoint for multi-stream paths.
func GetURL(host string, project string, paths ...types.StreamPath) string {
values := make([]string, len(paths))
for i, p := range paths {
values[i] = fmt.Sprintf("%s/%s", project, p)
}
u := url.URL{
Scheme: "https",
Host: host,
}
if len(values) == 1 {
u.Path = "logs/" + values[0]
} else {
u.Path = "v/"
u.RawQuery = url.Values{
"s": values,
}.Encode()
}
return u.String()
}