Class Function

All Implemented Interfaces:
IAsset, ICatalog, IFunction, IReferenceable, ISQL, AuditDetail, Serializable, Comparable<Reference>

@Generated("com.atlan.generators.ModelGeneratorV2") public class Function extends Asset implements IFunction, ISQL, ICatalog, IAsset, IReferenceable
Instance of a function in Atlan.
See Also:
  • Field Details

  • Constructor Details

  • Method Details

    • trimToReference

      public Function trimToReference() throws InvalidRequestException
      Builds the minimal object necessary to create a relationship to a Function, from a potentially more-complete Function object.
      Overrides:
      trimToReference in class Asset
      Returns:
      the minimal object necessary to relate to the Function
      Throws:
      InvalidRequestException - if any of the minimal set of required properties for a Function relationship are not found in the initial object
    • select

      public static FluentSearch.FluentSearchBuilder<?,?> select(AtlanClient client)
      Start a fluent search that will return all Function assets. Additional conditions can be chained onto the returned search before any asset retrieval is attempted, ensuring all conditions are pushed-down for optimal retrieval. Only active (non-archived) Function assets will be included.
      Parameters:
      client - connectivity to the Atlan tenant from which to retrieve the assets
      Returns:
      a fluent search that includes all Function assets
    • select

      public static FluentSearch.FluentSearchBuilder<?,?> select(AtlanClient client, boolean includeArchived)
      Start a fluent search that will return all Function assets. Additional conditions can be chained onto the returned search before any asset retrieval is attempted, ensuring all conditions are pushed-down for optimal retrieval.
      Parameters:
      client - connectivity to the Atlan tenant from which to retrieve the assets
      includeArchived - when true, archived (soft-deleted) Functions will be included
      Returns:
      a fluent search that includes all Function assets
    • refByGuid

      public static Function refByGuid(String guid)
      Reference to a Function by GUID. Use this to create a relationship to this Function, where the relationship should be replaced.
      Parameters:
      guid - the GUID of the Function to reference
      Returns:
      reference to a Function that can be used for defining a relationship to a Function
    • refByGuid

      public static Function refByGuid(String guid, Reference.SaveSemantic semantic)
      Reference to a Function by GUID. Use this to create a relationship to this Function, where you want to further control how that relationship should be updated (i.e. replaced, appended, or removed).
      Parameters:
      guid - the GUID of the Function to reference
      semantic - how to save this relationship (replace all with this, append it, or remove it)
      Returns:
      reference to a Function that can be used for defining a relationship to a Function
    • refByQualifiedName

      public static Function refByQualifiedName(String qualifiedName)
      Reference to a Function by qualifiedName. Use this to create a relationship to this Function, where the relationship should be replaced.
      Parameters:
      qualifiedName - the qualifiedName of the Function to reference
      Returns:
      reference to a Function that can be used for defining a relationship to a Function
    • refByQualifiedName

      public static Function refByQualifiedName(String qualifiedName, Reference.SaveSemantic semantic)
      Reference to a Function by qualifiedName. Use this to create a relationship to this Function, where you want to further control how that relationship should be updated (i.e. replaced, appended, or removed).
      Parameters:
      qualifiedName - the qualifiedName of the Function to reference
      semantic - how to save this relationship (replace all with this, append it, or remove it)
      Returns:
      reference to a Function that can be used for defining a relationship to a Function
    • get

      public static Function get(AtlanClient client, String id) throws AtlanException
      Retrieves a Function by one of its identifiers, complete with all of its relationships.
      Parameters:
      client - connectivity to the Atlan tenant from which to retrieve the asset
      id - of the Function to retrieve, either its GUID or its full qualifiedName
      Returns:
      the requested full Function, complete with all of its relationships
      Throws:
      AtlanException - on any error during the API invocation, such as the NotFoundException if the Function does not exist or the provided GUID is not a Function
    • get

      public static Function get(AtlanClient client, String id, boolean includeAllRelationships) throws AtlanException
      Retrieves a Function by one of its identifiers, optionally complete with all of its relationships.
      Parameters:
      client - connectivity to the Atlan tenant from which to retrieve the asset
      id - of the Function to retrieve, either its GUID or its full qualifiedName
      includeAllRelationships - if true, all the asset's relationships will also be retrieved; if false, no relationships will be retrieved
      Returns:
      the requested full Function, optionally complete with all of its relationships
      Throws:
      AtlanException - on any error during the API invocation, such as the NotFoundException if the Function does not exist or the provided GUID is not a Function
    • get

      public static Function get(AtlanClient client, String id, Collection<AtlanField> attributes) throws AtlanException
      Retrieves a Function by one of its identifiers, with only the requested attributes (and relationships).
      Parameters:
      client - connectivity to the Atlan tenant from which to retrieve the asset
      id - of the Function to retrieve, either its GUID or its full qualifiedName
      attributes - to retrieve for the Function, including any relationships
      Returns:
      the requested Function, with only its minimal information and the requested attributes (and relationships)
      Throws:
      AtlanException - on any error during the API invocation, such as the NotFoundException if the Function does not exist or the provided GUID is not a Function
    • get

      public static Function get(AtlanClient client, String id, Collection<AtlanField> attributes, Collection<AtlanField> attributesOnRelated) throws AtlanException
      Retrieves a Function by one of its identifiers, with only the requested attributes (and relationships).
      Parameters:
      client - connectivity to the Atlan tenant from which to retrieve the asset
      id - of the Function to retrieve, either its GUID or its full qualifiedName
      attributes - to retrieve for the Function, including any relationships
      attributesOnRelated - to retrieve on each relationship retrieved for the Function
      Returns:
      the requested Function, with only its minimal information and the requested attributes (and relationships)
      Throws:
      AtlanException - on any error during the API invocation, such as the NotFoundException if the Function does not exist or the provided GUID is not a Function
    • restore

      public static boolean restore(AtlanClient client, String qualifiedName) throws AtlanException
      Restore the archived (soft-deleted) Function to active.
      Parameters:
      client - connectivity to the Atlan tenant on which to restore the asset
      qualifiedName - for the Function
      Returns:
      true if the Function is now active, and false otherwise
      Throws:
      AtlanException - on any API problems
    • updater

      public static Function.FunctionBuilder<?,?> updater(String qualifiedName, String name)
      Builds the minimal object necessary to update a Function.
      Parameters:
      qualifiedName - of the Function
      name - of the Function
      Returns:
      the minimal request necessary to update the Function, as a builder
    • trimToRequired

      public Function.FunctionBuilder<?,?> trimToRequired() throws InvalidRequestException
      Builds the minimal object necessary to apply an update to a Function, from a potentially more-complete Function object.
      Overrides:
      trimToRequired in class Asset
      Returns:
      the minimal object necessary to update the Function, as a builder
      Throws:
      InvalidRequestException - if any of the minimal set of required properties for Function are not found in the initial object
    • removeDescription

      public static Function removeDescription(AtlanClient client, String qualifiedName, String name) throws AtlanException
      Remove the system description from a Function.
      Parameters:
      client - connectivity to the Atlan tenant on which to remove the asset's description
      qualifiedName - of the Function
      name - of the Function
      Returns:
      the updated Function, or null if the removal failed
      Throws:
      AtlanException - on any API problems
    • removeUserDescription

      public static Function removeUserDescription(AtlanClient client, String qualifiedName, String name) throws AtlanException
      Remove the user's description from a Function.
      Parameters:
      client - connectivity to the Atlan tenant on which to remove the asset's description
      qualifiedName - of the Function
      name - of the Function
      Returns:
      the updated Function, or null if the removal failed
      Throws:
      AtlanException - on any API problems
    • removeOwners

      public static Function removeOwners(AtlanClient client, String qualifiedName, String name) throws AtlanException
      Remove the owners from a Function.
      Parameters:
      client - connectivity to the Atlan tenant from which to remove the Function's owners
      qualifiedName - of the Function
      name - of the Function
      Returns:
      the updated Function, or null if the removal failed
      Throws:
      AtlanException - on any API problems
    • updateCertificate

      public static Function updateCertificate(AtlanClient client, String qualifiedName, CertificateStatus certificate, String message) throws AtlanException
      Update the certificate on a Function.
      Parameters:
      client - connectivity to the Atlan tenant on which to update the Function's certificate
      qualifiedName - of the Function
      certificate - to use
      message - (optional) message, or null if no message
      Returns:
      the updated Function, or null if the update failed
      Throws:
      AtlanException - on any API problems
    • removeCertificate

      public static Function removeCertificate(AtlanClient client, String qualifiedName, String name) throws AtlanException
      Remove the certificate from a Function.
      Parameters:
      client - connectivity to the Atlan tenant from which to remove the Function's certificate
      qualifiedName - of the Function
      name - of the Function
      Returns:
      the updated Function, or null if the removal failed
      Throws:
      AtlanException - on any API problems
    • updateAnnouncement

      public static Function updateAnnouncement(AtlanClient client, String qualifiedName, AtlanAnnouncementType type, String title, String message) throws AtlanException
      Update the announcement on a Function.
      Parameters:
      client - connectivity to the Atlan tenant on which to update the Function's announcement
      qualifiedName - of the Function
      type - type of announcement to set
      title - (optional) title of the announcement to set (or null for no title)
      message - (optional) message of the announcement to set (or null for no message)
      Returns:
      the result of the update, or null if the update failed
      Throws:
      AtlanException - on any API problems
    • removeAnnouncement

      public static Function removeAnnouncement(AtlanClient client, String qualifiedName, String name) throws AtlanException
      Remove the announcement from a Function.
      Parameters:
      client - connectivity to the Atlan client from which to remove the Function's announcement
      qualifiedName - of the Function
      name - of the Function
      Returns:
      the updated Function, or null if the removal failed
      Throws:
      AtlanException - on any API problems
    • replaceTerms

      public static Function replaceTerms(AtlanClient client, String qualifiedName, String name, List<IGlossaryTerm> terms) throws AtlanException
      Replace the terms linked to the Function.
      Parameters:
      client - connectivity to the Atlan tenant on which to replace the Function's assigned terms
      qualifiedName - for the Function
      name - human-readable name of the Function
      terms - the list of terms to replace on the Function, or null to remove all terms from the Function
      Returns:
      the Function that was updated (note that it will NOT contain details of the replaced terms)
      Throws:
      AtlanException - on any API problems
    • appendTerms

      public static Function appendTerms(AtlanClient client, String qualifiedName, List<IGlossaryTerm> terms) throws AtlanException
      Link additional terms to the Function, without replacing existing terms linked to the Function. Note: this operation must make two API calls — one to retrieve the Function's existing terms, and a second to append the new terms.
      Parameters:
      client - connectivity to the Atlan tenant on which to append terms to the Function
      qualifiedName - for the Function
      terms - the list of terms to append to the Function
      Returns:
      the Function that was updated (note that it will NOT contain details of the appended terms)
      Throws:
      AtlanException - on any API problems
    • removeTerms

      public static Function removeTerms(AtlanClient client, String qualifiedName, List<IGlossaryTerm> terms) throws AtlanException
      Remove terms from a Function, without replacing all existing terms linked to the Function. Note: this operation must make two API calls — one to retrieve the Function's existing terms, and a second to remove the provided terms.
      Parameters:
      client - connectivity to the Atlan tenant from which to remove terms from the Function
      qualifiedName - for the Function
      terms - the list of terms to remove from the Function, which must be referenced by GUID
      Returns:
      the Function that was updated (note that it will NOT contain details of the resulting terms)
      Throws:
      AtlanException - on any API problems
    • appendAtlanTags

      public static Function appendAtlanTags(AtlanClient client, String qualifiedName, List<String> atlanTagNames) throws AtlanException
      Add Atlan tags to a Function, without replacing existing Atlan tags linked to the Function. Note: this operation must make two API calls — one to retrieve the Function's existing Atlan tags, and a second to append the new Atlan tags.
      Parameters:
      client - connectivity to the Atlan tenant on which to append Atlan tags to the Function
      qualifiedName - of the Function
      atlanTagNames - human-readable names of the Atlan tags to add
      Returns:
      the updated Function
      Throws:
      AtlanException - on any API problems
    • appendAtlanTags

      public static Function appendAtlanTags(AtlanClient client, String qualifiedName, List<String> atlanTagNames, boolean propagate, boolean removePropagationsOnDelete, boolean restrictLineagePropagation) throws AtlanException
      Add Atlan tags to a Function, without replacing existing Atlan tags linked to the Function. Note: this operation must make two API calls — one to retrieve the Function's existing Atlan tags, and a second to append the new Atlan tags.
      Parameters:
      client - connectivity to the Atlan tenant on which to append Atlan tags to the Function
      qualifiedName - of the Function
      atlanTagNames - human-readable names of the Atlan tags to add
      propagate - whether to propagate the Atlan tag (true) or not (false)
      removePropagationsOnDelete - whether to remove the propagated Atlan tags when the Atlan tag is removed from this asset (true) or not (false)
      restrictLineagePropagation - whether to avoid propagating through lineage (true) or do propagate through lineage (false)
      Returns:
      the updated Function
      Throws:
      AtlanException - on any API problems
    • removeAtlanTag

      public static void removeAtlanTag(AtlanClient client, String qualifiedName, String atlanTagName) throws AtlanException
      Remove an Atlan tag from a Function.
      Parameters:
      client - connectivity to the Atlan tenant from which to remove an Atlan tag from a Function
      qualifiedName - of the Function
      atlanTagName - human-readable name of the Atlan tag to remove
      Throws:
      AtlanException - on any API problems, or if the Atlan tag does not exist on the Function
    • _internal

      public static Function.FunctionBuilder<?,?> _internal()
    • toBuilder

      public Function.FunctionBuilder<?,?> toBuilder()
      Overrides:
      toBuilder in class Reference
    • getCalculationViewName

      public String getCalculationViewName()
      Simple name of the calculation view in which this SQL asset exists, or empty if it does not exist within a calculation view.
      Specified by:
      getCalculationViewName in interface IFunction
      Specified by:
      getCalculationViewName in interface ISQL
    • getCalculationViewQualifiedName

      public String getCalculationViewQualifiedName()
      Unique name of the calculation view in which this SQL asset exists, or empty if it does not exist within a calculation view.
      Specified by:
      getCalculationViewQualifiedName in interface IFunction
      Specified by:
      getCalculationViewQualifiedName in interface ISQL
    • getDatabaseName

      public String getDatabaseName()
      Simple name of the database in which this SQL asset exists, or empty if it does not exist within a database.
      Specified by:
      getDatabaseName in interface IFunction
      Specified by:
      getDatabaseName in interface ISQL
    • getDatabaseQualifiedName

      public String getDatabaseQualifiedName()
      Unique name of the database in which this SQL asset exists, or empty if it does not exist within a database.
      Specified by:
      getDatabaseQualifiedName in interface IFunction
      Specified by:
      getDatabaseQualifiedName in interface ISQL
    • getDbtModels

      public SortedSet<IDbtModel> getDbtModels()
      TBC
      Specified by:
      getDbtModels in interface IFunction
      Specified by:
      getDbtModels in interface ISQL
    • getDbtSources

      public SortedSet<IDbtSource> getDbtSources()
      TBC
      Specified by:
      getDbtSources in interface IFunction
      Specified by:
      getDbtSources in interface ISQL
    • getDbtTests

      public SortedSet<IDbtTest> getDbtTests()
      TBC
      Specified by:
      getDbtTests in interface IFunction
      Specified by:
      getDbtTests in interface ISQL
    • getFunctionArguments

      public SortedSet<String> getFunctionArguments()
      Arguments that are passed in to the function.
      Specified by:
      getFunctionArguments in interface IFunction
    • getFunctionDefinition

      public String getFunctionDefinition()
      Code or set of statements that determine the output of the function.
      Specified by:
      getFunctionDefinition in interface IFunction
    • getFunctionIsDMF

      public Boolean getFunctionIsDMF()
      Whether the function is a data metric function.
      Specified by:
      getFunctionIsDMF in interface IFunction
    • getFunctionIsExternal

      public Boolean getFunctionIsExternal()
      Whether the function is stored or executed externally (true) or internally (false).
      Specified by:
      getFunctionIsExternal in interface IFunction
    • getFunctionIsMemoizable

      public Boolean getFunctionIsMemoizable()
      Whether the function must re-compute if there are no underlying changes in the values (false) or not (true).
      Specified by:
      getFunctionIsMemoizable in interface IFunction
    • getFunctionIsSecure

      public Boolean getFunctionIsSecure()
      Whether sensitive information of the function is omitted for unauthorized users (true) or not (false).
      Specified by:
      getFunctionIsSecure in interface IFunction
    • getFunctionLanguage

      public String getFunctionLanguage()
      Programming language in which the function is written.
      Specified by:
      getFunctionLanguage in interface IFunction
    • getFunctionReturnType

      public String getFunctionReturnType()
      Data type of the value returned by the function.
      Specified by:
      getFunctionReturnType in interface IFunction
    • getFunctionSchema

      public ISchema getFunctionSchema()
      Schema in which this function exists.
      Specified by:
      getFunctionSchema in interface IFunction
    • getFunctionType

      public String getFunctionType()
      Type of function.
      Specified by:
      getFunctionType in interface IFunction
    • getInputToAirflowTasks

      public SortedSet<IAirflowTask> getInputToAirflowTasks()
      Tasks to which this asset provides input.
      Specified by:
      getInputToAirflowTasks in interface ICatalog
      Specified by:
      getInputToAirflowTasks in interface IFunction
      Specified by:
      getInputToAirflowTasks in interface ISQL
    • getInputToProcesses

      public SortedSet<ILineageProcess> getInputToProcesses()
      Processes to which this asset provides input.
      Specified by:
      getInputToProcesses in interface ICatalog
      Specified by:
      getInputToProcesses in interface IFunction
      Specified by:
      getInputToProcesses in interface ISQL
    • getInputToSparkJobs

      public SortedSet<ISparkJob> getInputToSparkJobs()
      TBC
      Specified by:
      getInputToSparkJobs in interface ICatalog
      Specified by:
      getInputToSparkJobs in interface IFunction
      Specified by:
      getInputToSparkJobs in interface ISQL
    • getIsProfiled

      public Boolean getIsProfiled()
      Whether this asset has been profiled (true) or not (false).
      Specified by:
      getIsProfiled in interface IFunction
      Specified by:
      getIsProfiled in interface ISQL
    • getLastProfiledAt

      public Long getLastProfiledAt()
      Time (epoch) at which this asset was last profiled, in milliseconds.
      Specified by:
      getLastProfiledAt in interface IFunction
      Specified by:
      getLastProfiledAt in interface ISQL
    • getModelImplementedAttributes

      public SortedSet<IModelAttribute> getModelImplementedAttributes()
      Attributes implemented by this asset.
      Specified by:
      getModelImplementedAttributes in interface ICatalog
      Specified by:
      getModelImplementedAttributes in interface IFunction
      Specified by:
      getModelImplementedAttributes in interface ISQL
    • getModelImplementedEntities

      public SortedSet<IModelEntity> getModelImplementedEntities()
      Entities implemented by this asset.
      Specified by:
      getModelImplementedEntities in interface ICatalog
      Specified by:
      getModelImplementedEntities in interface IFunction
      Specified by:
      getModelImplementedEntities in interface ISQL
    • getOutputFromAirflowTasks

      public SortedSet<IAirflowTask> getOutputFromAirflowTasks()
      Tasks from which this asset is output.
      Specified by:
      getOutputFromAirflowTasks in interface ICatalog
      Specified by:
      getOutputFromAirflowTasks in interface IFunction
      Specified by:
      getOutputFromAirflowTasks in interface ISQL
    • getOutputFromProcesses

      public SortedSet<ILineageProcess> getOutputFromProcesses()
      Processes from which this asset is produced as output.
      Specified by:
      getOutputFromProcesses in interface ICatalog
      Specified by:
      getOutputFromProcesses in interface IFunction
      Specified by:
      getOutputFromProcesses in interface ISQL
    • getOutputFromSparkJobs

      public SortedSet<ISparkJob> getOutputFromSparkJobs()
      TBC
      Specified by:
      getOutputFromSparkJobs in interface ICatalog
      Specified by:
      getOutputFromSparkJobs in interface IFunction
      Specified by:
      getOutputFromSparkJobs in interface ISQL
    • getQueryCount

      public Long getQueryCount()
      Number of times this asset has been queried.
      Specified by:
      getQueryCount in interface IFunction
      Specified by:
      getQueryCount in interface ISQL
    • getQueryCountUpdatedAt

      public Long getQueryCountUpdatedAt()
      Time (epoch) at which the query count was last updated, in milliseconds.
      Specified by:
      getQueryCountUpdatedAt in interface IFunction
      Specified by:
      getQueryCountUpdatedAt in interface ISQL
    • getQueryUserCount

      public Long getQueryUserCount()
      Number of unique users who have queried this asset.
      Specified by:
      getQueryUserCount in interface IFunction
      Specified by:
      getQueryUserCount in interface ISQL
    • getQueryUserMap

      public Map<String,Long> getQueryUserMap()
      Map of unique users who have queried this asset to the number of times they have queried it.
      Specified by:
      getQueryUserMap in interface IFunction
      Specified by:
      getQueryUserMap in interface ISQL
    • getSchemaName

      public String getSchemaName()
      Simple name of the schema in which this SQL asset exists, or empty if it does not exist within a schema.
      Specified by:
      getSchemaName in interface IFunction
      Specified by:
      getSchemaName in interface ISQL
    • getSchemaQualifiedName

      public String getSchemaQualifiedName()
      Unique name of the schema in which this SQL asset exists, or empty if it does not exist within a schema.
      Specified by:
      getSchemaQualifiedName in interface IFunction
      Specified by:
      getSchemaQualifiedName in interface ISQL
    • getSqlDBTSources

      public SortedSet<IDbtSource> getSqlDBTSources()
      TBC
      Specified by:
      getSqlDBTSources in interface IFunction
      Specified by:
      getSqlDBTSources in interface ISQL
    • getSqlDbtModels

      public SortedSet<IDbtModel> getSqlDbtModels()
      TBC
      Specified by:
      getSqlDbtModels in interface IFunction
      Specified by:
      getSqlDbtModels in interface ISQL
    • getTableName

      public String getTableName()
      Simple name of the table in which this SQL asset exists, or empty if it does not exist within a table.
      Specified by:
      getTableName in interface IFunction
      Specified by:
      getTableName in interface ISQL
    • getTableQualifiedName

      public String getTableQualifiedName()
      Unique name of the table in which this SQL asset exists, or empty if it does not exist within a table.
      Specified by:
      getTableQualifiedName in interface IFunction
      Specified by:
      getTableQualifiedName in interface ISQL
    • getViewName

      public String getViewName()
      Simple name of the view in which this SQL asset exists, or empty if it does not exist within a view.
      Specified by:
      getViewName in interface IFunction
      Specified by:
      getViewName in interface ISQL
    • getViewQualifiedName

      public String getViewQualifiedName()
      Unique name of the view in which this SQL asset exists, or empty if it does not exist within a view.
      Specified by:
      getViewQualifiedName in interface IFunction
      Specified by:
      getViewQualifiedName in interface ISQL
    • equals

      public boolean equals(Object o)
      Overrides:
      equals in class Asset
    • canEqual

      protected boolean canEqual(Object other)
      Overrides:
      canEqual in class Asset
    • hashCode

      public int hashCode()
      Overrides:
      hashCode in class Asset
    • toString

      public String toString()
      Description copied from class: AtlanObject
      Overrides:
      toString in class Asset
    • getTypeName

      public String getTypeName()
      Fixed typeName for Functions.
      Specified by:
      getTypeName in interface AuditDetail
      Specified by:
      getTypeName in interface IAsset
      Specified by:
      getTypeName in interface ICatalog
      Specified by:
      getTypeName in interface IFunction
      Specified by:
      getTypeName in interface IReferenceable
      Specified by:
      getTypeName in interface ISQL
      Overrides:
      getTypeName in class Reference