From c13817b1b45e245cf9a8763eb9a93c6fe51a952e Mon Sep 17 00:00:00 2001 From: "erik.novembit" Date: Wed, 4 Nov 2020 20:13:26 +0400 Subject: [PATCH] Added basic sample data --- .gitignore | 1 + Dockerfile | 96 +++++++ LICENSE | 661 +++++++++++++++++++++++++++++++++++++++++++ logo.png | Bin 0 -> 23052 bytes scripts/package.json | 18 ++ scripts/rebase.js | 114 ++++++++ test/test.sh | 22 ++ 7 files changed, 912 insertions(+) create mode 100644 .gitignore create mode 100644 Dockerfile create mode 100644 LICENSE create mode 100644 logo.png create mode 100644 scripts/package.json create mode 100644 scripts/rebase.js create mode 100644 test/test.sh diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..dc988bd --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +scripts/node_modules diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..7c4dcb7 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,96 @@ +# https://hub.docker.com/_/ubuntu/?tab=tags +FROM ubuntu:bionic-20200311@sha256:e5dd9dbb37df5b731a6688fa49f4003359f6f126958c9c928f937bec69836320 + +ENV DEBIAN_FRONTEND noninteractive +# Do not cache apt packages +# https://wiki.ubuntu.com/ReducingDiskFootprint +RUN echo 'Acquire::http {No-Cache=True;};' > /etc/apt/apt.conf.d/no-cache && \ + echo 'APT::Install-Recommends "0"; APT::Install-Suggests "0";' > /etc/apt/apt.conf.d/01norecommend && \ + echo 'Dir::Cache { srcpkgcache ""; pkgcache ""; }' > /etc/apt/apt.conf.d/02nocache && \ + echo 'Acquire::GzipIndexes "true"; Acquire::CompressionTypes::Order:: "gz";' > /etc/apt/apt.conf.d/02compress-indexes + +SHELL ["/bin/bash", "-c"] + +RUN apt remove -y php* && \ + apt-get -y update && \ + # Software installation (for add-apt-repository and apt-key) + apt-get -y install ca-certificates curl dirmngr git gpg gpg-agent wget unzip zip software-properties-common build-essential make gcc g++ sudo cron && \ + add-apt-repository -y ppa:ondrej/php && \ + # yarn + apt-key adv --fetch-keys http://dl.yarnpkg.com/debian/pubkey.gpg && \ + echo "deb http://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list && \ + apt-get -y update && \ + apt-get -y install \ + # Process managers + supervisor \ + # install net packages useful for debugging + iputils-ping telnet netcat lsof net-tools openssl dnsutils rsync bind9-host \ + # config file manipulation + crudini xmlstarlet moreutils jq \ + # General purpose + pwgen swaks vim nano cmake pkg-config openssh-client openssh-server uuid less zip file yarn \ + # apache + apache2 libapache2-mod-perl2 apache2-dev \ + # nginx + nginx-full \ + # Databases (clients) + sqlite3 mysql-client redis-tools postgresql-client ldap-utils mongodb-clients mongo-tools \ + # Dev packages (useful for native modules in ruby, node) + gettext imagemagick libcurl4 libcurl4-openssl-dev libexpat1-dev libffi-dev libgdbm-dev libicu-dev libmysqlclient-dev \ + libncurses5-dev libpq-dev libre2-dev libreadline-dev libssl-dev libxml2-dev libxslt-dev libyaml-dev zlib1g-dev \ + libmcrypt-dev libgmp-dev libfreetype6-dev libjpeg-dev libjpeg-turbo8-dev libpng-dev chrpath libxft-dev libfontconfig1-dev \ + libkrb5-dev libpq-dev libxslt1-dev libldap2-dev libsasl2-dev libtool libzmq3-dev yarn \ + # perl + perl libimage-exiftool-perl \ + # ruby (note that gem is now called gem2.1 and gem2.2) + ruby2.5-dev \ + # Python 3 + python3-dev python3-pip uwsgi-plugin-python python-dev python-pip python-setuptools python3-setuptools virtualenv virtualenvwrapper \ + # php 7.3 + php7.3 php7.3-{bcmath,bz2,cgi,cli,common,curl,dba,dev,enchant,fpm,gd,gmp,imap,interbase,intl,json,ldap,mbstring,mysql,odbc,opcache,pgsql,phpdbg,pspell,readline,recode,soap,sqlite3,sybase,tidy,xml,xmlrpc,xsl,zip} libapache2-mod-php7.3 php-{apcu,date,geoip,gettext,imagick,gnupg,mailparse,pear,redis,twig,uuid,validate,zmq} && \ + # good to have! + ghostscript libgs-dev ffmpeg && \ + # keep this here, otherwise it installs php 7.2 + apt install -y composer && \ + # Delete apt-cache and let people apt-update on start. Without this, we keep getting apt-get errors for --fix-missing + rm -rf /var/cache/apt /var/lib/apt/lists + +# gosu +RUN curl -L https://github.com/tianon/gosu/releases/download/1.12/gosu-amd64 -o /usr/local/bin/gosu && chmod +x /usr/local/bin/gosu + +## the installations are kept separate since these change a lot compared to above +# node (https://nodejs.org/en/download/) +ARG NODEVERSION=12.16.2 +RUN mkdir -p /usr/local/node-${NODEVERSION} && \ + curl -L https://nodejs.org/dist/v${NODEVERSION}/node-v${NODEVERSION}-linux-x64.tar.xz | tar Jxf - --strip-components 1 -C /usr/local/node-${NODEVERSION} + +# Go (https://golang.org/dl/) +ARG GOVERSION=1.14.2 +ENV GOROOT /usr/local/go-${GOVERSION} +RUN mkdir -p /usr/local/go-${GOVERSION} && \ + curl -L https://storage.googleapis.com/golang/go${GOVERSION}.linux-amd64.tar.gz | tar zxf - -C /usr/local/go-${GOVERSION} --strip-components 1 + +# Keep bash history around as long as /run is alive. .dbshell is mongodb +RUN ln -sf /run/.bash_history /root/.bash_history && \ + ln -sf /run/.psql_history /root/.psql_history && \ + ln -sf /run/.mysql_history /root/.mysql_history && \ + ln -sf /run/.dbshell /root/.dbshell && \ + ln -sf /run/.mongorc.js /root/.mongorc.js + +# Put node, go in the path by default +ENV PATH /usr/local/node-${NODEVERSION}/bin:$GOROOT/bin:$PATH + +# add a non-previleged user that apps can use +# by default, account is created as inactive which prevents login via openssh +# https://github.com/gitlabhq/gitlabhq/issues/5304 +RUN adduser --uid 1000 --disabled-login --gecos 'Cloudron' cloudron && \ + passwd -d cloudron + +# add the two commonly used users to the volume group +RUN addgroup --gid 500 --system media && \ + usermod -a -G media cloudron && \ + usermod -a -G media www-data + +RUN echo "set noswapfile" >> /root/.vimrc && \ + echo "set noswapfile" >> /home/cloudron/.vimrc + diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..d57114b --- /dev/null +++ b/LICENSE @@ -0,0 +1,661 @@ + GNU AFFERO GENERAL PUBLIC LICENSE + Version 3, 19 November 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU Affero General Public License is a free, copyleft license for +software and other kinds of works, specifically designed to ensure +cooperation with the community in the case of network server software. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +our General Public Licenses are intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + Developers that use our General Public Licenses protect your rights +with two steps: (1) assert copyright on the software, and (2) offer +you this License which gives you legal permission to copy, distribute +and/or modify the software. + + A secondary benefit of defending all users' freedom is that +improvements made in alternate versions of the program, if they +receive widespread use, become available for other developers to +incorporate. Many developers of free software are heartened and +encouraged by the resulting cooperation. However, in the case of +software used on network servers, this result may fail to come about. +The GNU General Public License permits making a modified version and +letting the public access it on a server without ever releasing its +source code to the public. + + The GNU Affero General Public License is designed specifically to +ensure that, in such cases, the modified source code becomes available +to the community. It requires the operator of a network server to +provide the source code of the modified version running there to the +users of that server. Therefore, public use of a modified version, on +a publicly accessible server, gives the public access to the source +code of the modified version. + + An older license, called the Affero General Public License and +published by Affero, was designed to accomplish similar goals. This is +a different license, not a version of the Affero GPL, but Affero has +released a new version of the Affero GPL which permits relicensing under +this license. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU Affero General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Remote Network Interaction; Use with the GNU General Public License. + + Notwithstanding any other provision of this License, if you modify the +Program, your modified version must prominently offer all users +interacting with it remotely through a computer network (if your version +supports such interaction) an opportunity to receive the Corresponding +Source of your version by providing access to the Corresponding Source +from a network server at no charge, through some standard or customary +means of facilitating copying of software. This Corresponding Source +shall include the Corresponding Source for any work covered by version 3 +of the GNU General Public License that is incorporated pursuant to the +following paragraph. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the work with which it is combined will remain governed by version +3 of the GNU General Public License. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU Affero General Public License from time to time. Such new versions +will be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU Affero General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU Affero General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU Affero General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + docker-base-image + Copyright (C) 2016 yellowtent + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published + by the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If your software can interact with users remotely through a computer +network, you should also make sure that it provides a way for users to +get its source. For example, if your program is a web application, its +interface could display a "Source" link that leads users to an archive +of the code. There are many ways you could offer source, and different +solutions will be better for different programs; see section 13 for the +specific requirements. + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU AGPL, see +. diff --git a/logo.png b/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..4ac67a9cf07e0c9218fe0327e6dc4516525fbf79 GIT binary patch literal 23052 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 0.0.x + var nextVersion = semver.inc(latestVersion, 'minor'); + + var imageName = 'girish/' + appName + ':' + nextVersion; + + console.log('Building ', imageName); + + if (!shellExec('docker build -t ' + imageName + ' .')) return false; + if (!shellExec('docker push ' + imageName)) return false; + + if (isApp) { + var manifest = JSON.parse(fs.readFileSync('CloudronManifest.json', 'utf8')); + manifest.dockerImage = imageName; + manifest.version = nextVersion; + fs.writeFileSync('CloudronManifest.json', JSON.stringify(manifest, null, 2)); + } + + if (!shellExec('git commit -a -m "Rebase to girish/base:' + baseVersion + '"')) return false; + if (!shellExec('git tag -f v' + nextVersion + ' -a -m "Version ' + nextVersion + '"')) return false; + if (!shellExec('git push origin master --tags')) return false; + if (isApp && !shellExec('cloudron publish')) return false; + } + + return true; +} + +function rebaseApps() { + var apps = fs.readdirSync(PARENT_DIR).filter(function (file) { return /-app$/.test(file); }); + var failed = [ ]; + apps.forEach(function (app) { + var appName = app.replace(/-app$/, ''); + if (!rebase(app, appName, true /* isApp */)) failed.push(app); + }); + + if (failed.length !== 0) console.log(util.format('Failed: %j', failed).red); +} + +function rebaseAddons() { + var addons = fs.readdirSync(PARENT_DIR).filter(function (file) { return /-addon$/.test(file); }); + var failed = [ ]; + addons.forEach(function (addon) { + var addonName = addon.replace(/-addon$/, ''); + if (!rebase(addon, addonName, false /* isApp */)) failed.push(addon); + }); + + if (failed.length !== 0) console.log(util.format('Failed: %j', failed).red); +} + diff --git a/test/test.sh b/test/test.sh new file mode 100644 index 0000000..bd74e2d --- /dev/null +++ b/test/test.sh @@ -0,0 +1,22 @@ +#!/bin/bash + +set -eu + +image=cloudron/basetest + +function check_go() { + if ! docker run $image go version; then + return 1 + fi +} + +function check_node() { + if ! docker run $image node --version; then + return 1 + fi +} + +check_go +check_node +echo "All tests passed" +