blob: a7c709cb219981f94160b6ca082d7e647fd6150b [file] [log] [blame]
// Licensed to the Apache Software Foundation (ASF) under one or more
// contributor license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright ownership.
// The ASF licenses this file to You 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.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Google.Protobuf;
namespace Apache.Arrow.Flight
{
public class FlightDescriptor
{
private readonly Protocol.FlightDescriptor _flightDescriptor;
private FlightDescriptor(ByteString command)
{
_flightDescriptor = new Protocol.FlightDescriptor()
{
Cmd = command,
Type = Protocol.FlightDescriptor.Types.DescriptorType.Cmd
};
}
private FlightDescriptor(params string[] paths)
{
_flightDescriptor = new Protocol.FlightDescriptor()
{
Type = Protocol.FlightDescriptor.Types.DescriptorType.Path
};
foreach (var path in paths)
{
_flightDescriptor.Path.Add(path);
}
}
public static FlightDescriptor CreateCommandDescriptor(byte[] command)
{
return new FlightDescriptor(ByteString.CopyFrom(command));
}
public static FlightDescriptor CreateCommandDescriptor(string command)
{
return new FlightDescriptor(ByteString.CopyFromUtf8(command));
}
public static FlightDescriptor CreatePathDescriptor(params string[] paths)
{
return new FlightDescriptor(paths);
}
internal FlightDescriptor(Protocol.FlightDescriptor flightDescriptor)
{
if (flightDescriptor.Type != Protocol.FlightDescriptor.Types.DescriptorType.Cmd && flightDescriptor.Type != Protocol.FlightDescriptor.Types.DescriptorType.Path)
{
throw new NotSupportedException();
}
_flightDescriptor = flightDescriptor;
}
internal Protocol.FlightDescriptor ToProtocol()
{
return _flightDescriptor;
}
public FlightDescriptorType Type => (FlightDescriptorType)_flightDescriptor.Type;
public IEnumerable<string> Paths => _flightDescriptor.Path;
public ByteString Command => _flightDescriptor.Cmd;
public override int GetHashCode()
{
return _flightDescriptor.GetHashCode();
}
public override bool Equals(object obj)
{
if (obj is FlightDescriptor other)
{
return Equals(_flightDescriptor, other._flightDescriptor);
}
return false;
}
}
}