Seaside: a Flexible Environment for Building Dynamic Web Applications

Total Page:16

File Type:pdf, Size:1020Kb

Seaside: a Flexible Environment for Building Dynamic Web Applications focusdynamically typed 1 languages Seaside: A Flexible Environment for Building Dynamic Web Applications Stéphane Ducasse, Université de Savoie Adrian Lienhard and Lukas Renggli, University of Bern, Switzerland age-centric Web development structures an application into indi- The Seaside vidual scripts, each responsible for processing a user request and framework generating a response. Links pass control from one script to the provides a uniform, next. This imposes a go-to hardwiring of the control flow because pure object-oriented P each page must know what comes next. Although software developers have view for Web long considered go-to statements harmful,1 they are still present in today’s applications. mainstream frameworks, and they hamper the reuse of pages in different parts Exploiting Smalltalk’s of the application. Another issue with Web ap- approaches provide mechanisms to model con- plication frameworks is the limited support trol flow over several pages with one piece of reflective features, they provide for composing multiple parts on code.3–5 WebObjects, Ruby on Rails, Google Seaside reintroduces the same page. The client-server relationship’s Web Toolkit, and .NET, on the other hand, of- stateless nature requires passing the current fer better abstractions by composing an appli- procedure call state back and forth between browser and cation from components, but they fail to model abstraction in server, inevitably leading to undesired coupling control flow at a high level. With any solution, between these parts. combining multiple simultaneous flows inside a client-server Recent Web application frameworks have the same page is difficult. context. tackled both of these problems. JWIG (Java In this article, after briefly discussing the key Extensions for High-Level Web Service Devel- challenges of modern Web application develop- opment),2 RIFE (Full-Stack Open Source Java ment, we present Seaside (www.seaside.st), a Web Application Framework), Jakarta Struts, highly dynamic framework for developing Web and JBoss SEAM (Web 2.0 Application Frame- applications in Smalltalk. By exploiting Small- work) solutions model control flow explicitly. talk’s dynamic nature and reflective capabili- However, most of these approaches don’t inte- ties, Seaside offers a unique way to have multi- grate well with the rest of the code, because it’s ple control flows active simultaneously on the necessary to specify the flow in external XML same page. Furthermore, there’s no need to re- page-flow specifications or to use a different compile and restart Seaside application servers programming language. Continuation-based after each modification. Web developers can 56 IEEE SOFTWARE Published by the IEEE Computer Society 0740-7459/07/$25.00 © 2007 IEEE debug and update applications on the fly, thus between the client and server to provide the il- reducing development time considerably. lusion of developing a desktop application. Smalltalk’s reflective capabilities make this Web development challenges high abstraction level possible. Smalltalk is a To bring Web application development to uniform language that applies simple princi- the same level as desktop application develop- ples systematically. In Smalltalk, everything is ment, a Web development environment or lan- an object—an instance of a class. Objects ex- guage should offer the following key features: clusively communicate through message pass- First, it should have reusable and compos- ing. In addition, Smalltalk supports closures, able components. A Web application logically anonymous functions that can be passed contains reusable components—input forms, around, stored in variables, or executed at a sortable reports, and so on. Building applica- later time. tions from reusable parts is natural. In addition, Smalltalk is written in itself and offers pow- these components should define their own con- erful reflective capabilities: structural as well trol flow. Composing new components out of as behavioral reflection.7 We limit our brief several other components, each having a differ- overview to the reflective capabilities that en- ent flow, should be easy to achieve. able creating a powerful Web development Second, it needs to produce valid XHTML. framework that offers multiple control flow Producing valid XHTML code and connecting composition, hot debugging, and hot recompi- it to the application logic is difficult, especially if lation. The reflective features of Smalltalk are the XHTML code and application logic must be comparable to those of the Common Lisp Ob- developed in different environments. Template- ject System (CLOS),8 except that Smalltalk of- based XHTML generation lacks the host lan- fers full access to the execution stack. These guage’s power and expressiveness. Seamless in- features include the following: tegration of development tools is often missing. Third, it should enable hot debugging. Effi- I Shape and class changing. Objects are in- ciently identifying bugs is a major challenge for stances of classes. When the class changes Web developers. Web applications are becom- (that is, when instance variables are added, ing increasingly more complex, and the charac- renamed, or removed), Smalltalk automat- teristics of client-server interaction make de- ically migrates all instances of the class. bugging more complicated, especially because I On-the-fly recompilation. Developers can advanced debugging support is often missing in define and recompile methods on the fly. A today’s mainstream approaches. The ability to changed method’s currently active execu- hot-debug exceptions and use break points tion contexts run to completion using the would speed up productivity considerably. old definition. Once a problem was fixed, the session could re- I Stack reification. In addition to self and sume at the place where it had left off. There super, Smalltalk offers a third pseudovari- should be no need to restart and navigate to the able, thisContext, which represents the problematic part of the application continually. execution stack on demand. For efficiency, Fourth, it should support hot recompilation. Smalltalk reifies the stack (that is, makes it On-the-fly method recompilation—that is, re- an object) only when the pseudovariable is compiling a method while the application is run- used. This object is causally connected to ning—is important because it lets developers up- the stack it represents. Therefore, not only date the code without restarting the session. does this object represent the stack, but any This is especially beneficial for Web develop- change made to the object reflects onto the ment because it avoids time-consuming edit- execution stack itself. Hence, developers compile-run cycles. Hot recompilation is a nec- can manipulate the stack to change the pro- essary requirement for hot-debugging support. gram’s execution. For a more in-depth presentation of these problems, please see our previous work.6 Seaside’s key features Seaside is open source, and many applica- Smalltalk’s reflective capabilities tions have used it since the first version of it Seaside introduces an abstraction layer was released in 2002. Originally written by Avi over the asynchronous interaction protocol Bryant (a consultant at the time, and now September/October 2007 IEEE SOFTWARE 57 I Programmatic XHTML generation. Fol- TodoFilterView lowing Smalltalk’s principle of treating http:/ / localhost/seaside/todo everything as an object, Seaside provides a TodoApplication very different approach to XHTML gener- To-Do List ation compared to template systems. Sea- What can you do today? side generates XHTML through an object TodoListView Filter: All Completed Pending Due Date layer using pure message sending. Using block closures, Seaside binds action call- Repair and clean the bike 1 February 2007 edit remove backs to components. Read “The ACME Novelty Library” I Multiple simultaneous control flows. Each 15 May 2007 edit remove component can define its own control Buy birthday present 11 June 2007 edit remove flow independently from the other com- add ponents displayed on the same page. This makes it possible to implement business logic spanning multiple pages as one con- tinuous piece of code. The enabling fea- ture is the concept of continuations, which Figure 1. The to-do harness Smalltalk’s ability to access and application, built from owner of dabbledb.com), Seaside is continually manipulate an execution stack. three different Seaside under active development by a growing com- I Hot debugging, code-editing, and recom- components. munity of contributors, including the third au- pilation. Seaside offers excellent develop- thor of this article. Here, we discuss the key ment support; most notably, it makes the features and characteristics of Seaside and how debugger work seamlessly with Web ap- they address the Web development challenges plication code. Smalltalk enables this that we identified earlier. Because of space lim- through hot recompilation and its treat- itations, we won’t discuss the advanced AJAX ment of exceptions as first-class objects, (Asynchronous JavaScript and XML) support which can be inspected and resumed. offered by Seaside (see http://scriptaculous. seasidehosting.st for details). In the remainder Domain-specific language of this article, we use a simple application that for generating XHTML lets users manage a to-do list of pending tasks. Seaside doesn’t keep XHTML code fragments Figure 1 shows the main view, which contains in external files; there is no template
Recommended publications
  • Transform View
    4/20/04 Doc 17 Model-View-Controller part 2 slide 1 CS 635 Advanced Object-Oriented Design & Programming Spring Semester, 2004 Doc 17 Model-View-Controller part 2 Contents Transform View ......................................................................... 2 Context Object .......................................................................... 5 Application Controller ................................................................ 7 Continuation-Based Web Servers ............................................. 9 References Patterns of Enterprise Application Architecture, Folwer, 2003, pp 330-386 Core J2EE Patterns: Best Practices and Design Strategies, 2nd, Alur, Crupi, Malks, 2003 Copyright ©, All rights reserved. 2004 SDSU & Roger Whitney, 5500 Campanile Drive, San Diego, CA 92182-7700 USA. OpenContent (http://www.opencontent.org/opl.shtml) license defines the copyright on this document. 4/20/04 Doc 17 Model-View-Controller part 2 slide 2 Transform View A view that processes domain data elements by element and transforms them into HTML Given a domain object, MusicAlbum, how to generate a web page for the object? • Use Template View • Convert object into html 4/20/04 Doc 17 Model-View-Controller part 2 slide 3 Converting object into html One could add toHtml to the object MusicAlbum ragas = new MusicAlbum.find(“Passages”); String html = ragas.toHtml(); • Domain object is coupled to view language • Provides only one way to display object Better use XML and XSLT • Convert domain object to XML • Use XSLT to convert XML into HTML Now
    [Show full text]
  • VAST Platform 2021 Design It. Build It. Deploy
    VAST Platform 2021 10.0.2 Design it. Build it. Deploy it. Create object-oriented software that’s stable, easy to maintain, and deploys smoothly — all from the same comprehensive development environment. The VAST Platform is a comprehensive integrated development environment (IDE) that works with a Smalltalk language New in 9.2.2 runtime. Because it’s Smalltalk-based, the IDE and the runtime are essentially a development ‘image’ that’s executed by a virtual machine (VM). First released as IBM® VisualAge® Smalltalk in 1993, the VAST Platform has built upon this original foundation starting in 2005 and has continued to grow in power and flexibility through ongoing research and development. VAST has evolved beyond what the original VisualAge developers could have foreseen, and allows developers to quickly iterate new ideas with proven Smalltalk-based live programming methodologies and deploy to a variety of desktop, cloud, Internet of Things (IoT), and on-premise server hardware. Version Control What’s New in VAST 2021 • Git/Tonel tooling Platform Development Tools • Brace array syntax • Migration to LLVM 10 compiler toolchain • Method type annotations • Asynchronous call-ins • SELinux Support (As of 10.0.1) Look and Feel Core Libraries • Hi-DPI fixes and enhancements • Cross-platform OsProcess framework • Product branding and other visual updates • Futures/promises asynchronous framework • High-resolution timer • Secure RNG stream • Swapper performance increase • Enhanced walkback generator Documentation • Lightweight/mobile-friendly documentation Communications • IBM MQ Series SSL/TLS support and 64-bit updates • Improved SMTP handling • Socket fixes and enhancements Top Features Type Analysis & Enhanced Multi-CPU Capable with Asynchronous Code Completion FFI & OsProcess Programming Real-time and lag free.
    [Show full text]
  • Dead Babies and Seaside Towns Ebook, Epub
    DEAD BABIES AND SEASIDE TOWNS Author: Alice Jolly Number of Pages: 432 pages Published Date: 25 Sep 2018 Publisher: Unbound Publication Country: London, United Kingdom Language: English ISBN: 9781783523610 DOWNLOAD: DEAD BABIES AND SEASIDE TOWNS Dead Babies and Seaside Towns PDF Book More than 100 fiction films and documentaries are discussed in this completely original and definitive work on how film meets neurology. Creatively imagined and beautifully written, this book: Interweaves theoretical concepts and professional practice on every pageUses cultural economy to teach the essential concepts and thinkersIntegrates case studies from fashion and gaming to journalism and musicTeaches strategies for navigating the links between skills, industries, creativity and markets. How the statutory residence test applies from April 2013. Gen. Environment focuses on inclusion, including residence life, the local community, the working and learning environment, and external factors and events such as national and international news events or town gown relationships. She has built up a professional reputation from her hands-on, direct client experience, as well as through evidence gained from many years of conducting client surveys and analysis of client data. With this book, you will learn about technical, legal, and resource sharing developments that will contribute to the future distribution of global information in libraries. All you have to do is read the book to start your new journey today. "-Gary Stoner, Ph. " Murach's ADO. She also illustrates assumptions about language and being American, as these are both debated and shared by each "side" of the language and immigration debates in California and Georgia. The report lays out clear evidence of the significant successes that can be achieved by properly structured RCM programs.
    [Show full text]
  • Car Agency in Lakewood Going to the Dogs!
    July 7th, 2016 The Ocean County Gazette - www.ocgazette.news 1 The OC Gazette P.O. Box 577 Seaside Heights NJ 08751 On The Web at: www.ocgazette.news JULY 29TH, 2016 VOL. 16 NO. 570 THIS WEEKS Car Agency in Lakewood Going ALERT SHERIFF’S ISSUE OFFICER CATCHES Pages 8-9 to the Dogs! Ocean County POSSIBLE BURGLARY Featured Events FROM COURTROOM Pages 10-11 Ocean County WINDOW; WARRANT Library Weekend Events and ISSUED Exhibits TOMS RIVER – The keen eye of Pages 12-13 an Ocean County Sheriff’s Officer Ocean County caught a suspicious male gaining Artists Guild entry into an apartment on Washington Street in the downtown Page - 16-17 area on July 21. And now, that Long Beach Island Foundation of the person has a warrant out for his Arts & Sciences arrest on charges of burglary, theft Events and criminal trespassing. According to a report provided Page 25 by Ocean County Sheriff Michael Museums, Historic, G. Mastronardy, Sheriff’s Officer Arts & Exhibits Robert Mazur was just completing Photo credits: Courtesy of Caregiver Volunteers; Picture of Alice, courtesy of Michael his security detail around noon in Page 25 Bagley Photography Alice, Lavallette, with Golden Retriever Simon Courtroom 214 on the third floor A Summary of of 213 Washington St., when he Comedy & Stage glanced out the window toward the Performances Kick off the “Dog Days of Summer” $5.00 to the nonprofit Caregiver with a celebration of Caregivers, Canines® program for every vehicle Harbor Front Condominiums at 215 Page 27-34 Canines, and Cars at the Larson Ford sold during the Caregivers, Canines, Washington Street.
    [Show full text]
  • Design and Analysis of Web Application Frameworks
    Aarhus University PhD Dissertation Design and Analysis of Web Application Frameworks Mathias Schwarz Supervisor: Anders Møller Submitted: January 29, 2013 Abstract Numerous web application frameworks have been developed in recent years. These frameworks enable programmers to reuse common components and to avoid typical pitfalls in web application development. Although such frameworks help the pro- grammer to avoid many common errors, we find that there are important, common errors that remain unhandled by web application frameworks. Guided by a survey of common web application errors and of web application frameworks, we identify the need for techniques to help the programmer avoid HTML invalidity and security vulnerabilities, in particular client-state manipulation vulnerabilities. The hypothesis of this dissertation is that we can design frameworks and static analyses that aid the programmer to avoid such errors. First, we present the JWIG web application framework for writing secure and maintainable web applications. We discuss how this framework solves some of the common errors through an API that is designed to be safe by default. Second, we present a novel technique for checking HTML validity for output that is generated by web applications. Through string analysis, we approximate the out- put of web applications as context-free grammars. We model the HTML validation algorithm and the DTD language, and we generalize the validation algorithm to work for context-free grammars. Third, we present a novel technique for identifying client-state manipulation vulnerabilities. The technique uses a combination of output analysis and informa- tion flow analysis to detect flow in the web application that might be exploited by malicious clients.
    [Show full text]
  • “Develop in Pharo, Deploy in Gemstone” with Seaside Johan Brichau
    10 Years later “develop in Pharo, deploy in Gemstone” with Seaside Johan Brichau - [email protected] Yesplan ? Web Application (SaaS) to manage an event venue Yesplan ? Web Application (SaaS) to manage an event venue Yesplan ? Web Application (SaaS) to manage an event venue Yesplan ? Web Application (SaaS) to manage an event venue - jQuery - jQuery-UI - KnockoutJs - D3.js - Datatables - Jasper reports - …. Yesplan ? Web Application (SaaS) to manage an event venue - jQuery - jQuery-UI - KnockoutJs - D3.js - Datatables - Jasper reports ReactJs - …. Yesplan ? • Founded by aa. and arts centre • Over 200 customers (in BE, NL, Lux, CH, UK, NO, DK, FI) • Currently 25 employees: • 5 software engineers, 1 dev ops engineer, 1 interaction designer and 1 report engineer • sales, account management, marketing, support, • Emphasis on making an application that not only works, but also is enjoyable to use Yesplan 0.1 (2009) • Yesplan calendar built using Seaside’s “full page rendering” in-place editing info bubbles title • Standard ‘component calls component’ implementation group • A lot of jQuery for animations and ajax updates group visualization • Javascript universe was “big mess” (excluding notable exceptions) • More errors than functionality in most ‘plugins’ • Bad performance and horrible engineering • Pharo + GoodsDB in production Yesplan 1.0 (2010) • Yesplan calendar with incremental ajax updates • A lot of jQuery-based scripts • SVG animations using generated Javascript • Develop in Pharo, deploy in GemStone • Pharo for development • GemStone
    [Show full text]
  • Clackamas County Reopening Plan
    Clackamas County Phase I Reopening Application May 2020 CLACKAMAS COUN T Y 1 May 19 \ 2020 Honorable Governor Kate Brown c/o/Jennifer Andrew 254 State Capitol Salem, OR 97301-4047 Clackamas County's Application for Phase One Reopening Dear Governor Brown: On behalf of the Clackamas County Board of Commissioners, we are pleased to submit Clackamas County's Phase 1 Reopening Application for consideration by the Governor's Office and the Oregon Health Authority. Our residents have taken your directive to "Stay Home, Save Lives" seriously and local efforts have been highly effective in "flatting the curve" for COVID-19 in Clackamas County. Our community has experienced significant community impacts, and it is time to begin gradually reopening additional sectors of our local economy. Staff within our Clackamas County Emergency Operations Center have worked hard on an in-depth analysis of each of the 7 prerequisites required for entering Phase 1. We are confident that we either meet the necessary requirements or have comprehensive plans in place to address urgent needs as our businesses (identified in Phase 1) start to reopen. Additional financial and technical resources from state and federal sources will be critical to implement our plans related to testing, contact tracing and monitoring, and isolation facilities. We have been in regular communication with our partners in Health Region 1 and neighboring Local Public Health Authorities to coordinate local response efforts, prepare for reopening, and monitor the established gating criteria. We are doing all we can to prevent having to re-impose restrictions. We also recognize the need for our residents and visitors to remain vigilant in protecting themselves and others from the risks of COVID-19.
    [Show full text]
  • Aranea—Web Framework Construction and Integration Kit
    Aranea—Web Framework Construction and Integration Kit Oleg Murk¨ Jevgeni Kabanov Dept. of Computer Science and Engineering, Dept. of Computer Science, Chalmers University of Technology, University of Tartu, SE-412 96 Goteborg,¨ Sweden J. Liivi 2, EE-50409 Tartu, Estonia [email protected] [email protected] ABSTRACT proaches and ideas are tried out. Indeed, many very good Currently there exist dozens of web controller frameworks ideas have been proposed during these years, many of which that are incompatible, but at the same time have large por- we will describe later in this paper. On a longer time- tions of overlapping functionality that is implemented over scale the stronger (or better marketed) frameworks and ap- and over again. Web programmers are facing limitations on proaches will survive, the weaker will diminish. However, in code reuse, application and framework integration, extensi- our opinion, such situation also has a lot of disadvantages. bility, expressiveness of programming model and productiv- 1.1 Problem Description ity. In this paper we propose a minimalistic component model First of all let’s consider the problems of the web frame- Aranea that is aimed at constructing and integrating server- work ecosystem from the viewpoint of application develop- side web controller frameworks in Java. It allows assembling ment. Framework user population is very fragmented as a most of available web programming models out of reusable result of having many incompatible frameworks with simi- components and patterns. We also show how to integrate lar programming models. Each company or even project, is different existing frameworks using Aranea as a common using a different web framework, which requires learning a protocol.
    [Show full text]
  • Smalltalk Web Frameworks
    Smalltalk Web frameworks Comparison of Aida/Web and Seaside Janko Mivšek [email protected] Vsebina Definition of Web App server Aida's ideas and architecture Comparison to Seaside Examples Conclusion Web application server Web + application server For web applications Dynamic, on-the-fly built web pages Web pages instead of GUI apps Thin clients instead of fat clients Examples: business apps, portals, ... Swazoo vs. Aida & Seaside Swazoo Seaside AIDA SmallWiki Methods of building web pages Embedded tags into HTML jsp, asp, php Cincom Web Toolkit Programming Java Servlets Struts AIDA/Web, Seaside Embedded tags ± SSP example <html> <head><title>Toyz Employees</title></head> <body> <table border=1> <% employees := (Toyz new) getEmployees. employees do: [:each | response write: ‘<tr>’. response write: (‘<td>’, each number’, ‘</td>’). response write: (‘<td>’, each name, ‘ ‘, each surname, ‘</td>’). response write: ‘</tr>’]. %> </table> </body> </html> Enbedded commands Pros Simple for web designers Cons Functional logic get lost among presentation logic (HTML) ªspaghettiº code ± hard to maintain and extend Programming ± two examples Aida: element := WebElement new. element table width: 500; cell color: (self navigatorColor); cell colspan: 3; addText: self title header: 3; newRow; cell colspan: 3; addRulerSize: 1; newRow; cell addText: 'uptime: '; newCell align: #right; addText: (self printSeconds: self session site uptime); newRow. ^self pageFrameWith: element title: self title . Seaside: renderContentOn: html html form: [ html table:
    [Show full text]
  • Uncommon Web Technologies*
    Uncommon web technologies* Or “A look at Seaside, and a discussion about esoteric web frameworks” * The topics there are no Oreilly books about Who am I • Lars Rustemeier • System architect at Snowmen Solutions • Previously: KTH, Razorfish, GameDesign Sweden, Netbaby, ACNE, Automata (still so), Ongame • I prefer dynamic languages* • Professional programming** in C, C++, Lua, Java, Python, Smalltalk, Ruby, Perl, Scheme and Common Lisp * Languages that defer as many decisions as possible until runtime They also tend to be expressive: “Programs must be written for people to read, and only incidentally for machines to execute”. /Sussman ** In the sense that I have been paid to program in the language Cutting edge web sw Why bother with this esoteric stuff • Makes you a better developer • The future lies in some of the radical projects • Paradigm changes tend to scare developers (reluctance to change) • Good for experimentation, prototyping* (does anyone do prototyping?) • In a nutshell: It is fun Consequence of the fact that most apps are deployed as web applications • You can write web apps in any language! • Not so for desktop applications Developer courage Seaside • I want to talk about Seaside since it seem to be unknown outside the Lisp/Smalltalk world • Why is this? • Smalltalk, an extremely dynamic* language (even more so than Ruby) • Everything is an object, even the runtime stack, “reification” • The syntax (or lack there of) is scary to some • Image based development is not fashionable Features Programmatic HTML generation. Callback-based request handling. Embedded components. Modal session management. Interactive debugging support. Features • Halos in squeak • Halos in seaside • Inspector • Backtracking • Thinking about things at the component level Back tracking • What happens when we use the back button? Pages Page1 Page2 Page3 Session state state1 state2 state3 • What do we want? Continuations • Travel in time color = color_picker() set_background(color) ..
    [Show full text]
  • Tinyblog: Building a Web Interface with Seaside
    CHAPTER 1 TinyBlog: Building a Web Interface with Seaside 1.1 Previous Week Solution You can load the solution of the previous week using the following snippet: Gofer new smalltalkhubUser: 'PharoMooc' project: 'TinyBlog'; package: 'ConfigurationOfTinyBlog'; load. #ConfigurationOfTinyBlog asClass loadWeek3Correction Make sure that you Teapot server is stopped. TBTeapotWebApp stop 1.2 A Web UI for TinyBlog with Seaside The work presented in this exercise does not require the one on Voyage and MongoDB. This week, we start with a web UI dedicated to display posts to users. Next week, we will develop another web UI for the blog owner to admnistrate the posts. In both cases, we will define Seaside components http://www.seaside.st which has a freely available book online here: http://book.seaside.st. 1 Figure 1.1 Start Seaside Server. Figure 1.2 Accessing Seaside Home Page. 2 1.3 Start Seaside 1.3 Start Seaside There are two ways to start Seaside. The first one consists in executing the following code: ZnZincServerAdaptor startOn: 8080. The second one uses the graphical tool named ”Seaside Control Panel” (World Menu>Tools>Seaside Control Panel). In the contextual menu (right clic) of this tool, select ”add adaptor...” and add a server of type ZnZincServer- Adaptor, then define the port number (e.g. 8080) it should run on (cf. figure 1.1). By opening a web browser on the URL http://localhost:8080, you should see the Seaside home page as displayed on Figure 1.2. 1.4 Entry Point for TinyBlog Web UI Create a class named TBApplicationRootComponent which will be the entry point of the application.
    [Show full text]
  • MMAC Dba Seaside Service Co, LLC Reviewer
    CITY OF PASADENA Applicant Name: MMAC dba Seaside Service Co, LLC Reviewer: Tim Cromartie Date: 4/19/19 Maximum Points Percent OVERALL SCORE Points Awarded Score 1,575 1,415 89.84% GENERAL COMMENTS Applicant provided a very thorough and detailed packet that included sections prepared by a variety of qualified professional consultants. The applicant has demonstrated ample previous experience that is directly applicable to operating a cannabis retailers and has generally presented themselves in a very professional manner. Applicant appears to have anticipated many potential issues and has been proactive in addressing them. SECTION 1: QUALIFICATIONS OF OWNERS/ OPERATORS 750 684 91.20% Experience Applicant provided documentation to show that they are or have been part owner of 3 licensed retailers in Los Angeles over the past year. Temporary BCC license numbers are provided. Cannabis Industry Knowledge Application demonstrated a high degree of knowledge about the cannabis industry from both legally permitted and non-permitted businesses. Application provided great detail about how the business will address requirements of State and local laws. Ownership Team Application fails to provide clear information on who the owners are. It appears that an LLC has 100% ownership, and one member of the management team is listed as the manager. Other than providing titles, narrative does not describe what most members of the management team will do via-a-vis day-to-day operations. SEASIDE SERVICE CO, LLC'S APPLICATION FOR CANNABIS RETAILER LICENSE, CITY OF PASADENA 1 OF 108 SECTION 2: BUSINESS PLAN 525 455 86.67% Standard Operating Procedures (SOP) Applicant provided highly detailed excerpts from an employee procedures manual, currently in use at its other facilities and relevant to cannabis retail operations.
    [Show full text]