• Home

  • Custom Ecommerce
  • Application Development
  • Database Consulting
  • Cloud Hosting
  • Systems Integration
  • Legacy Business Systems
  • Security & Compliance
  • GIS

  • Expertise

  • About Us
  • Our Team
  • Clients
  • Blog
  • Careers

  • VisionPort

  • Contact
  • Our Blog

    Ongoing observations by End Point Dev people

    Automating DNS Management with GitLab CI/CD

    Kannan Ponnusamy

    By Kannan Ponnusamy
    September 6, 2024

    Several robotic arms sit perched over mechanical tracks in a factory, ready to do some type of assembly.
    Photo by Simon Kadula

    At End Point, managing DNS records across multiple domains has historically been a manual task. This blog post details our journey from manual processes to an automated workflow using GitLab CI/CD.

    Our Initial Approach

    With multiple domains and frequent updates necessary to manage the servers, manual handling of DNS changes became a bottleneck. Initially, our process looked like this:

    • Make changes to the OpenTofu configuration files
    • Create a merge request (MR) in GitLab
    • They would run tofu plan manually and paste the plan output into the MR for review
    • A coworker would review the MR and approve the changes
    • Once merged, the engineer would manually run tofu apply to implement the changes

    While this process worked, automating it could enhance our productivity and minimize errors, integrating our DNS management directly into our CI/CD pipeline.

    The Solution: Automating with GitLab CI/CD

    • Change Submission: Engineers make changes to the OpenTofu files and submit a merge request
    • Plan Creation: A GitLab CI/CD job automatically generates an OpenTofu plan when changes are proposed
    • Review Process: A coworker reviews the automatically generated plan in the MR
    • Applying …

    terraform git cloud devops

    Streamlining SELinux Policies: From Policy Modules to Modules and Silent SELinux Denials

    Bharathi Ponnusamy

    By Bharathi Ponnusamy
    August 26, 2024

    Cars drive across a road bridge over light blue water. Above are several large hotels, and white clouds against a light blue sky.

    Introduction

    SELinux (Security-Enhanced Linux) provides a robust security layer that enforces security policies to control system access. When dealing with SELinux, you often encounter the terms “policy_module” and “module”. Understanding the difference between these and knowing how to convert between them is crucial for efficient system administration.

    What is a policy_module?

    A policy_module in SELinux is a type of module used to define additional policies. These modules encapsulate specific security rules that can be loaded into the SELinux policy to grant or restrict permissions. Policy modules are particularly useful for adding or modifying policies without changing the base SELinux policy.

    policy_module(my_policy, 1.0)
    
    require {
        type my_app_t;
    }
    
    #============= my_app_t ==============
    allow my_app_t my_log_t:file read;
    

    What is a module?

    A module in SELinux is a compiled version of a policy module. The compilation process translates the high-level policy rules into a binary format that SELinux can enforce. Modules are loaded into the SELinux policy store to extend or modify the active policy.

    module my_module 1.0;
    
    require {
        type my_app_t; …

    selinux sysadmin security

    Exploring Geodatabase Files

    Constante “Tino” Gonzalez

    By Constante “Tino” Gonzalez
    August 14, 2024

    The sun shines brightly behind a cloud, casting a half halo of rays to the left of the image, and leaving the right of the image quite dim.

    One of our clients recently provided us with a dataset of real estate properties that they manage, and asked us to generate content based off of the points and polygons in the dataset.

    We will walk through the process of extracting polygons, placemarks, and other info from a geodatabase file and converting them into separate KML files using the ogr2ogr command-line tool, adding some logic to the data selection to limit the subset of features. We will also explore the GDB file using the GDAL Python library to export the data as JSON for use in other scripts.

    Prerequisites

    • Basic understanding of geospatial data
    • Installed versions of the GDAL/OGR library
    • A geodatabase file (.gdb, .gdb.zip, or .shp)

    A first look into the contents of the GDB file

    Google earth showing a campus of several buildings, surrounded by a yellow rectangle overlay, and with a blue pin labeled “label” on one side.

    ogrinfo example.gdb.zip
    

    This command will list all layers that are available in the dataset. Add a specific layer as a parameter to the same command, and it will output all the fields, their types, and values for every feature in the layer.

    ogrinfo example.gdb.zip a_layer_name
    

    The parameter -so can be used to omit the values from the output and get only the layer field names and types:

    #$> ogrinfo example.gdb.zip Land_Points -so
    INFO: …

    gis python google-earth open-source visionport

    Measuring Metamorphopsia

    Darius Clynes

    By Darius Clynes
    August 7, 2024

    Two black circles are broken by irregularly shaped cutouts showing concentric circles beneath, some of which are labeled. There are geometric shapes in between the circles, showing some kind of diagram.
    Photo in public domain.

    Metamorphopsia is an abnormal condition of vision that can cause deformation of the visual field. This condition, aside from having a wonderful name, has a real effect on my vision: Even after a successful operation to correct the macular hole which causes this, I still see circles as ellipses. Faces are elongated vertically like in a funhouse mirror, so I have an “ugly face” eye and a “normal face” eye.

    My ophthalmologist assured me that with time — 6 weeks to 6 months — my vision should become normal and this distortion and visual alignment problem should disappear, or at least improve drastically. It occurred to me it would be nice to have an application to measure any progress in the restoration of my vision.

    What Causes Metamorphopsia?

    The most common cause of metamorphopsia is an irregularity in the retinal surface of the eye. A typical irregularity of the retinal surface that can produce a noticeable distortion in the center of the visual field is referred to as a “macular” anomaly. Macular anomalies come in different varieties. One such anomaly, a macular hole, arises when the retina in the area of the fovea in the center of the eye is …


    tools

    The Perl and Raku Conference 2024

    Andrew Baerg

    By Andrew Baerg
    August 2, 2024

    A conference room with around 30 people visible watching a speaker talk, in front of a TPRC banner. Next Generation of Perl

    I attended The Perl and Raku Conference in Las Vegas, NV, which took place June 25–28, 2024. It was HOT outside (over 40 °C/110 °F) but we stayed cool inside at the Alexis Park Resort.

    Curtis Poe (Ovid) got things started with the keynote encouraging us to Party Like It’s 19100+e^iπ, and reminded us that Vegas is lexically scoped (what happens in Vegas stays in Vegas)! More importantly he reminded us that Perl is about people, not just the technology. The Perl community has been meeting all over the world since 1999, with this being the 25th anniversary of the first The Perl Conference (aka YAPC::NA).

    A man with a beard presents on a small stage. Ovid Keynote

    Meeting in person with people who you interact with primarily through digital channels, code commits, and MetaCPAN documentation really highlighted the importance of the community. On the first day, I messed up timezones, showed up an hour before registration opened, and witnessed the conference organizers and core members arrive and greet each other with hugs. I also enjoyed visiting with one of the very welcoming board members of The Perl and Raku Foundation (TPRF).

    Many of the speakers and attendees put a “Hallway++” …


    perl conference open-source

    Writing a WebSocket-Controlled State Machine

    Will Plaut

    By Will Plaut
    July 20, 2024

    A light blue cloudy sky is broken horizontally down the center of the image by the bottom side of a light tan roof viewed from below at a high angle. Below the roof, under a thin shadow from the roof, a thick stucco wall has a center beam and curves down away from it into two arches.

    This article was co-authored by Jacob Minshall

    We recently developed a state machine to control a piece of software for a client. The client wanted to have an API to interact with the state machine, triggering state changes while it was running. Depending on the current state’s requirements, the state machine could either wait for a WebSocket message to proceed to another state or transition to the next state without outside input. WebSockets allow for two way communication so the clients can also have visibility into the state machine’s current state.

    To start, we looked for a simple way to implement a state machine within our TypeScript/Node.js based project. The typescript-fsm library on GitHub was a good solution for us. What made us consider this package was the simplicity of the library: the entire source file is around 100 lines of code.

    We did end up making some custom changes to the library that won’t be shown here; for example, we wanted to broadcast state change messages via WebSockets to any connected clients. With such a simple library, it was a breeze adding that code. The code in this post will still run with the vanilla library, it just won’t notify you when …


    javascript typescript

    Using Docker Compose to Deploy a Multi-Application .NET System

    Kevin Campusano

    By Kevin Campusano
    July 13, 2024

    The bottom of the image is spanned by a white fence, behind which a lush green garden and house sit. Above is a moody, cloudy sky. There are prominent pink flowers in the center, while there are white and dark purple flowers sprinkled through the rest of the garden.

    This post was co-authored by Juan Pablo Ventoso

    We recently developed a system that involved several runtime components. It was an ecommerce site that included a database, a web API, an admin control panel web app, and a frontend SPA.

    There are many ways to deploy such a system. For us, we wanted the infrastructure to be easily replicable for multiple environments with slightly different configurations. We wanted to be able to have, for example, a production and a staging version that could be deployed easily, with minimal configuration changes. We also wanted the infrastructure to be captured in files and version controlled, to further help replicability and maintainability.

    With all that in mind, Docker Compose seemed like an ideal option. We could author a series of configuration files, parameterize environment-specific changes and, with a single command, we could spin up a whole environment to run the various applications within the system.

    In this blog post, I’ll explain how we did that using a demo .NET code base that has a similar set of components. Let’s get started.

    Getting familiar with the demo project

    In .NET terms, our demo code base is organized as a …


    dotnet aspdotnet csharp docker nginx

    Introduction to Nuxt3 and Rendering Modes

    Bimal Gharti Magar

    By Bimal Gharti Magar
    July 12, 2024

    Billowing clouds tower over a tree-covered mountain range. Their texture is oddly smooth, and they are slightly tinged by orange light. On the right side of the image, vertically centered, is a light pole which arches to the left.

    Nuxt is a free and open-source framework which helps us build performant full-stack web applications and websites with Vue.js. Nuxt is built on top of Vue, so it is also called a meta-framework. Nuxt uses conventional style directory structure to streamline repetitive tasks and allow developers to focus on more important operational tasks. The configuration file can be used to customize the default behaviors.

    Nuxt3 features

    1. File-based routing. Nuxt generates routes based on the Vue files and folder structure within the pages/ directory. For example, if we have a pages/contact.vue file, Nuxt will generate a corresponding route at /contact. It also supports dynamic routing: pages/product/[sku].vue includes the route /product/APPLE, giving the [sku].vue single-file component access to the value APPLE.

    2. Auto-imports. Components, composables, and helper functions have their respective directories which can be used across the project without importing them. This feature enhances the developer experience by removing the long list of imports. Nuxt also supports automatic importing of Vue APIs. It can be configured to import third-party packages using the nuxt.config file. Auto import …


    javascript vue frameworks
    Page 1 of 217 • Next page