business logic

back to index

188 results

pages: 161 words: 44,488

The Business Blockchain: Promise, Practice, and Application of the Next Internet Technology
by William Mougayar
Published 25 Apr 2016

In 2013, attention started to shift to the “blockchain 2.0” applications: uses of the same technology that underlies Bitcoin's decentralization and security to other applications, ranging from domain name registration to financial contracts to crowdfunding and even games. The core insight behind my own platform, Ethereum, was that a Turing-complete programming language, embedded into the protocol at the base layer, could be used as the ultimate abstraction, allowing developers to build applications with any kind of business logic or purpose while benefiting from the blockchain's core properties. Around the same time, systems such as the decentralized storage platform InterPlanetary File System (IPFS) began to emerge, and cryptographers came out with powerful new tools that could be used in combination with blockchain technology to add privacy, particularly zk-SNARKs, or zero-knowledge Succinct Non-Interactive ARgument Knowledge.

From a software development point of view, one of the biggest paradigm shifts that the blockchain claims is in challenging the function and monopoly of the traditional database as we currently know it. Therefore we need to deeply understand how the blockchain makes us rethink the existing database constructs. The blockchain is changing how we write applications via a new form of scripting languages that can program business logic as smart contracts that are enforced on the blockchain. SOFTWARE, GAME THEORY AND CRYPTOGRAPHY Another way to understand the blockchain is in seeing it as a triad of combustion of the known fields of 1) game theory, 2) cryptography science, and 3) software engineering. Separately, these fields have existed for a long time, but for the first time, they have together intersected harmoniously and morphed inside blockchain technology.

So, blockchains bring with them an economic model, and that is a key feature that will be expanded upon later in this book. 10. Trust Services Layer All blockchains commonly hold trust as an atomic unit of service. In essence, it is a function and a service that is delivered. But trust does not apply only to transactions. It is extended to data, services, processes, identity, business logic, terms of an agreement, or physical objects. It applies to almost anything that can be digitized as a (smart) asset with an inherent or related value attached to it. Now, imagine the possible mashup of innovations that will spring out on top of these 10 powerful features and characteristics.

Backbone.js Cookbook
by Vadim Mirgorod
Published 25 Aug 2013

So, our application should provide additional functionalities to the end user, such as the following: ‰‰ ‰‰ ‰‰ ‰‰ ‰‰ The ability to see a list of buyers and use it when generating an invoice The ability to manage buyers (create, read, update, and delete) The ability to see a list of bank accounts and use it when generating an invoice The ability to manage his/her own bank accounts (create, read, update, and delete) The ability to edit personal details and use them when generating an invoice Of course, we may want to have more functions, but this is enough for demonstrating how to design an application using the MVC pattern. 3. Next, we architect an application using the MVC pattern. After we have defined the features of our application, we need to understand what is more related to the model (business logic) and what is more related to the view (presentation). Let's split the functionality into several parts. 4. Then, we learn how to define models. Models present data and provide data-specific business logic. Models can be related to each other. In our case, they are as follows: ‰‰ ‰‰ InvoiceModel InvoiceItemModel 9 Understanding Backbone ‰‰ BuyerModel ‰‰ SellerModel ‰‰ BankAccountModel 5.

A controller allows users to interact with an application. In MVC, each view can have a different controller that is used to do following: ‰‰ Map a URL to a specific view ‰‰ Fetch models from a server ‰‰ Show and hide views ‰‰ Handle user input Defining business logic with models and collections Now, it is time to design business logic for the Billing Application using the MVC and OOP approaches. In this recipe, we are going to define an internal structure for our application with model and collection objects. Although a model represents a single object, a collection is a set of models that can be iterated, filtered, and sorted.

See model backbone-mongodb extension downloading 224 Backbone.Mousetrap extension 136 Backbone objects events, handling 117, 118 using, with mixins 210, 211 Backbone Query about 78 downloading 78 Backbone.QueryCollection 79 Backbone.Relational 87 Backbone relational extension downloading 87 Backbone.RelationalModel 89 Backbone.Router used, for switching views 110-113 Backbone.Router object 18, 25 Backbone.stickit extension advanced usage 132 model getters/setters, overriding 132 specific HTML event, listening to 133 used, for bi-directional binding 128-132 view element updates, overriding 132 Backbone.sync() method 206 260 Backbone.Validation extension 50, 54 Backbone.View 171 Backbone.View object 18 Backgrid documentation URL 175 Backgrid example 167 Backgrid extension 175 Backgrid.Grid 171 bidirectional binding performing, with Backbone.stickit 128-131 Billing Application business logic, designing 11 designing, MVC pattern used 8-11 Bootstrap framework downloading 160 used, for customizing form 158-160 built-in events about 119 add 119 change 119 change:[attribute] 119 destroy 119 error 119 invalid 119 remove 119 reset 119 route 119 route:[name] event 119 sort 119 sync 119 built-in validators acceptance 50 equalTo 52 length 51 max 51 maxLength 52 min 51 minLength 51 oneOf 52 pattern 53 range 51 rangeLength 52 required 50 using 50 bulk operations performing, on grid models 172, 173 business logic, for Billing Application BankAccountModel properties, defining 12 BuyerModel properties, defining 12 designing, with models and collections 11-13 InvoiceItemModel methods, defining 12 InvoiceItemModel properties, defining 12 InvoiceModel methods, defining 13 InvoiceModel properties, defining 13 SellerModel properties, defining 12 C callbacks binding, to transition events 47, 48 Cascading Style Sheets (CSS) 103 chain() method 78 change:[attribute] event 119 changedAttributes() method 118 change event 119 changePage() method 228 changeView() method 113 clear() method 33 clone() method 30, 68 CoffeeScript 47 collection about 93 binding, to select list 134-136 binding, to view 122-128 chaining 77, 78 common operations 65 creating 66 existing models, adding 70 index, getting 68 iterating through 75 model, adding 69 model, getting from by ID 69 model, getting from by index 67 model, removing 71 models, filtering 74 multiple models, adding 70 No SQL queries, running 78, 79 one-to-many relationship, implementing 86-89 rendering, in view 101, 102 sorting 73 various types model, storing 83-85 working, as queue 72 working, as stack 72 combining operators, No SQL operators $and 81 $nor 81 $not 81 $or 81 commit() method 152 comparator about 73 model pair, comparing 74 compatibility ensuring, search engine used 245-247 compiled templates using 148 Cross-site scripting enabling 226 D data fetching, polling technique used 201-205 data grid building 167-170 deepEqual() 218 delegateEvents() method 110 destroy event 119 destroy() method 187, 201 Document Object Model (DOM) 106, 226 DOM events handling, in view 106-110 E each() method 75, 218 Ender.js 98 equalTo validator 52 error event 119 error messages customizing 155 events callback, unbinding 117 delegating, manually 110 listening, on objects 117 managing 116 undelegating, manually 110 events, Backbone objects handling 117, 118 261 event triggering avoiding, while working with objects 119 every() method 76 executePolling() method 205 extend() method 24, 211 F fetch() method 186, 220 form customizing, Bootstrap framework used 158-160 defining 149-151 using without model 152 validation, adding 153, 154 form events handling 156-158 form templates overriding 161 Foursquare 6 G getContext() method 178 get() method about 33 using 69 getters or setters overriding 37-40 GitHub 211 Google Boot 246 Googlebot 247 Google Chrome Heap Profiler using, to detect memory leak 251-256 Groupon Now!

Service Design Patterns: Fundamental Design Solutions for SOAP/WSDL and RESTful Web Services
by Robert Daigneau
Published 14 Sep 2011

The receiver decides how the document should be processed based upon its content and type. Domain Layer [DDD] Domain logic is “business logic.” Therefore, a Domain Layer is that part of an application or system which contains business logic. This layer may include Domain Models and Table Modules [POEAA]. A Domain Layer may also be divided further. It may, for example, have a Service Layer [POEAA] containing web services that control the activities of Domain Objects. Domain Model [POEAA] An object model where each class encapsulates the data and behavior (i.e., business logic) of significant entities in the problem domain. Event Message [EIP] A message which carries data about a topic of interest to the receiver.

Most discussions on these topics were rife with ambiguity, hyperbole, misinformation, and arguments that appealed to emotion rather than reason. Still, as a developer who had struggled with distributed object technologies, I was fascinated by web services. I saw them as a pragmatic way to integrate systems and reuse common business logic. Since then, REST has gained significant momentum, WS* services have established a solid foothold, and SOA was proclaimed dead [Manes]. Through it all, my fascination with web services never waned. As mobile, cloud, and Software-as-a-Service (SaaS) platforms cause software to become increasingly distributed, the importance of web services will only continue to increase.

• How can generic functions like authentication, validation, caching, and logging be supported on the client or service? 1 2 What Are Web Services? C HAPTER 1 F ROM O BJECTS TO W EB S ERVICES • What changes to a service cause clients to break? • What are the common ways to version a service? • How can services be designed to support the continuing evolution of business logic without forcing clients to constantly upgrade? These are just a few of the questions that must be answered. This book will help you find solutions that are appropriate for your situation. In this chapter, you’ll learn what services are and how web services address the shortcomings of their predecessors.

Mastering Blockchain, Second Edition
by Imran Bashir
Published 28 Mar 2018

Platform for smart contracts: A blockchain is a platform on which programs can run to execute business logic on behalf of the users. Not all blockchains have a mechanism to execute smart contracts; however, this is a very desirable feature, and it is available on newer blockchain platforms such as Ethereum and MultiChain. Smart Contracts Blockchain technology provides a platform for running smart contracts. These are automated, autonomous programs that reside on the blockchain network and encapsulate the business logic and code needed to execute a required function when certain conditions are met. For example, think about an insurance contract where a claim is paid to the traveler if the flight is canceled.

Blockchain has once again given this vision of decentralization to the world, and now concerted efforts are being made to harness this technology and take advantage of the benefits that it can provide. Computing power and decentralization Decentralization of computing or processing power is achieved by a blockchain technology such as Ethereum, where smart contracts with embedded business logic can run on the blockchain network. Other blockchain technologies also provide similar processing-layer platforms, where business logic can run over the network in a decentralized manner. The following diagram shows a decentralized ecosystem overview. At the bottom layer, the internet or Meshnets provide a decentralized communication layer. On the next layer up, a storage layer uses technologies such as IPFS and BigchainDB to enable decentralization.

Smart contracts A smart contract is a decentralized program. Smart contracts do not necessarily need a blockchain to run; however, due to the security benefits that blockchain technology provides, blockchain has become a standard decentralized execution platform for smart contracts. A smart contract usually contains some business logic and a limited amount of data. The business logic is executed if specific criteria are met. Actors or participants in the blockchain use these smart contracts, or they run autonomously on behalf of the network participants. More information on smart contracts will be provided in Chapter 9, Smart Contracts. Decentralized Organizations DOs are software programs that run on a blockchain and are based on the idea of actual organizations with people and protocols.

pages: 419 words: 102,488

Chaos Engineering: System Resiliency in Practice
by Casey Rosenthal and Nora Jones
Published 27 Apr 2020

Index A above-the-line systems, Putting the Principles into Practice, Conclusion accidental complexity, Accidental Complexity adaptive capacity, Engineering Adaptive Capacity adoptionfour considerations of, Adoption obstacles to, Obstacles to Adoption obtaining management buy-in, Adoption organization-wide progression of, Who Bought into Chaos Engineering organization-wide spread of, How Much of the Organization Participates in Chaos Engineering perquisites to, Prerequisites After phasedefined, Creating Foresight summary of, Hypothesize Agile movement, Economic Pillars of Complexity Applied to Software alerting, Monitoring and alerting Allspaw, John, Human Factors, People in the Loop-Conclusion Alquraan, Ahmed, Fault Injection in the Network Alvaro, Peter, Human Factors, The Substitution Myth, The Experiment Selection Problem (and a Solution)-Conclusion Amazon Web Services (AWS)Christmas Eve 2012 outage, Chaos Monkey Is Born early days of, Management Principles as Code Antifragility, Antifragility application logiccontinuous verification for, Correctness fault injection testing, Fault Injection in Applications mismatch with business logic, Example 1: Mismatch Between Business Logic and Application Logic-Example 1: Mismatch Between Business Logic and Application Logic Aschbacher, Nathan, Evolution, Let’s Get Cyber-Physical-Conclusion automated canaries, Types of CV Systems B backup and restorein older systems, Design Patterns Common in Older Systems security Game Days, Security Game Days Barker, James, Moving your organization forward Beck, Kent, Economic Pillars of Complexity Before phasecognitive interviews, Effectively Partnering Internally-Understand Operating Procedures defined, Creating Foresight discussion of scope, Discuss Scope experiment design, Designing the Experiment-Tool Support for Chaos Experiment Design goal of, Steps of the Chaos Engineering Cycle hypothesis creation, Hypothesize-Hypothesize role determination, Hypothesize summary of, Hypothesize below-the-line systems, Putting the Principles into Practice, Conclusion blind resiliency testing, Blind Resiliency Testing Blue Teams, Security Chaos Engineering and Current Methods bootcamp concept, The hypothesis, All You Need Is Altitude and a Direction bootstrapping, Reboot everything Borg, Scope of Tests at Google “breaking stuff”, Breaking Stuff, Chaos Engineering and Resilience Brooks, Frederick, Confronting Complexity bullwhip effect, Contemplating Complexity bureaucratic organizations, Safely Organizing the Chaos bus factor, People outages business concernsbenefits of collaborative mindset, Open Minds, Open Science, and Open Chaos-Conclusion Chaos Maturity Model (CMM), Chaos Maturity Model-Putting It All Together return on investment (ROI), ROI of Chaos Engineering-Conclusion business continuity plans (BCPs), Business continuity plans business logiccontinuous verification for, Correctness mismatch with application logic, Example 1: Mismatch Between Business Logic and Application Logic-Example 1: Mismatch Between Business Logic and Application Logic C cache inconsistency, Avoid Cache Inconsistency Cahoon, Jason, Principles in Action, Google DiRT: Disaster Recovery Testing-Conclusion call graph tracing, Observability: The Opportunity canary testing, Types of CV Systems capacitycapacity management, Capacity management role in fault tolerance, Getting to Basic Fault Tolerance Capital Oneachievements of, A Capital One Case Study approach to Chaos Engineering at, Principles in Action case studyblind resiliency testing, Blind Resiliency Testing chaos experiments in CI/CD, Chaos Experiments in CI/CD designing experiments, Things to Watch Out for While Designing the Experiment evangelism, Evangelism team structure, Team Structure tooling, Tooling transition to Chaos Engineering, Transition to Chaos Engineering case studies (see use cases) Chaos Automation Platform (ChAP)application of Advanced Principles, The Advanced Principles in ChAP benefits of, ChAP as Continuous Verification demonstrating ROI for, Alternative ROI Example limiting blast radius in, Minimize Blast Radius overview of, Tool Support for Chaos Experiment Design, CV in the Wild: ChAP running experiments, ChAP: Running Experiments selecting experiments, ChAP: Selecting Experiments Chaos Community Day, Community Is Born, The Future of “The Principles” Chaos Engineering (see also Principles of Chaos Engineering)applying to databases, Applying Chaos Engineering-Fault Injection in the Filesystem applying to sociotechnical systems, Humanistic Chaos-If You’re Not Failing, You’re Not Learning benefits of, Safety, Conclusion, Degree of Variation characteristics of, Fast Evolution, The Systemic Perspective, What Chaos Engineering Is-Antifragility conflicting guidance on, Principles in Action, Human Factors core philosophy of, Google DiRT: Disaster Recovery Testing defined, Formalizing the Discipline, What Chaos Engineering Is, Chaos Engineering and Resilience evaluation of, Chaos Maturity Model Failure Mode and Effects Analysis (FMEA) and, FMEA and Chaos Engineering foundational models for, Safety, Economic Pillars of Complexity Applied to Software goals of, Formalizing the Discipline, Breaking Stuff, Chaos Engineering and Resilience, ROI of Chaos Engineering, The Rise of Cyber-Physical Systems history of, Introduction: Birth of Chaos-Fast Evolution Human and Organizational Performance (HOP) and, HOP Meets Chaos Engineering-Chaos Engineering and HOP in Practice in IT and cloud-dominated ecosystems, Let’s Get Cyber-Physical role in complex systems, Setting the Stage, Encountering Complex Systems steps of experimentation, What Chaos Engineering Is, Tooling, Steps of the Chaos Engineering Cycle-Hypothesize team structure, Team Structure Chaos Kong, Going Big, Automation of the platforms Chaos Maturity Model (CMM)Adoption, Adoption-Obstacles to Adoption benefits of, Business Factors, Chaos Maturity Model development of, Chaos Maturity Model mapping the properties, Putting It All Together Sophistication, Sophistication-Automation of the platforms Chaos Monkeyas low-hanging fruit of Chaos Engineering, Vary Real-World Events birth of, Chaos Monkey Is Born, Adoption initial use of, Automation of the platforms popularity of, Why Do We Need Chaos Engineering?

Chaos Kong took a similar approach at the macroscopic level, turning off entire regions. As the tooling grows more sophisticated, it moves up into application logic, affecting requests between services. Above that, we see even more sophisticated experiments when the variable affects business logic, for example, delivering a plausible but unexpected response to a service. The natural progression of experimentation is Infrastructure -> Application -> Business Logic. Putting It All Together Drawing the two properties, Adoption and Sophistication, as axes orthogonal to each other provides us with a map (see Figure 15-1). Starting in the lower-left quadrant of this map we have Game Days run by individual SREs or other interested folks.

Unfortunately, even if all of the components of a complex system are provable correct, the system as a whole can still emit undesirable behavior. Business This is often implicit in assumptions made apparent in a user interface. In order for a business to be competitive, it will often have to innovate. If the business logic is innovative, then it is not practical to rigorously specify it since it will likely change in response to conditions in an uncertain environment. Business logic therefore is the most difficult to verify, and mismatches between business, application, and infrastructure logic are an inevitable possibility in any situation with resource constraints. If the guarantees of the three layers above are out-of-sync, then issues of correctness will manifest over time.

pages: 328 words: 77,877

API Marketplace Engineering: Design, Build, and Run a Platform for External Developers
by Rennay Dorasamy
Published 2 Dec 2021

For example, an API product to retrieve a Customer profile could leverage a number of middleware components to assemble the response. The response from one system could be interrogated and transformed to construct the request for another. It is extremely important to differentiate between application and business logic. Routing a request to a middleware service to create a customer is an example of application logic. The process to create the customer record is an example of business logic. As the Marketplace is a new channel to the enterprise, it should leverage centrally owned and controlled business processes. Figure 8-7Logic microservice orchestration The northbound interface of this component is typically the swagger definition which is published on the API Gateway.

I have since apologized to the annoyed engineers who initially suggested the use of gRPC and have rightfully attributed its discovery and introduction to them. With that being said, I retain the claim for “weaponizing” the technology and taking it from a R&D construct to an operational environment. The Power of Port-Forward As our Business Logic components could leverage several integration microservices to fulfill a specific function, it became increasingly more challenging to assemble the solution. DevOps Continuous Integration (CI) pipelines can be leveraged for code deployments to the server. CI processes are great for transitioning between environments, but for initial development tasks, I consider using a CI pipeline like having a conversation with someone on a remote planet.

Each component fit into a specific layer and, like a military chain of command, a strict protocol was enforced – a component was only allowed to receive requests from the immediate layer above and could only relay requests to the layer below. Although the Architecture diagrams were great, they did not translate well from a development and execution perspective. Integrating into a new backend, adding or updating business logic required changes to various layers which slowed down delivery and increased operational overhead. Adding in new elements into the architecture also caused significant angst and architectural conjecture when solutioning. Based on the battle scars of trying to compartmentalize components into layers, we have deliberately adopted a fairly “loose” architectural pattern.

pages: 420 words: 79,867

Developing Backbone.js Applications
by Addy Osmani
Published 21 Jul 2012

The answer largely comes down to where the application logic and workflow is coded. In the case of an event aggregator, the third party object is there only to facilitate the pass-through of events from an unknown number of sources to an unknown number of handlers. All workflow and business logic that needs to be kicked off is put directly into the object that triggers the events and the objects that handle the events. In the case of the mediator, though, the business logic and workflow is aggregated into the mediator itself. The mediator decides when an object should have its methods called and attributes updated based on factors that the mediator knows about. It encapsulates the workflow and process, coordinating multiple objects to produce the desired system behaviour.

The rise of arbitrary code on the client-side which can talk to the server however it sees fit has meant an increase in client-side complexity. Good architecture on the client has gone from an afterthought to essential - you can’t just hack together some jQuery code and expect it to scale as your application grows. Most likely, you would end up with a nightmarish tangle of UI callbacks entwined with business logic, destined to be discarded by the poor soul who inherits your code. Thankfully, there are a growing number of JavaScript libraries that can help improve the structure and maintainability of your code, making it easier to build ambitious interfaces without a great deal of effort. Backbone.js has quickly become one of the most popular open-source solutions to these issues and in this book we will take you through an in-depth walkthrough of it.

At its core are the three MVC components we would expect - the Model, View and Controller architecture. In Rails: Models represent the data in an application and are typically used to manage rules for interacting with a specific database table. You generally have one table corresponding to one model with much of your application’s business logic living within these models. Views represent your user interface, often taking the form of HTML that will be sent down to the browser. They’re used to present application data to anything making requests from your application. Controllers offer the glue between models and views. Their responsibility is to process requests from the browser, ask your models for data and then supply this data to views so that they may be presented to the browser.

pages: 255 words: 55,018

Architecting For Scale
by Lee Atchison
Published 25 Jul 2016

To implement an improved piece of business functionality, an individual developer must make changes within the single application, and all developers making changes must make them within the same single application. Developers can easily step on one another’s toes, and make conflicting changes that result in problems and outages. In a service-oriented architecture, individual services are created that encompass a specific subset of business logic. These individual services are interconnected to provide the entire set of business logic for the application. The Monolith Application Figure 11-1 shows an application that is a large, single entity with a complex, indecipherable infrastructure. This is how most applications begin to look if they are constructed and grow as monolithic applications.

How should you collect, process, and store these credit cards and the payments they represent? A good business strategy would be to put the credit card processing in a different service, separate from the rest of the system. Putting critical business logic such as credit card processing into its own service is valuable for several reasons: Legal/regulatory requirements There are legal and regulatory requirements around how you store credit cards that require you to treat them in different ways from other business logic and other business data. Separating this into a distinct service makes it easier to treat this data differently from the rest of your business data. Security You might need additional firewalls for security reasons around these servers.

This sort of data integration would require tighter coordination between Service A and Service B than is desired, and it can cause problems when data maintenance and schema migration activities need to occur. In general, the accessing of Service B’s data directly by Service A without involving Service B’s business logic in that process can cause serious data versioning and data corruption issues. It should be strictly avoided. Figure 12-2. Incorrect way to share data As you can see, determining data division lines is an important characteristic in determining service division lines. Does it make sense for a given service to be the “owner” of its data and provide access to that data only via external service interfaces?

pages: 196 words: 58,122

AngularJS
by Brad Green and Shyam Seshadri
Published 15 Mar 2013

This certainly does have the negative side effects that folks talk about when describing the issue labeled as structure/behavior. There’s a simple acid test we can use to figure out if our system suffers from this coupling: can we create a unit test for our app logic that doesn’t require the DOM to be present? In Angular, yes we can write controllers containing our business logic without having references to the DOM.The problem was never in the event handlers, but rather in the way we needed to write JavaScript previously. Notice that in all the controllers we’ve written so far, here and elsewhere in this book, there are no references to the DOM or DOM events anywhere.

So spend some extra time thinking about your model, what the attributes of your object are going to be, and how you are going to retrieve it from the server and save it. The view will get updated automatically through the use of data bindings, so the focus should always be on the model. The controller holds the business logic: how you retrieve your model, what kinds of operations you perform on it, what kind of information your view needs from the model, and how you transform the model to get what you want. The responsibility of validation, making server calls, bootstrapping your view with the right data, and mostly everything in between belongs on your controller.

It should mostly be restricted to the following: Displaying your model Defining the ways the user can interact with your application (clicks, input fields, and so on) Styling the app, and figuring out how and when some elements are displayed (show or hide, hover, and so on) Filtering and formatting your data (both input and output) Realize that the template in Angular is not necessarily the view part of the Model View Controller design paradigm. Instead, the view is the compiled version of the template that gets executed. It is a combination of the template and the model. What should not go into the template is any kind of business logic or behavior; this information should be restricted to the controller. Keeping the template simple allows a proper separation of concerns, and also ensures that you can get the most code under test using only unit tests. Templates will have to be tested with scenario tests. But, you might ask, where does DOM manipulation go?

pages: 422 words: 86,414

Hands-On RESTful API Design Patterns and Best Practices
by Harihara Subramanian
Published 31 Jan 2019

As a platform or a framework, it's good that it addresses a few technical cross-cutting concerns, such as auditing, load-balancing, authentication, and health checks, so that service or API developers can focus on business logic without worrying too much about those technical concerns, also called non-functional requirements. Light 4j provides various handler logic and separates those non-functional requirements from the business context, to help the API developers to focus on developing business logic. Learning about Light Rest 4j Light Rest 4j is a framework that is built on top of Light 4j, and designed to speed up RESTful API development and deployment.

While layered systems bring additional latency and overhead as a drawback, there are trade-offs that are the benefits of layers and layered system designs, as follows: Encapsulates legacy services Introduces intermediaries Limits system complexity Improves scalability Code on demand In distributed computing, code on demand (COD) is any technology that enables the server to send the software code to the clients to be executed on the client computer upon request from the client's software. Some well-known examples of the COD paradigm on the web are Java applets, the Adobe ActionScript language for the Flash player, and JavaScript. The following can also be called the advantages of COD: COD is the optional constraint of REST and intends to allow business logic within the client web browser, applets, JavaScript, and ActionScript (Flash). I think video on demand sites are good examples of COD, as the video data files are downloaded and played according to the client system's specifications. Only one optional constraint according to REST architectural style and it is COD.

As design patterns provide generic, time-tested, proven, and reusable solutions to familiar yet recurring design problems, API design patterns are essential for software designers to learn and adapt in their RESTful API applications. API design patterns provide a description or templates to solve specific, recurring API design problems that any software architects and API designers would like to adopt in their API designs. Adopting patterns provides much flexibility to developers and helps them focus on business logic implementation and deliver the service with high quality. As part of this chapter, we will learn the following common yet essential API design patterns, along with a few sample pieces of code as well. However, please note that there is no specific order to the following patterns and each pattern addresses the RESTful constraints.

pages: 378 words: 67,804

Learning Android
by Marko Gargenta
Published 11 Mar 2011

As it stands right now, the SimpleCursorAdapter is capable only of mapping straight from a database value to layout view. This doesn’t work for our needs, because we need to add some business logic in between the data and the view. To do this, we’ll create our own adapter. TimelineAdapter TimelineAdapter is our custom adapter, shown in Example 10-6. Although SimpleCursorAdapter did a straightforward mapping of data in the database to views on the screen, we had an issue with the timestamp. The job of TimelineAdapter is to inject some business logic to convert the Unix timestamp to relative time. The method in SimpleCursorAdapter that creates a displayable view from input data is bindView(), so we’ll override that method and ask it to massage the data before it is displayed.

ViewBinder: A Better Alternative to TimelineAdapter Instead of creating a new TimelineAdapter that is a subclass of SimpleCursorAdapter and overriding its bindView() method, we could attach the business logic directly to the existing SimpleCursorAdapter. This approach is more efficient because we are not overriding bindView() and we do not require a separate custom adapter class. To attach business logic to an existing SimpleCursorAdapter, use its setViewBinder() method. We will need to supply the method with an implementation of ViewBinder. ViewBinder is an interface that specifies setViewValue(), where the actual binding of a particular date element to a particular view happens.

Since there may be quite a bit of data, we will use ScrollView to wrap our text and provide scroll bars. The second iteration uses the much more scalable and efficient ListView and Adapter approach. In this step, you will learn how adapters and lists work. Finally, we will create a custom Adapter to handle some additional business logic. At this point, we are going under the hood of an adapter and adding custom processing. You’ll understand the purpose and usage of adapters better after this exercise. Basic TimelineActivity Layout In this first iteration, we are creating a new layout for the TimelineActivity. This layout initially uses a TextView to display all the data that we have in the database.

Refactoring: Improving the Design of Existing Code
by Martin Fowler , Kent Beck , John Brant , William Opdyke and Don Roberts
Published 9 Mar 2012

