This tutorial contains notes about Eclipse Package Drone.
1. Package Drone
Package Drone is an artifact manager like Artifactory or Nexus, which is based on OSGi. Since this artifact manager itself is based on OSGi it comes with very strong support for OSGi environments.
2. Install Package Drone
2.1. Installation on unix systems
Package drone offers installers for several unix systems including Ubuntu, CentOs, OpenSuse and others.
Further information about that can be found here: https://wiki.eclipse.org/PackageDrone/Installation
2.2. Using the plain zip
Download locations
After downloading the ZIP it can be extracted and started like a normal OSGi application.
2.3. Running Package Drone from the Eclipse IDE
Package drone provides an easy to use Oomph setup.
The Oomph installer can be downloaded on: http://download.eclipse.org
After starting the Oomph installer and switching to it’s advanced mode the "Eclipse IDE for Eclipse Committers" can be chosen.
data:image/s3,"s3://crabby-images/0daf6/0daf6163a06e5e8eda29f361424885e64e531a8b" alt="oomph installer eclipse comitter"
On the next page of the Eclipse Installer the Package Drone profile has to be chosen.
data:image/s3,"s3://crabby-images/236ba/236ba4c80c7cfc99a07063308292f153eff03d9f" alt="oomph installer package drone profile"
When pressing Next > some workspace and install settings can be applied.
data:image/s3,"s3://crabby-images/e10b6/e10b6ed2e8b5899d57452c8b1ac32d5bc5304552" alt="oomph installer settings"
After pressing Next > again the profile settings can be seen.
data:image/s3,"s3://crabby-images/03c2e/03c2ebafd3f3c61d1897f505222ff6b4f9d45b16" alt="oomph installer profile settings"
When Finish is pressed a setup Eclipse IDE containing the Package Drone project is available.
After starting the Eclipse IDE there will be a runtime project to setup the target platform.
There are two ways to download the libs for the target definition:
-
Run the build.ant build file of the runtime project with Apache Ant
-
Run a
mvn clean install
build with Apache Maven in the runtime folder on the pom.xml
After that the target definition file can be used to set the target platform.
data:image/s3,"s3://crabby-images/80516/80516dc02395e922b4052a47901c23557a01fdf2" alt="set target platform"
To launch Package Drone from the IDE the Package Drone Server.launch file can be used.
data:image/s3,"s3://crabby-images/ea0f2/ea0f298c7da4a2b0b5b9c5df9507b244b36e0bb5" alt="launching from IDE"
3. Channels and Aspects
A Channel is a binary repository instance, where binary files like *.jar files can be deployed to.
Package Drone provides 3 channel types:
-
Plain Channel
-
APT Channel
-
RPM Channel
4. Exercise: Setup Package Drone
To run Package Drone use:
~$ cd /{package-drone-directory}/
~$ ./server
By default Package Drone uses
http://localhost:8080/
as URL, which leads to this:
data:image/s3,"s3://crabby-images/c0786/c0786be880f1a72d1dfd7ee49ac6d90f71ac4743" alt="web package drone setup"
The Sign in link can be found on the right hand side of the web page.
In the console should appear something similar to this:
data:image/s3,"s3://crabby-images/a44a7/a44a74358539cca4a8eab12a1f1bebf5155acbe0" alt="console package drone pw"
This User and Password are supposed to be used to sign in for the very first time.
After the login a new user with Admin and Manager rights should be created.
data:image/s3,"s3://crabby-images/b5bab/b5babef6cb37544d3ac18b03f121ad4cf30315eb" alt="user menu entry"
Then press on Add user to create it.
data:image/s3,"s3://crabby-images/62598/62598116f9617d0f26ed2122d2aa5c2a88e0646a" alt="user new"
Pressing Submit will result in the user overview.
First of all a new password should be generated by clicking the Change password link.
data:image/s3,"s3://crabby-images/cdee4/cdee4d587c87369dac81da457d89ac780389b1f4" alt="user created"
To get all necessary rights for the user press the Edit user button and check the ADMIN and MANAGER role.
data:image/s3,"s3://crabby-images/de294/de294a7bf26217b62078d56008f7410fe2119cd0" alt="user edit"
5. Exercise: Setup Channels
Once a user with the MANAGER role has been created and is signed in, a new Channel can be created.
data:image/s3,"s3://crabby-images/50c35/50c35ab0ffa99a3e8ed1961475312d796635d0fb" alt="channel new"
1.) Click on the Channel Section 2.) Then press the Create Channel button
data:image/s3,"s3://crabby-images/979f5/979f5cc4c30fda8de7f8b4f4bec3bff1772ca8b4" alt="channel create"
6. Exercise: Deploying to a Channel
To deploy to a Channel with Maven or Gradle a Deploy Group has to be created.
data:image/s3,"s3://crabby-images/12825/1282508e2ab39344088b6a33dfb29936ed61dff9" alt="deploy group create"
-
Press on Menu:Administration[Deploy Keys]
-
Press add group
Create a group called Maven and create a key for this group.
data:image/s3,"s3://crabby-images/d3970/d3970a1aa4c70f365cee2180e9b20b7f15359136" alt="deploy key create"
Once a deploy key has been created it can be applied to a Channel.
data:image/s3,"s3://crabby-images/755bd/755bdb1ae8caefb587ba4ba4d9a0e7f604dd44b2" alt="channel apply deploy key"
-
Select Channels Section
-
Select the previously created channel in the list, e.g., My_first_Channel
-
Go to Deploy Keys
Add the Deploy Group, which just has been created
When clicking on the View Maven settings link, the following dialog, containing the maven setup, will appear.
data:image/s3,"s3://crabby-images/aa0f9/aa0f9ac6c55be4df0838fde17a5e0ed81f47f93a" alt="channel maven settings"
These settings can then be specified in the pom.xml and settings.xml file.
Finally mvn clean deploy
can be called on a Maven project to deploy it to the Package Drone instance.
For the usage in a Gradle project, please see Gradle tutorial |
7. Exercise: Use Aspects
So called Aspects can be applied to a Channel like this:
data:image/s3,"s3://crabby-images/03909/03909b6a5550462be57e8349b57a580be79d2175" alt="aspects config link"
In the Channel aspects section additional Aspects can be added.
Default categories of additional Aspects:
-
Debian
-
Maven
-
OSGi
-
Other
-
RPM
7.1. Exercise: The P2 Repository Aspect
When OSGi bundles have been added to a channel, it is usually helpful to provide these bundles as p2 update site. For example, when bundles and features should be provided for a Maven Tycho build, which only works with p2 update sites.
Package Drone has the capability to automatically generate a p2 update site by using the P2 Repository Aspect.
The P2 Repository Aspect can be found in the OSGi category of the Channel aspects section.
data:image/s3,"s3://crabby-images/2cd8e/2cd8e8e6f494ce652e869d5b7cd4399664ce0e75" alt="aspects p2 repo"
The P2 Repository Aspect requires the Hasher and Mine Aspect. But when pressing on the Add button, one can confirm to Add with dependencies, to also add the Hasher and Mine Aspect.
data:image/s3,"s3://crabby-images/923fe/923feee748c389e946d5cf97d02121d0ef648e06" alt="aspects assigned"
The p2 update site for this Channel be accessed with this URL schema: {server}:{port}/p2/{channel-id}, e.g.,
http://localhost:8080/p2/828d10a6-c682-4d56-9d68-74dfe6dbb1e4/
Do not add the Tycho Cleaner or the P2 Meta Data Generator Aspect, otherwise these Aspects would interfere with the P2 Repository Aspect and cause invalid results. |
8. PackageDrone resources
8.1. vogella Java example code
endifdef::printrun[]
If you need more assistance we offer Online Training and Onsite training as well as consulting