// Copyright 2012-2023 The NATS 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 builtin

import (
	
	
)

// JsonEncoder is a JSON Encoder implementation for EncodedConn.
// This encoder will use the builtin encoding/json to Marshal
// and Unmarshal most types, including structs.
//
// Deprecated: Encoded connections are no longer supported.
type JsonEncoder struct {
	// Empty
}

// Encode
//
// Deprecated: Encoded connections are no longer supported.
func ( *JsonEncoder) ( string,  any) ([]byte, error) {
	,  := json.Marshal()
	if  != nil {
		return nil, 
	}
	return , nil
}

// Decode
//
// Deprecated: Encoded connections are no longer supported.
func ( *JsonEncoder) ( string,  []byte,  any) ( error) {
	switch arg := .(type) {
	case *string:
		// If they want a string and it is a JSON string, strip quotes
		// This allows someone to send a struct but receive as a plain string
		// This cast should be efficient for Go 1.3 and beyond.
		 := string()
		if strings.HasPrefix(, `"`) && strings.HasSuffix(, `"`) {
			* = [1 : len()-1]
		} else {
			* = 
		}
	case *[]byte:
		* = 
	default:
		 = json.Unmarshal(, )
	}
	return
}