Duplicate Observed Data You have domain data available only in a GUI control, and domain methods need access. Copy the data to a domain object. Set up an observer to synchronize the two pieces of data. Motivation A well-layered system separates code that handles the user interface from code that handles the business logic. It does this for several reasons. You may want several interfaces for similar business logic; the user interface becomes too complicated if it does both; it is easier to maintain and evolve domain objects separate from the GUI; or you may have different developers handling the different pieces. Although the behavior can be separated easily, the data often cannot.

This idea underpinned the relationship between the graphical user interface (GUI) and domain objects in Smalltalk-80. 302 The gold at the heart of MVC is the separation between the user interface code (the view, these days often called the presentation) and the domain logic (the model). The presentation classes contain only the logic needed to deal with the user interface. Domain objects contain no visual code but all the business logic. This separates two complicated parts of the program into pieces that are easier to modify. It also allows multiple presentations of the same business logic. Those experienced in working with objects use this separation instinctively, and it has proved its worth. But this is not how most people who work with GUIs do their design. Most environments with client-server GUIs use a logical two-tier design: the data sits in the database and the logic sits in the presentation classes.

One-way links are easier, but sometimes you need to Change Unidirectional Association to Bidirectional to support a new function. Change Bidirectional Association to Unidirectional removes unnecessary complexity should you find you no longer need the two-way link anymore. I've often run into cases in which GUI classes are doing business logic that they shouldn't. To move the behavior into proper domain classes, you need to have the data in the domain class and support the GUI by using Duplicate Observed Data. I normally don't like duplicating data, but this is an exception that is usually impossible to avoid. One of the key tenets of object-oriented programming is encapsulation.

Designing Web APIs: Building APIs That Developers Love
by Brenda Jin , Saurabh Sahni and Amir Shevat
Published 28 Aug 2018

Designing for a Great Developer Experience | 51 Make Troubleshooting Easy Another best practice for designing APIs is making troubleshooting easy for developers. This can be done through returning meaningful errors as well as by building tooling. Meaningful errors What’s in an error? An error can occur in many places along your code path, from an authorization error during an API request, to a business logic error when a particular entity doesn’t exist, to a lowerlevel database connection error. When designing an API, it is help‐ ful to make troubleshooting as easy as possible by systematically organizing and categorizing errors and how they are returned. Incorrect or unclear errors are frustrating and can negatively affect adoption of your APIs.

Map out the vari‐ ous high-level categories of errors that occur during the course of an API request, from the beginning of the request to any service boundaries within your architecture. Table 4-2 provides a brief example to get you started. Table 4-2. Group errors into high-level categories Error category System-level error Examples Database connection issue Backend service connection issue Fatal error Business logic error Rate-limited Request fulfilled, but no results were found Business-related reason to deny access to information API request formatting error Required request parameters are missing Combined request parameters are invalid together Authorization error OAuth credentials are invalid for request Token has expired After grouping your error categories throughout your code path, think about what level of communication is meaningful for these errors.

Table 4-3 offers examples of how you might begin to organize your errors as you design your API. Table 4-3. Organize your errors into status codes, headers, machinereadable codes, and human-readable strings Error category HTTP status HTTP headers Error code (machine-readable) System-level 500 error Business logic 429 error -- -- RetryAfter rate_limit_exceeded API request formatting error Auth error 400 -- 401 -- Error message (humanreadable) -- “You have been rate-limited. See Retry-After and try again.” missing_required_parameter “Your request was missing a {user} parameter.” “Your ClientId is invalid_request invalid.”

Python Web Development With Django
by Jeff Forcier

Controlling Which Stories Are Viewed Our database contains both publishable (3 and 4 from STATUS_CHOICES previously shown) and not-yet-publishable (statuses 1 and 2) stories.We want a convenient way to have only the former viewable on the site’s public pages, although of course making sure the full set is editable in the admin. Because this is a matter of business logic rather than presentation style, it should be implemented in our model. We could make it happen via {% if...%} tags in our templates, but that solution would end up being needlessly brittle, verbose, and repetitive. (If you don’t believe this, we encourage you to try it—the negatives become apparent before you’re through!) Based on your authors’ collective experience, it’s always a good idea to keep business logic out of your templates because over time they turn into spaghetti! We add this capability to our Story model via a custom Manager.

If you added 'title' after the comma, and you had two posts titled “A” and “B” with the same timestamp, post “A” would come first. Timestamp Formatting Via a Template Filter That timestamp is handy, but its ISO8601 format is a little nerdy. Let’s humanize it a bit by using a cool feature of the Django template system: filters. Because this is a presentation detail, not a data structure or business logic detail, the appropriate place for it is in the template. Open your archive.html file and change the “post.timestamp” line to <p>{{ post.timestamp|date }}</p> To apply a filter to a variable, you simply tack it on to the end of the variable name— inside the curly brackets—using a vertical bar, or “pipe,” character.

In the course of building this skeletal blog app you’ve seen a number of Django’s elegant, laborsaving features: n n n n The built-in Web server, which makes your development work more self-contained and automatically reloads your code if you edit it The pure-Python approach to data model creation, which saves you from having to write or maintain SQL code or XML description files The automatic admin application, which provides full-fledged content-editing features even for nontechnical users The template system, which can be used to produce HTML, CSS, JavaScript, or any textual output format 75 76 Chapter 2 Django for the Impatient: Building a Blog n n Template filters, which can alter the presentation of your data (such as dates) without messing with your application’s business logic The URLconf system, which gives you great flexibility in URL design while keeping application-specific portions of URLs in the application, where they belong Just to give you an idea of what’s ahead, the following are some things we could proceed to do to our blog using Django’s built-in features: n n n Publish Atom or RSS feeds of our latest posts (see Chapter 11) Add a search feature so that users can locate blog posts containing specific terms (see the CMS example app in Chapter 8,“Content Management System”) Adopt Django’s “generic views” to avoid having to write any code in views.py at all (see the Pastebin example app in Chapter 10,“Pastebin”) You’ve completed your whirlwind tour of Django basics.

pages: 39 words: 10,453

Designing Great Web APIs: Creating Business Value Through Developer Experience
by James Higginbotham
Published 14 Apr 2015

This mimics how we use the Web: we go to a homepage, click the login link, enter our credentials, then navigate to various areas of the application. Using hypermedia enables our clients to be more flexible and reduces the amount of business logic we have to code into them. Instead, they look for the existence of specific links within a response payload and offer (or hide) specific actions based on the server’s determination of what is and isn’t allowed. If the business logic needs to change in a workflow, the server simply adds or removes the appropriate hypermedia links that are used to guide the client’s behavior. Some REST purists believe that hypermedia is a requirement for an API to be labeled REST.

In addition to modern browsers, there has been explosive growth in mobile devices such as phones and tablets. These devices have access to the Internet from most locations and offer GPS location and app-store distribution. Applications no longer have to be web pages in a browser. Instead, they can use APIs to access data and business logic to get things done. Finally, the Internet of Things (IoT) is moving the world of devices, previously requiring human intervention, into autonomous replacements that combine the physical world with the world of software. As a result, APIs enable IoT devices to broadcast their telemetry data and receive commands from other systems.

pages: 2,054 words: 359,149

The Art of Software Security Assessment: Identifying and Preventing Software Vulnerabilities
by Justin Schuh
Published 20 Nov 2006

This presentation logic could be an XSLT stylesheet written by a designer that instructs the server how to render the data into HTML. Business Logic The programs that make up a Web application have to deal with the vagaries of a HTTP/HTML-based user interface as well as the actual business logic that drives the site. Business logic is a somewhat nebulous term, but it generally refers to procedures and algorithms an application performs that directly relate to business items and processes. For example, in a banking Web site, business logic includes tasks such as looking up bank accounts, enforcing rules for money transfers, and verifying a request for a credit limit increase. Business logic doesn’t include tasks related to the Web site infrastructure or interface, such as expiring a user’s token, making sure a user is authenticated to the Web site, formatting HTML output, and handling missing form input in a user request.

(Web services and SOAP are discussed more in Chapter 18.) The Web tier is essentially the Web server. This tier is typically responsible for handling user requests, dispatching requests to the business logic, handling the results from the business logic, and rendering results into HTML for end users. The Web tier is composed of Web server software; application code such as ASP, PHP, or Java servlets; and HTML and any accompanying presentation logic. The business tier handles the business logic of a Web application. This tier handles requests from the Web tier to perform business functions. It’s often implemented by using an application server that hosts business objects.

Business logic doesn’t include tasks related to the Web site infrastructure or interface, such as expiring a user’s token, making sure a user is authenticated to the Web site, formatting HTML output, and handling missing form input in a user request. Another related concept is business objects, which encapsulate business logic in an object-oriented framework. For example, a banking site might define business objects such as Customer, Account, and Transfer, and define methods that carry out business logic, such as Account.getStatement() and Transfer.Validate(). N-Tier Architectures Many enterprise Web applications are constructed with multiple tiers, in which Web site functionality is divided into separate components and distributed across multiple servers, as shown in Figure 17-3.

Reactive Messaging Patterns With the Actor Model: Applications and Integration in Scala and Akka
by Vaughn Vernon
Published 16 Aug 2015

Message Routing In Chapter 4, “Messaging with Actors,” you were introduced to the basic idea of Message Routers (140) and why they should be used, both in your local actor system and beyond, for integration purposes. Routers allow you to decouple the message source from the message destination, and you can place business logic in any given Message Router (140) to determine how the routing should take place. There’s nothing inherently wrong with a Message Router (140) being responsible for the business logic, but depending on the type of router used, you can limit the amount of business logic needed. Since routing can be used both within an Akka cluster and across clusters for integration, remember that routing to remote routees is at your disposal.

* * * Amazon.com Designs with Actor Model Principles In an interview with Association for Computing Machinery (ACM), Amazon.com CTO Werner Vogels comments on service orientation in Amazon’s architecture [ACM-Amazon]: This was way before service-oriented was a buzzword. For us service orientation means encapsulating the data with the business logic that operates on the data, with the only access through a published service interface. No direct database access is allowed from outside the service, and there’s no data sharing among the services. As you will see in the “How the Actor Model Helps” section, these very principles of “encapsulating the data with the business logic...and there’s no data sharing among the services” are central to the Actor model. * * * Since scalability is necessary and must never be an afterthought, there had better be some way to deal with the network’s impact on distributed systems.

In Chapter 5, “Messaging Channels,” I expand on the basic channel mechanism and explore several kinds of channels, each with a specific advantage when dealing with various application and integration challenges. Chapter 6, “Message Construction,” shows you how each message must convey the intent of the sender’s reason to communicate with the receiver. Chapter 7, “Message Routing,” shows you how to decouple the message source from the message destination and how you might place appropriate business logic in a router. In Chapter 8, “Message Transformation,” you’ll dig deeper into various kinds of transformations that messages may undergo in your applications and integrations. In Chapter 9, “Message Endpoints,” you will see the diverse kinds of endpoints, including those for persistent actors and idempotent receivers.

pages: 133 words: 42,254

Big Data Analytics: Turning Big Data Into Big Money
by Frank J. Ohlhorst
Published 28 Nov 2012

Of course, one of the primary capabilities offered by abstraction tools is the ability to normalize and interpret the data into a uniform structure, which can be further worked with. The key here is to make sure that whatever abstraction technology is employed deals with current and future data sets efficiently. Business logic. A critical component of the Big Data analytics process is logic, especially business logic, which is responsible for processing the data. Currently, MapReduce reigns supreme in the realm of Big Data business logic. MapReduce was designed to handle the processing of massive amounts of data through moving the processing logic to the data and distributing the logic in parallel to all nodes. Another factor that adds to the appeal of MapReduce is that developing parallel processing code is very complex.

See Business intelligence (BI) Big Data and Big Data analytics analysis categories application platforms best practices business case development challenges classifications components defined evolution of examples of 4Vs of goal setting introduction investment in path to phases of potential of privacy issues processing role of security (See Security) sources of storage team development technologies (See Technologies) value of visualizations Big Science BigSheets Bigtable Bioinformatics Biomedical industry Blekko Business analytics (BA) Business case best practices data collection and storage options elements of introduction Business intelligence (BI) as Big Data analytics foundation Big Data analytics team incorporation Big Data impact defined extract, transform, and load (ETL) information technology and in-memory processing limitations of marketing campaigns risk analysis storage capacity issues unstructured data visualizations Business leads Business logic Business objectives Business rules C Capacity of storage systems Cassandra Census data CERN Citi Classification of data Cleaning Click-stream data Cloud computing Cloudera Combs, Nick Commodity hardware Common Crawl Corpus Communication Competition Compliance Computer security officers (CSOs) Consulting firms Core capabilities, data analytics team Costs Counterintelligence mind-set CRUD (create, retrieve, update, delete) applications Cryptographic keys Culture, corporate Customer needs Cutting, Doug D Data defined growth in volume of value of See also Big Data and Big Data analytics Data analysis categories challenges complexity of as critical skill for team members data accuracy evolution of importance of process technologies Database design Data classification Data discovery Data extraction Data integration technologies value creation Data interpretation Data manipulation Data migration Data mining components as critical skill for team members defined examples methods technologies Data modeling Data protection.

pages: 193 words: 46,550

Twisted Network Programming Essentials
by Jessica McKellar and Abe Fettig
Published 15 Mar 2013

The Components of Twisted Cred Before we get into the usage examples, there are a few terms that you should familiarize yourself with: Credentials Information used to identify and authenticate a user. Common credentials are a username and password, but they can be any data or object used to prove a user’s identity, such as a certificate or challenge/response protocol. Objects that provide credentials implement twisted.cred.credentials.ICredentials. Avatar A business logic object in a server application that represents the actions and data available to a user. For example, an avatar for a mail server might be a mailbox 81 object, an avatar for a web server might be a resource, and an avatar for an SSH server might be a remote shell. Avatars implement an interface that inherits from zope.interface.Interface.

Authentication in Twisted Applications So far these Twisted Cred examples have used servers outside the Twisted application infrastructure discussed in Chapter 6. Twisted makes it easy to integrate authentication into applications deployed through twistd using the AuthOptionMixin class, and this is in fact where Twisted Cred really shines for providing a standard interface for swapping in and out authentication mechanisms decoupled from the business logic of your ap‐ plication. As a concrete example, let’s convert our authenticating echo server from Example 9-1 to a Twisted application. First, delete the realm, portal, and reactor code, which twistd and the plugin will handle instead, from that server file: -realm = Realm() -myPortal = portal.Portal(realm) -checker = checkers.InMemoryUsernamePasswordDatabaseDontUse() -checker.addUser("user", "pass") -myPortal.registerChecker(checker) -reactor.listenTCP(8000, EchoFactory(myPortal)) -reactor.run() Then, create a plugin for this application using the same template from Example 6-4: in the directory containing the server application, create a twisted directory containing a plugins directory containing a file echo_cred_plugin.py.

An implementor of imap4.IMailbox, which represents an individual mailbox. Users can check, add messages to, and expunge messages from their mailboxes. The mailbox must understand how a message is stored—in our case, in the Maildir format. 3. An implementor of imap4.IAccount, which is the avatar—the business logic object in the Twisted Cred model. Through this mail account, users can manage and list their mailboxes. Example 13-4 shows a minimal IMAP server implementation. Example 13-4. IMAP Maildir server, imapserver.py import email import os import random from StringIO import StringIO import sys from zope.interface import implements IMAP Clients and Servers | 133 from from from from twisted.cred import checkers, portal twisted.internet import protocol, reactor twisted.mail import imap4, maildir twisted.python import log class IMAPUserAccount(object): implements(imap4.IAccount) def __init__(self, userDir): self.dir = userDir def _getMailbox(self, path): fullPath = os.path.join(self.dir, path) if not os.path.exists(fullPath): raise KeyError, "No such mailbox" return IMAPMailbox(fullPath) def listMailboxes(self, ref, wildcard): for box in os.listdir(self.dir): yield box, self.

pages: 739 words: 174,990

The TypeScript Workshop: A Practical Guide to Confident, Effective TypeScript Programming
by Ben Grynhaus , Jordan Hudgens , Rayon Hunte , Matthew Thomas Morgan and Wekoslav Stefanovski
Published 28 Jul 2021

You have added some behavior while keeping everything that already was. Now, you can replace the original method with the new improved one. What you will get with this approach is this: the original method won't know or care about the cross-cutting concerns of the application, instead focusing on its own business logic – the application can "upgrade" the method at runtime with one that has all the necessary business logic as well as all the required additions. This kind of transparent "upgrade" is often termed a decoration, and the method that does the decorating is called a decorator method. What has been shown here is just one form that a decoration can take.

Introduction So far, we've learned some of the basics of TypeScript, how to set up a project, and the use of definition files. Now we will delve into the topic of functions, which are going to be the most important tools in your arsenal. Even object-oriented programming paradigms depend heavily on functions as a basic building block of business logic. Functions, sometimes called routines or methods, are part of every high-level programming language. The ability to reuse segments of code is critical, but functions provide an even more important role than that in that they can be given different arguments, or variables, to act against and produce different results.

The aim of this activity is to demonstrate the uses of class and method decorators in order to address a cross-cutting concern of your application, without changing the functionality of the given class. You should have a detailed statistic of the life cycles of your objects, without adding any complexity to the business logic. The following steps should help you with the solution: Note Before you begin, make sure you have set up the correct compiler options as mentioned in the Setting Up Compiler Options section. The code file for this activity can also be downloaded from https://packt.link/UK49t. Create a class called Person with public properties named firstName, lastName, and birthday.

pages: 462 words: 172,671

Clean Code: A Handbook of Agile Software Craftsmanship
by Robert C. Martin
Published 1 Jan 2007

The information sent with the exception can distinguish the errors. Use different classes only if there are times when you want to catch one exception and allow the other one to pass through. Define the Normal Flow If you follow the advice in the preceding sections, you’ll end up with a good amount of separation between your business logic and your error handling. The bulk of your code will start to look like a clean unadorned algorithm. However, the process of doing this pushes error detection to the edges of your program. You wrap external APIs so that you can throw your own exceptions, and you define a handler above your code so that you can deal with any aborted computation.

