All Downloads are FREE. Search and download functionalities are using the official Maven repository.

core.pure.extensions.extension.pure Maven / Gradle / Ivy

// Copyright 2020 Goldman Sachs
//
// 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.

import meta::java::metamodel::*;
import meta::pure::graphFetch::executionPlan::*;
import meta::pure::graphFetch::routing::*;
import meta::pure::graphFetch::*;
import meta::pure::tds::schema::*;
import meta::pure::executionPlan::*;
import meta::pure::router::routing::*;
import meta::pure::router::clustering::*;
import meta::pure::mapping::*;
import meta::core::runtime::*;
import meta::pure::store::*;
import meta::pure::extension::*;
import meta::external::format::shared::*;

Class meta::pure::extension::Extension
{
  type : String[1];

  // Store Extension --------------------------------------------------------------------------
  availableStores : StoreContract[*];
  // -------------------------------------------------------------------------- Store Extension

  // External Format Extension ----------------------------------------------------------------
  // TODO: We should change this package to better align with our strategy to have binding as core feature
  availableExternalFormats : meta::external::format::shared::ExternalFormatContract[*];
  // ---------------------------------------------------------------- External Format Extension

  // Feature Extension ------------------------------------------------------------------------
  availableFeatures : FeatureExtension[*];
  // ------------------------------------------------------------------------ Feature Extension

  routerExtensions()
  {
    $this.availableStores->concatenate($this.availableFeatures)->cast(@meta::pure::router::extension::RouterExtension)
  } : meta::pure::router::extension::RouterExtension[*];

  executionPlanExtensions()
  {
    $this.availableStores->concatenate($this.availableFeatures)->cast(@meta::pure::executionPlan::extension::ExecutionPlanExtension)
  } : meta::pure::executionPlan::extension::ExecutionPlanExtension[*];

  // Platform binding -------------------------------------------------------------------------
  availablePlatformBindings : meta::pure::executionPlan::platformBinding::PlatformBinding[*];
  // ------------------------------------------------------------------------- Platform binding

  // ExecutePlan
  executionPlan_execution_processNode : Function<{Mapping[1], Runtime[1], Pair[*], meta::pure::extension::Extension[*] -> Function<{Nil[1] -> Result[1]}>[*]}>[0..1];
  executionPlan_execution_allNodes : Function<{meta::pure::extension::Extension[*] -> Function<{Nil[1] ->  ExecutionNode[*]}>[*]}>[0..1];
  executionPlan_execution_buildVariableTemplateString : Function<{String[1], Any[1], meta::pure::metamodel::type::Type[1] -> Function<{Nil[1] ->  String[1]}>[*]}>[0..1];

  // M2M concern that leaks to CSV and Flatdata. Remove when CSV and Flatdata are absorbed by ExternalFormat ------------------------------
  graphExtension_calculateSourceTree : Function<{RootGraphFetchTree[1] -> Function<{Nil[1]->RootGraphFetchTree[1]}>[1]}>[0..1];
  // --------------------------------------------------------------------------------------------------------------------------------------

  //---------------------------------------------------------------------------------------------------------------------------------------
  // meta::pure::tds::join is WRONGLY in Relational because it uses JoinType
  // meta::pure::tds::extensions::columnValueDifference is WRONGLY in Relational because it uses Join
  // meta::pure::tds::project(tds:meta::relational::mapping::TableTDS[1], columnFunctions:ColumnSpecification[*]) is in relational because of TableTDS but it should be deleted as TableTDS is a TabularDataSet
  tdsSchema_resolveSchemaImpl : Function<{FunctionExpression[1], Map>[1], Extension[*] -> Pair, Function<{->SchemaState[1]}>>[*]}>[0..1];
  //---------------------------------------------------------------------------------------------------------------------------------------

  // testedBy navigates the Database structure. Should probably delete --------------------------------------------------------------------
  testExtension_testedBy : Function<{ReferenceUsage[1], Extension[*] -> Function<{TestedByResult[1]->TestedByResult[1]}>[*]}>[0..1];
  //---------------------------------------------------------------------------------------------------------------------------------------

  // logActivities implementation is in Relationl because it casts Activity to RelationalActivity -----------------------------------------
  logActivities : Function<{meta::pure::mapping::Activity[*] -> Nil[0]}>[0..1];
  //---------------------------------------------------------------------------------------------------------------------------------------

  // Used by the graph serializer to ensure we push serialize Test models stored in the system area ---------------------------------------
  validTestPackages : String[*];
  //---------------------------------------------------------------------------------------------------------------------------------------

  // Serializer Extension ---------------------------------------------------------------------
  serializerExtension : Function<{String[1]->String[1]}>[0..1];
  serializerExtensionByProtocolVersion : Pair[*];

  serializerExtension(version : String[1])
  {
    let ext = $this;
    $this.serializerExtensionByProtocolVersion->filter(p|$p.first == $version)->match([
      { found : Pair [1] | $found.second; },
      { missing : Pair [0] |
          let serializer = $this.fetchSerializerExtension($version);
          if($serializer->isEmpty(),
            | $serializer,
            | $ext->mutateAdd('serializerExtensionByProtocolVersion', pair($version, $serializer->toOne()));
                $serializer->toOne();
          );
      }]);
  } : SerializerExtension[0..1];

  fetchSerializerExtension(version : String[1])
  {
    if ($this.serializerExtension->isEmpty(),
      |[],
      |let funcString = $this.serializerExtension->toOne()->eval($version);
       let func = $funcString->forgivingPathToElement()->cast(@Function<{String[1]->SerializerExtension[1]}>);
       if($func->isEmpty(),
          |[],
          |$func->toOne()->eval($this.type)
       );
    )
  } : SerializerExtension[0..1];
  // --------------------------------------------------------------------- Serializer Extension

  // Module Extension ---------------------------------------------------------------------
  moduleExtensions : ModuleExtension[*];

  moduleExtension(module:String[1])
  {
    $this.moduleExtensions->filter(f|$f.module == $module)->first()
  } : ModuleExtension[0..1];
  // --------------------------------------------------------------------- Module Extension
}

