001/*
002 *  Copyright (c) 2022-2023, Mybatis-Flex (fuhai999@gmail.com).
003 *  <p>
004 *  Licensed under the Apache License, Version 2.0 (the "License");
005 *  you may not use this file except in compliance with the License.
006 *  You may obtain a copy of the License at
007 *  <p>
008 *  http://www.apache.org/licenses/LICENSE-2.0
009 *  <p>
010 *  Unless required by applicable law or agreed to in writing, software
011 *  distributed under the License is distributed on an "AS IS" BASIS,
012 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 *  See the License for the specific language governing permissions and
014 *  limitations under the License.
015 */
016package com.mybatisflex.core.audit;
017
018
019public class ConsoleMessageCollector implements MessageCollector {
020
021    private SqlDebugPrinter printer = (sql, tookTimeMillis) -> {
022        if (tookTimeMillis != null) {
023            System.out.println("Flex exec sql took " + tookTimeMillis + " ms >>>  " + sql);
024        } else {
025            System.out.println("Flex exec sql >>>  " + sql);
026        }
027    };
028
029    public ConsoleMessageCollector() {
030    }
031
032    public ConsoleMessageCollector(SqlDebugPrinter printer) {
033        this.printer = printer;
034    }
035
036    @Override
037    public void collect(AuditMessage message) {
038        printer.print(message.getFullSql(), message.getElapsedTime());
039    }
040
041    public interface SqlDebugPrinter {
042
043        void print(String sql, Long tookTimeMillis);
044
045    }
046
047}