# ACE Installation via Wamp or PHP Stack
Use this guide if you are not installing ACE using the Docker Environment.
# Install Apache and PHP
Please follow the Assure Deployment documentation for these two if there are not already installed.
# Install Node and NPM
Go to the following link here (opens new window) to download the Node installer (please select the LTS version) and proceed to install it on the server. After it is installed, open a command line window and type the following to verify that Node and NPM is installed:
node -v
npm -v
# Install Composer
Navigate to the Composer Website (opens new window) and click on getting started and then from the page that loads a menu should display at the top with links to Intallation - Windows (opens new window). Use these directions to install Composer on your windows machine.
# Clone ACE Repository
Now that all requirements are installed:
- Log into Bitbucket (opens new window) and navigate to the ACE repository (opens new window).
- Click the Clone button located on the repository and copy the command to clone the repo.
- It should look something like this: git clone https://{username}@bitbucket.org/epicphp/client-interface.git
 
- It should look something like this: 
- Open a terminal window and go to the Apache www folder (usually located at c:\wamp\www).
- Paste the git clone command you got from the repo and add to the end of it with a space before it: {company_code}_aceand press enter.- Replace the {company_code}with the Assure company code that it will be linked to.
 
- Replace the 
# Configure Apache
- Navigate to the Apache vhost config file (usually found at c:\wamp\bin\apache\apache2.4.41\conf\extra\httpd-vhosts.conf).
- Add a new virtualhost block for ACE. It should look like the example below:
<VirtualHost *:{port number}>
	ServerName ace.epicassure.com:{port number}
	DocumentRoot "c:/wamp/www/{ace_folder_name}/public"
	<Directory "c:/wamp/www/{ace_folder_name}/public/">
		Options Indexes FollowSymLinks MultiViews
		Allowoverride all
		Require all granted
	</Directory>
</VirtualHost>
- After the Apache vhost file has been modified, restart the Apache service.
- Confirm that ACE loads within the browser locally at http://localhost:{port setup in apache}and externally (at the public IP and/or domain of the server and port setup in apache).
# Configure Assure Connection
- Log into the Assure Application and navigate to the System Config Section.
- Go to the API PSKs Tab and create a new API Pre-Shared Key.
- Make a note of the PSK created as it will be used in the ACE configuration.
 
- Go to the API IP Whitelist and create a whitelist for the ACE App (use the public IP or domain that is used in the Apache vhost config).
- Enable ACE Module
- Go to System configuration
- Master Config -> Serials
- Click on Edit in the top right hand corner
- Then click the key icon beside ACE Module
- When popup screen is visible,
- Select date Module should be disabled / Expire
- select the modules you would like to enable for ACE
- Click Submit
 
 
# Configure ACE
- Navigate to the folder that ACE was cloned to. 
- Copy the - .env.examplefile and then paste and rename it to- .env.
- Within the - .envfile:- Locate the variable called - MIX_API_BASE_URLand add the IP or domain of the Assure Application that the ACE App will be linked to. Example:- MIX_API_BASE_URL="201.111.11.11"
- Locate the variable called - MIX_PSKand add the PSK that was created within Assure here. Example:- MIX_PSK="d4039lksdjf03420934iup"
- Locate the variable called - APP_ENVand change the value to production.
- Locate the variable called - APP_DEBUGand change the value to false.
 
- Modify - composer.jsonfile in the root folder of ACE- NOTE - If you are running application on Windows you may run into an issue when you try to generate a key using the artisan command. To overcome this issue simple add the following to your - composer.jsonfile. Add the following in the config object- "platform": { "ext-pcntl": "8.0", "ext-posix": "8.0" }- When you are done it should look like something like this: - "config": { "platform": { "ext-pcntl": "8.0", "ext-posix": "8.0" }, "optimize-autoloader": true, "prefferred-install": "dist", "sort-packages": true }
- Run the following commands one after each other: - composer install php artisan key:generate npm ci npm run dev
- Once all are completed without an issue, verify that the application is up and running within the browser.