Listing 11-2 shows the corresponding implementation class for the Bank bean. Listing 11-2 The corresponding EJB2 Entity Bean Implementation package com.example.banking; import java.util.Collections; import javax.ejb.*; public abstract class Bank implements javax.ejb.EntityBean { // Business logic… public abstract String getStreetAddr1(); public abstract String getStreetAddr2(); public abstract String getCity(); public abstract String getState(); public abstract String getZipCode(); public abstract void setStreetAddr1(String street1); public abstract void setStreetAddr2(String street2); public abstract void setCity(String city); public abstract void setState(String state); public abstract void setZipCode(String zip); public abstract Collection getAccounts(); public abstract void setAccounts(Collection accounts); public void addAccount(AccountDTO accountDTO) { InitialContext context = new InitialContext(); AccountHomeLocal accountHome = context.lookup(”AccountHomeLocal”); AccountLocal account = accountHome.create(accountDTO); Collection accounts = getAccounts(); accounts.add(account); } // EJB container logic public abstract void setId(Integer id); public abstract Integer getId(); public Integer ejbCreate(Integer id) { … } public void ejbPostCreate(Integer id) { … } // The rest had to be implemented but were usually empty: public void setEntityContext(EntityContext ctx) {} public void unsetEntityContext() {} public void ejbActivate() {} public void ejbPassivate() {} public void ejbLoad() {} public void ejbStore() {} public void ejbRemove() {} } I haven’t shown the corresponding LocalHome interface, essentially a factory used to create objects, nor any of the possible Bank finder (query) methods you might add.

.*; public abstract class Bank implements javax.ejb.EntityBean { // Business logic… public abstract String getStreetAddr1(); public abstract String getStreetAddr2(); public abstract String getCity(); public abstract String getState(); public abstract String getZipCode(); public abstract void setStreetAddr1(String street1); public abstract void setStreetAddr2(String street2); public abstract void setCity(String city); public abstract void setState(String state); public abstract void setZipCode(String zip); public abstract Collection getAccounts(); public abstract void setAccounts(Collection accounts); public void addAccount(AccountDTO accountDTO) { InitialContext context = new InitialContext(); AccountHomeLocal accountHome = context.lookup(”AccountHomeLocal”); AccountLocal account = accountHome.create(accountDTO); Collection accounts = getAccounts(); accounts.add(account); } // EJB container logic public abstract void setId(Integer id); public abstract Integer getId(); public Integer ejbCreate(Integer id) { … } public void ejbPostCreate(Integer id) { … } // The rest had to be implemented but were usually empty: public void setEntityContext(EntityContext ctx) {} public void unsetEntityContext() {} public void ejbActivate() {} public void ejbPassivate() {} public void ejbLoad() {} public void ejbStore() {} public void ejbRemove() {} } I haven’t shown the corresponding LocalHome interface, essentially a factory used to create objects, nor any of the possible Bank finder (query) methods you might add. Finally, you had to write one or more XML deployment descriptors that specify the object-relational mapping details to a persistence store, the desired transactional behavior, security constraints, and so on. The business logic is tightly coupled to the EJB2 application “container.” You must subclass container types and you must provide many lifecycle methods that are required by the container. Because of this coupling to the heavyweight container, isolated unit testing is difficult. It is necessary to mock out the container, which is hard, or waste a lot of time deploying EJBs and tests to a real server.

Django Book
by Matt Behrens
Published 24 Jan 2015

If you follow this philosophy, it’s easy to make changes to one particular piece of the application without affecting the other pieces. In view functions, for instance, we discussed the importance of separating the business logic from the presentation logic by using a template system. With the database layer, we’re applying that same philosophy to data access logic. Those three pieces together – data access logic, business logic, and presentation logic – comprise a concept that’s sometimes called the Model-View-Controller (MVC) pattern of software architecture. In this pattern, “Model” refers to the data access layer, “View” refers to the part of the system that selects what to display and how to display it, and “Controller” refers to the part of the system that decides which view to use, depending on user input, accessing the model as needed.

The first thing to note is that we split it over four Python files (models.py, views.py, urls.py) and an HTML template (latest_books.html). # models.py (the database tables) from django.db import models class Book(models.Model): name = models.CharField(max_length=50) pub_date = models.DateField() # views.py (the business logic) from django.shortcuts import render from models import Book def latest_books(request): book_list = Book.objects.order_by('-pub_date')[:10] return render(request, 'latest_books.html', {'book_list': book_list}) # urls.py (the URL configuration) from django.conf.urls.defaults import * import views urlpatterns = patterns('', (r'^latest/$', views.latest_books), ) # latest_books.html (the template) <html><head><title>Books</title></head> <body> <h1>Books</h1> <ul> {% for book in book_list %} <li>{{ book.name }}</li> {% endfor %} </ul> </body></html> Again, don’t worry about the particulars of syntax; just get a feel for the overall design.

The main thing to note here is the separation of concerns: The models.py file contains a description of the database table, represented by a Python class. This class is called a model. Using it, you can create, retrieve, update and delete records in your database using simple Python code rather than writing repetitive SQL statements. The views.py file contains the business logic for the page. The latest_books() function is called a view. The urls.py file specifies which view is called for a given URL pattern. In this case, the URL /latest/ will be handled by the latest_books() function. In other words, if your domain is example.com, any visit to the URL http://example.com/latest/ will call the latest_books() function.

pages: 509 words: 92,141

The Pragmatic Programmer
by Andrew Hunt and Dave Thomas
Published 19 Oct 1999

We document knowledge in specifications, we make it come alive in running code, and we use it to provide the checks needed during testing. Unfortunately, knowledge isn't stable. It changes—often rapidly. Your understanding of a requirement may change following a meeting with the client. The government changes a regulation and some business logic gets outdated. Tests may show that the chosen algorithm won't work. All this instability means that we spend a large part of our time in maintenance mode, reorganizing and reexpressing the knowledge in our systems. Most people assume that maintenance begins when an application is released, that maintenance means fixing bugs and enhancing features.

Among other problems, the user interface needs to be intuitive and the algorithms you use to determine optimal packing are very complex. You could prototype a user interface for your end users in a GUI tool. You code only enough to make the interface responsive to user actions. Once they've agreed to the layout, you might throw it away and recode it, this time with the business logic behind it, using the target language. Similarly, you might want to prototype a number of algorithms that perform the actual packing. You might code functional tests in a high-level, forgiving language such as Perl, and code low-level performance tests in something closer to the machine. In any case, once you'd made your decision, you'd start again and code the algorithms in their final environment, interfacing to the real world.

This example is in C++. 27. Metaprogramming No amount of genius can overcome a preoccupation with detail • Levy's Eighth Law Details mess up our pristine code—especially if they change frequently. Every time we have to go in and change the code to accommodate some change in business logic, or in the law, or in management's personal tastes of the day, we run the risk of breaking the system—of introducing a new bug. So we say "out with the details!" Get them out of the code. While we're at it, we can make our code highly configurable and "soft"—that is, easily adaptable to changes.

pages: 1,302 words: 289,469

The Web Application Hacker's Handbook: Finding and Exploiting Security Flaws
by Dafydd Stuttard and Marcus Pinto
Published 30 Sep 2007

We will examine the security implications of these and other recent trends in the appropriate locations throughout this book. Despite all the changes that have occurred within web applications, some categories of "classic" vulnerabilities show no sign of diminishing. They continue to arise in pretty much the same form as they did in the earliest days of the web. These include defects in business logic, failures to properly apply access controls, and other design issues. Even in a world of bolted-together application components and everything-as-a-service, these timeless issues are likely to remain widespread. Summary In a little over a decade, the World Wide Web has evolved from purely static information repositories into highly functional applications that process sensitive data and perform powerful actions with real-world consequences.

The application design may deliberately sacrifice security in favor of speed, perhaps in the mistaken belief that traders are trusted users, or that the browser extension includes its own defenses. Recalling the core security problem discussed in Chapter 2, and the earlier sections of this chapter, we know that the concept of a client-side component defending its business logic is impossible. Browser extensions can capture data in various ways — via input forms and in some cases by interacting with the client operating system's filesystem or registry. They can perform arbitrarily complex validation and manipulation of captured data before submission to the server. Furthermore, because their internal workings are less transparent than HTML forms and JavaScript, developers are more likely to assume that the validation they perform cannot be circumvented.

In many cases, this is the quickest and easiest way to start testing the component, but you may encounter several limitations. The data being transmitted may be obfuscated or encrypted, or may be serialized using schemes that are specific to the technology being used. By looking only at the traffic generated by the component, you may overlook some key functionality or business logic that can be discovered only by analyzing the component itself. Furthermore, you may encounter obstacles to using your intercepting proxy in the normal way; however, normally these can be circumvented with some careful configuration, as described later in this chapter. Second, you can target the component itself directly and attempt to decompile its bytecode to view the original source, or interact dynamically with the component using a debugger.

pages: 231 words: 71,248

Shipping Greatness
by Chris Vander Mey
Published 23 Aug 2012

If you’ve ever used Microsoft Access at a moderately advanced level, you’ve encountered SQL. The business logic is the brains of your operation. It’s where all the tricky calculations happen and where the IF {Charlie said no;} THEN {kill Charlie;} type statements go. Your engineers will build this in Java or C++ or something similar. The presentation layer is generally HTML and JavaScript. It formats the output of your business logic so the data looks pretty. JavaScript allows users to interact in real time. AJAX (Asynchronous JavaScript and XML) is nothing more than allowing JavaScript to submit mini-page requests to your business logic, rather than requiring the user to submit a whole form.

Instead of the server returning HTML and JavaScript, it returns just a tiny bit of data in the form of XML. So AJAX has nothing to do with a three-tier architecture. It is possible to flatten this three-tier architecture into two tiers and allow your engineering team to write one file that contains both business logic and presentation logic. Shudder to think. Some frameworks will even hook up with databases in such a way that the database can return XML that can be used directly by frontend JavaScript! These and other great time savers are lovely initially but will haunt you for years after, just like that bad job you did on the grout in the shower.

They’re great for internal projects but will probably not survive the sale of your business. The Second S: Services A service-oriented architecture (SOA) doesn’t have much to do with a three-tier architecture—but you had better believe you want one! An SOA breaks down the middle tier that contains your business logic into a collection of independent services. These services may run on the same server, but they are built, versioned, and run independently. Figure 9-2 shows an example SOA. Figure 9-2. A system architecture organized around services In the SOA shown in Figure 9-2, your engineering team will put the system that figures out Charlie’s response into the answer service.

pages: 180 words: 37,187

AngularJS Essentials
by Rodrigo Branas
Published 20 Aug 2014

The topics that we'll be covering in this chapter are: • Introduction to AngularJS • Understanding the architectural concepts • Setting up the framework • Organizing the code Introduction to AngularJS Created by Miško Hevery and Adam Abrons in 2009, AngularJS is an open source, client-side JavaScript framework that promotes a high-productivity web development experience. It was built on the belief that declarative programming is the best choice to construct the user interface, while imperative programming is much better and preferred to implement an application's business logic. To achieve this, AngularJS empowers traditional HTML by extending its current vocabulary, making the life of developers easier. The result is the development of expressive, reusable, and maintainable application components, leaving behind a lot of unnecessary code and keeping the team focused on the valuable and important things.

It also takes advantage of the directives mechanism, which is a type of extension of the HTML vocabulary that brings the ability to perform programming language tasks such as iterating over an array or even evaluating an expression conditionally. Behind the view, there is the controller. At first, the controller contains all the business logic implementation used by the view. However, as the application grows, it becomes really important to perform some refactoring activities, such as moving the code from the controller to other components (for example, services) in order to keep the cohesion high. The connection between the view and the controller is done by a shared object called scope.

Low cohesion applications contain plenty of duplicated code and are hard to unit test because it is difficult to isolate the behavior, which is usually hidden inside the component. It also reduces the reuse opportunities, demanding much more effort to implement the same thing several times. In the long term, the productivity decreases while the maintenance costs are raised. With AngularJS, we are able to create services, isolating the business logic of every component of our application. Also, we can use the framework's dependency injection mechanism to easily supply any component with a desired dependency. The framework also comes with a bunch of built-in services, which are very useful in daily development. In this chapter, we'll be covering the following topics: • Dependency injection • Creating services • Using AngularJS built-in services Dependency Injection and Services Dependency injection In order to create testable and well-designed applications, we need to take care about the way their components are related to each other.

pages: 31 words: 9,168

Designing Reactive Systems: The Role of Actors in Distributed Architecture
by Hugh McKee
Published 5 Sep 2016

This report is targeted toward decision makers in the enterprise and provides some high-level insight into how actors and actor systems can be used to create lightweight business systems that evolve quickly, that can scale, and that can run without stopping. Inside, you’ll read how the Actor model’s proven approach to concurrent computation is the best way to build distributed systems correctly from the start, allowing your teams to focus on the business logic of your applications instead of wiring together low-level protocols, in turn helping you accelerate time-to-market while keeping infrastructure costs low. Chapter 2. Actors, Humans, and How We Live Imagine a world where most people are glued to small, hand-held devices that let them send messages to other humans across oceans and continents... wait, we already live in this world!

If a problem is escalated to the actor system, its default recovery process is to restart the worker (or terminate the worker when more serious problems occur). This supervisory approach frees up the worker from handling its own errors, which means that it is focused completely on performing its tasks. This allows for creating actors with much less error handling code that clutters and hides the main business logic. Figure 4-1. Actors form hierarchies Actors Watching Actors, Watching Actors... In addition to this supervision strategy, the actor system provides a way for one actor to monitor another actor. If the watched actor is terminated, the watcher actor is sent an “actor terminated” message.

pages: 419 words: 130,627

Last Man Standing: The Ascent of Jamie Dimon and JPMorgan Chase
by Duff McDonald
Published 5 Oct 2009

“There are three things that have to make sense,” he said. “And they are not in order of importance. One is the business logic. There should be clear business logic to it. The second is the price. Sometimes there is a price [at] which you cannot make it pay for shareholders. And the third is the ability to execute. [You have to be able to] see clearly getting done what you need to get done, whether it’s management or systems or marketing or culture or something like that. If those things make sense, you can then weigh and balance them. Meaning, if you have exceptional business logic and an easy ability to execute, you could pay a higher price. And conversely, if those things are a little more complex, you want a margin of error by getting a lower price.”

A thoughtful man who luxuriates in rigorous analysis, he was being asked to put his own company at risk because another firm had played too fast and too loose. Another firm, it bears repeating, that he’d passed on buying just six months before. Recall Dimon’s three components of a successful deal: business logic, the ability to execute, and price. In this instance, the business logic was a mixed bag. Buying Bear would give JPMorgan Chase a few assets it wanted but would also saddle it with some it most certainly did not. The ability to execute was totally unknown, especially on such short notice. Bear’s customers could continue to bolt, as could valuable employees.

That kind of growth will get you a higher value for your shareholders, by the way. M&A is risky and tough, so the discipline is different. You really need to think about the landscape, to ask yourself what’s changing.” In any event, at the time, JPMorgan Chase stood out as having the strongest business logic with Bank One. (FleetBoston had been number one in a theoretical merger of equals before it was sold.) In this era of intense consolidation, the two CEOs spent a lot of time discussing “what ifs” about the future of industry. The fit between the companies seemed solid on paper. JPMorgan Chase could expand its branch banking business in the process, reducing its dependency on its volatile trading and investment banking franchises.

pages: 719 words: 181,090

Site Reliability Engineering: How Google Runs Production Systems
by Betsy Beyer , Chris Jones , Jennifer Petoff and Niall Richard Murphy
Published 15 Apr 2016

Framework modules address the various SRE concerns enumerated earlier, such as: Instrumentation and metrics Request logging Control systems involving traffic and load management SRE builds framework modules to implement canonical solutions for the concerned production area. As a result, development teams can focus on the business logic, because the framework already takes care of correct infrastructure use. A framework essentially is a prescriptive implementation for using a set of software components and a canonical way of combining these components. The framework can also expose features that control various components in a cohesive manner. For example, a framework might provide the following: Business logic organized as well-defined semantic components that can be referenced using standard terms Standard dimensions for monitoring instrumentation A standard format for request debugging logs A standard configuration format for managing load shedding Capacity of a single server and determination of “overload” that can both use a semantically consistent measure for feedback to various control systems Frameworks provide multiple upfront gains in consistency and efficiency.

Requirements of the Cloud Environment in Perspective Cloud environments introduce a unique combination of technical challenges: If the environment uses a mixture of transactional and nontransactional backup and restore solutions, recovered data won’t necessarily be correct. If services must evolve without going down for maintenance, different versions of business logic may act on data in parallel. If interacting services are versioned independently, incompatible versions of different services may interact momentarily, further increasing the chance of accidental data corruption or data loss. In addition, in order to maintain economy of scale, service providers must provide only a limited number of APIs.

Therefore, structure your engineering teams such that a central infrastructure team provides a data validation framework for multiple product engineering teams. The central infrastructure team maintains the out-of-band data validation framework, while the product engineering teams maintain the custom business logic at the heart of the validator to keep pace with their evolving products. Knowing That Data Recovery Will Work When does a light bulb break? When flicking the switch fails to turn on the light? Not always—often the bulb had already failed, and you simply notice the failure at the unresponsive flick of the switch.

pages: 680 words: 157,865

Beautiful Architecture: Leading Thinkers Reveal the Hidden Beauty in Software Design
by Diomidis Spinellis and Georgios Gousios
Published 30 Dec 2008

These are translated to in-memory data and passed to some business logic for intelligent processing. The output module translates these data objects for display, into HTML, JavaScript, CSS, and so on. Here, on the top of the figure, is an application’s n-tier stack running on its infrastructure. Before the advent of applications in its Platform, Facebook operated wholly under the same architecture. Importantly, in both architectures, the business logic (including Facebook’s privacy) is effectively executed according to rules established in some data component of the system. More voluminous and relevant data means the business logic may deliver more personally tailored content, so the experience of browsing books to review, read, or purchase on http://fettermansbooks.com (or any such application) would be powerfully augmented by a user’s social data from Facebook.

GUI changes require a code release, whether the changes are implemented in straight Java code or in XML files. Why keep two languages in your head—Java plus the XML schema—instead of just Java? Besides, XML makes a clumsy programming language. GUI builders had burned all of us before. Nobody wanted to end up with business logic woven into action listeners embedded in JPanels. Reluctantly, we settled on a pure Swing GUI, but with some ground rules. Over a series of lunches at our local Applebee’s, we hashed out a novel way of using Swing without getting mired in it. UI and UI Model The typical layered architecture goes “Presentation,” “Domain,” and “Persistence.”

For instance, the maximum length of a last name will show up as a column width in the database, possibly a validation rule in the domain, and as a property setting on a JTextField in the UI. At the same time, the presentation embeds logic such as “if this checkbox is selected, then enable these four other text fields.” It sounds like a statement about the UI, but it really captures a bit of business logic: when the customer is a member of the Portrait Club, the application needs to capture their club number and expiration date. So within the typical three-layer architecture, one type of information is spread out across layers, whereas another type of important information is stuck inside GUI control logic.

pages: 282 words: 88,320

Brick by Brick: How LEGO Rewrote the Rules of Innovation and Conquered the Global Toy Industry
by David Robertson and Bill Breen
Published 24 Jun 2013

As for the younger designers who remained, they couldn’t be expected to roust that classic LEGO look by simply riffing off Andersen’s fire truck. “There were so many people who hadn’t been around when the core was building with LEGO bricks,” recalled Paal Smith-Meyer, who heads the company’s new business group. “They didn’t know who the core consumer was and they didn’t understand the core business logic. It was very, very hard.” Nevertheless, resetting the company’s direction around classic play experiences such as LEGO City proved both clarifying and liberating. The hot air had leaked out of the previous management regime’s overinflated declaration that LEGO would be the world’s strongest brand among families with children.

Recalling the stirring debut of the original Mindstorms, LEGO decided to tap the talents of the world’s most creative Mindstorms customers by inviting a handful of them to codevelop the new kit. Such a move was unprecedented at LEGO. Although LEGO had invited expert adult fans to contribute ideas and prototypes for Factory sets, never before had it allowed outsiders into a secret project’s core development process. Nevertheless, the business logic for inviting customers to codesign the future of Mindstorms was inescapable. “It was obviously relevant to engage them,” said Nipper. “They knew stuff that we didn’t.” So began the LEGO Group’s disciplined bid to amplify one of the past decade’s most talked-about business innovations—tapping the “wisdom of the crowd” to create breakthrough products.

A nondisclosure agreement provided little real protection, since the source of a leak is often hard to identify. And the remedy—in this case, suing one of your most influential and respected customers—is unpalatable. Before Lund and Smith-Meyer took the irreversible step of inviting outside innovators into the inner sanctum of the Mindstorms development team, the pair sought to map out the core business logic for cocreating Mindstorms. First, they bet that tapping into outside experts’ knowledge and insights would radically increase the odds of breaking out a hit kit. Second, by engaging expert customers—people who were semicelebrities in the Mindstorms world—those customers could in turn act as persuasive ambassadors for the next generation of Mindstorms.

pages: 960 words: 125,049

Mastering Ethereum: Building Smart Contracts and DApps
by Andreas M. Antonopoulos and Gavin Wood Ph. D.
Published 23 Dec 2018

A really large monolithic smart contract may cost a lot of gas to deploy and use. Therefore, some applications may choose to have off-chain computation and an external data source. Keep in mind, however, that having the core business logic of the DApp be dependent on external data (e.g., from a centralized server) means your users will have to trust these external resources. Frontend (Web User Interface) Unlike the business logic of the DApp, which requires a developer to understand the EVM and new languages such as Solidity, the client-side interface of a DApp can use standard web technologies (HTML, CSS, JavaScript, etc.).

For example, a frontend can be developed as a web app that runs on a centralized server, or as a mobile app that runs on your device. The backend and storage can be on private servers and proprietary databases, or you can use a smart contract and P2P storage. There are many advantages to creating a DApp that a typical centralized architecture cannot provide: Resiliency Because the business logic is controlled by a smart contract, a DApp backend will be fully distributed and managed on a blockchain platform. Unlike an application deployed on a centralized server, a DApp will have no downtime and will continue to be available as long as the platform is still operating. Transparency The on-chain nature of a DApp allows everyone to inspect the code and be more sure about its function.

In the Ethereum ecosystem as it stands today, there are very few truly decentralized apps — most still rely on centralized services and servers for some part of their operation. In the future, we expect that it will be possible for every part of any DApp to be operated in a fully decentralized way. Backend (Smart Contract) In a DApp, smart contracts are used to store the business logic (program code) and the related state of your application. You can think of a smart contract replacing a server-side (aka “backend”) component in a regular application. This is an oversimplification, of course. One of the main differences is that any computation executed in a smart contract is very expensive and so should be kept as minimal as possible.

The Art of Readable Code
by Dustin Boswell and Trevor Foucher
Published 14 Sep 2010

Consider this thought experiment: someone new just joined your team, she’s sitting next to you, and you need to get her familiar with the codebase. As you’re giving her a tour of the codebase, you might point out certain files or classes and say things like: “This is the glue code between our business logic and the database. None of the application code should use this directly.” “This class looks complicated, but it’s really just a smart cache. It doesn’t know anything about the rest of the system.” After a minute of casual conversation, your new team member will know much more than she would from reading the source by herself.

What we discussed in this chapter is a simple and particular case of when to extract a method. Chapter 11. One Task at a Time Code that does multiple things at once is harder to understand. A single block of code might be initializing new objects, cleansing data, parsing inputs, and applying business logic, all at the same time. If all that code is woven together, it will be harder to understand than if each “task” is started and completed on its own. Key Idea Code should be organized so that it’s doing only one task at a time. Said another way, this chapter is about “defragmenting” your code.

Instead, we can handle the USA and non-USA cases separately: var first_half, second_half; if (country === "USA") { first_half = town || city || "Middle-of-Nowhere"; second_half = state || "USA"; } else { first_half = town || city || state || "Middle-of-Nowhere"; second_half = country || "Planet Earth"; } return first_half + ", " + second_half; In case you aren’t familiar with JavaScript, a || b || c is idiomatic and evaluates to the first “truthy” value (in this case, a defined, nonempty string). This code has the benefit that it’s very easy to inspect the preference list and update it. Most of the if statements have been swept away, and the business logic is represented by fewer lines of code. A Larger Example In a web-crawling system we built, a function named UpdateCounts() was called to increment various statistics after each web page was downloaded: void UpdateCounts(HttpDownload hd) { counts["Exit State" ][hd.exit_state()]++; // e.g.

pages: 290 words: 119,172

Beginning Backbone.js
by James Sugrue
Published 15 Dec 2013

Model View Presenter As you can see from the name its name, the Model View Presenter (MVP) pattern differs only in the replacement of the controller with a presenter. The presenter is responsible for the interaction between the view and the model and contains all the business logic for the view. 5 Chapter 1 ■ An Introduction to Backbone.js The important distinction is that a higher level of decoupling is introduced, where the presenter communicates with the view through an interface. The addition of this interface means that it is easier to test the business logic independently of the real view, and the logic for your application can be written before any UI code has been written. Also, there is typically no direct link between the view and the model, with the presenter passing on the data and acting as a true intermediary between both.

Mission Statement To put it really simply, Backbone helps developers manage a data model in their client-side web app with as much discipline and structure as you would get in traditional server-side application logic. To appreciate how important this is for JavaScript developers, we need to look at the history of how web sites and applications have traditionally been developed and how Backbone fits into this evolution. Server-Side Logic Up until 2005, web sites were pretty static, with all the real business logic implemented in the server side, using languages such as PHP, Java, and .NET. While these sites were far from the dynamic experiences we are accustomed to today, this approach allowed front-end developers to have very clean code bases, with HTML for structure, CSS for presentation, and perhaps a little JavaScript for things such as form field validation and pop-up windows.

Even though Thorax is opinionated, with the requirement that Handlebars templates are utilized, it provides a really simple way of binding models and collections to views. And as with Marionette, nested views and rendering are dealt with by the framework and allow developers to focus on the core business logic. This chapter should be enough to get you started with either Marionette or Thorax. If you choose to base your Backbone application on either framework, you’ll see that there is a lot to discover. No matter which one you choose, your applications will be more structured and scalable as a result. 229 Chapter 11 Best Practices with Backbone In the previous chapters we’ve seen how to use Backbone, along with some useful add-ons, to create high-quality web applications.

pages: 355 words: 81,788

Monolith to Microservices: Evolutionary Patterns to Transform Your Monolith
by Sam Newman
Published 14 Nov 2019

This can be mitigated through the use of views, which we’ll discuss shortly, but it’s not a total solution. Figure 4-1. Multiple services all directly accessing the same database Another issue is that it becomes unclear as to who “controls” the data. Where is the business logic that manipulates this data? Is it now spread across services? That in turn implies a lack of cohesion of business logic. As we discussed previously, when thinking about a microservice as being a combination of behavior and state, encapsulating one or more state machines. If the behavior that changes this state is now spread around the system, making sure this state machine can be properly implemented is a tricky issue.

The company in question is Music Corp, a large multi-national organization that somehow remains in business, despite it focusing almost entirely on selling CDs. We’ve decided to move Music Corp kicking and screaming into the 21st century, and as part of that we’re assessing the existing system architecture. In Figure 1-1, we see a simple three-tiered architecture. We have a web-based user interface, a business logic layer in the form of a monolithic backend, and data storage in a traditional database. These layers, as is common, are owned by different teams. Figure 1-1. Music Corp’s systems as a traditional three-tiered architecture We want to make a simple change to our functionality: we want to allow our customers to specify their favorite genre of music.

All the limitations of database views will apply, however; changing the monolith to make calls to the new Invoice service directly is greatly preferred. Figure 4-11. Projecting Invoice data back into the monolith as a view Where to use it This one is a little more clear-cut. If your newly extracted service encapsulates the business logic that changes some data, that data should be under the new service’s control. The data should be moved from where it is, over into the new service. Of course, the process of moving data out of an existing database is far from a simple process. In fact, this will be the focus of the remainder of this chapter.

pages: 725 words: 168,262

API Design Patterns
by Jj Geewax
Published 19 Jul 2021

This pattern is, quite simply, about taking lots of self-contained data points and helping to shuffle them between an API service and an external storage system without an application server acting as the middleman. If you do indeed need the ability to connect multiple resources together and manipulate those resources in any meaningful way, this middleman is no longer just a middleman; it’s become an important piece of business logic. The custom import and export methods are not intended to contain or implement any special business logic; they’re designed to be simple data movers. This leads us to the next major drawback: it’s easy to confuse import and export with backup and restore functionality (after all, they both typically involve shuffling data between an API and a storage system).

Many of these failed requests will be due to client-side errors such as invalid request messages, while others might be due to failed preconditions and constraints being enforced on the API server. All of these types of errors share an important attribute: the problem is with the request itself violating some constraints or going against the API’s business logic. Put differently, if we replayed the same invalid request again, we should get the same error response. After all, the business logic typically doesn’t change from one moment to another. An entire other category of errors is quite different. Sometimes a request leads to an error response that is completely transient. This type of error has absolutely nothing to do with the request itself and is instead the result of some problem internal to the API.

When the COVID-19 pandemic hit, I suddenly had rather different priorities in terms of considering the audio/visual needs of my local church, both while we were worshiping remotely and considering how we might meet in person again. This involved learning about protocols such as VISCA, NDI, and OSC (for cameras and audio mixers) as well as more software-oriented integration with Zoom, VLC, PowerPoint, Stream Deck, and more. These projects don’t have huge amounts of business logic. Almost all the code is integration code, which is at once frustrating and hugely empowering. It’s frustrating because of protocols that are obscurely documented or aren’t really designed for the kind of usage I’m trying to achieve, or are just inconsistent with each other. It’s empowering because once you’ve cracked the integration aspect, you can write useful apps really easily, standing on the shoulders of multiple giants.

Scala in Action
by Nilanjan Raychaudhuri
Published 27 Mar 2012

In this application you can easily represent that using case classes: case class Location(stateCode: Option[String], zipCode: Option[String]) case class Req(productId: String, location: Location, claim: Claim) Except for Generic claim, the pricing for each claim is determined by specific business logic, and all the calculations start with some base prices associated with the product. To determine the final price of a product and the claim, you have to provide the request information and the base price. You can capture that with a type variable called PC (Pricing Criteria): type PC = Tuple2[Req, Option[Double]] Here the Option[Double] represents the base price of the product. The following code example implements the business logic associated with each Full and Partial claim: def handleFullClaim: PartialFunction[PC, PC] = { case (c@Req(id, l, Full(claimId)), basePrice) => ... } def handlePartialClaim: PartialFunction[PC, PC] = { case (c@Req(id, l, Partial(claimId, percentage)), basePrice) => ... } Similarly, the final price to the provider is also influenced by the location of the claim.

In smaller projects, it’s reasonable to have the wiring of dependencies implemented like the PricingSystem and the TestPricingSystem, but for large projects it may become difficult to manage them. For large projects it makes more sense to use a DI framework (section 10.5.2 shows how to use off-the-shelf DI) that allows you to completely separate object creation and injection from business logic. 10.4.3. Structural typing Structural typing in Scala is the way to describe types by their structure. The previous section created the Calculators trait as a namespace for all the calculators, and CalculatePriceService used it to get to individual calculators. The contract between these two traits is the two abstract vals: costPlusCalculator and externalPriceSourceCalculator, because CalculatePriceService doesn’t care about anything else.

Using a dependency injection framework: Spring Scala’s abstract members, self type and mixin provide more abstraction techniques than are available in Java, but DI frameworks provide the following additional services that aren’t available in these abstraction techniques: They create a clean separation between object initialization and creation from the business logic. These frameworks provide a separate lifecycle to create dependencies as part of the application initialization. This way, your wiring between components becomes transparent from the code. These frameworks help you to work with various other frameworks. For example, if you’re planning to use existing Java web frameworks, then a DI framework will help to inject your Scala objects as dependencies.

pages: 226 words: 17,533

Programming Scala: tackle multicore complexity on the JVM
by Venkat Subramaniam
Published 1 May 2009

The rest of the code will deal with sending requests to the Yahoo service and receiving the responses using the StockPriceFinder we wrote earlier. Once we get those responses, we will have to compute the value of each stock and the net assets—that’s our business logic. I’m sure you’d like to keep the code cohesive by separating the business logic from the code that manipulates the GUI components. So, let’s first take a look at the singleton object NetAssetStockPriceHelper that will handle the business logic and act as a liaison between the GUI and StockPriceFinder: Download UsingScala/NetAssetStockPriceHelper.scala import scala.actors._ import Actor._ object NetAssetStockPriceHelper { val symbolsAndUnits = StockPriceFinder.getTickersAndUnits def getInitialTableValues : Array[Array[Any]] = { val emptyArrayOfArrayOfAny = new Array[Array[Any]](0,0) Download at Boykma.Com Report erratum Prepared exclusively for sam kaplan this copy is (P1.0 printing, June 2009) 203 P UTTING A GUI ON THE N ET A SSET A PPLICATION (emptyArrayOfArrayOfAny /: symbolsAndUnits) { (data, element) => val (symbol, units) = element data ++ Array(List(symbol, units, "?"

pages: 420 words: 61,808

Flask Web Development: Developing Web Applications With Python
by Miguel Grinberg
Published 12 May 2014

On the server, a request that includes the data from the user arrives and Flask dispatches it to the view function that handles registration requests. This view function needs to talk to the database to get the new user added and then generate a response to send back to the browser. These two types of tasks are formally called business logic and presentation logic, respectively. Mixing business and presentation logic leads to code that is hard to understand and maintain. Imagine having to build the HTML code for a large table by concatenating data obtained from the database with the necessary HTML string literals. Moving the presentation logic into templates helps improve the maintainability of the application.

The topic of social features is completed with this chapter. In the next chapter, you will learn how to expose the application functionality as an API that clients other than web browsers can use. Chapter 14. Application Programming Interfaces In recent years, there has been a trend in web applications to move more and more of the business logic to the client side, producing an architecture that is known as Rich Internet Application (RIA). In RIAs, the server’s main (and sometimes only) function is to provide the client application with data retrieval and storage services. In this model, the server becomes a web service or Application Programming Interface (API).

End-to-end tests of the type that the Flask test client and Selenium can carry out are sometimes necessary, but due to the increased complexity to write them, they should be used only for functionality that cannot be tested in isolation. The application code should be organized so that it is possible to push as much of the business logic as possible into database models or other auxiliary classes that are independent of the context of the application and thus can be tested easily. The code that exists in view functions should be simple and just act as a thin layer that accepts requests and invokes the corresponding actions in other classes or functions that encapsulate the application logic.

pages: 540 words: 103,101

Building Microservices
by Sam Newman
Published 25 Dec 2014

The concept of continuous delivery showed how we can more effectively and efficiently get our software into production, instilling in us the idea that we should treat every check-in as a release candidate. Our understanding of how the Web works has led us to develop better ways of having machines talk to other machines. Alistair Cockburn’s concept of hexagonal architecture guided us away from layered architectures where business logic could hide. Virtualization platforms allowed us to provision and resize our machines at will, with infrastructure automation giving us a way to handle these machines at scale. Some large, successful organizations like Amazon and Google espoused the view of small teams owning the full lifecycle of their services.

Instead of a client initiating requests asking for things to be done, it instead says this thing happened and expects other parties to know what to do. We never tell anyone else what to do. Event-based systems by their nature are asynchronous. The smarts are more evenly distributed — that is, the business logic is not centralized into core brains, but instead pushed out more evenly to the various collaborators. Event-based collaboration is also highly decoupled. The client that emits an event doesn’t have any way of knowing who or what will react to it, which also means that you can add new subscribers to these events without the client ever needing to know.

Some types of UI may need a minimal server-side footprint, while others may need a lot more. If you need an API authentication and authorization layer, this can sit between our BFFs and our UIs. We’ll explore this more in Chapter 9. The danger with this approach is the same as with any aggregating layer; it can take on logic it shouldn’t. The business logic for the various capabilities these backends use should stay in the services themselves. These BFFs should only contain behavior specific to delivering a particular user experience. A Hybrid Approach Many of the aforementioned options don’t need to be one-size-fits-all. I could see an organization adopting the approach of fragment-based assembly to create a website, but using a backends-for-frontends approach when it comes to its mobile application.

pages: 283 words: 78,705

Principles of Web API Design: Delivering Value with APIs and Microservices
by James Higginbotham
Published 20 Dec 2021

Below is an example HAL-based response for an article within a content management system that offers hypermedia links to valid operations based on the status of the article and the user’s role as an author: { "articleId":"12345", "status":"draft", "_links": [ { "rel":"self", "url":"..."}, { "rel":"update", "url":"..."}, { "rel":"submit", "url":"..."} ], "authors": [ ... ], ... } Once the author is ready to submit the article for editorial review, the editor would retrieve the article and receive the following actions based on the submitted status of the article and the editor’s role: { "articleId":"12345", "status": "submitted", "_links": [ { "rel":"self", "url":"..."}, { "rel":"reject", "url":"..."}, { "rel":"approve", "url":"..."} ], "authors": [ ... ], ... } Hypermedia controls have big implications for API-driven workflows that use context-driven hypermedia controls. They help to reduce the amount of business logic that has to be repeated in the client to mimic intended server behavior. Without them, the client would need to be coded to know what actions are allowed based on the status of the article and the role of the user. Instead, the client may be coded to look for specific hypermedia links that indicate if specific buttons are displayed or disabled for the end user, avoiding the need to keep in sync with the server-side business logic. This ensures the API is evolvable without breaking client code. There are four primary hypermedia control types offered by REST-based APIs: ■ Index hypermedia controls: Offer a list of all available API operations, typically as an API homepage ■ Navigation hypermedia controls: Includes pagination links within payload responses or by using the Link header ■ Relationship hypermedia controls: Links that indicate relationships with other resources or for master-detail relationships ■ Context-driven hypermedia controls: Server state that informs the client what actions are available It is important to note that any API style that does not encourage a unique URL per resource is unable to take advantage of hypermedia controls.

It describes the absence or presence of links as indicators of what operations the client may perform. Since the server understands both the user executing the operation and the authorization requirements of the operation itself, it is better positioned to determine what the client is able to do. Without this constraint, clients are required to re-implement the same server-side business logic and keep that logic in sync at all times. It is important to note that Dr. Fielding has expressed a preference to use the term hypermedia controls rather than HATEAOS. Through the remainder of the book, the term hypermedia controls will be used in place of HATEOAS for clarity. Below is an example HAL-based response for an article within a content management system that offers hypermedia links to valid operations based on the status of the article and the user’s role as an author: { "articleId":"12345", "status":"draft", "_links": [ { "rel":"self", "url":"..."}, { "rel":"update", "url":"..."}, { "rel":"submit", "url":"..."} ], "authors": [ ... ], ... } Once the author is ready to submit the article for editorial review, the editor would retrieve the article and receive the following actions based on the submitted status of the article and the editor’s role: { "articleId":"12345", "status": "submitted", "_links": [ { "rel":"self", "url":"..."}, { "rel":"reject", "url":"..."}, { "rel":"approve", "url":"..."} ], "authors": [ ... ], ... } Hypermedia controls have big implications for API-driven workflows that use context-driven hypermedia controls.

pages: 296 words: 41,381

Vue.js
by Callum Macrae
Published 23 Feb 2018

Vue evaluates simple expressions inside v-if: <div id="app"> <p v-if="hours < 12">Good morning!</p> <p v-if="hours >= 12 && hours < 18">Good afternoon!</p> <p v-if="hours >= 18">Good evening!</p> </div> <script> new Vue({ el: '#app', data: { hours: new Date().getHours() } }); </script> Writing code in this manner, with the business logic in the JavaScript and the view logic in the template, means that we can tell at a glance exactly what will be displayed when on the page. This is a much better approach than having the code responsible for deciding whether to show or hide the element in some JavaScript far away from the element in question.

passing into components with slot element, Passing Content into Components with Slots running through preprocessors, Preprocessors setting dynamically, Setting HTML Dynamically HTML5 history API, HTML5 History Mode(see also history mode) I inline style binding, Inline Style Binding-Scoped CSS with vue-loaderarray syntax, Array Syntax providing multiple values in an array, Multiple Values inputs and events, Inputs and Events-Event Modifiers inserted hook, Custom Directives installation and setup, Installation and Setup-vue-loader and webpack interpolationcombining with directives to display text, Templates, Data, and Directives using filters with, Filters using to pass data into templates, Templates, Data, and Directives J JavaScriptanimations, JavaScript Animations business logic in, Templates, Data, and Directives prerequisites for using Vue.js, Who This Book Is For running through preprocessors, Preprocessors jQuery, Vue.js vs., Why Vue.js? JSX, JSX-Summary, Routingimporting components, JSX spread operator, JSX vs. templates, in React and Vue, JSX Versus Templates K kebab case, Casing of Props key, specifying with v-for, Components and v-for keyboard events, key event modifiers, Event Modifiers keyboard modifier keys, event modifiers for, Event Modifiers L leave transitions, CSS Transitions life-cycle hooks, Life-Cycle Hookscomparison in Vue and React, Life-Cycle Hooks in mixins and components, Merging Mixins and Components listeners object, mount() Options location.pathname, Templates, Data, and Directives looping in templates, Looping in Templates(see also v-for directive) M mapActions function, Action Helpers, Namespaced Modules mapGetters, Getter Helpers, Namespaced Modules mapMutations method, Mutation Helpers, Namespaced Modules mapState helper function, State Helpers, Namespaced Modulescombining with existing computed properties, State Helpers in modules, Modules .meta modifier key event modifier, Event Modifiers meta property (routes), Navigation Guards methods, Methodscomponent, Data, Methods, and Computed Properties deciding when to use, vs. data object or computed properties, Computed Properties differences from computed properties, Computed Properties private methods in mixins, Merging Mixins and Components this in, this mixins, Mixins-Merging Mixins and Componentsmerging with components, Merging Mixins and Components private properties in, Merging Mixins and Components mocking and stubbing data, Mocking and Stubbing Data, Working with Events mocks, mount() Options modifier keys, event modifiers for, Event Modifiers modifiers (event), Event Modifierschaining, Event Modifiers mouse event modifiers, Event Modifiers modules (CSS), in React vs.

pages: 448 words: 84,462

Testing Extreme Programming
by Lisa Crispin and Tip House
Published 15 Apr 2003

Struts managed the form, the actions, the information that goes in and out of the session, and the errors. The automated acceptance tests used mock objects for forms, requests, responses, and sessions. When a user pushes a button such as Submit, the Struts form calls a "button push" action, and the test methods emulate this with a mock object and the action. The action is where the business logic is located, and at that point the system code is called. The tests could verify that a Save button led to the correct validating and persisting data in the database and could emulate series of button pushes and verify that data persists between sessions. This team designed their code specifically for ease of testing.

You now have a library of methods or modules that can be reused in new tests. Automating and executing acceptance tests for a story normally takes the team between 20% and 30% of the time spent on developing that story. If your team spent a lot more time than this, stop and look at your approach. Does your application have too much business logic in the user interface layer? Does it take too long to script automated tests with the tool you're using? Do team members need more training in test automation techniques? Brainstorm ways to reduce the time spent creating and maintaining automated tests. Regression Testing Run all the executable acceptance tests as a regression test on every new build in your test environment.

If your team consistently spends 30% or more of development time doing test automation tasks, see what you can do to improve testability. Summary If your project presents special challenges, take a look at our road hazard survival kit for tools and techniques that can help. If your application has a user interface, keep it as thin as possible. Shift business logic to the layers below the user interface. The database design is a key factor in testability. Use XP principles to find the simplest design that could possibly work. Since the team, not just the tester, is responsible for test automation, programmers also feel the pain of automating tests for systems not designed for testability.

pages: 779 words: 116,439

Test-Driven Development With Python
by Harry J. W. Percival
Published 10 Jun 2014

As we go through the chapter, we’ll also spend a bit of time tidying up our unit tests, and making sure each of them only tests one thing at a time. Moving Validation Logic into a Form In Django, a complex view is a code smell. Could some of that logic be pushed out to a form? Or to some custom methods on the mod‐ el class? Or maybe even to a non-Django module that represents your business logic? Forms have several superpowers in Django: • They can process user input and validate it for errors. • They can be used in templates to render HTML input elements, and error messages too. • And, as we’ll see later, some of them can even save data to the database for you. You don’t have to use all three form superpowers in every form.

Tips Thin views If you find yourself looking at complex views, and having to write a lot of tests for them, it’s time to start thinking about whether that logic could be moved elsewhere: possibly to a form, like we’ve done here. Another possible place would be a custom method on the model class. And—once the complexity of the app demands it—out of Django-specific files and into your own classes and functions, that capture your core business logic. Each test should test one thing The heuristic is to be suspicious if there’s more than one assertion in a test. Some‐ times two assertions are closely related, so they belong together. But often your first draft of a test ends up testing multiple behaviours, and it’s worth rewriting it as several tests.

Mainly these involve trying to identify the boundaries of your system—the points at which your code interacts with external systems, like the database or the filesystem, or 402 | Chapter 22: Fast Tests, Slow Tests, and Hot Lava www.it-ebooks.info the Internet, or the UI—and trying to keep them separate from the core business logic of your application. Ports and Adapters/Hexagonal/Clean Architecture Integrated tests are most useful at the boundaries of a system—at the points where our code integrates with external systems, like a database, filesystem, or UI components. Similarly, it’s at the boundaries that the downsides of test isolation and mocks are at their worst, because it’s at the boundaries that you’re most likely to be annoyed if your tests are tightly coupled to an implementation, or to need more reassurance that things are integrated properly.

pages: 190 words: 52,865

Full Stack Web Development With Backbone.js
by Patrick Mulder
Published 18 Jun 2014

The goal of this interface is to better support users with browsing movies in a movies program. Based on the wireframe of Munich Cinema, an important principle of Backbone.js was explained: decoupling state from the user interface. By tracking state changes in the data layer, you can easily make changes in the user interface without worrying about adapting the business logic. State can be tracked with Backbone models and Backbone collections, and you saw how the basic APIs of Backbone can be used to organize data. We then used a monitor to inspect events around data changes. Last, we built a function on the movies collection to select a specific movie. In the next chapter, we will bind the data to layer to a user interface.

What we want in many situations are a number of 145 blueprints that help us to make faster choices. This is especially useful if you regularly build new applications, or if your team has to maintain multiple projects. Although frameworks help you with making development faster and easier, they often enforce a higher coupling between your business logic and implementing technology. In other words, if the framework changes, your application might need quite a few changes, too. In the Backbone.js ecosystem, a number of frameworks exist: Marionette This framework by Derick Bailey provides components to render collections to combine multiple views and boilerplate to manage events from different parts of an application.

pages: 538 words: 138,544

The Story of Stuff: The Impact of Overconsumption on the Planet, Our Communities, and Our Health-And How We Can Make It Better
by Annie Leonard
Published 22 Feb 2011

Quote appears on the Water Footprint website: waterfootprint.org/?page=files/home. 67. Bergkamp and Sadoff, “Water in a Sustainable Economy,” p. 114. 68. “Dublin Statements and Principles,” Global Water Partnership (gwpforum.org/servlet/PSP?iNodeID=1345). 69. Ray Anderson, “The business logic of sustainability,” TED talk filmed February 2009, posted May 2009 (ted.com/talks/ray_anderson_on_the_business_ logic_of_sustain ability.html). 70. Dirty Metals: Mining, Communities, and the Environment, Earthworks and Oxfam America, 2004, p. 4 (nodirtygold.org/pubs/DirtyMetals.pdf). 71. “Bingham Canyon Mine,” Wikipedia (wikipedia.org/wiki/Bingham_Canyon_Mine). 72.

Joel Makower, “Calculating the Gross National Trash,” March 17, 2009 (readjoel.com/joel_makower/2009/03/calculating-the-gross-national-trash.html). 12. Makower, “Industrial Strength Solution.” 13. Ibid. 14. “A Natural Step Network Case Study: Interface, Atlanta, Georgia,” The Natural Step (naturalstep.org/en/usa/interface-atlanta-georgia-usa). 15. Ray Anderson, “The business logic of sustainability,” TED talk filmed February 2009, posted May 2009 (ted.com/talks/ray_anderson_on_the_business_ logic_of_sustain ability.html). 16. Ibid. 17. Ibid. 18. Charles Fishman, “Sustainable Growth—Interface, Inc.” Fast Company, December 18, 2007 (fastcompany.com/magazine/14/sustaing.html). 19. Kate Fletcher, Sustainable Fashion and Textiles (London: Earthscan, 2008), p. 158. 20.

pages: 671 words: 228,348

Pro AngularJS
by Adam Freeman
Published 25 Mar 2014

You will see a larger example of this in Chapter 6 when I start to build a more complex and realistic AngularJS application; there is a lot of initial setup and configuration required, but then the features start to quickly snap into place. Creating a Controller The controller defines the business logic required to support a view, although the term business logic isn’t helpful. The best way of describing a controller is to explain what kinds of logic it doesn’t contain—and what’s left goes into the controller. Logic that deals with storing or retrieving data is part of the model. Logic that deals with formatting the data to display to the user is part of the view.

Fortunately, the Batarang extension for Google Chrome makes it easy to explore and monitor the model (and some other AngularJS features). See Chapter 1 for details of the Batarang extension. Creating and Using Controller Behaviors Controllers define behaviors on the scope. Behaviors are functions that operate on the data in the model to implement the business logic in the application. The behaviors defined by a controller support a view to display data to the user and to update the model based on user interactions. To demonstrate a simple behavior, I am going to change the label displayed to the right of the header in todo.html so that it displays only the number of incomplete to-do items.

These are not coding errors but rather problems with the overall shape of the web app that prevent the project team from getting the benefits that AngularJS and the MVC pattern can provide. Putting the Logic in the Wrong Place The most common problem is logic put into the wrong component such that it undermines the MVC separation of concerns. Here are the three most common varieties of this problem: • Putting business logic in views, rather than in controllers • Putting domain logic in controllers, rather than in model • Putting data store logic in the client model when using a RESTful service These are tricky issues because they take a while to manifest themselves as problems. The application still runs, but it will become harder to enhance and maintain over time.

pages: 1,758 words: 342,766

Code Complete (Developer Best Practices)
by Steve McConnell
Published 8 Jun 2004

Programmers who program "into" a language first decide what thoughts they want to express, and then they determine how to express those thoughts using the tools provided by their specific language. Example of Programming into a Language In the early days of Visual Basic, I was frustrated because I wanted to keep the business logic, the UI, and the database separate in the product I was developing, but there wasn't any built-in way to do that in the language. I knew that if I wasn't careful, over time some of my Visual Basic "forms" would end up containing business logic, some forms would contain database code, and some would contain neither—I would end up never being able to remember which code was located in which place. I had just completed a C++ project that had done a poor job of separating those issues, and I didn't want to experience déjà vu of those headaches in a different language.

Late-wave environments provide numerous programming language choices, comprehensive error checking for code written in those languages, powerful debugging tools, and automatic, reliable performance optimization. The compilers are nearly bug-free. The tools are well documented in vendor literature, in third-party books and articles, and in extensive Web resources. Tools are integrated, so you can do UI, database, reports, and business logic from within a single environment. If you do run into problems, you can readily find quirks of the tools described in FAQs. Many consultants and training classes are also available. In early-wave environments—Web programming in the mid-1990s, for example—the situation is the opposite. Few programming language choices are available, and those languages tend to be buggy and poorly documented.

Debuggers might not exist at all, and compiler optimizers are still only a gleam in some programmer's eye. Vendors revise their compiler version often, and it seems that each new version breaks significant parts of your code. Tools aren't integrated, and so you tend to work with different tools for UI, database, reports, and business logic. The tools tend not to be very compatible, and you can expend a significant amount of effort just to keep existing functionality working against the onslaught of compiler and library releases. If you run into trouble, reference literature exists on the Web in some form, but it isn't always reliable and, if the available literature is any guide, every time you encounter a problem it seems as though you're the first one to do so.

Android Developer Tools Essentials: Android Studio to Zipalign
by Mike Wolfson and Donn Felker
Published 13 Aug 2013

The files contain information defining the widgets you wish to display and detailed information about them (for example, orientation, spacing, or the specific location of an element on the screen). The advantage of placing the layout into XML is that it separates the presentation of your application from the business logic. Your layout definitions are separate from your application code, so you can modify the layout without needing to change your source code or recompile. You can create different layouts for multiple device orientations, screen sizes, or locations. It is worth noting that almost everything you do in XML can also be done in Java code, or by using a combination of both.

Hierarchy View: good detail Fixing Problems Using Lint ADT includes a static code analysis tool designed to check source code for potential issues and identify optimization opportunities. It automatically analyzes source code for a variety of criteria. You have likely encountered it before, as it is involved in other aspects of Android development, including writing the business logic (Java classes). Lint is launched by pressing the little red button on the far right of the Graphical Editor toolbar (), which we discussed in the previous chapter (Chapter 12). This number indicates the number of issues Lint has identified. Clicking it will launch the Lint tool (Figure 13-17).

pages: 1,380 words: 190,710

Building Secure and Reliable Systems: Best Practices for Designing, Implementing, and Maintaining Systems
by Heather Adkins , Betsy Beyer , Paul Blankinship , Ana Oprea , Piotr Lewandowski and Adam Stubblefield
Published 29 Mar 2020

In addition, some organizations may have to consider their particular regulatory or contractual requirements when designing authorization policies. This code can be difficult to implement correctly, and its complexity can rapidly compound if many services each implement their own authorization logic. In our experience, it’s helpful to separate the complexities of authorization decisions from core API design and business logic with frameworks like the AWS or GCP Identity & Access Management (IAM) offerings. At Google, we also extensively use a variation of the GCP authorization framework for internal services.15 The security policy framework allows our code to make simple checks (such as “Can X access resource Y?”) and evaluate those checks against an externally supplied policy.

For example, OpenAPI has API versioning as a built-in feature. Protocol buffers, used for declaring gRPC interfaces, have well-documented guidelines on how to update message definitions to retain backward compatibility. In contrast, an API built on free-form JSON strings can be hard to understand unless you inspect its implementation code and core business logic. This unconstrained approach may lead to security or reliability incidents. For example, if a client and a server are updated independently, they may interpret an RPC payload differently, which could cause one of them to crash. The lack of an explicit API specification also makes evaluating the security posture of the service difficult.

Tink prevents many mistakes that could result in low-level cryptographic vulnerabilities, but does not prevent mistakes based on using the wrong crypto API (or not using crypto at all). Similarly, a secure-by-construction web framework prevents XSS vulnerabilities, but does not prevent security bugs in an application’s business logic. Conclusion Reliability and security benefit, in a deep and intertwined way, from understandable systems. Although “reliability” is sometimes treated as synonymous with “availability,” this attribute really means upholding all of a system’s critical design guarantees—availability, durability, and security invariants, to name a few.

pages: 262 words: 60,248

Python Tricks: The Book
by Dan Bader
Published 14 Oct 2017

After all, what I just mentioned sounded quite abstract, and it might be difficult to see how decorators can benefit you in your day-to-day work as a Python developer. Let me try to bring some clarity to this question by giving you a somewhat real-world example: Imagine you’ve got 30 functions with business logic in your report-generating program. One rainy Monday morning your boss walks up to your desk and says: “Happy Monday! Remember those TPS reports? I need you to add input/output logging to each step in the report generator. XYZ Corp needs it for auditing purposes. Oh, and I told them we can ship this by Wednesday.”

Fields stored on classes are mutable, and new fields can be added freely, which you may or may not like. It’s possible to provide more access control and to create read-only fields using the @property decorator,19 but once again, this requires writing more glue code. Writing a custom class is a great option whenever you’d like to add business logic and behavior to your record objects using methods. However, this means that these objects are technically no longer plain data objects. class Car: def __init__(self, color, mileage, automatic): self.color = color self.mileage = mileage self.automatic = automatic >>> car1 = Car('red', 3812.4, True) >>> car2 = Car('blue', 40231.0, False) # Get the mileage: >>> car2.mileage 40231.0 # Classes are mutable: >>> car2.mileage = 12 >>> car2.windshield = 'broken' # String representation is not very useful # (must add a manually written __repr__ method): >>> car1 <Car object at 0x1081e69e8> collections.namedtuple – Convenient Data Objects The namedtuple class available in Python 2.6+ provides an extension of the built-in tuple data type.20 Similar to defining a custom class, using namedtuple allows you to define reusable “blueprints” for your records that ensure the correct field names are used.

pages: 628 words: 107,927

Node.js in Action
by Mike Cantelon , Marc Harter , Tj Holowaychuk and Nathan Rajlich
Published 27 Jul 2013

This simple concept of configurable middleware is used throughout the Connect community, and it’s used for all core Connect middleware to maintain consistency. Now let’s write a middleware component with a little more involved logic. Let’s create a router to map incoming requests to business logic! 6.5.2. Building a routing middleware component Routing is a crucial web application concept. Put simply, it’s a method of mapping incoming request URLs to functions that employ business logic. Routing comes in many shapes and sizes, ranging from highly abstract controllers used by frameworks like Ruby on Rails to simpler, less abstract, routing based on HTTP methods and paths, such as the routing provided by frameworks like Express and Ruby’s Sinatra.

In order to use Node’s built-in functionality, each test case had to include a lot of boilerplate to set up the test (such as deleting all items) and to keep track of progress (the “completed” counter). All this boilerplate shifts the focus away from the primary concern of writing test cases, and it’s better left to a dedicated framework that can do the heavy lifting while you focus on testing business logic. Let’s look at how you can make things easier using nodeunit, a third-party unit-testing framework. 10.1.2. Nodeunit Using a unit-testing framework simplifies unit testing. Frameworks generally keep track of how many tests have run and they make it easy to run multiple test scripts. A number of excellent testing frameworks have been created by the Node community.

pages: 982 words: 221,145

Ajax: The Definitive Guide
by Anthony T. Holdener
Published 25 Jan 2008

Then the user interface waits for new input from the user, and the pattern starts over again. Calls Request Business logic Controller Return forward Forward Client Response View Update Uses Model Figure 2-5. The Model-View-Controller design pattern For web applications, the view module is in charge of building the XHTML whenever there is a user request. The controller is all of the navigation code that runs the application, and it can be both client- and server-side scripting. The model is the data access module for the design pattern, handling most data access requests and all business logic. I said most because if there is a user request for an XML response, for example, the view module alone may respond through an XML transformation or something similar.

They function like traditional desktop applications by changing the browser from a thin to a fat client, through the use of JavaScript. A truly robust RIA usually incorporates the MVC design pattern into its model for stability and reliability, as shown in Figure 2-6. 30 | Chapter 2: From Web Sites to Web Applications RIA Calls Request Business logic Controller Return forward Forward Client Response View Update Uses Model Figure 2-6. An RIA implementation on top of MVC RIA applications are getting a bigger and bigger push, as more people realize that their traditional desktop applications can be ported to the Web. This way of thinking has many merits: • Ajax web applications require no installation, updating, or distribution, as everything is served up by a web server. • Ajax web applications are less prone to virus attacks (generally). • Ajax web applications can be accessed anywhere, and if they are built properly, you can run them on any operating system.

Zope 2 is the code base that most programmers are familiar with, as it is behind many open source CMSs and ERP5 (http://www.erp5.com/), an open source Enterprise Resource Planning (ERP) package. The problem with Zope 2 is that a lot of “magic” code must go along with every distribution. Zope 2 also does a poor job of separating business logic from the presentation layer. Zope 3 is a rewrite of Zope that attempts to fix the problems that exist in Zope 2 while keeping true to the roots that make Zope popular. It is taking a different approach, though, mixing components of various origins to create a faster, stronger, and more reliable Ajax web development framework.

pages: 234 words: 63,522

Puppet Essentials
by Felix Frank
Published 20 Nov 2014

In most cases, however, the landscape of servers and other computing nodes is rather heterogeneous, at least in subtle ways. Even in unified networks, there are likely multiple generations of machines, with small or larger differences required for their respective configurations. For example, a common task for Puppet is to handle the configuration of system monitoring. Your business logic will likely dictate warning thresholds for gauges such as the system load value. However, those thresholds can rarely be static. On a two-processor virtual machine, a system load of 10 represents a crippling overload, while the same value can be absolutely acceptable for a busy DBMS server that has cutting-edge hardware of the largest dimensions.

This code sample has some notable aspects: • Since you are essentially wrapping multiple resource types, the titles of all inner resources are derived from the instance title (or name) of the current defined type instance; actually, this is a safe practice for all defined types • You can hardcode parts of your business logic; in this example, we dispensed with the support for non-RSA SSH keys and define users as the default group • Resources inside defined types can and should manage ordering among themselves (using the chaining arrow -> in this case) Using defined types as macros Some source code requires many repetitive tasks.

Demystifying Smart Cities
by Anders Lisdorf

For an overview of the different aspects of data management see Table 4-4.Table 4-4Data management Organization Data Level Responsibility Process CDO Business Conceptual Definitions, processes, guidelines Data governance Data owner Business Logical Solution ownership, definitions Data governance Data steward Business Logical Operational at the data level MDM Data analyst Business/IT Logical/physical Operational at the data level, data user MDM/data quality Database administrator IT Physical Operational at the physical level MDM/data quality Summary In this chapter, we have taken a deeper look into the different forces that affect how we use data in the city.

pages: 145 words: 40,897

Gamification by Design: Implementing Game Mechanics in Web and Mobile Apps
by Gabe Zichermann and Christopher Cunningham
Published 14 Aug 2011

A System for Tracking Scores and Levels Now that we have a basic game design in hand—with points, levels, and badges clearly defined—we can begin to modify Altered Beast. We’ll start by implementing a general framework to award and track points and levels. Once that’s in place, we can add business logic based on our game design. Creating a Level Model Let’s begin by adding a few basic models and methods to award player points. To do this, we’ll need to define a Levels model to track the available levels. We’ll also need to modify the Player model to track points and levels. The Levels model defines hierarchical ranks, which players achieve by earning points.

This describes the “User has many Levels” relationship so that we can access attributes in a very readable way—for example, by writing things like user.level.display_name. Now, we have a score and a level_id attribute defined on the User model. This would be a sufficient framework to allow us to jump right into coding business logic, but there is one problem. Although we have an attribute to track a player’s score, we have no way to log the activities that generated that score. This makes it hard to audit how players achieved a given score, limiting our ability to explain to players how they earned their points. Let’s add one more model to log events that generate points, so that we have a history of how a player achieved her current score.

Seeking SRE: Conversations About Running Production Systems at Scale
by David N. Blank-Edelman
Published 16 Sep 2018

It’s up to each SRE organization to determine how much risk they can assume as one factor in finding the split between a context- versus control-based model. I believe there is a difference between information and context. In systems monitoring, information could just be a bunch of availability metrics I jam into a dashboard and email to the team. A typical engineer receiving such an email would ignore it because, 1) they are in charge of writing business logic for a service, and 2) they lack the expertise to digest and understand resource and availability metrics presented as time series. At Netflix we have hundreds of thousands of operational metrics available to us. In order to support a context-driven model to improve availability, we have to bring specific domain knowledge to bear on the data.

Our backend, as originally envisioned, consists of many small services — a pattern now called microservices — which together provide the content for the Spotify clients. The microservices themselves are programs that do one thing and do it well. During these first two years, work was distributed between dev and ops as follows: developers took care of the business logic in the form of client features or backend services, whereas ops owned everything else, including detecting problems in production as well as taking care of office technology. This was a startup, and as you might imagine, almost everything was done manually, like deployment of backend services and desktop client rollouts.

Key Learnings Some of our key learnings from this early period were: Including an ops engineer from the get-go influenced the engineering culture and proved highly beneficial as we grew. You should introduce an operational mindset into the engineering culture as early as possible. Aside from business logic architecture, ensure that an infrastructural architecture is in place, as early as possible. Beta and Release: 2008–2009 Three ops engineers ~10 backend engineers 1 data center 10–20 backend services 4 clients: Windows, Mac, iPhone, libspotify Prelude In this section, we’ll talk about how our “Ops by default” philosophy shifted and how that links up with our core engineering values: Ops by default Bringing in operations into regular discussions of scalability and reliability with developers from the start was pivotal to creating the foundation of our engineering approach.

pages: 386 words: 113,709

Why We Drive: Toward a Philosophy of the Open Road
by Matthew B. Crawford
Published 8 Jun 2020

The contest for control between humans and computers often looks like no contest at all, as a political reality. Viewed through the lens of press releases and credulous journalism, the logic of automation is joined, in the public mind, to the moral logic of safety, which similarly admits no limit to its expansion.28 These two are symbiotic in the sense that safetyism provides legitimation to the business logic of ever more automation. Together they are unimpeachable in the minds of all right-thinking people, and to question Team Progress is to invite being labeled pro-death. If we confine ourselves to factual questions about the likely safety gains to be had from self-driving cars, it seems to me the most prudent position would be to join the agnosticism of the human factors researchers.29 As Casner et al. say, “In the coming decades, we will all participate in driving research as an enormous uncontrolled experiment takes place on our streets and highways.”

He oscillates between a determination to seize control back from the automation, and second-guessing himself. Maybe the computer knows best? In the case of the 737 MAX, this second-guessing was in fact appropriate, because pilots were underinformed—and for reasons that in retrospect are not surprising, given the business logic of selling airplanes. (The deployment of driverless cars on public roads has in some cases revealed a similarly cavalier attitude about public safety, likely due to the imperative of being “first to market.”11) How much trust does the pilot place in things beyond his own comprehension? The greater the complexity of the plane’s control systems, the more such trust is an element of his everyday flying.

Alternatively, we may accept technocratic competence as a legitimate claim to rule, even if it is inscrutable. But then we are in a position of trust. This would be to move away from the originating insight of liberalism: power corrupts. Such a move toward trust seems unlikely, given that people are waking up to the business logic that often stands behind the promise of technocratic competence and good will. Let us consider a couple of recent cases of “smart” road infrastructure development. When Kansas City was ripping up its Main Street to install a trolley line, Cisco convinced city officials that this was a perfect opportunity to install various sensors and a fiber-optic cable, to monitor traffic.

pages: 58 words: 12,386

Big Data Glossary
by Pete Warden
Published 20 Sep 2011

It can be used in a very similar way to Flume, keeping its high throughput, but with a more flexible system for creating multiple clients and an underlying architecture that’s more focused on parallelization. Kafka relies on ZooKeeper to keep track of its distributed processing. Azkaban The trickiest part of building a working system using these new data tools is the integration. The individual services need to be tied together into sequences of operations that are triggered by your business logic, and building that plumbing is surprisingly time consuming. Azkaban is an open source project from LinkedIn that lets you define what you want to happen as a job flow, possibly made up of many dependent steps, and then handles a lot of the messy housekeeping details. It keeps track of the log outputs, spots errors and emails about errors as they happen, and provides a friendly web interface so you can see how your jobs are getting on.

pages: 408 words: 63,990

Build Awesome Command-Line Applications in Ruby: Control Your Computer, Simplify Your Life
by David B. Copeland
Published 6 Apr 2012

Let’s see it in action: ​$ bin/todo -f ~/todo.txt new -f "A new task" "Another task"​ ​Global:​ ​-f - /Users/davec/todo.txt​ ​Command:​ ​-f - true​ ​-p -​ ​args - A new task,Another task​ We can see that :f in global_options contains the file specified on the command line; that options[:f] is true, because we used the command-specific option -f; and that options[:priority] is missing, since we didn’t specify that on the command line at all. Once we’ve done this, we can add our business logic to each of the c.action blocks, using global_options, options, and args as appropriate. For example, here’s how we might implement the logic for the to-do app list command: ​c.action do |global_options,options,args|​ ​ todos = read_todos(global_options[:filename])​ ​ if options[:s] == 'name'​ ​ todos = todos.sort { |a,b| a <=> b }​ ​ end​ ​ todos.each do |todo|​ ​ puts todo​ ​ end​ ​end​ We’ve used very few lines of code yet can parse a sophisticated user interface.

By manipulating the environment, setting up test-specific infrastructure, and mocking system calls, we can simulate almost anything that might happen when our app runs. Toward the end, when we learned about unit testing, we talked briefly about refactoring. Refactoring is difficult without tests, but with a good suite of tests, we can safely change the internal design of our code. We got a taste of that when we extracted our business logic out of bin/todo and put it into lib/todo/task.rb so we could unit test it. In the next chapter, we’ll learn some patterns and techniques for organizing our code so that it’s easy to maintain, test, and enhance. Footnotes [45] Cucumber supports other human languages as well, from Arabic to Vietnamese

Team Topologies: Organizing Business and Technology Teams for Fast Flow
by Matthew Skelton and Manuel Pais
Published 16 Sep 2019

There were, of course, valid historical reasons for the predominance of monolithic databases (such as the rise in specialism of people and teams on technical stack layers) up until DevOps and microservices gained traction. Factors such as project orientation, cost cutting via outsourcing, or junior teams without sufficient experience have contributed to the perpetuation of this (now recognizable) anti-pattern. Monolithic databases couple the applications that depend on them and become magnets for small-business logic changes at the database level (more on this in Chapter 6). Yet, to avoid them, organizations need not only good architectural practices but also actual team structures and composition that align with this new way of thinking. Sportswear company Adidas went through an interesting transformation where they explicitly looked at Conway’s law as a driver for organization design.

We’ve seen extreme cases where, because there were no stable teams and all changes were made via temporary projects (mostly outsourced), applications became deeply coupled at the database level (shared data and procedures). This later impeded adoption of commodity systems for certain parts of the business since the latter could not be decoupled from the rest of the business logic. Instead of freeing up in-house engineers to work on differentiating features that meet evolving customer needs, accruing technical debt like this curtails an organization’s ability to move faster and make a difference against competitors. So, how can the reverse Conway maneuver help steer team organization to obtain the desired software architecture?

pages: 232 words: 71,237

Kill It With Fire: Manage Aging Computer Systems
by Marianne Bellotti
Published 17 Mar 2021

You may need to rethink hooks or stored procedures. One software language often has any number of minor languages that facilitate specific functions. There are command processors like bash or JCL that trigger jobs, templating languages to build interfaces, querying languages to access data, and so on. How well is business logic separated out between these layers? Does logic stay where it is sensible, or is it injected to where it is convenient? Most web development projects, for example, run on Linux machines. Therefore, it is not uncommon for web applications to include shell scripts as part of their code base—particularly as part of the setup/installation routine.

Numbers 3-Arm Sweater award, 166 4+1 architectural view model, 173–176 18F, 144 20 percent projects, 99 A abstraction, 39, 64, 102, 146, 157, 204 abstract syntax tree, 71 Accelerated Mobile Pages (AMP), 8 ACM (Association for Computing Machinery), 30 Adobe Acrobat, 67 ADS-B (automatic dependent surveillance), 204 affinity mapping, 139–140 agile development, 75, 181 air cover, 161 alignable and nonalignable difference, 3–4, 9, 18, 21, 22 Amazon, 69, 204, 208 ambiguity, 34, 83, 90, 152 AOL, 13 application programming interface (API), 64, 66, 102, 108 Ariely, Dan, 163 artificial consistency, 35, 101 ASR-33 Teletype, 26 Association for Computing Machinery (ACM), 30 AT&T, 13, 23–25 automatic dependent surveillance (ADS-B), 204 automation, 69, 99, 206–207 B baudot code, 20 Beats 1, 204 Bell Labs, 21, 23 Bell Systems, 23 Berkeley Software Distribution (BSD), 25 biases confirmation, 138 gambler’s fallacy, 169 self-serving, 60 Big Data, 15 blue-green deploys, 56–57, 184 breaking change, 170–171, 179 Brooks, Fred, 33, 140, 213 bullet journaling, 186–187 business logic, 65 C Canaday, Rudd, 23 Castelfranchi, Cristiano, 168 cellphones, 8 data usage, 14 DynaTAC 800, 5 HTC Dream, 7 IBM Simon, 5 iPhone, 6 Nokia, 198 Nokia N95, 6 size, 5–7 chaos experiments. See failure drills chief information officer (CIO), 15 CloudFlare, 204 Code Yellow, 116–122, 156, 193 Collins Aerospace, 204 column width, 18 commercial cloud, 3, 15, 69, 86 Committee on Data Systems Languages (CODASYL), 29 compiler design, 71 complexity, 41, 46–50, 61, 103, 108, 137, 146, 173, 207 compliance, 90 configuration management, 65 containerization, 65 continuous integration, 72, 183 contract testing, 110 control flow graphs, 72 conventions, 106 Conway, Melvin, 140, 144 Conway’s law, 98, 140–141, 149–152, 156, 159 costs, 9 coupling, 46–50, 56, 64, 66, 85, 101, 103, 173 cross-compatibility, 64, 69 D databases, 36 data contracts, 102–110, 171 data flow graphs, 72 Deep Impact probe, the, 198 Dekker, Sidney, 145, 167 delays, 211 Department of Justice, 24 Department of Treasury, 15 Department of Veterans Affairs, 68 dependencies, 68, 111, 115 graphs, 71 management, 64 deprecations, 179 development environments, 72 development view, 173 DevOps, 150, 218 diagnosis-policies-actions, 184–187 drift, 145–146 E ECMA Office Open XML specification, 61 encoding, 20 enterprise architects, 77 enterprise service buses (ESB), 7–8 Etsy, 166 Excel, 61 F FAA (Federal Aviation Administration), 204 Facebook, 114 failovers, 55 failure drills, 114, 153, 172, 178 Falcone, Rino, 168 Feathers, Michael, 55 feature parity, 79 Federal Aviation Administration (FAA), 204 feedback loops, 210–211, 218–219 filetypes PDF, 67 fixed-point, 70 Flickr, 102 floating-point, 70 flows, 210 Fog Creek Software, 33 Ford, Neal, 105 formal methods, 109 Alloy, 110 Petri nets, 110 TLA+, 110 formal specification, 109–110 Fowler, Chad, 33 frameworks Angular.js, 150 Node.js, 36, 68 React.js, 36, 150 Vue.js, 150 G garbage collection, 44, 206 Gawker Media, 204 Glidden, Carlos, 19 GNU, 25 Google, 113, 117–118, 169, 205, 207 Chrome 119 GPS, 202–204 Groupon, 102 H Hadoop, 15 hard cutoff, 57 hardware lifecycles, 196 Harvard Business Review, 140 Harvard’s Kennedy School for Government, 162 Hölzle, Urs, 119 hooks, 65 HTTPS (HyperText Transfer Protocol Secure), 114 human factors, 145 I IBM, 19, 140, 198 Simon, 5 incentives, 34, 122, 140–144, 148–156, 163–165 incident commander, 121 incident response, 109, 188 InsightMaker, 212 Instagram, 204 International Telegraph Alphabet No. 1.

pages: 593 words: 118,995

Relevant Search: With Examples Using Elasticsearch and Solr
by Doug Turnbull and John Berryman
Published 30 Apr 2016

The scores across all fields are then combined either by summing them or taking the value of the highest-scoring field. Finally, the relevance engineer may choose to apply an additional multiplicative or additive boost based on the numerical value of a field or the numerical value of a function that itself uses values from one or more fields. This is where the “business logic” of search often comes into play. In our example movie search, it’s probably advantageous to boost more-popular movies because they tend to sell better than older movies. Therefore, you can declare the final score to be the score across all fields (last paragraph) multiplied by whatever value is in the popularity field.

On the other hand, you might have little nudge or tie-breaker boosts—nice-to-have, lower-priority boosts that nudge relevance up or down. These two phases, shown in figure 7.6, are highly interdependent. Figure 7.6. Two activities of score shaping are signal modeling (measuring pieces of ranking information) and the ranking function (combining the influence of different signals to implement business logic). How much your boost nudges or overrides might depend exactly on the precision of the signal. Perhaps it’s a text-based relevancy nudge. Or a nudge based on multiplying a carefully crafted function. You’re always traversing both layers, optimizing signals, thinking how they’ll be used, and modifying the ranking function accordingly.

Naïve recency boost for news articles Figure 7.5. Tuned recency boost: a less aggressive recency boost for analysts Figure 7.6. Two activities of score shaping are signal modeling (measuring pieces of ranking information) and the ranking function (combining the influence of different signals to implement business logic). Figure 7.7. Flowchart representation of the custom business ranking rules as understood/specified by the business Figure 7.8. High-recall base query in black augmented with a highprecision tier of unequivocally more valuable search results Figure 7.9. Flowchart representing the custom business ranking rules for exact-name (cast/director) matching Figure 7.10.

pages: 434 words: 77,974

Mastering Blockchain: Unlocking the Power of Cryptocurrencies and Smart Contracts
by Lorne Lantz and Daniel Cawrey
Published 8 Dec 2020

Like Mastercoin (discussed in Chapter 4), it was built on top of the Bitcoin blockchain but aimed to offer a lot more programming capabilities than its antecedent. Most notably, programmers were able to create their own crypto-based blockchain assets on the platform. It featured smart contracts, which contain code that provides a blockchain application with business logic, giving developers more control over when and under what conditions a block would be written to the blockchain (this concept is also explored more in the next chapter). Counterparty also has its own cryptocurrency, called XCP. Interestingly, to raise funds for the project, the developers took in around $1.6 million in bitcoin and “burned” it.

Uniswap smart contracts and transactions are powered by and recorded by thousands of miners. The smart contracts and transactions are immutable and can never be changed. The only way to shut down the smart contract or stop transactions from completing is by shutting down the Ethereum network. Authorizing code execution Before executing any business logic, the backend authorizes API requests using security standards like JWT or OAuth. Smart contract code is run on the Ethereum Virtual Machine (EVM). The smart contract runs on the node of the miner producing the block and everyone in the network running a full node validating the chain. Figure 7-7 shows part of the Uniswap V1 Exchange Template smart contract, viewable on the blockchain.

pages: 448 words: 71,301

Programming Scala
by Unknown
Published 2 Jan 2010

xxii | Preface Download at WoweBook.Com CHAPTER 1 Zero to Sixty: Introducing Scala Why Scala? Today’s enterprise and Internet applications must balance a number of concerns. They must be implemented quickly and reliably. New features must be added in short, incremental cycles. Beyond simply providing business logic, applications must support secure access, persistence of data, transactional behavior, and other advanced features. Applications must be highly available and scalable, requiring designs that support concurrency and distribution. Applications are networked and provide interfaces for both people and other applications to use.

customer } } By now, this should all look very familiar. Each Shop creates and starts a new Barber, prints a message telling the world that the shop is open, and sits in a loop waiting for customers. When a Customer comes in, he’s sent to the barber. We now see an unexpected benefit of Actors: they allow us to describe concurrent business logic in easily understood terms. “Send the customer to the barber” makes perfect sense, much more so than “Notify the barber, unlock the mutex around the customer seats, increment the number of free seats,” and so forth. Actors get us closer to our domain. Finally, we have a driver for our simulation: // code-examples/Concurrency/sleepingbarber/barbershop-simulator.scala package sleepingbarber import scala.actors.Actor._ import scala.collection.

Each abstract trait declares a “start” method that does the work of initializing the tier. (We’re ignoring issues like success versus failure of startup, etc.) Each abstract tier is implemented by a corresponding concrete trait (not a class, so we can use them as mixins). We have traits for database persistence, some sort of computation cluster to do the heavy lifting for the business logic, and a web-based UI. The App trait wires the tiers together. For example, it does the work of starting the tiers in the run method. Note the self-type annotation, self: Persistence with Midtier with UI =>. It has two practical effects: 1. The body of the trait can assume it is an instance of Persistence, Midtier, and UI, so it can call methods defined in those types, whether or not they are actually defined at this point.

The Trade Lifecycle: Behind the Scenes of the Trading Process (The Wiley Finance Series)
by Robert P. Baker
Published 4 Oct 2015

New technology The system was originally built in C++ and Visual Basic linked by the common object model (COM). This model made installation difficult, time consuming and error prone. At some point during the development, the technology was upgraded, which meant some of the front-end, graphical user interface had to be rewritten. Fortunately, as the application was well-layered this did not affect the business logic and so the time wasted was not as great as it might have been. The mathematical library was originally built and remained in the C programming language. Extra products As anticipated, extra financial products in the form of exotic currency options were required during development. This meant new input screens being added.

What actually happened? The project required a framework known as a technical architecture. It also had a database for the capture and retrieval of trades and other data. Architecture The system was built according to the common three-tier architecture with one unusual modification. The graphical user interface and business logic used standard technologies but the database was object oriented rather than relational. Case Studies 251 This was a benefit for the developers as they could learn something new but, as the object-oriented database was untested in a major commercial environment, it was somewhat risky. The database The database design was acceptable but was very tied to particular trade types being traded at that time.

The database The database design was acceptable but was very tied to particular trade types being traded at that time. This meant it was not easily extendable in the future when new trades were on the market and extensions were costly in development and testing time. The object-oriented database tied in well with the OTTC business logic and screens and facilitated quicker development. But it was slower on filtering and sorting and, with the benefit of hindsight, it would have been better to have chosen a relational database. Trade capture The trade capture facility was the basis of the success of OTTC. It was easy to use, very popular with users and set the standard for future GUIs within the IT department.

pages: 411 words: 80,925

What's Mine Is Yours: How Collaborative Consumption Is Changing the Way We Live
by Rachel Botsman and Roo Rogers
Published 2 Jan 2010

Walter R Stahel, The Industrial Green Game (National Academy Press, 1997), 91. 33. John Thackara, Inside the Bubble (MIT Press, 2006), 224. 34. Rifkin, The Age of Access, 93. 35. Fishman, “Sustainable Growth.” 36. Ray Anderson, “The Business Logic of Sustainability,” a TED talk (February 2009), www.ted.com/talks/ray_anderson_on_the_business_logic_of_sustainability.html. 1. “Largest Environmental Web Community in the World,” Freecycle press release (September 9, 2008), www.freecycle.org/pressreleases/08-09-09_Freecycle_press_release.pdf. 2. Statistics on membership numbers and group numbers retrieved from www.freecycle.org.

pages: 289 words: 80,763

User Story Mapping: Discover the Whole Story, Build the Right Product
by Jeff Patton and Peter Economy
Published 14 Apr 2014

Most people break down software the same way. Instead of just a little user interface, a little business logic, and a little database interaction, there’s lots of each. But remember that software isn’t cake. It doesn’t take that much more time to measure two pounds of flour than it does to measure two cups of flour. But building the user interface for 20 screens takes a lot more time than for just 2 screens. So, if teams use the simple breakdown structure that seems logical, they get tempted to break software down into weeks of frontend development, weeks of business logic development, and so on. When we use that strategy, it takes a long time before we can “taste any cake,” so to speak.

pages: 584 words: 149,387

Essential Scrum: A Practical Guide to the Most Popular Agile Process
by Kenneth S. Rubin
Published 19 Jul 2012

During the daily scrum, team members collectively describe, in a highly visible manner, the big-picture plan for that day. This also allows the team to use resource alerts. For example, someone might say, “Today I am going to work on the stored procedure task, and I should have that done by lunch. Whoever is going to work on the business logic task, please keep in mind that the business logic task is on the critical path for getting our work done this sprint and you should be ready to work on it right after lunch.” Such communications can quickly identify potential work blockages and enable a better flow through sprint execution. Closing This chapter illustrated how planning at multiple levels of detail happens on a development effort using Scrum.

Teams composed solely of people with the same skills (traditional silo teams) can at most do part of the job. As a result, silo teams end up handing off work products to other silo teams. For example, the development team hands the code off to the testing team, or the UI team hands off screen designs to the business logic team. Handoffs represent an excellent opportunity for miscommunication and costly mistakes. Having diverse teams minimizes the number of handoffs. And creating diverse teams doesn’t prevent us from having multiple team members who might be highly skilled in the same discipline such as Java or C++ development or testing.

Digital Accounting: The Effects of the Internet and Erp on Accounting
by Ashutosh Deshmukh
Published 13 Dec 2005

The Advanced Business Application Programming (ABAP) language can be used to define and manipulate such stored data. Application servers can run on various operating systems such as Uniplexed Information and Computing System (UNIX), its variations, Virtual Memory System (VMS) and Windows New Technology (NT), and its successors. Business logic runs on Copyright © 2006, Idea Group Inc. Copying or distributing in print or electronic forms without written permission of Idea Group Inc. is prohibited. The Evolution of Accounting Software 25 Exhibit 8. SAP R/3 implementation of client-server architecture • Common look and feel across different platforms Presentation Browser access SAPGUI clients •Internet connections •Transaction management Web enabling SAP Internet transaction servers Application Application servers Database Data warehouse RDBMS •User dialogs •Database update •Enqueue •Background jobs •Message coordination •Gateway services •Spooling •Master data •Transaction data •Metadata application servers, and these servers also perform basic services: the user dialogs service processes user inputs using business logic; database updates service updates the database after the transaction is complete; enqueue service controls business objects by generating, holding and releasing locks; background jobs service completes transaction processing; message coordination service controls to and fro movement of data; gateways service controls communication between SAP R/3 and the external systems; and spooling service controls printing.

SAP R/3 implementation of client-server architecture • Common look and feel across different platforms Presentation Browser access SAPGUI clients •Internet connections •Transaction management Web enabling SAP Internet transaction servers Application Application servers Database Data warehouse RDBMS •User dialogs •Database update •Enqueue •Background jobs •Message coordination •Gateway services •Spooling •Master data •Transaction data •Metadata application servers, and these servers also perform basic services: the user dialogs service processes user inputs using business logic; database updates service updates the database after the transaction is complete; enqueue service controls business objects by generating, holding and releasing locks; background jobs service completes transaction processing; message coordination service controls to and fro movement of data; gateways service controls communication between SAP R/3 and the external systems; and spooling service controls printing.

Copying or distributing in print or electronic forms without written permission of Idea Group Inc. is prohibited. 270 Deshmukh Exhibit 6. Business intelligence tools •Data extraction •Data transformation •Data load Business information warehouse ERP system Reports •Key performance measures •Ad-hoc queries •Business intelligence metadata •OLAP metadata Business intelligence tools OLAP Analysis •Business logic •Mathematical/statistical models •Data mining Executive dashboards Management dashboards Executive information systems Pre-packaged solutions •Planning and budgeting •Consolidations •Financial analytics •Abc/abm •Balanced scorecard •Corporate performance management These tools were soon superceded by specialized report writing tools and analytical tools, which now have evolved to a new category of Business Intelligence (BI) tools; Crystal Reports/Business Objects and Cognos are examples of leading software vendors in this area.

pages: 505 words: 161,581

The Founders: The Story of Paypal and the Entrepreneurs Who Shaped Silicon Valley
by Jimmy Soni
Published 22 Feb 2022

Indeed, a July 10 communication from one V2 engineer testified to the issues. Asked how a million new accounts would impact the V2 system, the engineer replied, “Right now, the business logic isn’t quite in a state to handle creation of a million accounts directly due to memory leaks (we’re down to about 20k/sec under maximum load—leading to approx 2.5 hours of operation, and thus 225K accounts before a restart of the business logic is needed).” Eventually, another engineer recalled, the servers needed rebooting “every thirteen seconds.” As work on V2 progressed, the team’s doubts deepened. Testing an early V2 iteration, the site’s Send Money button—arguably the most vital one of all—failed to function.

“It’s a more friendly environment to write things in Unix, because Unix has always been, since day one, a multi-user platform. Windows was grown up as a desktop PC OS [operating system]. It was never meant for multi-user, concurrent transactions,” Mak explained. On the other hand, Microsoft’s off-the-shelf tools made some tasks simpler. “Business logic is easy to write in Windows,” recalled Mak. “You have to do quite a bit in Unix to make that happen.” Microsoft simplified basic tasks like standing up a barebones website, he recalled. And if you ran into issues, customer support was but a phone call away. Ultimately, though, Doug Mak and many others on the team concluded that while the V2 effort had led to some modest improvements, the juice wasn’t worth the squeeze.

pages: 153 words: 27,424

REST API Design Rulebook
by Mark Masse
Published 19 Oct 2011

A benefit of this methodology is that it reuses the exact same schema structures as templates for the backend to fill in and as contracts for clients to consume and introspect. In a world of multi-device clients with different formatting needs, this architecture frees up server developers to focus on advancing the web application’s business logic in their backend systems, instead of worrying about all of the REST API design rules presented in this book. With a baseline level of server interface uniformity, new client-side frameworks can be developed to abstract away the mundane code related to HTTP-based communication and data marshalling.

pages: 134 words: 29,488

Python Requests Essentials
by Rakesh Vidya Chandra and Bala Subrahmanyam Varanasi
Published 16 Jun 2015

. >>> print Question.query.get(1) None Views A view is a Python function, which receives a web request and sends back a web response. The response of a view can be a simple string, web page, the content of a file, or anything. Whenever a Flask application gets a request from the client, it will look for a view function to service it. The view contains the business logic which is necessary to process a request. In the previous sections, we have created the necessary database models. Now, in this section, we will write the view functions. Let us create view for every resource we mentioned in the previous table, which throws spot light on how we are going to design the URLs.

pages: 696 words: 111,976

SQL Hacks
by Andrew Cumming and Gordon Russell
Published 28 Nov 2006

The title is NULL because it is optional for comments. Finally, there is a large string data type column for the comment text, which you might think need not be as large as the column for the article text, but the business logic may allow for comments of arbitrary length. This is a classical one-to-many relationship. Each article can have one or more comments, and each comment belongs to only one article. Technically, it's a one-to-zero-or-many relationship, because the business logic dictates that an article must be able to exist without any comments, which is the situation that pertains immediately after the article is first added, before the first comment on it is created.

Kanban in Action
by Marcus Hammarberg and Joakim Sunden
Published 17 Mar 2014

Sometimes, when WIP limits are described, they come across as something definitive; this adds to the confusion, because WIP limits should be moving targets. 6.6.1. Work items or tasks—what are you limiting? Quite often, teams split up work items into tasks for certain steps in their workflow. For Development, it could be tasks like “implement data access,” “write HTML page,” and “complete business logic.” In a Testing column, they could be tasks like “prepare test data,” “write report,” and “perform manual tests.” Tasks are part of a work item and can be thought of as all the things you need to do to complete the work item in a given column. Not until every task is completed in Development are the work items moved to the next step of the workflow.

Consider, as a contrast, a component team that creates just the data-access layer or just the user-interface layer. When structuring teams like this, you run the risk of having teams waiting for each other to be able to complete features. A complete feature might involve several teams: the UI team, the business-logic team, and the data-layer team. If any of them are late, the complete feature is delayed. Information is lost, and miscommunication happens in handoffs between teams. Hence it’s a greater risk to the overall schedule and quality of the result. A Word from the Coach One giant project organization map that Marcus briefly looked at had about 250 people layered in a big five-level-deep hierarchical map.

pages: 7,371 words: 186,208

The Long Twentieth Century: Money, Power, and the Origins of Our Times
by Giovanni Arrighi
Published 15 Mar 2010

When such control has been achieved, it may be to [the investors’] interest to make and maintain business conditions which shall facilitate the smooth and efficient working of what has come under his control . . . for, other things equal, the gains from what has come under his hands permanently in the way of industrial plant are greater the higher and the more uninterrupted its industrial efficiency. (Veblen 1978: 30) This contrast between a strictly pecuniary business logic, which is indifferent to disturbances in the industrial balance, and a technological business logic, which has an interest in uninterrupted industrial efficiency, has been widely held as describing the different responses of the British and of the German business communities to the challenges and opportunities posed by the nineteenth-century reconstitution of the world market on industrial foundations.

In these and other instances, the record of Dutch brutality in enslaving the indigenous peoples (literally and metaphorically) or in depriving them of their means of livelihood, and in using violence to break their resistance to the policies of the Company, matched or even surpassed the already abysmal standards established by the crusading Iberians throughout the extra-European world. But this brutality was wholly internal to a business logic of action and buttressed, instead of undermining, profitability: The historian, while horrified by such a record of brutality, cannot but be entertained by the calculated, extraordinary and sometimes grotesque web of interlocking purchases, cargoes, sales and exchanges. Fine spices did not find a ready market only in Holland: India consumed twice as much as Europe, and in the Far East they were a sought-after exchange currency, the key that opened many markets, just as the grain and ships’ masts of the Baltic were in Europe.

pages: 821 words: 178,631

The Rust Programming Language
by Steve Klabnik and Carol Nichols
Published 14 Jun 2018

src/main.rs fn main() { let simulated_user_specified_value = 10; let simulated_random_number = 7; generate_workout( simulated_user_specified_value, simulated_random_number ); } Listing 13-2: A main function with hardcoded values to simulate user input and random number generation We’ve hardcoded the variable simulated_user_specified_value as 10 and the variable simulated_random_number as 7 for simplicity’s sake; in an actual program, we’d get the intensity number from the app’s frontend, and we’d use the rand crate to generate a random number, as we did in the Guessing Game example in Chapter 2. The main function calls a generate_workout function with the simulated input values. Now that we have the context, let’s get to the algorithm. The function generate_workout in Listing 13-3 contains the business logic of the app that we’re most concerned with in this example. The rest of the code changes in this example will be made to this function. src/main.rs fn generate_workout(intensity: u32, random_number: u32) { ➊ if intensity < 25 { println!( "Today, do {} pushups!", simulated_expensive_calculation(intensity) ); println!

( "Next, do {} situps!", simulated_expensive_calculation(intensity) ); } else { ➋ if random_number == 3 { println!("Take a break today! Remember to stay hydrated!"); ➌ } else { println!( "Today, run for {} minutes!", simulated_expensive_calculation(intensity) ); } } } Listing 13-3: The business logic that prints the workout plans based on the inputs and calls to the simulated_expensive_calculation function The code in Listing 13-3 has multiple calls to the slow calculation function. The first if block ➊ calls simulated_expensive_calculation twice, the if inside the outer else ➋ doesn’t call it at all, and the code inside the second else case ➌ calls it once.

Change the values in the simulated_user_specified_value and simulated_random_number variables to verify that in all the cases in the various if and else blocks, calculating slowly... appears only once and only when needed. The Cacher takes care of the logic necessary to ensure we aren’t calling the expensive calculation more than we need to so generate_workout can focus on the business logic. Limitations of the Cacher Implementation Caching values is a generally useful behavior that we might want to use in other parts of our code with different closures. However, there are two problems with the current implementation of Cacher that would make reusing it in different contexts difficult.

Robot Futures
by Illah Reza Nourbakhsh
Published 1 Mar 2013

He agrees to double-cross his friends in return for permanent, manufactured bliss: “You know, I know this steak doesn’t exist. I know that when I put it in my mouth, the Matrix is telling my brain that it is juicy and delicious. After nine years, you know what I realize? Ignorance is bliss.” Perfectly manufactured desire is, of course, not only about bliss—we need to remember that at its foundation is business logic. The calculus of success has always been about closing the gap between promise and desire. But when desire can be so directly manipulated, individually, then business decisions may change more radically yet. Do not worry about promise nearly as much. Instead consider what consumer demands are in the best interests of the company, within the range of feasible desires that the company’s universal remote can manipulate, and then follow through.

pages: 508 words: 120,339

Working Effectively With Legacy Code
by Michael Feathers
Published 14 Jul 2004

Figure 10.2 AccountDetailFrame crudely refactored. This is an extremely crude refactoring of the original code, but at least it separates responsibilities somewhat. The AccountDetailFrame is tied to the GUI (it is a subclass of Frame) and it still contains business logic. With further refactoring, we can move beyond that, but at the very least, now we can run the method that contained business logic in a test case. It is a positive step forward. The SymbolSource class is a concrete class that represents the decision to create another Frame and get information from it. However, we named it SymbolSource here because, from the point of view of the AccountDetailFrame, its job is to get symbol information any way it needs to.

pages: 511 words: 111,423

Learning SPARQL
by Bob Ducharme
Published 22 Jul 2011

Your form could include these values in a drop-down list, and if someone eventually adds ab:piano as a new instance of this class, the SPARQL query that generates that part of the form will pass the new instrument name (most likely, the rdfs:label value associated with ab:piano) along to be added to that drop-down list. While these examples describe the use of rdfs:domain and rdfs:range values to generate a data entry form, the dynamic use of model values can go far beyond that. Using similar techniques, this metadata can help your application format reports; it can even play a role in the business logic and rules that drive your application. Whatever you do with it, SPARQL is the simplest way to get those values from your model to your application. The use of RDFS and OWL can let you take these ideas even further. Note This idea of model-driven development and deployment is not limited to the use of the RDF family of specifications, but the fact that these specifications are standards with a range of commercial and open source implementations makes it an attractive choice for many developers using this methodology.

After running the command, running this next one deletes the “seven” and “eight” triples from the default graph, leaving the remaining triples in the g1 and g2 graphs alone: curl -X DELETE -H "Content-Type: text/turtle" \ http://localhost:3030/myDataset/data?graph=default Summary In this chapter, we learned: How some applications (or application components) can execute business logic based on the presence of specific values—especially predicates—in the triples that they see How to send a SPARQL query to an endpoint from popular scripting languages and from a web form, and how applications that use these can make use of the returned data The role that standalone, triplestore, and middleware SPARQL processors can play to make RDF and non-RDF data available to applications that use SPARQL queries How RESTful (or, perhaps, “REST-like”) applications can use the SPARQL Graph Store HTTP Protocol to manage named graphs of triples on a remote server Chapter 11.

pages: 434 words: 114,583

Faster, Higher, Farther: How One of the World's Largest Automakers Committed a Massive and Stunning Fraud
by Jack Ewing
Published 22 May 2017

Some Volkswagen executives argued that the brands also provided platforms to try out costly new technologies, like the use of lightweight carbon fiber for body parts in place of steel, which would eventually make their way into less expensive vehicles. In addition, the chance to work on exotic cars may have helped Volkswagen attract top engineers and designers. Whatever the business logic, it was obvious that Piëch’s personal fascination with the three carmakers played a big role in the acquisitions. He bought them, it seemed, because he could. Piëch made no apologies. He even admitted that his interest in Bugatti was inspired in part by his youngest son, Gregor. While vacationing on the Spanish island of Majorca, Piëch showed the lad a model of a Rolls-Royce on display in a local shop that catered to tourists.

The cars were clean, practical, and economical, said Volkswagen, which boasted about how much less carbon dioxide the motors produced. The United States was also a big part of the plan. It was the largest car market on the planet. To sell ten million cars a year and overtake GM and Toyota, Volkswagen could not ignore the United States. Beyond the business logic, the United States was an embarrassment for Volkswagen. Volkswagen was the dominant carmaker in Europe. It was a powerhouse in China and Latin America. But in the United States it was little more than a niche brand, in the same league as imports like Subaru. Behind the scenes, there were problems.

pages: 444 words: 118,393

The Nature of Software Development: Keep It Simple, Make It Valuable, Build It Piece by Piece
by Ron Jeffries
Published 14 Aug 2015

One consequence is that anything logged at level “ERROR” or “SEVERE” should be something that requires action on the part of operations. Not every exception needs to be logged as an error. Just because a user entered a bad credit card number and the validation component threw an exception doesn’t mean anything has to be done about it. Log errors in business logic or user input as warnings (if at all). Reserve “ERROR” for a serious system problem. For example, a circuit breaker tripping to “open” is an error. It’s something that should not happen under normal circumstances, and it probably means action is required on the other end of the connection. Failure to connect to a database is an error—there’s a problem with either the network or the database server.

I’ll assume that you don’t want to just make a complete copy of all the v1 code to handle v2 requests. Internally, we want to reduce code duplication as much as possible, so long as we can still make future changes. My preference is to handle this in the controller. Methods that handle the new API go directly to the most current version of the business logic. Methods that handle the old API get updated so they convert old objects to the current ones on requests and convert new objects to old ones on responses. Now you know how to make your service behave like a good citizen. Unfortunately, not every service is as well behaved as yours. We need to look at how to handle input from others.

pages: 169 words: 41,887

Literary Theory for Robots: How Computers Learned to Write
by Dennis Yi Tenen
Published 6 Feb 2024

This skeleton of skeletons was made of questions, documenting the bare-­bones outline of any manufacturing process. Its blanks left space for the number of workers employed, hours worked, tools and maintenance involved, maintenance, the division of labor, the list of operations and the number of times each was repeated, among other exacting elements of business logic. Among the industries queried, Babbage made special note of the printing process itself, in the “copying through six Stages in Printing this volume.” “It is here that the union of the intellectual and the mechanical departments takes place,” he wrote, recalling Lovelace—­in a pattern, on a template, along the cells of a table—­“down to the cavity punched through the letters a, b, d, e, g, &c.”

pages: 241 words: 43,073

Puppet 3 Beginner's Guide
by John Arundel
Published 16 Apr 2013

There's no actual server named base-server; however, actual servers can inherit from this node declaration and get everything in it: node 'cluster660' inherits 'base-server' { We know what role this machine has because it includes this class: class { 'hadoop::node': It takes a parameter to identify the cluster master: master => 'cluster1', This node declaration contains only the key information that the node needs to do its job, and tells us at a glance what that job is. If your node declarations contain business logic, or individual resources, think about refactoring these into a class or module that the node can include. Use puppet-lint puppet-lint is a useful tool that checks your manifest to make sure it conforms to the Puppet Labs official style guidelines, and catches a number of common problems.

pages: 1,038 words: 137,468

JavaScript Cookbook
by Shelley Powers
Published 23 Jul 2010

The key to making these work now and in the future is to wrap the library use in such a way that you can swap one library out for another, without having to recode your applications—or, at least, minimize the amount of recoding you would have to do. Rather than use the jQuery ready event, create your own so you don’t build a higher- level dependency on jQuery. Rather than use jQuery methods directly in your business logic, use your own objects and methods, and call the jQuery methods within these. By providing a layer of abstraction between the implementation of your application’s business logic and the external framework library, if someday you stumble upon Frew, the Wonder Library, you can swap out jQuery (or Prototype, or Dojo) and build on Frew. See Also jQuery Cookbook by Cody Lindley (O’Reilly) is an excellent book providing a comprehensive overview and detailed how-tos for jQuery.

The Corporation: The Pathological Pursuit of Profit and Power
by Joel Bakan
Published 1 Jan 2003

"This is not a sudden discovery of moral virtue or a sense of guilt about past errors," he says of his green agenda. "It is about long-term self-interest-enlightened, I hope, but self-interest nonetheless ." BP's social responsibility, he says, is "good business"; "driven by practical commercial reality" and "hard-headed business logic." The company's good deeds are "in our direct business interest," "not Page 45 HE CORPORATION 45 acts of charity but of what could be called enlightened self-interest," "coldly realistic." "The fundamental test for any company," says Browne, "is performance. That is the imperative."" By implication, social responsibility is not appropriate when it could undermine a company's performance.

pages: 215 words: 55,212

The Mesh: Why the Future of Business Is Sharing
by Lisa Gansky
Published 14 Oct 2010

Design, Architecture for Humanity argues, is the ultimate renewable resource. Today, they have 40,000 members in eighty chapters in twenty-five countries that participate. Their cheeky slogan is “Design like you give a damn.” Why create share platforms where ideas and information can be freely shared? Once the core offering is refined, traditional business logic dictates that a more proprietary approach will distinguish you from competitors, and create protection against them. Individual creators and companies have long built businesses and fortunes by registering patents and enforcing secrecy. General Electric controlled the patents on lightbulbs, invested heavily in plants to manufacture the bulbs efficiently, and made profits by cranking out the bulbs for decades to follow.

pages: 201 words: 63,192

Graph Databases
by Ian Robinson , Jim Webber and Emil Eifrem
Published 13 Jun 2013

There are two drivers here: performance and business responsiveness. Performance issues have dogged TeleGraph’s self-service application for several years. The original system is based on a relational database, which uses recursive joins to model complex organisational structures and product hierarchies, and stored procedures to implement the access control business logic. Because of the join-intensive nature of the data model, many of the most important queries are unacceptably slow: for large com‐ Real-World Examples | 107 panies, generating a view of the things an administrator can manage takes many mi‐ nutes. This creates a very poor user experience, and hampers the revenue-generating capabilities of the self-service offering.

pages: 215 words: 59,188

Seriously Curious: The Facts and Figures That Turn Our World Upside Down
by Tom Standage
Published 27 Nov 2018

“We are open the rest of the year, seven days a week, so these days are earned,” says Rita Zubelli, who works in an ice-cream parlour in Milan that, bafflingly, shuts down at the height of the summer. In such sectors the practice of a shut-down seems driven more by habit, and the social acceptance of holidaymaking at that time, than by business logic. If you are a tourist looking for an ice-cream, a local trying to find a plumber, or even a journalist trying to write a story, Europe’s attitude to summer can be deeply frustrating. Yet despite, or perhaps because of, their leisure-seeking ways, Europeans are the most productive workers in the world.

Learning Ansible 2 - Second Edition
by Fabio Alessandro Locati
Published 21 Nov 2016

The same functionality could have been achieved without the module, but it would have required a series of tasks with existing modules to accomplish the end goal and often also command and shell modules. For example, let's say you wanted to provision a server via Preboot Execution Environment (PXE). Without a custom module, you would have probably used a few shell or command tasks to accomplish the same. However, with a custom module, you would just pass the required parameters to it and the business logic will be embedded within the custom module in order to perform the PXE boot. This gives you the ability to write playbooks that are much simpler to read and a bigger reusability of the code, since you create the module once and you can use it everywhere, in your roles and playbooks. The arguments that you pass to a module, provided they are in a key-value format, will be forwarded in a separate file along with the module.

pages: 292 words: 62,575

97 Things Every Programmer Should Know
by Kevlin Henney
Published 5 Feb 2010

We test and refactor the source code throughout a project. The deployment deserves no less. Chapter 21. Distinguish Business Exceptions from Technical Dan Bergh Johnsson THERE ARE BASICALLY TWO REASONS that things go wrong at runtime: technical problems that prevent us from using the application and business logic that prevents us from misusing the application. Most modern languages, such as LISP, Java, Smalltalk, and C#, use exceptions to signal both these situations. However, the two situations are so different that they should be carefully held apart. It is a potential source of confusion to represent them both using the same exception hierarchy, not to mention the same exception class.

Catalyst 5.8: The Perl MVC Framework
by Antano Solar John , Jonathan Rockway and Solar John Antano
Published 15 Nov 2010

All your action has to do is implement the logic associated with the request; there is no setup that you have to manually perform, as illustrated in the following diagram: Although this dispatch mechanism is already an improvement over the traditional process, Catalyst doesn't stop here. Your actions can call on the help of Models and Views as well. [] Chapter 1 In fact, for more complex problem domains that have a small and flexible Controller handling the actual business logic via models usually gives the most maintainable results. A Model is a source of data. Most applications use a single relational database such as MySQL or PostgreSQL as their Model, but Catalyst does not require that—you can use anything from files on a disk, to an e-mail server, or remote RSS feeds; also you can have as many Models as your application needs.

pages: 282 words: 63,385

Attention Factory: The Story of TikTok and China's ByteDance
by Matthew Brennan
Published 9 Oct 2020

The Mindie team was gracious in reflecting back on what had happened: “Musical.ly made a great work of optimizing and scaling what we initially created,” said co-founder Stanislas. Louis then turned to outline how he saw competition in his local market. “Here in China, it’s a different way—if you do something right… they will follow, they will do exactly the same thing … People here have a very different business logic, they think you can always get a market share very quickly by powering in with money, and once you have that, you can kick the others out… people don’t have that patience to grow up very gradually. Everything happening in China is so fast, so people lose their patience.” 170 Here Louis was referring to a new, more challenging competition that had just begun.

pages: 292 words: 66,588

Learning Vue.js 2: Learn How to Build Amazing and Complex Reactive Web Applications Easily With Vue.js
by Olga Filipova
Published 13 Dec 2016

The data object is our Model and the DOM element where the Vue instance is bound is our View: Classic View-Model representation where the Vue instance binds one to another In the meantime, our Vue instance is something that helps to bind our Model to the View and vice versa. Our application thus follows Model-View-ViewModel (MVVM) pattern, where the Vue instance is a ViewModel: The simplified diagram of the Model-View-ViewModel pattern Our Model contains data and some business logic, and our View is responsible for its representation. ViewModel handles data binding, ensuring that the data changed in the Model is immediately affecting the View layer and vice versa. Our Views thus become completely data driven. ViewModel becomes responsible for the control of the data flow, making data binding fully declarative for us.

pages: 239 words: 62,311

The Next Factory of the World: How Chinese Investment Is Reshaping Africa
by Irene Yuan Sun
Published 16 Oct 2017

We will meet the Chinese entrepreneurs who run these factories and understand the business models that have allowed them to thrive so far from home. Despite the current hype about the rise of robotics and the possibility of fully automating production, the classic factory model, in which real people make tangible goods, is far from dead. There’s still lots of money to be made with this way, and this business logic is what drives Chinese factory owners to Africa. By and large, these manufacturing entrepreneurs have little to do with the massive tranches of Chinese government–led investment and aid in Africa that the Western press often reports on in tones of fear and incredulity.7 These private investors care little about geopolitics.

pages: 254 words: 61,387

This Could Be Our Future: A Manifesto for a More Generous World
by Yancey Strickler
Published 29 Oct 2019

With so much at stake and movies costing more than ever, studios became more conservative and the diversity of ideas decreased. Saying movies have gone downhill is hardly controversial. But what about TV? The kinds of shows Netflix, HBO, AMC, and others make are original and diverse. Doesn’t that disprove this point? Traditional broadcast television, which follows a similar business logic as movies, absolutely suffers from these same forces. Sitcoms, cop, doctor, and lawyer shows are rarely known for their originality. But it’s also true that prestige television operates on a level above movies and broadcast TV. It’s where some of the most original and forward-thinking creative work happens.

pages: 237 words: 67,154

Ours to Hack and to Own: The Rise of Platform Cooperativism, a New Vision for the Future of Work and a Fairer Internet
by Trebor Scholz and Nathan Schneider
Published 14 Aug 2017

As apps and the Open Web gradually give way to big platforms, we’ll see more and more people converse with machines in natural language rather than tapping icons and finagling user-interfaces. It’s possible that the bulk of our utilities and content consumption will be further embedded into our messaging apps as bots bump out buttons. What does this mean for platform co-ops who need to capture the attention of people, communicate with them, and transact following the prevailing business logics, and do this ethically? There is an urgent and critical need to build AI platforms that are co-owned and governed by the people who will use them for more and more purposes. These crucial efforts will help alternative AI software mature and develop toward an intelligence that truly represents us, not just the wealthy few who funded the earliest research and development expenditures.

pages: 233 words: 67,596

Competing on Analytics: The New Science of Winning
by Thomas H. Davenport and Jeanne G. Harris
Published 6 Mar 2007

In order to make the data in a warehouse decision-ready, it is necessary to first clean and validate it using business rules that use data cleansing tools such as Trillium. (For example, a simple rule might be to have a full nine-digit ZIP code for all U.S. addresses.) Transformation procedures define the business logic that maps data from its source to its destination. Both business and IT managers must expend significant effort in order to transform data into usable information. While automated tools from vendors such as Informatica Corporation, Ab Initio Software Corporation, and Ascential Software can ease this process, considerable manual effort is still required.

pages: 239 words: 56,531

The Secret War Between Downloading and Uploading: Tales of the Computer as Culture Machine
by Peter Lunenfeld
Published 31 Mar 2011

Jobs and Gates, along with their collaborators and competitors in the mid-1970s, were positioned at a fulcrum point, when a diversion turned into a business. What made them both rich and powerful was their ability to meld the attributes of the two generations that preceded them—fusing the hardheaded business logic of the Plutocrats with the visionary futurity of the Aquarians. 163 GENERATIONS Jobs and Gates have an interesting competitive history, leapfrogging each other in the quest to achieve “insane greatness,” in Jobs’s words, and global market preeminence, for Gates.21 Jobs and his partner, Wozniak, were the first to make the leap from hobbyists to industrialists with their Apple computers, launched in 1976.

Learning Node.js: A Hands-On Guide to Building Web Applications in JavaScript
by Marc Wandschneider
Published 18 Jun 2013

When you run into the term middleware for the first time, you can be forgiven for being worried that you’ve missed out on some key new concept or technology shift. Fortunately, it’s nothing so complicated. Effectively, middleware originally was used to describe software components (typically on the server side of things) that connected two things together, such as a business logic layer and a database server, or storage services with application modules, and so on. Over time, however, the term seems to have become more generic and broad, and now seems to cover any piece of software that connects two things together in some way, shape, or form. For the purposes of this book, the middleware exposed by connect that you see in express is basically just a collection of modules that allow your web apps to seamlessly integrate functionality from either the server or browser

pages: 224 words: 13,238

Electronic and Algorithmic Trading Technology: The Complete Guide
by Kendall Kim
Published 31 May 2007

The Xenomorph XDB provides higher performance than traditional relational databases currently on the market. This database has the ability to handle all major asset classes including equities, fixed income, and derivatives. It performs integrated analysis of historical time-series and real-time tick data. It can take business logic and transport that calculation to the centralized database. It has a flexible data model to handle multiple instrument data feeds in a consistent manner and rapidly support any new products that can be integrated into existing legacy systems and traditional relational databases using TimeScape XDK.

One Billion Americans: The Case for Thinking Bigger
by Matthew Yglesias
Published 14 Sep 2020

Early in the selection process there had been a lot of hype around bids made by smaller cities, midwestern cities, and cities desperate for an economic shot in the arm. Those choices would have been more exciting for journalists and better for America. But Amazon is, obviously, a for-profit business that is trying to make decisions that make business sense. And while I wasn’t happy with the outcome of the selection process, I don’t think Amazon’s business logic was mistaken. Building a bigger America will mean finding ways to fit more people into our most crowded and expensive cities. These are the places where the job opportunities are most plentiful and where additional people could be most economically valuable—if we could unlock the potential for more growth.

pages: 276 words: 64,903

Built for Growth: How Builder Personality Shapes Your Business, Your Team, and Your Ability to Win
by Chris Kuenne and John Danner
Published 5 Jun 2017

Suriyakumar explained he felt the company was thinking about the problem entirely wrong: seeking price concessions for higher volumes of conventional blueprints. The astonished CEO, who had never before been rebuffed by a vendor, invited Suriyakumar to fly to Australia to share his point of view. After listening intently to the CEO’s description of the business model, Suriyakumar then applied his own practical business logic. He explained that creating additional analog blueprints that would be used once and then relegated to a storage facility for decades was not a long-term solution for this global construction company. Rather, they should move all of their construction plans to a digital format and store them in the cloud so the information could be accessed throughout the useful life of the building and later to inform future construction companies, which would be called to either renovate or demolish the building.

pages: 245 words: 68,420

Content Everywhere: Strategy and Structure for Future-Ready Content
by Sara Wachter-Boettcher
Published 28 Nov 2012

Q&A with Mike Atherton, Digital Product Designer at Huddle From 2007 to 2011, London-based UXer Mike Atherton served as an information architect for the BBC, where he focused on using domain-driven design to make the media organization’s seemingly endless archives of content more findable and contextually relevant for the British public. He answered a few of my questions about the role domain-driven design can play in making content work harder. You’re known for the term “domain-driven design.” Can you define that? Domain-driven design is a technique borrowed from software engineering, where it’s used to express complex business logic by defining the entities in a subject domain and the relationships between them. For content strategists and information architects, it’s a way of saying “What are the ‘things’ that my content talks about and how do those things join up in the real world?” I typically express this by sketching a domain model: a simple entity-relationship diagram where the boxes are the “things” within your subject and the arrows are all the connections between those things.

Bulletproof Problem Solving
by Charles Conn and Robert McLean
Published 6 Mar 2019

(OECD Publishing, 2017). 7  Douglas Belkin, “Exclusive Test Data: Many Colleges Fail to Improve Critical‐Thinking Skills,” Wall Street Journal, June 5, 2017. 8  Philip Tetlock and Dan Gardner, Superforecasting: The Art and Science of Prediction (Random House, 2015). 9   Tobias Baer, Sven Hellistag, and Hamid Samandari, “The Business Logic in Debiasing,” McKinsey Latest Thinking, May 2017. 10  Planting Healthy Air (The Nature Conservancy, 2016). 11  Herbert Simon, The Sciences of the Artificial (MIT Press, 1968). Chapter One Learn the Bulletproof Problem Solving Approach In the 1980s, when Charles was at business school, he wanted to understand the then‐ascendant Japanese business practices better.

pages: 234 words: 67,589

Internet for the People: The Fight for Our Digital Future
by Ben Tarnoff
Published 13 Jun 2022

They are discovering the embryonic forms of an internet where the people rule. 3 The People’s Pipes In 1935, the residents of Chattanooga, Tennessee, were living in one of the poorest parts of the country in the middle of the Great Depression. Among the many things in distressingly short supply was electricity. Power, long available in the big cities, remained scarce in rural areas like the Tennessee Valley. This wasn’t an accident. Rather, it reflected a basic business logic. Private monopolies dominated the electricity market. This “power trust” was notorious for refusing to serve communities it didn’t consider profitable, and for price-gouging the ones it did. So Chattanoogans decided to take their power supply out of private hands. They voted overwhelmingly for a municipal bond issue that funded the creation of a city-owned electricity distribution system called the Electric Power Board.

pages: 834 words: 180,700

The Architecture of Open Source Applications
by Amy Brown and Greg Wilson
Published 24 May 2011

Consistency: If you've partitioned and replicated your records across multiple servers, how do the servers coordinate when a record changes? Transactional semantics: When you run a series of operations, some databases allow you to wrap them in a transaction, which provides some subset of ACID (Atomicity, Consistency, Isolation, and Durability) guarantees on the transaction and all others currently running. Does your business logic require these guarantees, which often come with performance tradeoffs? Single-server performance: If you want to safely store data on disk, what on-disk data structures are best-geared toward read-heavy or write-heavy workloads? Is writing to disk your bottleneck? Analytical workloads: We're going to pay a lot of attention to lookup-heavy workloads of the kind you need to run a responsive user-focused web application.

The key lookup model is beneficial because it means that the database has a consistent query pattern—the entire workload consists of key lookups whose performance is relatively uniform and predictable. Profiling to find the slow parts of an application is simpler, since all complex operations reside in the application code. On the flip side, the data model logic and business logic are now more closely intertwined, which muddles abstraction. Let's quickly touch on the data associated with each key. Various NoSQL systems offer different solutions in this space. Key-Value Stores The simplest form of NoSQL store is a key-value store. Each key is mapped to a value containing arbitrary data.

pages: 302 words: 73,581

Platform Scale: How an Emerging Business Model Helps Startups Build Large Empires With Minimum Investment
by Sangeet Paul Choudary
Published 14 Sep 2015

Social feedback is the new sales commission 13. Algorithms are the new decision makers 14. Real-time customization is the new market research 15. Plug-and-play is the new business development 16. The invisible hand is the new iron fist 1.3 THE RISE OF THE INTERACTION-FIRST BUSINESS A Fundamental Redesign Of Business Logic Platforms compete with each other on the basis of their ability to enable interactions sustainably. Platforms do not compete merely on the strength of better features or larger user bases. They build sustainable businesses when producers and consumers participate regularly in interactions. Uber repeatedly enables interactions between drivers and travelers, resulting in rides being exchanged for money.

pages: 254 words: 76,064

Whiplash: How to Survive Our Faster Future
by Joi Ito and Jeff Howe
Published 6 Dec 2016

What if instead of subjecting readers to increasingly invasive and offensive ads, readers donated some spare CPUs—excess computing power—instead? For however long they were on the site their computers would perform some of that laborious math that goes into the creation of each bitcoin. By the end of the hackathon, Rubin and the rest of his team had not only demonstrated the basic business logic behind the idea, but they had also built an elegant little app that websites could install to make it happen. And it would all take place in the background; once the reader opted in, they wouldn’t even know their computer had entered the mine. The Node Knockout hackathon awarded them the top prize in innovation.

pages: 268 words: 74,724

Who Needs the Fed?: What Taylor Swift, Uber, and Robots Tell Us About Money, Credit, and Why We Should Abolish America's Central Bank
by John Tamny
Published 30 Apr 2016

You wonder if we ought to be doing it or not.”20 As USA Today’s Rick Jervis noted in the fall of 2014, when the price of oil began to decline, the “break even” point in terms of profitable oil extraction was $40 per barrel in Pennsylvania’s Marcellus region, $60 per barrel in the Eagle Ford region of Texas, and $70 per barrel in North Dakota’s Bakken region.21 Absent the weak dollar, heavy investment in oil extraction almost certainly never takes place. More to the point, oil’s scarcity in the 2000s was wholly a monetary illusion. Those who believe otherwise ignore voluminous oil-price history and simple business logic. How is it that entrepreneurs generally grow rich? Historically it’s been because individuals figured out ways to mass market formerly obscure items through relentless price cutting. Silicon Valley is the richest region in the world, and a magnet for investment, not because the entrepreneurs who toil there strive to drive up prices but precisely because they excel at pushing them down.

pages: 550 words: 84,515

Vue.js 2 Cookbook
by Andrea Passaglia
Published 27 Apr 2017

getWorldWonder: state => nth => state.worldWonders[nth] } In our recipe, a practical example could specify the average cost of a house in the getter from the previous paragraph: const store = new Vuex.Store({ state: { bitcoin: 600, rate: 1000 }, getters: { euro: state => state.bitcoin * state.rate, houses: (state, getters) => averageHousePrice => { return getters.euro() / averageHousePrice } }) Testing your store As you know from Chapter 7, Unit Testing and End-To-End Testing, testing is the most important part of professional software. As the store often defines the business logic of your application, testing it may be vital for your application. In this recipe, you will write tests for a Vuex store. Getting ready This recipe requires knowledge from Chapter 7, Unit Testing and End-To-End Testing and familiarity with Vuex; you can get it from the earlier recipes of this chapter.

pages: 284 words: 75,744

Death Glitch: How Techno-Solutionism Fails Us in This Life and Beyond
by Tamara Kneese
Published 14 Aug 2023

Csordas, Thomas J. “Computerized Cadavers: Shades of Being and Representation in Virtual Reality.” In Biotechnology and Culture: Bodies, Anxieties, Ethics, edited by Paul E. Brodwin, 173–93. Bloomington: Indiana University Press, 2001. Daub, Adrian. “The Undertakers of Silicon Valley: How Failure Became Big Business.” Logic Magazine, August 1, 2018. logicmag.io/failure/the-undertakers-of-silicon-valley. Dawdy, Shannon Lee. Patina: A Profane Archaeology. Chicago: University of Chicago Press, 2015. Daws, Ryan. “Research: 90% of US Consumers Own a Smart Home Device.” IoT News, May 15, 2018. iottechnews.com/news/2018/may/15/research-us-consumers-smart-home-device.

pages: 1,409 words: 205,237

Architecting Modern Data Platforms: A Guide to Enterprise Hadoop at Scale
by Jan Kunigk , Ian Buss , Paul Wilkinson and Lars George
Published 8 Jan 2019

Typically, BI and data science organizations have naturally evolved on top of original use cases. The Traditional Approach Let us start with an overview of the traditional solution approach, as shown in Figure 5-1. The data stored in data warehouses mostly originates from the core business use cases, which are sophisticated applications—in our example a web frontend and business logic implemented in a middleware application server. The use cases that run on the application server are each implemented by a team of developers. This could be a webshop, a hotel booking system, or a message board, for example. The BI solution is typically implemented by a separate development team.

As we already mentioned, the data scientist is well versed in coding in third-generation and functional programming languages, such as Scala, Java, and Python, in addition to the domain-specific languages of the classic analytics world. In this function, the data scientist collaborates with development departments to build fully fledged distributed applications that can be productively deployed to Hadoop. The work split could be that the development organization builds the ingest and business logic of the application and maintains the build-and-deployment process, while the data scientist owns and tests the modules and routines that perform the actual learning and modeling algorithms at scale. In order to apply state-of-the-art analytics methods to big data, organizations should ensure that their analyst staff extend their skill sets into these domains and evolve into what we refer to as data scientists.

pages: 219 words: 15,438

The Essays of Warren Buffett: Lessons for Corporate America
by Warren E. Buffett and Lawrence A. Cunningham
Published 2 Jan 1997

This level of tangible assets was adequate to conduct the business without use of debt, except for short periods seasonally. See's was earning about $2 million after tax at the time, and such earnings seemed conservatively representative of future earning power in constant 1972 dollars. Thus our first lesson: businesses logically are worth far more than net tangible assets when they can be expected to produce earnings on such assets considerably in excess of market rates of return. The capitalized value of this excess return is economic Goodwill. In 1972 (and now) relatively few businesses could be expected to consistently earn the 25% after tax on net tangible assets that was earned by See's-doing it, furthermore, with conservative accounting and no financial leverage.

pages: 317 words: 87,566

The Happiness Industry: How the Government and Big Business Sold Us Well-Being
by William Davies
Published 11 May 2015

Once marketing campaigns are being mediated by individuals, in their informal social lives, it quickly becomes plain that certain individuals – well-connected influencers – are more useful instruments of communication than others. In the workplace, the socially connected employee will come to appear more valuable than the more isolated one. The business logic which emerges from this is to be highly generous towards a small minority of already well-connected people, and pay far less attention to everybody else. Celebrities have long had gifts lavished upon them by companies, hoping to have their brands boosted by association. The same process is beginning to apply to social networks: the people who are least in need of this corporate generosity are the most likely recipients of it, and vice versa.

pages: 283 words: 85,824

The People's Platform: Taking Back Power and Culture in the Digital Age
by Astra Taylor
Published 4 Mar 2014

According to Shirky, the television version failed because of excessive bureaucracy and meddling from the Writers Guild: “The critical fact about this negotiation wasn’t about the mothers, or their stories, or how those stories might be used. The critical fact was that the negotiation took place in the grid of the television industry, between entities incorporated around a 20th-century business logic, and entirely within invented constraints. At no point did the negotiation about audience involvement hinge on the question ‘Would this be an interesting thing to try?’ ” Shirky paints the original “In the Motherhood” as a grassroots phenomenon to make a point when it was anything but. The Web series was actually designed and executed by MindShare, the “branded content powerhouse.”

pages: 365 words: 88,125

23 Things They Don't Tell You About Capitalism
by Ha-Joon Chang
Published 1 Jan 2010

These regulations, pro-business commentators argue, not only harmed the large firms but made everyone else worse off by reducing the overall size of the pie to be shared out. By limiting the ability of firms to experiment with new ways of doing business and enter new areas, these regulations slowed down the growth of overall productivity. In the end, however, the folly of this anti-business logic became too obvious, the argument goes. As a result, since the 1970s, countries from all around the world have come to accept that what is good for business is good for the national economy and have adopted a pro-business policy stance. Even communist countries have given up their attempts to stifle the private sector since the 1990s.

pages: 629 words: 83,362

Programming TypeScript
by Boris Cherny
Published 16 Apr 2019

With Angular, you generate component boilerplate with Angular CLI, then fill in the details by hand. An Angular component consists of a few different files: A template, which describes the DOM a component renders A set of CSS styles A component class, which is a TypeScript class that dictates your components’ business logic Let’s start with the component class: import {Component, OnInit} from '@angular/core' @Component({ selector: 'simple-message', styleUrls: ['./simple-message.component.css'], templateUrl: './simple-message.component.html' }) export class SimpleMessageComponent implements OnInit { message: string ngOnInit() { this.message = 'No messages, yet' } } For the most part, this is a pretty standard TypeScript class, with just a few differences that bring out how Angular leverages TypeScript.

pages: 328 words: 84,682

The Business of Platforms: Strategy in the Age of Digital Competition, Innovation, and Power
by Michael A. Cusumano , Annabelle Gawer and David B. Yoffie
Published 6 May 2019

Platform businesses also have different ways of making money, since they may not directly sell a stand-alone product or service. At the same time, though, platforms do not all require “revolutionary” strategies and business models that did not exist before the digital age or that make conventional business logic obsolete.15 Nor is it always useful to think of platform companies simply as “matchmakers” bringing different market actors together, although that is a common function for many platform businesses.16 We also have argued for many years that, in a platform market, having the best platform is more important than having the best product.17 Look at the history of the Apple Macintosh.

Uncomfortably Off: Why the Top 10% of Earners Should Care About Inequality
by Marcos González Hernando and Gerry Mitchell
Published 23 May 2023

We at the top might wish for a more equitable future if those of us in this group thought a little more about [what] our final year of life might be like; often being cared for by people in the lowest 10% pay band in care homes (our successful children having migrated far away).2 If economic structures are not working for the most privileged in our society, then this is a sign that the wider system of reward is not working for anyone. As Mike Savage points out, inequality bothers those with privilege much more now because they cannot use wealth to guarantee their own security in a world they can no longer predict and control: ‘The rules of the game, orientated toward a market-driven business logic (and that have shaped the world since the 1980s) can no longer be taken for granted.’3 What will these structural changes mean for them? As parents, they may be forced to accept that the economy and hiring demands are changing and that includes a hollowing out of middle-class jobs (not to mention current developments in artificial intelligence).

Industry 4.0: The Industrial Internet of Things
by Alasdair Gilchrist
Published 27 Jun 2016

The platform tier is also responsible for managing control data flowing in the other direction, for example, from the enterprise to the edge tiers. It is within the platform tier that we will locate the majority of the functions related to the information and operations domains. The Enterprise Tier The enterprise tier implements the application and business logic for decision support systems and end-user interfaces, such as for operations specialists. This tier hosts most of the application and business domain functions. To get a clearer idea of how this all comes together, consider Figure 4-5. Industry 4.0 Figure 4-5. Three-tier architecture In Figure 4-5, we can see the relationship between functional domains and the three-tier architecture.

pages: 713 words: 93,944

Seven Databases in Seven Weeks: A Guide to Modern Databases and the NoSQL Movement
by Eric Redmond , Jim Wilson and Jim R. Wilson
Published 7 May 2012

Contrast this with the convention of using one general-purpose language throughout a project. This is useful because of the different inherent strengths of languages. A framework like Scala may be better suited for server-side stateless transactions on the Web, but a language like Ruby may be friendlier for business logic. Used together, they create a synergy. A polyglot language system like this was famously used at Twitter. Some of the databases we’ve seen themselves support polyglot programming—Riak supports both JavaScript and Erlang when writing mapreduce, and a single request can execute both. Similar to its language-centric cousin, polyglot persistence is where you can leverage the strengths of many kinds of databases in the same system, as opposed to the currently familiar practice of a single database, probably a relational style.

pages: 297 words: 93,882

Winning Now, Winning Later
by David M. Cote
Published 17 Apr 2020

We mandated that bosses do the actual work of appraising how well their reports were doing. This sparked howls of protest, with leaders claiming they didn’t have time to write up thoughtful performance reviews every year—they were too busy meeting with customers and focusing on strategy. I defended our new policy by taking these leaders through the business logic, in a conversation that went like this: Me:Does having the best people make a difference? Reluctant Leader:Yes. Me:How long does it take to do an appraisal? Reluctant Leader:An hour. Me:How long does it take to give an appraisal? Reluctant Leader:An hour. Me:How many reports do you have?

pages: 285 words: 86,853

What Algorithms Want: Imagination in the Age of Computing
by Ed Finn
Published 10 Mar 2017

This culture machine and the knowledge ontologies it contains impose profound limits on the kinds of intellectual relationships we can have with it, because while Siri can learn from us (by aggregating billions of voice recordings for analysis, for example), we can directly teach it almost nothing. The ontologies are Siri’s secret sauce, the synapses that hold the entire operation together, and they are constructed according to the business logic, legal agreements, and licensing schemes of Apple and its partners. This can lead to failures like Siri responding to the question “where do babies come from” by offering a list of “baby stores” in the area.21 But it also leads to absences and exclusions that can be harder to detect. An invisible ontology does not reveal its seams and edges, but rather is designed to resist exactly that kind of questioning.

pages: 343 words: 91,080

Uberland: How Algorithms Are Rewriting the Rules of Work
by Alex Rosenblat
Published 22 Oct 2018

Under our noses, the company has ushered in a wave of changes touching most aspects of society, be it family life or childcare arrangements, worker conditions or management practices, commuting patterns or urban planning, or racial equality campaigns and labor rights initiatives. Uber’s wide-ranging impacts have not just upset the status quo across society but have also created a future of uncertain implications. The company has harnessed technology to create an entirely new business logic for employment, like Napster did for music and Facebook did for journalism.14 Uber is a symbol of the New Economy, a powerful case study illustrating how digital culture is changing the nature of work.15 RIDING IN CARS WITH “ENTREPRENEURS” For nearly four years, my job has mainly been to ride around in cars with strange men (and sometimes women).16 Studying Uber drivers from mid-2014 through the winter of 2018, I’ve crossed more than twenty-five cities and traversed more than five thousand miles in cars in the United States and Canada, from Juneau to Montreal.

pages: 321 words: 89,109

The New Gold Rush: The Riches of Space Beckon!
by Joseph N. Pelton
Published 5 Nov 2016

The New Space economy thus includes a wide range of new concepts for the global economy that include sustainability, recycling, limiting excesses, and evolving a kinder and more equitable approach to global society. The New Space economy can help steer us toward a new ethos and even a re-envisioning of the life styles of millennials and their children and their children’s children. The Business Logic and Technology for Solar Power Satellite Systems The idea of launching and operating a solar power satellite is far from new. Peter Glaser of Arthur D. Little, the father of solar power satellites, was on the “Cruise beyond Apollo” in 1972. This cruise on the S. S. Statendam was a destination voyage to watch the night launch of Apollo 17, the last launch to the Moon.

pages: 374 words: 94,508

Infonomics: How to Monetize, Manage, and Measure Information as an Asset for Competitive Advantage
by Douglas B. Laney
Published 4 Sep 2017

Preparing for the Real Information Ecosystem Speaking of loops, particularly feedback loops, another way to characterize information’s relative place in the world is as an ecosystem. A supply chain may seem too linear, and even a supply network too static and procedural for today’s (and especially tomorrow’s) more dynamic business environment. Indeed, supply chains/networks change and increasingly run pseudo-autonomously on business logic, embedded analytics, and always-on communication among stakeholders. But do they really evolve? Do they really sense and respond and adapt to both immediate and gradual shifts in their larger environment the way biological ecosystems do? Only if someone coded them that way. Someday soon we will witness an entire supply chain driven by a neural network.

The Internet Trap: How the Digital Economy Builds Monopolies and Undermines Democracy
by Matthew Hindman
Published 24 Sep 2018

One fact often overlooked is that Netflix already had reached the overall level of accuracy they paid one million dollars for. As the contest faq explained, The rmse experienced by customers on the Netflix site is significantly better than the rmse reported for the training dataset. This is due both to the increase in ratings data but also to additional business logic we use to tune which of the large number of ratings to learn from . . . let’s just say we’d be seriously in the running for a Progress Prize, if we were eligible.25 In other words, even at the start of the competition, Netflix was able to do significantly better than the raw CineMatch results indicated.

pages: 327 words: 90,013

Boundless: The Rise, Fall, and Escape of Carlos Ghosn
by Nick Kostov
Published 8 Aug 2022

In 2013, Ghosn had announced that he would move the production of Nissan’s Micra hatchback from India, where the company had recently built a factory, to a Renault plant in France, despite the higher labor costs there. He justified the move by saying it would free up plant capacity in India. But Nissan managers had questioned the business logic, and their engineers complained that Renault factory workers couldn’t be trusted to build their cars. Decision by decision, under a scrutiny motivated by adulation, then curiosity, then skepticism, Saikawa observed the changing tide of tolerance—or lack thereof—for his boss. The quiet, capable manager had grown increasingly aware that Ghosn didn’t have the sway at Renault that he enjoyed in Japan.

pages: 496 words: 174,084

Masterminds of Programming: Conversations With the Creators of Major Programming Languages
by Federico Biancuzzi and Shane Warden
Published 21 Mar 2009

There are other situations where a prototype can be created using no “programming” at all—for example, using a spreadsheet or a set of find and grep commands. The earliest intentions I had for Python were simply for it to be a language to be used in cases where C was overkill and shell scripts became too cumbersome. That covers a lot of prototyping, but it also covers a lot of “business logic” (as it’s come to be called these days) that isn’t particularly greedy in computing resources but requires a lot of code to be written. I would say that most Python code is not written as a prototype but simply to get a job done. In most cases Python is fully up to the job, and there is no need to change much in order to arrive at the final application.

Then you work your way up until finally you have the highest-level word, and you call it go and you type go and everything happens. I have very little faith in systems analysts who work top-down. They decide what the problem is and then they factor it in such a way that it can be very difficult to implement. Domain-driven design suggests describing business logic in terms of the customer’s vocabulary. Is there a connection between building up a vocabulary of words and using the terms of art from your problem domain? Chuck: Hopefully the programmer knows the domain before he starts writing. I would talk to the customer. I would listen to the words he uses and I would try to use those words so that he can understand what the program’s doing.

pages: 471 words: 94,519

Managing Projects With GNU Make
by Robert Mecklenburg and Andrew Oram
Published 19 Nov 2004

The makefile can be a valuable tool for managing this process as previously noted. Of course, the get-file function can be used to automatically select beta or stable, local or remote jars by simply setting the JAR_PATH variable. Enterprise JavaBeans Enterprise JavaBeans™ is a powerful technique to encapsulate and reuse business logic in the framework of remote method invocation. EJB sets up Java classes used to implement server APIs that are ultimately used by remote clients. These objects and services are configured using XML-based control files. Once the Java classes and XML control files are written, they must be bundled together in a jar.

pages: 480 words: 99,288

Mastering ElasticSearch
by Rafal Kuc and Marek Rogozinski
Published 14 Aug 2013

Given all this, when we start designing our queries, we usually go for the simplest query that return the documents we want. However, given all the things we can do in ElasticSearch when it comes to scoring control, such queries return results that are not the best when it comes to user search experience. That's because ElasticSearch can't guess what our business logic is and what documents are the ones that are the best from our point of view when running a query. In this section we will try to follow a real-life example of query relevance tuning. We want to make this chapter a bit different, instead of only giving you insight, we have decided to give you a full example of how query tuning process may look like.

pages: 306 words: 97,211

Value Investing: From Graham to Buffett and Beyond
by Bruce C. N. Greenwald , Judd Kahn , Paul D. Sonkin and Michael van Biema
Published 26 Jan 2004

Of course, if they are sold-even if they are replaced with similar bonds offering better relative value-the loss must be booked immediately. And, just as promptly, published net worth must be adjusted downward by the amount of the loss. Under such circumstances, a great many investment options disappear, perhaps for decades. For example, when large underwriting losses are in prospect, it may make excellent business logic for some insurers to shift from tax-exempt bonds into taxable bonds. Unwillingness to recognize major bond losses may be the sole factor that prevents such a sensible move. But the full implications flowing from massive unrealized bond losses are far more serious than just the immobilization of investment intellect.

pages: 420 words: 100,811

We Are Data: Algorithms and the Making of Our Digital Selves
by John Cheney-Lippold
Published 1 May 2017

It’s important that dead privacy be kept away from its still-breathing relative, because a privacy that protects what writer David Shenk calls the “data smog” expelled by the motors of our online activities would mean a Facebook that can’t profit from that smog’s commodification.102 The current business logic of Facebook, and the rest of the Internet at large, is reliant on us not having/practicing this kind of privacy. We are made legible to Facebook on its own terms—not ours. This is another kind of “terms” of service, one more structural and much less apparent. An asymmetry of terms is what control is about, both offline and online.

pages: 302 words: 100,493

Working Backwards: Insights, Stories, and Secrets From Inside Amazon
by Colin Bryar and Bill Carr
Published 9 Feb 2021

In a 2006 interview by Jim Gray, Amazon CTO Werner Vogels recalled another watershed moment: We went through a period of serious introspection and concluded that a service-oriented architecture would give us the level of isolation that would allow us to build many software components rapidly and independently. By the way, this was way before service-oriented was a buzzword. For us service orientation means encapsulating the data with the business logic that operates on the data, with the only access through a published service interface. No direct database access is allowed from outside the service, and there’s no data sharing among the services.3 That’s a lot to unpack for non–software engineers, but the basic idea is this: If multiple teams have direct access to a shared block of software code or some part of a database, they slow each other down.

pages: 331 words: 95,582

Golden Gates: Fighting for Housing in America
by Conor Dougherty
Published 18 Feb 2020

Whatever rehabs they did were in the name of making things habitable and clean. They turned a profit by buying low and holding the line on costs. But as the foreclosure stock cleared and the demand for rentals grew, investors shifted from fire-sale bargains to buying “value-add” buildings where they could make money by renovating and significantly raising the rents. The business logic is thus: The higher average rents go, the easier it is to find someone to pay the area average. The easier it is to find someone to pay the average, the easier it is to make money by replacing tenants who pay less than average. Commercial real estate brokers describe older complexes as “primed for rent hikes” and will very clinically lay out how affordable buildings with easy-to-evict tenants promise the biggest returns.

pages: 364 words: 104,697

Were You Born on the Wrong Continent?
by Thomas Geoghegan
Published 20 Sep 2011

It’s stunning to me that people from the U.S. come over to look at German “education” and they never see all this adult education—unknown in the U.S.—going on all around them. And why is there even still a newspaper war in 2010? Well, of course it helps that German papers get nice tax breaks. But I’d say there’s a business logic to staying with the printed word, even if the big German dailies have been bleeding money. In a social democracy, collective decisions still matter to people. And if people need half an hour a day to stay up on what’s happening and not just three or four minutes to skim the news online, then it’s just more user-friendly to do it the old Gutenberg way.

Python Geospatial Development - Second Edition
by Erik Westra
Published 23 May 2013

These settings include a list of the applications you want to include in the project, which database to use, as well as various other project- and application-specific settings. As we saw in the previous chapter, a Django application has three main components: The model s define your application's data structures, the views contain your application's business logic, and the templates are used to control how information is presented to the user. These correspond to the data, application, and presentation tiers within a traditional web application stack. Let's take a closer look at each of these in turn. Models Because Django provides an object-relational mapper on top of the database, you don't have to deal with SQL directly.

pages: 459 words: 103,153

Adapt: Why Success Always Starts With Failure
by Tim Harford
Published 1 Jun 2011

But fewer lessons seem to have been learned from a related accident: a meltdown in the financial markets which was triggered by Piper Alpha’s destruction. This was the ‘LMX spiral’, and it nearly destroyed the venerable insurance market Lloyd’s. Insurers often sign contracts in which one insurer agrees to cover another insurer’s extraordinary losses on a particular claim. These ‘reinsurance’ contracts have a sound business logic and a long history. Yet in the Lloyd’s market, where different insurance syndicates traded risk with each other, reinsurers had begun to insure the total losses of other insurers, rather than losses on a single claim. The subtle distinction proved important. The reinsurance contracts pulled losses from one syndicate to a second, then a third – and perhaps then from the third back to the first.

pages: 430 words: 109,064

13 Bankers: The Wall Street Takeover and the Next Financial Meltdown
by Simon Johnson and James Kwak
Published 29 Mar 2010

Large multinational corporations have large, global financing needs, but there are currently no banks that can supply those needs alone; instead, corporations rely on syndicates of banks for major offerings of equity or debt. For example, Johnson & Johnson used eleven banks to manage its most recent debt offering in 2008 (and thirteen banks for the offering before that, in 2007).67 And even if there were a bank large enough to meet all of a large corporation’s financial needs, it would defy business logic for that corporation to restrict itself to a single source of financial services, instead of selecting banks based on their expertise in particular markets or geographies. In addition, U.S. corporations already benefit from competition between U.S. and foreign banks, which can provide identical financial products; there is no reason to believe that the global competitiveness of our nonfinancial sector depends on our having the world’s largest banks.

pages: 370 words: 105,085

Joel on Software
by Joel Spolsky
Published 1 Aug 2004

We have another product in the works that we haven't talked about publicly; this one will share a large portion of its code base with FogBUGZ (a subset we are going to name "Dispatcho") so it will remain VBScript/ASP at heart until we port FogBUGZ. For FogBUGZ/Dispatcho/SecretNewProduct, the plan is: Wait until it's OK to require CLR. Port existing "business logic" classes to C#. Keep current web forms in ASP. Create new web forms in ASP.NET. forty-five PLEASE SIR MAY I HAVE A LINKER? If I were paranoid, I'd say that Microsoft doesn't really want to make development tools for systems or application developers who might compete with their core business; they really just want to make development tools for IT departments building custom vertical software where there's no potential business for Microsoft.

pages: 461 words: 106,027

Zero to Sold: How to Start, Run, and Sell a Bootstrapped Business
by Arvid Kahl
Published 24 Jun 2020

Anyone doing that after teaching for 10 hours non-stop would be mentally exhausted. Find the critical problem where solving a problem takes a long time every time the problem occurs. A Critical Problem Forces People to Solve It Using Their Own System There is the joke that every SaaS is an Excel sheet transformed into business logic. The moment someone uses generic tools like word processors or spreadsheets to solve a problem, it’s an indicator that the problem is valuable enough to build tools. Most problems don’t have high complexity, and they can be solved on the spot. But a critical issue will be complicated enough to start developing a system.

pages: 362 words: 108,359

The Accidental Investment Banker: Inside the Decade That Transformed Wall Street
by Jonathan A. Knee
Published 31 Jul 2006

And, as Purcell liked to show in analyst presentations after the transaction closed in May 1997, the stock of the combined entity did actually outperform its peers through the boom. But the tongue-twisting moniker that emerged from the combination—Morgan Stanley Dean Witter Discover —was emblematic of how awkwardly the cultures of the two firms fit together. The business logic of the combination had been clear from the first time the two companies discussed the possibility—in 1993, the first year that Dean Witter Discover was spun off by Sears as an independent company. For Morgan Stanley, which had traded at a discount compared to its peers since its 1986 IPO because of its relatively volatile earnings, the deal promised both multiple expansion for its stock, and revenue enhancement from the new products that the retail distribution network would allow the investment bank to market more effectively.

pages: 361 words: 107,461

How I Built This: The Unexpected Paths to Success From the World's Most Inspiring Entrepreneurs
by Guy Raz
Published 14 Sep 2020

While Yvon, an avid outdoorsman and bona fide free spirit, has always considered himself a reluctant businessman (it’s in the sub­title of his book), decisions like these were not acts of pure charity. Patagonia’s policy of hiring nannies to go on business trips with employees who are new parents and don’t want to be away from their young children is as much about the importance of family as it is about the value of employee productivity. Policies like this one have a deep business logic, grounded in Yvon’s desire to build a company that will last. “I have probably 70 percent women working for me. I have more women than men in all upper management, and I don’t want to lose them,” he said. “If we are going to be here 100 years, it’s good business.” What makes these policies good business is not simply that they are kind and human gestures, though both things are true.

pages: 1,066 words: 273,703

Crashed: How a Decade of Financial Crises Changed the World
by Adam Tooze
Published 31 Jul 2018

Hobza and S. Zeugner, “The ‘Imbalanced Balance’ and Its Unravelling: Current Accounts and Bilateral Financial Flows in the Euro Area,” European Commission Economic Papers 520 (2014): table A.2. The flow of funds around Europe, as around the global economy, was driven not by trade flows but by the business logic of bankers, who sought out the cheapest funding and the best returns. The upward spiral of asset prices and balance sheets that drove the US boom was even more pronounced in Europe. Between 2001 and 2006, Greece, Finland, Sweden, Belgium, Denmark, the UK, France, Ireland and Spain all experienced real estate booms more severe than those that energized the United States.

They were all in it together. “I don’t really understand why this needs to be confrontational,” he said soothingly.102 The bankers stared at him in disbelief. The core of American financial capitalism was about to be partially nationalized. Beyond the general sense of shock, the reactions came down to business logic. For the weakest in the group it was evidently a great deal, and Vikram Pandit of Citigroup said so. Given the state of his balance sheet, he couldn’t afford to be fussy. As he blurted out: “This is cheap capital.” Indeed, it was. The yield on Citigroup bonds that day was 22 percent. Paulson was asking for 5 percent.103 A better-placed bank, like J.P.

pages: 470 words: 109,589

Apache Solr 3 Enterprise Search Server
by Unknown
Published 13 Jan 2012

The other interesting data point is that in this benchmark, running multiple threads did not offer appreciable greater performance over a single process. This is because the processing logic in threaded_test.rb for building the XML documents was so slight on the client side that having multiple threads didn't help. However, if your indexing script is doing more complex business logic, such as multiple SQL calls (often an issue with the DIH), extracting text from rich documents, or calling external services for operations like entity extraction, in order to build the correct document to be submitted to Solr then using a multi threaded process, or multiple separate processes, will increase index throughput.

pages: 541 words: 109,698

Mining the Social Web: Finding Needles in the Social Haystack
by Matthew A. Russell
Published 15 Jan 2011

Workaround. missing_tweets = [] for (doc_id, in_reply_to_id) in conversation: try: print [rt for rt in reply_tweets if rt['id'] == in_reply_to_id][0]['text'] except Exception, e: print >> sys.stderr, 'Refetching <<tweet %s>>' % (in_reply_to_id, ) results = makeTwitterRequest(t, t.statuses.show, id=in_reply_to_id) print results['text'] # These tweets are already on hand print db.get(doc_id)['text'] print A lot of this code should look familiar by now. With the ability to authenticate into Twitter’s API, store and retrieve data locally, and fetch remote data from Twitter, a lot can be done with a minimal amount of “business logic.” Abbreviated sample output from this script, presented in Example 5-10, follows and shows the flow of discussion between @timoreilly and @n2vip. Example 5-10. Sample output from Example 5-9 Question: If all Ins. Co. suddenly became non-profit and approved ALL Dr. ... @n2vip Don't know anyone who is advocating that.

pages: 421 words: 110,406

Platform Revolution: How Networked Markets Are Transforming the Economy--And How to Make Them Work for You
by Sangeet Paul Choudary , Marshall W. van Alstyne and Geoffrey G. Parker
Published 27 Mar 2016

Thiel and Levchin (along with a third partner, John Bernard Powers, who soon departed) launched Confinity, a startup aimed at enabling money transfers on Palm Pilots and other personal digital assistants (PDAs) equipped with infrared ports. At the time, the Palm Pilot was an exceptionally popular mobile device whose adoption rate was expected to grow, and launching a payment system on a mobile device that people carried with them everywhere made sense. The business logic behind Confinity seemed indisputable. The notion of a payment mechanism that could potentially liberate millions of people from reliance on government-sponsored currency also appealed to the idealistic Thiel’s libertarian streak, much as another ambitious online payment platform—Bitcoin—would fire the imagination of libertarians a decade later.

pages: 514 words: 111,012

The Art of Monitoring
by James Turnbull
Published 1 Dec 2014

We've also started to collect events and metrics to process and visualize. In the last three chapters we've gathered basic host metrics using collectd and set up the collection of logs from our hosts. In this chapter we're going to extend our monitoring and collection to applications. Application and business logic monitoring We're going to focus on three approaches to monitoring applications: Emitting metrics by instrumenting code. Generating structured or semantic log events. Building health checks and endpoints. We'll look at how to embed these methods in your applications and use the resulting measurements and metrics to analyze the performance of your applications.

pages: 350 words: 114,454

Docker: Up & Running: Shipping Reliable Containers in Production
by Sean P. Kane and Karl Matthias
Published 15 Mar 2018

Simple Docker Swarm Mode cluster The next thing you should do is create a default network for your services to use. Again, it’s pretty simple to do that: $ docker -H 172.17.4.1 network create --driver=overlay default-net ckwh5ph4ksthvx6843ytrl5ik Up to this point, we’ve just been getting the underlying pieces running, and so far we haven’t deployed any real business logic. So let’s launch your first service into the clus‐ ter. You can do that with a command like this: $ docker -H 172.17.4.1 service create --detach=true --name quantum \ --replicas 2 --publish published=80,target=8080 --network default-net \ spkane/quantum-game:latest tiwtsbf270mh83032kuhwv07c The service we’re launching with starts containers that host the Quantum web game.

pages: 385 words: 112,842

Arriving Today: From Factory to Front Door -- Why Everything Has Changed About How and What We Buy
by Christopher Mims
Published 13 Sep 2021

A representative for the company continued: “Unfortunately, statistically at this scale, traffic incidents have occurred and will occur again, but these are exceptions, and we will not be satisfied until we achieve zero incidents across our delivery operations.” Subsequent reporting by a variety of news outlets, including Vice, the New York Times, and NBC News, found that whatever Amazon’s protestations about its commitment to safety, the fundamental business logic pushing drivers up to and beyond their limits was in full effect both before and especially during the strained times of the pandemic. As of late 2020, drivers reported they still felt enormous pressure to finish all their deliveries before the end of their shifts, whatever it took. * * * UPS has more than 123,000 vehicles worldwide, and it is inevitable that, every year, some are involved in fatal accidents.

pages: 386 words: 116,233

The Millionaire Fastlane: Crack the Code to Wealth and Live Rich for a Lifetime
by Mj Demarco
Published 8 Nov 2010

They flushed money down the toilet as if there were an endless supply. Do we really need custom-branded water bottles? And logo T-shirts? Are these revenue generating actions? Decisions were made slowly and by committee. Customers were ignored. Incredulously, most of the company's executive management had Harvard MBAs, proof that the business logic doesn't come with expensive initials after your name. Despite having $12 million in venture capital to buoy the storm, my Web site slowly started to die. A few months later, near the cliff of bankruptcy, it was voted that my Web site would be dissolved, even though it was still profitable. Tech buyers dried up and stocks were in the tank.

pages: 464 words: 121,983

Disaster Capitalism: Making a Killing Out of Catastrophe
by Antony Loewenstein
Published 1 Sep 2015

The federal business is the best business for us. It’s the most consistent business for us and the events of September 11 are increasing that level of business.”11 Little has changed since, except that more people are in detention. Prisons for criminals and facilities for immigrants were separate, and yet the business logic behind them was the same. Ironically, despite the rhetoric of privatization advocates praising the wonders of the market, firms like CCA and Geo Group are leeching off government contracts.12 In 2014, CCA was caught falsifying staff hours to boost its profits in Idaho. The company escaped with a minor fine.13 It remains the country’s largest private prison contractor.

pages: 351 words: 123,876

Beautiful Testing: Leading Professionals Reveal How They Improve Software (Theory in Practice)
by Adam Goucher and Tim Riley
Published 13 Oct 2009

We knew our best return on investment (ROI) would be from automating tests at the unit level. We were keen to do the bulk of our functional test automation “behind” the GUI, and had chosen FitNesse as the tool to accomplish this. FIGURE 15-3. Test automation pyramid Our immediate problem was a huge, buggy legacy system where the presentation, business logic, and database layers were intertwined. The fastest way to get some automated regression test coverage was through the GUI. But GUI tests are notoriously brittle and hard to maintain. We had to find good tools to help us achieve a reasonable ROI. Choosing Tools by Team Consensus Since our entire development team takes responsibility for quality and for making sure all testing activities are successfully completed for each release, we choose tools as a team.

pages: 320 words: 87,853

The Black Box Society: The Secret Algorithms That Control Money and Information
by Frank Pasquale
Published 17 Nov 2014

Facebook hires people to assess the appropriateness of user-shared content; it’s no great burden upon the social networking behemoth to ask its human reviewers to stop algorithmic recommendations of obviously racist stories.25 Google runs proposed algorithmic changes by human testers, who not only choose the web pages that work best, but explain why. Such interventions are already an essential part of the business logic of these companies; they can equally be part of their response to legal norms and obligations.26 And when the technology really does outstrip policymakers’ understanding, they can hire experts to bridge the gap. A government attorney has already hired Silicon Valley’s Palantir to go after Wall Street crooks; it’s time for more law enforcers to follow his lead.27 Scale Fails: In Wall Street valuations, attaining scale at great speed is critical to attracting speculative capital.

Text Analytics With Python: A Practical Real-World Approach to Gaining Actionable Insights From Your Data
by Dipanjan Sarkar
Published 1 Dec 2016

This completes the list for Python’s core data types and data structures that you will be using most of the time in your code and implementations. We will now discuss some constructs typically used for controlling the flow of code. Controlling Code Flow Flow of code is extremely important. A lot of it is based on business logic and rules. It also depends on the type of implementation decisions developers take when building systems and applications. Python provides several control flow tools and utilities that can be used to control the flow of your code. Here are the most popular ones: if-elif-else conditionals for loop while loop break, continue, and else in loops try-except These constructs will help you understand several concepts including conditional code flow, looping, and handling exceptions.

User Friendly: How the Hidden Rules of Design Are Changing the Way We Live, Work & Play
by Cliff Kuang and Robert Fabricant
Published 7 Nov 2019

Yet the surprising thing revealed at Disney World was that when we see the same ease applied not just on our phones but in the environment around us, we usually shrug and dig into our roast beef sandwiches. This is the reason the MagicBands might have been worth $1 billion to Disney. Using them, the company had managed to recast its cold business logic—the chance to turn over tables quicker by eliminating many aspects of waiter service—into something a vacationing family of three had actually described as magic. Somehow, Disney World had turned a high-tech surveillance operation into a delight. When the MagicBands were being designed, that alchemy seemed to afford endless possibilities.

pages: 385 words: 123,168

Bullshit Jobs: A Theory
by David Graeber
Published 14 May 2018

There have always been smart students or graduates willing to pick up a little cash writing term papers for lazy classmates, but in America in recent decades, this has coalesced into an entire industry, coordinated on a national level, employing thousands of full-time paper writers. One of them suggested to me that the industry was the predictable result of the convergence of credentialism—the fact that one now needed a degree of some kind to gain access to almost all desirable jobs in America—and business logic. Barry: When I first started this work, I imagined I would be constantly learning fascinating, new information about a broad array of subjects. While I have had the opportunity to write the rare, interesting essay on queer theory or the history of Roman blood sport, I’ve found that I’m largely writing countless papers about business and marketing.

pages: 480 words: 122,663

The Art of SQL
by Stephane Faroult and Peter Robson
Published 2 Mar 2006

Further, do not forget that if your purpose is to update or insert rows (a frequent case when rows are counted first to check whether the key already exists), some database systems provide dedicated statements (for instance, Oracle 9i Database's MERGE statement) that operate far more efficiently than you can ever achieve by executing redundant counts. Important There is no need to code explicitly what the database performs implicitly. SQL Statements Mirror Business Logic Most database systems provide monitoring facilities that allow you to check statements currently being executed , as well as to monitor how many times they are executed. At the same time, you should have an idea of how many "business units" are being processed—activities such as orders or claims to be processed, customers to be billed, or anything else that makes sense to the business managers.

pages: 515 words: 126,820

Blockchain Revolution: How the Technology Behind Bitcoin Is Changing Money, Business, and the World
by Don Tapscott and Alex Tapscott
Published 9 May 2016

Congress had a lower score.14 In the preblockchain world, trust in transactions derived from individuals, intermediaries, or other organizations acting with integrity. Because we often can’t know our counterparties, let alone whether they have integrity, we’ve come to rely on third parties not only to vouch for strangers, but also to maintain transaction records and perform the business logic and transaction logic that powers commerce online. These powerful intermediaries—banks, governments, PayPal, Visa, Uber, Apple, Google, and other digital conglomerates—harvest much of the value. In the emerging blockchain world, trust derives from the network and even from objects on the network.

pages: 349 words: 134,041

Traders, Guns & Money: Knowns and Unknowns in the Dazzling World of Derivatives
by Satyajit Das
Published 15 Nov 2006

Some banks, including many Japanese banks, were late entrants into the new game of swaps. First, they paid exorbitant sums to attract suitable derivatives staff – only swaps royalty need apply – then, they bought their way into the cabal. They heavily subsidized borrowers to buy market share. The gaijin – non-Japanese – loved the hara-kiri swaps. The business logic was strange. People dealt with you because they were paid to do so. Why would they deal with you when you stopped paying? The hunt for arbitrage opportunities went on. At SEK, the hunt took on an entirely literal dimension. Bernt, it emerged, was a keen hunter in real life, going on trips to the north of Scandinavia to hunt real wild animals.

pages: 407 words: 135,242

The Streets Were Paved With Gold
by Ken Auletta
Published 14 Jul 1980

.…” The plan proposed to shift Manhattan’s economic base from light industry to office towers. It was silent about the subway system and largely ignored the issue of mass transportation. It was this plan that was later followed and supplemented by Robert Moses. Manhattan real-estate values soared, and roads cut wide swatches through neighborhoods. There was business logic to the plan. From a profit-making point of view, the crowded lofts and tenements and small factories were inefficient. Greater profits could be generated from high-rise buildings housing many more rent-paying tenants and businesses. The highways made for cheaper truck transportation. In a free economy, it was not surprising to see landlords and developers act in their own interest.

pages: 457 words: 143,967

The Bank That Lived a Little: Barclays in the Age of the Very Free Market
by Philip Augar
Published 4 Jul 2018

He told him that he had been given authority by the board to go further but that Barclays would not buy Lehman’s book of mortgages or real estate assets and would require the US authorities to provide Barclays with sufficient liquidity to meet Lehman’s trading obligations. Sants understood the business logic but reminded Varley that Barclays would need to demonstrate that it had sufficient capital and liquidity to satisfy the FSA stress tests after any acquisition.21 In fact the FSA was one of three public bodies keeping an eye on Barclays. During the afternoon Sants liaised with Tom Scholar, director general of financial services at the Treasury, and Sir John Gieve, one of the deputy governors at the Bank of England.

pages: 460 words: 130,820

The Cult of We: WeWork, Adam Neumann, and the Great Startup Delusion
by Eliot Brown and Maureen Farrell
Published 19 Jul 2021

He borrowed money from his sister, raised more from a wealthy hedge fund manager she was dating, and invested $100,000 he’d received from his grandmother. Neumann knew little about children. He was young and single, and his time was dominated by working, drinking with friends, chain-smoking cigarettes, and churning through dates with different women. And the business logic of Krawlers had obvious holes: typically babies crawl for only a period of months. Yet Neumann proved to be a gifted salesman, particularly when face-to-face with a potential buyer. At trade shows where many of the clothes were sold, Neumann was a magnet for the small-business owners.

Machine Learning Design Patterns: Solutions to Common Challenges in Data Preparation, Model Building, and MLOps
by Valliappa Lakshmanan , Sara Robinson and Michael Munn
Published 31 Oct 2020

When the entire codebase is inextricably linked, it becomes difficult for individual developers to debug errors and work independently on different parts of the application. In recent years, monolithic apps have been replaced in favor of a microservices architecture where individual pieces of business logic are built and deployed as isolated (micro) packages of code. With microservices, a large application is split into smaller, more manageable parts so that developers can build, debug, and deploy pieces of an application independently. This monolith-versus-microservice discussion provides a good analogy for scaling ML workflows, enabling collaboration, and ensuring ML steps are reproducible and reusable across different workflows.

pages: 433 words: 130,334

Docker: Up & Running: Shipping Reliable Containers in Production
by Sean Kane and Karl Matthias
Published 14 May 2023

There is a default network called ingress in Swarm, but it is very easy to create additional ones for better isolation: $ docker -H 172.17.4.1 network create --driver=overlay default-net ckwh5ph4ksthvx6843ytrl5ik $ docker -H 172.17.4.1 network ls NETWORK ID NAME DRIVER SCOPE 494e1a1bf8f3 bridge bridge local xqgshg0nurzu default-net overlay swarm 2e7d2d7aaf0f docker_gwbridge bridge local df0376841891 host host local n8kjd6oa44fr ingress overlay swarm b4720ea133d6 none null local Up to this point, we’ve just been getting the underlying pieces running, and so far we haven’t deployed any real business logic. So let’s launch your first service into the cluster. You can do that with a command like this: $ docker -H 172.17.4.1 service create --detach=true --name quantum \ --replicas 2 --publish published=80,target=8080 --network default-net \ spkane/quantum-game:latest tiwtsbf270mh83032kuhwv07c The service we’re launching with starts containers that host the Quantum game.

pages: 642 words: 141,888

Like, Comment, Subscribe: Inside YouTube's Chaotic Rise to World Domination
by Mark Bergen
Published 5 Sep 2022

Venture capitalists went wild for “web3,” an internet model based on cryptocurrencies that imagined regular people owning and profiting from their online activity; this was YouTube’s creator economy taken to its next extreme. Sequoia, YouTube’s first investor, minted its 2005 YouTube investment memo as a “non-fungible token,” which a crypto enthusiast purchased for $863,000 in digital coin. There was business logic behind this rush to embrace creators. The pandemic turbocharged online entertainment and commerce. At the same time, the Web 2.0 model of targeted advertising was being dismantled by regulators; companies had a harder time marketing things online. Creators were great marketers and salespeople.

Advanced Software Testing—Vol. 3, 2nd Edition
by Jamie L. Mitchell and Rex Black
Published 15 Feb 2015

No longer is the automation team held hostage by a particular tool that may become an orphan because a tool company decided to deprecate it. 6.2.4.4 Creating Keyword-Driven Tables Exercise Refer to the pseudo code recorded script as seen in Figure 6–3. This is the same code we saw in Figure 6–2. Devise a keyword grammar that could be used to test this portion of the application. Note that you will need to use your imagination a bit to figure out what the recorded script is doing. The important thing is to look for the underlying business logic while reading the actions. Figure 6–3 Recorded WinRunner script 6.2.4.5 Keyword-Driven Exercise Debrief The first six lines of this script could be seen as a single action. Note that the following would be a description of a human being (assume a doctor) interacting with the application using the keyboard and mouse: The doctor must have started the application earlier, causing a password dialog screen to pop up.

The First Tycoon
by T.J. Stiles
Published 14 Aug 2009

At Stone's urging, he met with Vanderbilt that evening in the Manhattan Club, where they began a long, frustrating, but fruitful relationship. The power of attraction worked both ways. Vanderbilt could be solicitous as well as commanding; Rockefeller himself wrote, “He is anxious to get our business, and said thought he could meet us on the terms.”5 Within the railroad industry, too, business logic demanded that the Commodore build close relationships with lines to the west. Previously freight from Chicago, Detroit, or Cleveland went by boat over the Great Lakes to Buffalo; now trains hauled most of it. The connecting lines needed to cooperate to coordinate schedules, set rates, divide costs, and allow freight to move without breaking bulk if at all possible.

More broadly, it represented the abandonment of the older, local purposes which had first brought railways into existence, as a truly national network emerged. No longer semipublic bodies, railroads now functioned entirely as business enterprises, operated for maximum profit, bought and sold in the market, managed as business logic would dictate. That logic led inexorably to consolidation. The day of the giant corporation had arrived. On May 20, Governor Hoffman signed both bills into law. In one day Vanderbilt nearly doubled the capitalization of his largest company and opened the door to increase it another 50 percent by annexing the Hudson River.

pages: 603 words: 141,814

Python for Unix and Linux System Administration
by Noah Gift and Jeremy M. Jones
Published 29 Jun 2009

This Model-View-Template approach is similar, if not identical, to a common approach called Model-View-Controller (MVC). Both are ways of developing applications so that the pieces of the application are not unnecessarily comingled. The database code is separated into an area referred to in both approaches as the “model.” The business logic is separated into an area referred to as the “view” in MVT and the “controller” in MVC. And the presentation is separated into an area referred to as the “template” in MVT and the “view” in MVC. Apache Log Viewer Application In the following example, which consists of several pieces of code, we will create another implementation of the Apache log viewer similar to the PyGTK implementation.

Data Wrangling With Python: Tips and Tools to Make Your Life Easier
by Jacqueline Kazil
Published 4 Feb 2016

Initializes our Manager object, which helps manage shared items and logging across processes. Creates a shared list object to keep track of what sites are up. Each of the pro‐ cesses will have the ability to alter this list. Creates a shared lock object to stop and announce if we encounter a site that is not up. If these were all sites we managed, we might have an important bit of business logic here for emergencies and therefore a reason to “stop everything.” Starts each of the processes returned by get_procs individually. Once they are started, join allows the Manager object and therefore all the child processes to communicate until the last one is finished. When using multiprocessing, you usually have a manager process and child pro‐ cesses.

pages: 565 words: 151,129

The Zero Marginal Cost Society: The Internet of Things, the Collaborative Commons, and the Eclipse of Capitalism
by Jeremy Rifkin
Published 31 Mar 2014

As Yerdle grows, it will allow its local networks to expand geographically, so items can be sold to strangers as well as to friends. Yerdle plans on taking a small transaction fee to cover its operational costs. The Yerdle plan, like so many others, helps advance the idea of a circular economy in which everything is recycled and reused and nothing is sent to the landfill before its time. The sustainable business logic makes perfect sense, but gets muddled when the founders try to make the case for the retailer’s buy-in. Werbach says that “if you can borrow that chain saw from the person next door, the retailer’s job is to help you with what you’re trying to do, not just sell you another chain saw.”45 Maybe . . . but likely?

pages: 559 words: 155,372

Chaos Monkeys: Obscene Fortune and Random Failure in Silicon Valley
by Antonio Garcia Martinez
Published 27 Jun 2016

Like the dinosaur fossils at a natural history museum, they’re there only for show. They’ve been replaced by expensive blinking boxes housed as close as possible to the real exchange, and connected with the shortest cables one can buy, rent, or bury in the ground. In this new world, the only speed limits were Moore’s law and Einstein’s relativity: the business logic was as fast as microchips can do math without melting themselves, and as fast as pulses of light can fly through fiber-optic cables. The key insight here is that what happened with SLK wasn’t some exceptional niche piece of technological innovation, but a harbinger of what would happen to the entire world.

The Cigarette: A Political History
by Sarah Milov
Published 1 Oct 2019

See also doubt-mongering Reemtsma, 158 referenda, 61–66, 69, 77, 84–85 Reich, Charles, 120–125, 284, 369n122 Reich, Robert, 281 Repace, James, 225–230, 280, 358n86 Reynolds v. Sims, 139 Richardson, Elliott, 195 Richmond, Julius, 195 Richmond Times-Dispatch, 115 RICO act, 290 Riggs, “Speed,” 30 rights: administrative agencies and, 122, 163; business logic and, 209–211; consumerism and, 143–145, 159, 189–195; gendered activism and, 175–184; localism and, 260–269, 285–287; “New Property” and, 121–125; nonsmokers as protected class and, 2–3, 10, 160–162, 173–175, 188–200, 211–214, 232, 306n48; paradoxes of, 160–162; quality of life discourse and, 184–188, 230–231, 306n48; race and, 199–200; unions and, 232–240; workplace battles and, 201–221 right to work laws, 332n132 R.

pages: 523 words: 154,042

Fancy Bear Goes Phishing: The Dark History of the Information Age, in Five Extraordinary Hacks
by Scott J. Shapiro

Vertical Integration In the hit NBC comedy 30 Rock, the corporate executive Jack Donaghy (played by Alec Baldwin) tries to explain to one of his head writers, Liz Lemon (played by Tina Fey), the economic concept of vertical integration: “Imagine that your favorite corn chip manufacturer also owned the number one diarrhea medication.” Liz’s eyes light up. “That’d be great ’cause then they could put a little sample of medication in each bag.” Jack can see that Liz does not fully appreciate the business logic. “Keep thinking.” Liz turns the idea over in her mind as she works out the economics. “Except then they might be tempted to make the corn chips give you…” Jack smiles. “Vertical integration.” Although Donaghy called it “vertical integration,” lawyers have traditionally used another term: racketeering.

pages: 483 words: 145,225

Rebel Code: Linux and the Open Source Revolution
by Glyn Moody
Published 14 Jul 2002

Promotion of his company is surprisingly restrained, although Young is always happy to don his trademark red hat for photo shoots: “I have a business card that reads Red Hat Spokesmodel,” he says in gentle self-mockery. But his apparently selfless devotion to the broader cause of open source has some hard-headed business logic behind it. “The moment we get across this point that Red Hat’s brand stands for this commitment of delivering open source technology to the marketplace, then we create massive opportunities for Red Hat’s sales team,” he says. “If I can’t do that, it doesn’t matter how much our sales team brag about their products being better, faster, and cheaper, the customer is going to say, ‘I can buy it from little Red Hat or I can buy it from big, safe Sun, or Microsoft’ and we’re going to end up losing the bid.”

pages: 504 words: 89,238

Natural language processing with Python
by Steven Bird , Ewan Klein and Edward Loper
Published 15 Dec 2009

This inference seems so obvious that you probably didn’t notice it was made, yet a natural language system needs to be endowed with this capability in order to interact naturally. Without it, when asked, Do you know when Saving Private Ryan is playing?, a system might unhelpfully respond with a cold Yes. However, the developers of commercial dialogue systems use contextual assumptions and business logic to ensure that the different ways in which a user might express requests or provide information are handled in a way that makes sense for the particular application. So, if you type When is ..., or I want to know when ..., or Can you tell me when ..., simple rules will always yield screening times.

Debtor Nation: The History of America in Red Ink (Politics and Society in Modern America)
by Louis Hyman
Published 3 Jan 2011

Credit card debt was unsecured by any claim on real property, while the installment debt of mortgages was secured by a claim on unmovable property. While these two different financial practices—borrowing against a home’s value and borrowing on SECURING DEBT 221 a credit card—appeared very different for consumers, the business logic and financial practices that underpinned them both grew more and more similar over time. By the late 1980s, these two different debts converged and become financially indistinguishable in how they were funded—by asset-backed securities. By the mid-1990s, even consumers began to use home mortgages and credit cards interchangeably, consolidating the debt of credit cards into the debt of mortgages.

Programming Python
by Mark Lutz
Published 5 Jan 2011

PythonCard describes itself as a GUI construction kit for building cross-platform desktop applications on Windows, Mac OS X, and Linux, using the Python language. Dabo An open source GUI builder also built on wxPython, and a bit more. Dabo is a portable, three-tier, cross-platform desktop application development framework, inspired by Visual FoxPro and written in Python. Its tiers support database access, business logic, and user interface. Its open design is intended to eventually support a variety of databases and multiple user interfaces (wxPython, tkinter, and even HTML over HTTP). Rich Internet Applications (RIAs) Although web pages rendered with HTML are also a kind of user interface, they have historically been too limited to include in the general GUI category.

Response page created by tutor5.py (2) Keeping display and logic separate In fact, this illustrates an important point in the design of larger websites: if we are careful to keep the HTML and script code separate, we get a useful division of display and logic—each part can be worked on independently, by people with different skill sets. Web page designers, for example, can work on the display layout, while programmers can code business logic. Although this section’s example is fairly small, it already benefits from this separation for the input page. In some cases, the separation is harder to accomplish, because our example scripts embed the HTML of reply pages. With just a little more work, though, we can usually split the reply HTML off into separate files that can also be developed independently of the script’s logic.

For instance, systems such as PHP, Python Server Pages (PSP), Zope’s DTML and ZPT, and Active Server Pages provide server-side templating languages, which allow scripting language code to be embedded in HTML and executed on the server, to dynamically generate or determine part of the HTML that is sent back to a client in response to requests. The net result can cleanly insulate Python code from the complexity of HTML code and promote the separation of display format and business logic, but may add complexities of its own due to the mixture of different languages. Generalized user interface development To cover both bases, some systems attempt to separate logic from display so much as to make the choice almost irrelevant—by completely encapsulating display details, a single program can, in principle, render its user interface as either a traditional GUI or an HTML-based web page.

PostGIS in Action
by Regina O. Obe and Leo S. Hsu
Published 2 May 2015

If your database is trigger-happy, we recommend developing a convention for naming your triggers to keep them organized. We’ll now move on to a series of examples showcasing how you can use triggers in a variety of situations to fortify your data model. Triggers are powerful tools, and your mastery of them will allow you to develop database applications that can control business logic without the need to touch the front-end application. Redirecting inserts with BEFORE triggers For our first trigger example, we’ll demonstrate how to redirect inserts on a parent table to the child tables. This is a common need when working with inherited tables. Recall that in an inheritance hierarchy with abstract parents, you want people to think they’re inserting into the parent table, but you don’t want any data going into it.

pages: 716 words: 192,143

The Enlightened Capitalists
by James O'Toole
Published 29 Dec 2018

To preserve what is unique in their culture, Tom’s of Maine’s managers would find it necessary to engage in “uneconomical” practices, and occasionally put meeting their subsidiary’s long-term social mission ahead of reaching Colgate’s short-term financial goals. Those uneconomical practices represent what Waddock calls a “fairly radical departure from mainstream business logic,”76 and she doubts that large corporations are capable of dealing with such deviations from the norm. Thus large companies must eventually force their “iconic” acquisitions into the corporate mold, in the process losing the very “quirky” factors that made the acquired company attractive to them.

pages: 933 words: 205,691

Hadoop: The Definitive Guide
by Tom White
Published 29 May 2009

The abstraction from the storage layer and ACID requirements are an enormous barrier and luxury that you cannot always afford when building for scale. HBase is a distributed, column-oriented, sorted map store and not much else. The only major part that is abstracted from the user is the distribution, and that’s exactly what we don’t want to deal with. Business logic, on the other hand, is very specialized and optimized. With HBase not trying to solve all of our problems, we’ve been able to solve them better ourselves and rely on HBase for scaling our storage, not our logic. It was an extremely liberating experience to be able to focus on our applications and logic rather than the scaling of the data itself.

pages: 678 words: 216,204

The Wealth of Networks: How Social Production Transforms Markets and Freedom
by Yochai Benkler
Published 14 May 2006

Someone represents a party or widely known opinion, and is juxtaposed with others who similarly represent alternative widely known views. These avatars of public opinion then enact a clash of opinion, orchestrated in order to leave the media neutral and free of blame, in the eyes of their viewers, for espousing an offensively partisan view. Third, and finally, this business logic often stands in contradiction to journalistic ethic. While there are niche markets for high-end journalism and strong opinion, outlets that serve those markets are specialized. Those that cater to broader markets need to subject journalistic ethic to business necessity, emphasizing celebrities or local crime over distant famines or a careful analysis of economic policy. 368 The basic drive behind programming choices in advertising-supported mass media was explored in the context of the problem of "program diversity" and competition.

The Art of Scalability: Scalable Web Architecture, Processes, and Organizations for the Modern Enterprise
by Martin L. Abbott and Michael T. Fisher
Published 1 Dec 2009

You can see that there are around 125 requests per second at peak for the Web servers. There are also around 80 requests per second at peak for the application servers. The reason for the difference is that there are a lot of preprocessed static pages on the Web servers that do not require any business logic computations to be performed. These pages include corporate pages, landing pages, images, and so on. You could make an argument that different types of pages scale differently and should be put on a different set of Web servers or at a minimum be analyzed differently for capacity planning. For simplicity of this example, we will continue to group them together as a total number of requests.

PostGIS in Action, 2nd Edition
by Regina O. Obe and Leo S. Hsu
Published 2 May 2015

If your database is trigger-happy, we recommend developing a convention for naming your triggers to keep them organized. We’ll now move on to a series of examples showcasing how you can use triggers in a variety of situations to fortify your data model. Triggers are powerful tools, and your mastery of them will allow you to develop database applications that can control business logic without the need to touch the front-end application. REDIRECTING INSERTS WITH BEFORE TRIGGERS For our first trigger example, we’ll demonstrate how to redirect inserts on a parent table to the child tables. This is a common need when working with inherited tables. Recall that in an inheritance hierarchy with abstract parents, you want people to think they’re inserting into the parent table, but you don’t want any data going into it.

Designing Data-Intensive Applications: The Big Ideas Behind Reliable, Scalable, and Maintainable Systems
by Martin Kleppmann
Published 17 Apr 2017

In some ways, services are similar to databases: they typically allow clients to submit and query data. However, while databases allow arbitrary queries using the query lan‐ guages we discussed in Chapter 2, services expose an application-specific API that only allows inputs and outputs that are predetermined by the business logic (applica‐ tion code) of the service [33]. This restriction provides a degree of encapsulation: services can impose fine-grained restrictions on what clients can and cannot do. A key design goal of a service-oriented/microservices architecture is to make the application easier to change and maintain by making services independently deploya‐ ble and evolvable.

pages: 1,237 words: 227,370

Designing Data-Intensive Applications: The Big Ideas Behind Reliable, Scalable, and Maintainable Systems
by Martin Kleppmann
Published 16 Mar 2017

In some ways, services are similar to databases: they typically allow clients to submit and query data. However, while databases allow arbitrary queries using the query languages we discussed in Chapter 2, services expose an application-specific API that only allows inputs and outputs that are predetermined by the business logic (application code) of the service [33]. This restriction provides a degree of encapsulation: services can impose fine-grained restrictions on what clients can and cannot do. A key design goal of a service-oriented/microservices architecture is to make the application easier to change and maintain by making services independently deployable and evolvable.

pages: 1,230 words: 357,848

Andrew Carnegie
by David Nasaw
Published 15 Nov 2007

To cover the costs of moving empty cars back to Connellsville, it had raised the freight rates to Pittsburgh. With a stranglehold on three quarters of the coke traffic to Pittsburgh and no real competition, the Pennsylvania could charge whatever it chose to. While Carnegie fully understood the business logic behind the Pennsylvania’s “discriminatory” practices, he cried foul nonetheless and threatened to wreak havoc if the railroad did not do right by his and other Pittsburgh firms. “We do not agree to be singled out & discriminated against,” he wrote Thomson. “Every manfr. in Pittsburgh & in the West will rise in indignation.