mirror of
https://github.com/NVIDIA/nvidia-container-toolkit
synced 2024-11-23 00:38:26 +00:00
3aeba886d4
This change moves most of the logging for the NVIDIA Container runtime from Info to Debug or Trace -- especially in the case where no modifications are requried. This removes execessive logging. Signed-off-by: Evan Lezar <elezar@nvidia.com>
90 lines
2.7 KiB
Go
90 lines
2.7 KiB
Go
/*
|
|
# Copyright (c) 2021, NVIDIA CORPORATION. All rights reserved.
|
|
#
|
|
# 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 oci
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/NVIDIA/nvidia-container-toolkit/internal/logger"
|
|
)
|
|
|
|
type modifyingRuntimeWrapper struct {
|
|
logger logger.Interface
|
|
runtime Runtime
|
|
ociSpec Spec
|
|
modifier SpecModifier
|
|
}
|
|
|
|
var _ Runtime = (*modifyingRuntimeWrapper)(nil)
|
|
|
|
// NewModifyingRuntimeWrapper creates a runtime wrapper that applies the specified modifier to the OCI specification
|
|
// before invoking the wrapped runtime. If the modifier is nil, the input runtime is returned.
|
|
func NewModifyingRuntimeWrapper(logger logger.Interface, runtime Runtime, spec Spec, modifier SpecModifier) Runtime {
|
|
if modifier == nil {
|
|
logger.Tracef("Using low-level runtime with no modification")
|
|
return runtime
|
|
}
|
|
|
|
rt := modifyingRuntimeWrapper{
|
|
logger: logger,
|
|
runtime: runtime,
|
|
ociSpec: spec,
|
|
modifier: modifier,
|
|
}
|
|
return &rt
|
|
}
|
|
|
|
// Exec checks whether a modification of the OCI specification is required and modifies it accordingly before exec-ing
|
|
// into the wrapped runtime.
|
|
func (r *modifyingRuntimeWrapper) Exec(args []string) error {
|
|
if HasCreateSubcommand(args) {
|
|
r.logger.Debugf("Create command detected; applying OCI specification modifications")
|
|
err := r.modify()
|
|
if err != nil {
|
|
return fmt.Errorf("could not apply required modification to OCI specification: %w", err)
|
|
}
|
|
r.logger.Debugf("Applied required modification to OCI specification")
|
|
}
|
|
|
|
r.logger.Debugf("Forwarding command to runtime %v", r.runtime.String())
|
|
return r.runtime.Exec(args)
|
|
}
|
|
|
|
// modify loads, modifies, and flushes the OCI specification using the defined Modifier
|
|
func (r *modifyingRuntimeWrapper) modify() error {
|
|
_, err := r.ociSpec.Load()
|
|
if err != nil {
|
|
return fmt.Errorf("error loading OCI specification for modification: %v", err)
|
|
}
|
|
|
|
err = r.ociSpec.Modify(r.modifier)
|
|
if err != nil {
|
|
return fmt.Errorf("error modifying OCI spec: %v", err)
|
|
}
|
|
|
|
err = r.ociSpec.Flush()
|
|
if err != nil {
|
|
return fmt.Errorf("error writing modified OCI specification: %v", err)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// String returns a string representation of the runtime.
|
|
func (r *modifyingRuntimeWrapper) String() string {
|
|
return fmt.Sprintf("modify on-create and forward to %s", r.runtime.String())
|
|
}
|