src/behaviours/zotonic_scomp.erl

%% @author Marc Worrell <marc@worrell.nl>
%% @copyright 2009 Marc Worrell
%%
%% Copyright 2009 Marc Worrell
%%
%% 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.
%%
%% @doc Scomp behaviour definition.  A scomp is a screen component that can optionally be cached.
%%
%%      render(Params, Vars, Context) -> {ok, NewContext} | {ok, iolist()} | {error, Error}
%%
%%      vary(Params, Context) -> {EssentialParams, MaxAge, Vary} | nocache | default
%%
%%          Params = proplist()
%%          EssentialParams = proplist()  (proplist with params that make differences in the cache key)
%%          MaxAge = integer()
%%          Vary = TermList  (used as dependencies for the depcache)


-module(zotonic_scomp).

-callback render(Params :: list(), Vars :: map(), Context :: z:context()) -> term().
-callback vary(Params :: list(), Context :: z:context()) -> atom().