Class meta::pure::extension::SerializerExtension
{
}

Class meta::pure::extension::FeatureExtension extends meta::pure::router::extension::RouterExtension, meta::pure::executionPlan::extension::ExecutionPlanExtension
{
  id : String[1];
}

Class meta::pure::extension::ModuleExtension
{
    module : String[1];
}




// Extension printing ------------------------------------------------------------------------------

###Pure
import meta::pure::extension::*;
import meta::pure::extension::print::*;
import meta::pure::store::*;
import meta::external::format::shared::*;
import meta::pure::executionPlan::platformBinding::*;


function meta::pure::extension::print::printExtensions(extensions: Extension[*]): String[1]
{
  $extensions->sortBy(x | $x.type->toLower())->map(ext | $ext->printExtension(1))->joinStrings('[\n', ',\n\n', '\n]')
}

function meta::pure::extension::print::printExtension(extension: Extension[1], depth: Integer[1]): String[1]
{
  let indent = indent($depth);

  let storeDetails =
    if ($extension.availableStores->isEmpty(),
        | '',
        | $extension.availableStores
            ->map(s | $s->printStoreContract($depth + 2))
            ->joinStrings(indent($depth + 1) + 'Store Contracts: [\n', ',\n', '\n' + indent($depth + 1) + ']\n')
    );

  let externalFormatDetails =
    if ($extension.availableExternalFormats->isEmpty(),
        | '',
        | $extension.availableExternalFormats
            ->map(c | $c->printExternalFormatContract($depth + 2))
            ->joinStrings(indent($depth + 1) + 'External Format Contracts: [\n', ',\n', '\n' + indent($depth + 1) + ']\n')
    );

  let featureDetails =
    if ($extension.availableFeatures->isEmpty(),
        | '',
        | $extension.availableFeatures
            ->map(f | $f->printFeatureExtension($depth + 2))
            ->joinStrings(indent($depth + 1) + 'Feature Extensions: [\n', ',\n', '\n' + indent($depth + 1) + ']\n')
    );

  let platformBindingDetails =
    if ($extension.availablePlatformBindings->isEmpty(),
        | '',
        | $extension.availablePlatformBindings
            ->map(p | $p->printPlatformBinding($depth + 2))
            ->joinStrings(indent($depth + 1) + 'Platform Bindings: [\n', ',\n', '\n' + indent($depth + 1) + ']\n')
    );

  $indent + $extension.type + '\n' +
  $indent + '(\n' +
    $storeDetails +
    $externalFormatDetails +
    $featureDetails +
    $platformBindingDetails +
  $indent + ')';
}

function <> meta::pure::extension::print::printStoreContract(contract: StoreContract[1], depth: Integer[1]): String[1]
{
  indent($depth) + $contract.id
}

function <> meta::pure::extension::print::printExternalFormatContract(contract: ExternalFormatContract[1], depth: Integer[1]): String[1]
{
  let indent = indent($depth);

  $indent + $contract.id + '\n' +
  $indent + '(\n' +
    $contract.contentTypes
      ->map(t | indent($depth + 2) + $t)
      ->joinStrings(indent($depth + 1) + 'ContentTypes: [\n', ',\n', '\n' + indent($depth + 1) + ']\n') +
  $indent + ')';
}

function <> meta::pure::extension::print::printFeatureExtension(feature: FeatureExtension[1], depth: Integer[1]): String[1]
{
  indent($depth) + $feature.id
}

function <> meta::pure::extension::print::printPlatformBinding(platformBinding: PlatformBinding[1], depth: Integer[1]): String[1]
{
  let indent = indent($depth);

  $indent + $platformBinding.platformId + '\n' +
  $indent + '(\n' +
    $platformBinding.platformBindingExtensions
      ->map(e | indent($depth + 2) + $e.id)
      ->joinStrings(indent($depth + 1) + 'Extensions: [\n', ',\n', '\n' + indent($depth + 1) + ']\n') +
  $indent + ')';
}


function <> meta::pure::extension::print::space(): String[1]
{
  '  '
}

function <> meta::pure::extension::print::indent(depth: Integer[1]): String[1]
{
  range($depth)->map(x | space())->joinStrings()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy