Statistics
| Branch: | Tag: | Revision:

root / src / main / scala / gr / grnet / aquarium / message / avro / AvroHelpers.scala @ 405ef20a

History | View | Annotate | Download (2.8 kB)

1
/*
2
 * Copyright 2011-2012 GRNET S.A. All rights reserved.
3
 *
4
 * Redistribution and use in source and binary forms, with or
5
 * without modification, are permitted provided that the following
6
 * conditions are met:
7
 *
8
 *   1. Redistributions of source code must retain the above
9
 *      copyright notice, this list of conditions and the following
10
 *      disclaimer.
11
 *
12
 *   2. Redistributions in binary form must reproduce the above
13
 *      copyright notice, this list of conditions and the following
14
 *      disclaimer in the documentation and/or other materials
15
 *      provided with the distribution.
16
 *
17
 * THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
18
 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
21
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
24
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
25
 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
27
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28
 * POSSIBILITY OF SUCH DAMAGE.
29
 *
30
 * The views and conclusions contained in the software and
31
 * documentation are those of the authors and should not be
32
 * interpreted as representing official policies, either expressed
33
 * or implied, of GRNET S.A.
34
 */
35

    
36
package gr.grnet.aquarium.message.avro
37

    
38
import gr.grnet.aquarium.util.json.JsonHelpers
39
import java.io.{OutputStream, ByteArrayOutputStream}
40
import org.apache.avro.Schema
41
import org.apache.avro.generic.{GenericRecord, GenericDatumWriter}
42
import org.apache.avro.io.{JsonEncoder, EncoderFactory}
43
import org.apache.avro.specific.{SpecificDatumWriter, SpecificRecord}
44

    
45

    
46
/**
47
 *
48
 * @author Christos KK Loverdos <loverdos@gmail.com>
49
 */
50
object AvroHelpers {
51
  def getJsonEncoder(schema: Schema, out: OutputStream): JsonEncoder = {
52
    val encoder = EncoderFactory.get().jsonEncoder(schema, out)
53
    val jsonGenerator = JsonHelpers.getJsonGenerator(out)
54
    encoder.configure(jsonGenerator)
55
  }
56

    
57
  def jsonStringOfSpecificRecord[T <: SpecificRecord](t: T): String = {
58
    val schema = t.getSchema()
59
    val out = new ByteArrayOutputStream()
60
    val encoder = getJsonEncoder(schema, out)
61
    val writer = new SpecificDatumWriter[T](schema)
62

    
63
    writer.write(t, encoder)
64
    encoder.flush()
65
    out.toString
66
  }
67

    
68
  def jsonStringOfGenericRecord[T <: GenericRecord](t: T): String = {
69
    val schema = t.getSchema()
70
    val out = new ByteArrayOutputStream()
71
    val encoder = getJsonEncoder(schema, out)
72
    val writer = new GenericDatumWriter[T](schema)
73

    
74
    writer.write(t, encoder)
75
    encoder.flush()
76
    out.toString
77
  }
78
}