• Resolved kiskitrains

    (@kiskitrains)


    Hi,

    I have a problem with DLM. I try to query single license but with non-existing license number.

    When I do it in Postman, everything works and I get correct JSON answer about license key not found or that in does not exist. No matter what exact call I use, either it is “activate”, “validate”, or just a “license”.

    But when I try to achieve the same result from my installer, I get Internal Server Error. Installer is made in Setup Factory 9, and I submitting my call with built-in function HTTP.SubmitSecure with all parameters provided. Funny thing is that with “activate” call everything works and I get an answer from server, but with either “validate” or “licenses/{license_key} I have only Internal Server Error.

    What can be possibly wrong? I have the same behavior with License Manager for WooCommerce, and I have hoped that it will work with yours. But no, it has the same behavior.

    The page I need help with: [log in to see the link]

Viewing 7 replies - 1 through 7 (of 7 total)
  • Plugin Author Darko G.

    (@darkog)

    Hey @kiskitrains ,

    Internal Server Error means that you aren’t providing something correctly.

    Can you enable debug.log and see what is the error? Internal Server Errors should be logged in wp-content/debug.log once they are triggered only if you have debug.log enabled.

    Read more on how to enable debug log

    Best Regards,
    Darko

    Thread Starter kiskitrains

    (@kiskitrains)

    Hi Darko,

    I have identified, where the problem is. In Postman, I′m able to see it because Postman is able to show error JSON messages even if they have status 404 or 500. But my installer is not, as it takes it as standard 404 message and shows me “Requested URL could not be found”, or shows standard message 500 “Internal Server Error”. Would it be possible to send those messages with status 200 or such? Or at least make it as an option for users to choose the number of message status? Default status would be those you have now, while some other users that need to change it would be able to do so in some, say, roll menu. Or if not, can you provide me with some custom patch at least?

    Thanks.

    Plugin Author Darko G.

    (@darkog)

    Hey @kiskitrains – I will add this to our back-log, for now i can only envision this change in a new future API version v2.

    Thread Starter kiskitrains

    (@kiskitrains)

    Hey Darko, would it be possible to solve this, at least temporary, with some tweaks in AbstractRestController? Or maybe directly in LicenseService.php in “Services” folder or maybe in Licenses.php in “Controller” folder? For me, it would be enough to send all messages with code==200.

    Thanks in advance.

    Plugin Author Darko G.

    (@darkog)

    Hey @kiskitrains ,

    I decided to add option to modify the response with filter.

    I will add this in the next update. If you want it now you can can swap the entire _responseError() function in AbstractRestController with the updated code below:

    https://github.com/gdarko/digital-license-manager/blob/master/includes/Abstracts/AbstractRestController.php#L79

    Updated code:

    /**
    * Respond with specific error message
    *
    * @param $code
    * @param $message
    * @param array $data
    *
    * @return WP_Error
    */
    public static function _responseError( $code, $message, $data = array() ) {
    $prefix = apply_filters( 'dlm_rest_code_prefix', '' );
    $code = str_replace( sprintf( '%s', $prefix ), '', $code );

    $error_prefilter = apply_filters('dlm_rest_api_pre_error', null, $code, $message, $data);

    if(!is_null($error_prefilter)) {
    return $error_prefilter;
    }

    return new WP_Error( sprintf( '%s%s', $prefix, $code ), $message, $data );
    }

    Next, in your functions.php (current theme) you can add this code to modify the response:

    add_filter("dlm_rest_api_pre_error", function( $code, $message, $data ){
    return new WP_REST_Response(
    ['code' => $code, 'message' => $message, 'data' => $data]
    );

    }, 10, 4);

    I am saying functions.php so it’s not overriden by future update, ideally the second code segment should be placed in a child theme’s functions.php or a mu-plugin.

    Let me know if that helps!

    Best Regards,
    Darko

    Thread Starter kiskitrains

    (@kiskitrains)

    Hi Darko, I have no problem with switching code in AbstractRestController file, but with adding code to functions.php for my current theme. I′m using Astra theme, and I found the file called functions.php. But I don′t know where exactly I should place that second code, in which part of file. I′m not so skilled in this, so please, if I may ask, can you help me? The whole content of that functions.php file is here:

    <?php
    /**
    * Astra functions and definitions
    *
    * @link https://developer.www.ads-software.com/themes/basics/theme-functions/
    *
    * @package Astra
    * @since 1.0.0
    */

    if ( ! defined( 'ABSPATH' ) ) {
    exit; // Exit if accessed directly.
    }

    /**
    * Define Constants
    */
    define( 'ASTRA_THEME_VERSION', '4.7.1' );
    define( 'ASTRA_THEME_SETTINGS', 'astra-settings' );
    define( 'ASTRA_THEME_DIR', trailingslashit( get_template_directory() ) );
    define( 'ASTRA_THEME_URI', trailingslashit( esc_url( get_template_directory_uri() ) ) );

    /**
    * Minimum Version requirement of the Astra Pro addon.
    * This constant will be used to display the notice asking user to update the Astra addon to the version defined below.
    */
    define( 'ASTRA_EXT_MIN_VER', '4.7.0' );

    /**
    * Setup helper functions of Astra.
    */
    require_once ASTRA_THEME_DIR . 'inc/core/class-astra-theme-options.php';
    require_once ASTRA_THEME_DIR . 'inc/core/class-theme-strings.php';
    require_once ASTRA_THEME_DIR . 'inc/core/common-functions.php';
    require_once ASTRA_THEME_DIR . 'inc/core/class-astra-icons.php';

    define( 'ASTRA_PRO_UPGRADE_URL', astra_get_pro_url( 'https://wpastra.com/pro/', 'dashboard', 'free-theme', 'upgrade-now' ) );
    define( 'ASTRA_PRO_CUSTOMIZER_UPGRADE_URL', astra_get_pro_url( 'https://wpastra.com/pro/', 'customizer', 'free-theme', 'upgrade' ) );

    /**
    * Update theme
    */
    require_once ASTRA_THEME_DIR . 'inc/theme-update/astra-update-functions.php';
    require_once ASTRA_THEME_DIR . 'inc/theme-update/class-astra-theme-background-updater.php';

    /**
    * Fonts Files
    */
    require_once ASTRA_THEME_DIR . 'inc/customizer/class-astra-font-families.php';
    if ( is_admin() ) {
    require_once ASTRA_THEME_DIR . 'inc/customizer/class-astra-fonts-data.php';
    }

    require_once ASTRA_THEME_DIR . 'inc/lib/webfont/class-astra-webfont-loader.php';
    require_once ASTRA_THEME_DIR . 'inc/lib/docs/class-astra-docs-loader.php';
    require_once ASTRA_THEME_DIR . 'inc/customizer/class-astra-fonts.php';

    require_once ASTRA_THEME_DIR . 'inc/dynamic-css/custom-menu-old-header.php';
    require_once ASTRA_THEME_DIR . 'inc/dynamic-css/container-layouts.php';
    require_once ASTRA_THEME_DIR . 'inc/dynamic-css/astra-icons.php';
    require_once ASTRA_THEME_DIR . 'inc/core/class-astra-walker-page.php';
    require_once ASTRA_THEME_DIR . 'inc/core/class-astra-enqueue-scripts.php';
    require_once ASTRA_THEME_DIR . 'inc/core/class-gutenberg-editor-css.php';
    require_once ASTRA_THEME_DIR . 'inc/core/class-astra-wp-editor-css.php';
    require_once ASTRA_THEME_DIR . 'inc/dynamic-css/block-editor-compatibility.php';
    require_once ASTRA_THEME_DIR . 'inc/dynamic-css/inline-on-mobile.php';
    require_once ASTRA_THEME_DIR . 'inc/dynamic-css/content-background.php';
    require_once ASTRA_THEME_DIR . 'inc/class-astra-dynamic-css.php';
    require_once ASTRA_THEME_DIR . 'inc/class-astra-global-palette.php';

    /**
    * Custom template tags for this theme.
    */
    require_once ASTRA_THEME_DIR . 'inc/core/class-astra-attr.php';
    require_once ASTRA_THEME_DIR . 'inc/template-tags.php';

    require_once ASTRA_THEME_DIR . 'inc/widgets.php';
    require_once ASTRA_THEME_DIR . 'inc/core/theme-hooks.php';
    require_once ASTRA_THEME_DIR . 'inc/admin-functions.php';
    require_once ASTRA_THEME_DIR . 'inc/core/sidebar-manager.php';

    /**
    * Markup Functions
    */
    require_once ASTRA_THEME_DIR . 'inc/markup-extras.php';
    require_once ASTRA_THEME_DIR . 'inc/extras.php';
    require_once ASTRA_THEME_DIR . 'inc/blog/blog-config.php';
    require_once ASTRA_THEME_DIR . 'inc/blog/blog.php';
    require_once ASTRA_THEME_DIR . 'inc/blog/single-blog.php';

    /**
    * Markup Files
    */
    require_once ASTRA_THEME_DIR . 'inc/template-parts.php';
    require_once ASTRA_THEME_DIR . 'inc/class-astra-loop.php';
    require_once ASTRA_THEME_DIR . 'inc/class-astra-mobile-header.php';

    /**
    * Functions and definitions.
    */
    require_once ASTRA_THEME_DIR . 'inc/class-astra-after-setup-theme.php';

    // Required files.
    require_once ASTRA_THEME_DIR . 'inc/core/class-astra-admin-helper.php';

    require_once ASTRA_THEME_DIR . 'inc/schema/class-astra-schema.php';

    /* Setup API */
    require_once ASTRA_THEME_DIR . 'admin/includes/class-astra-api-init.php';

    if ( is_admin() ) {
    /**
    * Admin Menu Settings
    */
    require_once ASTRA_THEME_DIR . 'inc/core/class-astra-admin-settings.php';
    require_once ASTRA_THEME_DIR . 'admin/class-astra-admin-loader.php';
    require_once ASTRA_THEME_DIR . 'inc/lib/astra-notices/class-astra-notices.php';
    }

    /**
    * Metabox additions.
    */
    require_once ASTRA_THEME_DIR . 'inc/metabox/class-astra-meta-boxes.php';

    require_once ASTRA_THEME_DIR . 'inc/metabox/class-astra-meta-box-operations.php';

    /**
    * Customizer additions.
    */
    require_once ASTRA_THEME_DIR . 'inc/customizer/class-astra-customizer.php';

    /**
    * Astra Modules.
    */
    require_once ASTRA_THEME_DIR . 'inc/modules/posts-structures/class-astra-post-structures.php';
    require_once ASTRA_THEME_DIR . 'inc/modules/related-posts/class-astra-related-posts.php';

    /**
    * Compatibility
    */
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-gutenberg.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-jetpack.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/woocommerce/class-astra-woocommerce.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/edd/class-astra-edd.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/lifterlms/class-astra-lifterlms.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/learndash/class-astra-learndash.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-beaver-builder.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-bb-ultimate-addon.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-contact-form-7.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-visual-composer.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-site-origin.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-gravity-forms.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-bne-flyout.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-ubermeu.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-divi-builder.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-amp.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-yoast-seo.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/surecart/class-astra-surecart.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-starter-content.php';
    require_once ASTRA_THEME_DIR . 'inc/addons/transparent-header/class-astra-ext-transparent-header.php';
    require_once ASTRA_THEME_DIR . 'inc/addons/breadcrumbs/class-astra-breadcrumbs.php';
    require_once ASTRA_THEME_DIR . 'inc/addons/scroll-to-top/class-astra-scroll-to-top.php';
    require_once ASTRA_THEME_DIR . 'inc/addons/heading-colors/class-astra-heading-colors.php';
    require_once ASTRA_THEME_DIR . 'inc/builder/class-astra-builder-loader.php';

    // Elementor Compatibility requires PHP 5.4 for namespaces.
    if ( version_compare( PHP_VERSION, '5.4', '>=' ) ) {
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-elementor.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-elementor-pro.php';
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-web-stories.php';
    }

    // Beaver Themer compatibility requires PHP 5.3 for anonymous functions.
    if ( version_compare( PHP_VERSION, '5.3', '>=' ) ) {
    require_once ASTRA_THEME_DIR . 'inc/compatibility/class-astra-beaver-themer.php';
    }

    require_once ASTRA_THEME_DIR . 'inc/core/markup/class-astra-markup.php';

    /**
    * Load deprecated functions
    */
    require_once ASTRA_THEME_DIR . 'inc/core/deprecated/deprecated-filters.php';
    require_once ASTRA_THEME_DIR . 'inc/core/deprecated/deprecated-hooks.php';
    require_once ASTRA_THEME_DIR . 'inc/core/deprecated/deprecated-functions.php';

    And when it will be done, all messages will flow with code=200 or should I modify something else?

    Thanks in advance.

    Plugin Author Darko G.

    (@darkog)

    Hey @kiskitrains

    Please contact us at [email protected] and i will send you the updated code.

    Also, to answer your question, if you entered the first code section, no other action is required.

    Best,
    Darko

Viewing 7 replies - 1 through 7 (of 7 total)
  • You must be logged in to reply to this topic.