org.neo4j.driver.internal.cluster.ClusterComposition Maven / Gradle / Ivy
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [http://neo4j.com]
*
* This file is part of Neo4j.
*
* 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 org.neo4j.driver.internal.cluster;
import java.util.LinkedHashSet;
import java.util.Objects;
import java.util.Set;
import java.util.function.Function;
import org.neo4j.driver.Record;
import org.neo4j.driver.Value;
import org.neo4j.driver.internal.BoltServerAddress;
public final class ClusterComposition
{
private static final long MAX_TTL = Long.MAX_VALUE / 1000L;
private static final Function OF_BoltServerAddress = value -> new BoltServerAddress( value.asString() );
private final Set readers;
private final Set writers;
private final Set routers;
private final long expirationTimestamp;
private final String databaseName;
private ClusterComposition( long expirationTimestamp, String databaseName )
{
this.readers = new LinkedHashSet<>();
this.writers = new LinkedHashSet<>();
this.routers = new LinkedHashSet<>();
this.expirationTimestamp = expirationTimestamp;
this.databaseName = databaseName;
}
/**
* For testing
*/
public ClusterComposition(
long expirationTimestamp,
Set readers,
Set writers,
Set routers,
String databaseName )
{
this( expirationTimestamp, databaseName );
this.readers.addAll( readers );
this.writers.addAll( writers );
this.routers.addAll( routers );
}
public boolean hasWriters()
{
return !writers.isEmpty();
}
public boolean hasRoutersAndReaders()
{
return !routers.isEmpty() && !readers.isEmpty();
}
public Set readers()
{
return new LinkedHashSet<>( readers );
}
public Set writers()
{
return new LinkedHashSet<>( writers );
}
public Set routers()
{
return new LinkedHashSet<>( routers );
}
public long expirationTimestamp()
{
return this.expirationTimestamp;
}
public String databaseName()
{
return databaseName;
}
@Override
public boolean equals( Object o )
{
if ( this == o )
{
return true;
}
if ( o == null || getClass() != o.getClass() )
{
return false;
}
ClusterComposition that = (ClusterComposition) o;
return expirationTimestamp == that.expirationTimestamp &&
Objects.equals( databaseName, that.databaseName ) &&
Objects.equals( readers, that.readers ) &&
Objects.equals( writers, that.writers ) &&
Objects.equals( routers, that.routers );
}
@Override
public int hashCode()
{
return Objects.hash( readers, writers, routers, expirationTimestamp, databaseName );
}
@Override
public String toString()
{
return "ClusterComposition{" +
"readers=" + readers +
", writers=" + writers +
", routers=" + routers +
", expirationTimestamp=" + expirationTimestamp +
", databaseName=" + databaseName +
'}';
}
public static ClusterComposition parse( Record record, long now )
{
if ( record == null )
{
return null;
}
final ClusterComposition result = new ClusterComposition( expirationTimestamp( now, record ), record.get( "db" ).asString( null ) );
record.get( "servers" ).asList( (Function) value ->
{
result.servers( value.get( "role" ).asString() )
.addAll( value.get( "addresses" ).asList( OF_BoltServerAddress ) );
return null;
} );
return result;
}
private static long expirationTimestamp( long now, Record record )
{
long ttl = record.get( "ttl" ).asLong();
long expirationTimestamp = now + ttl * 1000;
if ( ttl < 0 || ttl >= MAX_TTL || expirationTimestamp < 0 )
{
expirationTimestamp = Long.MAX_VALUE;
}
return expirationTimestamp;
}
private Set servers( String role )
{
switch ( role )
{
case "READ":
return readers;
case "WRITE":
return writers;
case "ROUTE":
return routers;
default:
throw new IllegalArgumentException( "invalid server role: " + role );
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy