// Copyright © 2019 The Knative 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 service import ( "github.com/knative/client/pkg/kn/commands" hprinters "github.com/knative/client/pkg/printers" servingv1alpha1 "github.com/knative/serving/pkg/apis/serving/v1alpha1" metav1beta1 "k8s.io/apimachinery/pkg/apis/meta/v1beta1" "k8s.io/apimachinery/pkg/runtime" ) // ServiceListHandlers adds print handlers for service list command func ServiceListHandlers(h hprinters.PrintHandler) { kServiceColumnDefinitions := []metav1beta1.TableColumnDefinition{ {Name: "Name", Type: "string", Description: "Name of the knative service."}, {Name: "Domain", Type: "string", Description: "Domain name of the knative service."}, //{Name: "LastCreatedRevision", Type: "string", Description: "Name of last revision created."}, //{Name: "LastReadyRevision", Type: "string", Description: "Name of last ready revision."}, {Name: "Generation", Type: "integer", Description: "Sequence number of 'Generation' of the service that was last processed by the controller."}, {Name: "Age", Type: "string", Description: "Age of the service."}, {Name: "Conditions", Type: "string", Description: "Conditions describing statuses of service components."}, {Name: "Ready", Type: "string", Description: "Ready condition status of the service."}, {Name: "Reason", Type: "string", Description: "Reason for non-ready condition of the service."}, } h.TableHandler(kServiceColumnDefinitions, printKService) h.TableHandler(kServiceColumnDefinitions, printKServiceList) } // Private functions // printKServiceList populates the knative service list table rows func printKServiceList(kServiceList *servingv1alpha1.ServiceList, options hprinters.PrintOptions) ([]metav1beta1.TableRow, error) { rows := make([]metav1beta1.TableRow, 0, len(kServiceList.Items)) for _, ksvc := range kServiceList.Items { r, err := printKService(&ksvc, options) if err != nil { return nil, err } rows = append(rows, r...) } return rows, nil } // printKService populates the knative service table rows func printKService(kService *servingv1alpha1.Service, options hprinters.PrintOptions) ([]metav1beta1.TableRow, error) { name := kService.Name domain := kService.Status.RouteStatusFields.DeprecatedDomain //lastCreatedRevision := kService.Status.LatestCreatedRevisionName //lastReadyRevision := kService.Status.LatestReadyRevisionName generation := kService.Status.ObservedGeneration age := commands.TranslateTimestampSince(kService.CreationTimestamp) conditions := commands.ConditionsValue(kService.Status.Conditions) ready := commands.ReadyCondition(kService.Status.Conditions) reason := commands.NonReadyConditionReason(kService.Status.Conditions) row := metav1beta1.TableRow{ Object: runtime.RawExtension{Object: kService}, } row.Cells = append(row.Cells, name, domain, //lastCreatedRevision, //lastReadyRevision, generation, age, conditions, ready, reason) return []metav1beta1.TableRow{row}, nil }