Subversion Repositories DevTools

Rev

Rev 4028 | Blame | Last modification | View Log | RSS feed

<%
'===================================================================
'                     Package Common
'===================================================================
%>
<!--#include file="../class/classTemplateManager.asp"-->
<!--#include file="../class/classTabControl.asp"-->
<!--#include file="../class/classActionButtonControl.asp"-->
<!--#include file="daemon_instructions.asp"-->
<!--#include file="daemon_status.asp"-->
<!--#include file="../_pkg_action_buttons.asp"-->
<%
'------------ VARIABLE DEFINITION -------------
Dim parPv_id
Dim nEnvTab         ' remember environment tab
Dim objBtnControl
Dim aTabBtnsDef
'------------ CONSTANTS DECLARATION -----------
'------------ VARIABLE INIT -------------------
parPv_id = Request("pv_id")
Set objBtnControl = New ActionButtonControl
'------------ CONDITIONS ----------------------
'----------------------------------------------
%>
<%
'------------ RUN BEFORE PAGE RENDER ----------

'--- Make sure rtag_id is always present
If (Request("rtag_id") = "") AND (Request("pv_id") = "") Then Response.Redirect("index.asp")


'--- Rebuild Environment
If (Request("rtag_id") <> "") Then
   Call Rebuild_Environment ( parRtag_id )
End If

'--- Persist following parameters between postbacks
objPMod.PersistInQryString ( aPersistList(enumPAR_RTAG_ID) )
objPMod.PersistInQryString ( aPersistList(enumPAR_PV_ID) )


'--- Get Environment (lefthand side menu) tab
nEnvTab = GetEnvTab ( Request("envtab") )


'--- Get Package General Information
Set pkgInfoHash = CreateObject("Scripting.Dictionary")
If Request("pv_id") <> "" Then
   Call Get_Pkg_Info ( Request("pv_id"), Request("rtag_id") )

   ' Make sure pv_id exists as it may be removed
   If pkgInfoHash.Item("pv_id") = "" Then Response.Redirect ("dependencies.asp?rtag_id="& Request("rtag_id"))

Else
   If (ScriptName <> "dependencies.asp") AND (ScriptName <> "find.asp")Then  Response.Redirect ("dependencies.asp?rtag_id="& Request("rtag_id"))
End If


'----------------------------------------------
%>
<%
'-----------------------------------------------------------------------------------------------------------------------------
Sub RenderPackageProperties (irtag_id)
%>
   <table width="100%" border="0" cellspacing="0" cellpadding="0">
   <tr>
     <td>
         <%
         If pkgInfoHash.Item ("is_patch") = "Y" Then
            '--- PATCH ---
            Response.write "<br><a href='patches.asp?pv_id="& pkgInfoHash.Item ("patch_parent_id") &"&rtag_id="& Request("rtag_id") &"' class='txt_linked'><img src='icons/i_caretone.gif' hspace='2' border='0' align='absmiddle'>Back To "& pkgInfoHash.Item ("pkg_name") &"</a><br><br>"

            If pkgInfoHash.Item ("is_obsolete") = "Y" Then
               Dim rsTemp
               Set rsTemp = OraDatabase.DbCreateDynaset( "select patch_obsoleted_by from package_patches where patch_id ="&pkgInfoHash.Item ("pv_id"), cint(0))

               If rsTemp("patch_obsoleted_by") <> "" Then

                  Set rsTemp = OraDatabase.DbCreateDynaset( "select pkg_version from package_versions where pv_id ="&rsTemp("patch_obsoleted_by"), cint(0))
                  Call Messenger ( "<SPAN class='err_alert'><b>Patch Is Obsolete!</b></SPAN><br>"& NewLine_To_BR( "<b>Obsoleted by patch "& rsTemp("pkg_version") & ". </b> " ) & NewLine_To_BR( pkgInfoHash.Item ("obsolete_comments") ), 3, "100%" )

                  rsTemp.Close()
                  Set rsTemp = nothing
               Else
                  Call Messenger ( "<SPAN class='err_alert'><b>Patch Is Obsolete!</b></SPAN><br>"& NewLine_To_BR( pkgInfoHash.Item ("obsolete_comments") ), 3, "100%" )
               End If
               Response.write enum_imgPatchObsolete
            Else
               Response.write enum_imgPatch
            End If


            If pkgInfoHash.Item ("dlocked") = "Y" Then
               Response.write "<SPAN class='lbox_ttl'>"& pkgInfoHash.Item ("pkg_version") &"<img src='images/i_locked.gif' width='12' height='14' border='0' hspace='5' align='top'></SPAN>"
            Else
               Response.write "<SPAN class='lbox_ttl'>"& pkgInfoHash.Item ("pkg_version") &"</SPAN>"
            End If
         Else
            '--- PACKAGE ---
            Response.write "<table cellspacing=1 cellpadding=0>"
            Response.write "<tr>"
            Response.write "<td>"
            Response.write "<SPAN class='lbox_ttl'>"& pkgInfoHash.Item ("pkg_name") &"&nbsp;"& pkgInfoHash.Item ("pkg_version") & "&nbsp;" & "&nbsp;" & "</SPAN>"
            Response.write "</td>"

            Response.write "<td>"
            ' dlocked: Y - release, N - unlocked, P - pending, A - approved, R - rejected
            If pkgInfoHash.Item ("dlocked") = "Y" Then
              Response.write "<img src='images/i_locked.gif' width='13' height='15' border='0' title='Released and locked'>"
            ElseIf pkgInfoHash("is_released") Then
              Response.write "<img src='images/i_unlocked.gif' width='16' height='15' border='0' title='Released and unlocked'>"
            ElseIf pkgInfoHash.Item ("dlocked") = "P" Then
              Response.write enum_imgPending
            ElseIf (pkgInfoHash.Item ("dlocked") = "N") OR (pkgInfoHash.Item ("dlocked") = "R") Then
              'ElseIf (irtag_id<>"") Then
              Response.write enum_imgBuilding
            End If
            Response.write "</td>"
            Response.write "<td>"

            If pkgInfoHash.Item ("product_state") = 4 Then
              Response.write enum_imgProductRejected
            End If
            Response.write "</td>"
            Response.write "<td>"

            Dim state_icon

            If Not IsNull(pkgInfoHash.Item ("deprecated_state")) Then
              Select Case CInt(pkgInfoHash.Item ("deprecated_state"))
                Case enumPKG_STATE_DEPRECATED
                  state_icon = enum_imgDeprecated
                Case enumPKG_STATE_DEPRECATED_DEPENDENT
                  state_icon = enum_imgDeprecatedDependent
              End Select
              Response.write state_icon
            End If
            Response.write "</td>"
            Response.write "<td>"

            If Not (IsNull(pkgInfoHash.Item ("pkg_state")) or pkgInfoHash.Item ("pkg_state") = 0) Then
              Select Case CInt(pkgInfoHash.Item ("pkg_state"))
                Case enumPKG_STATE_MAJOR
                  state_icon = enum_imgCritical
                Case enumPKG_STATE_MINOR
                  state_icon = enum_imgWarning
                Case enumPKG_STATE_MAJOR_READY
                  state_icon = enum_imgCReady
                Case enumPKG_STATE_MINOR_READY
                  state_icon = enum_imgWReady
                Case enumPKG_NOT_FOUND
                  state_icon = enum_imgNotFound
                Case enumPKG_STATE_NEW_PATCH
                  state_icon = enum_imgPatchAvailable
                Case enumPKG_ADVISORY_RIPPLE
                  state_icon = enum_imgAR
                Case enumPKG_ADVISORY_RIPPLE_DEPENDENT
                  state_icon = enum_imgARD
                Case enumPKG_PEGGED_VERSION
                  state_icon = enum_imgGreenPin
              End Select
              Response.write state_icon
            End If
            Response.write "</td>"
            Response.write "<td>"


            'build_type', and a value of 'M' = manual and 'A' = auto
            If pkgInfoHash.Item("build_type") = "M" Then
              Response.write "<img src='icons/i_manual.gif' width='12' height='14' border='0' title='Manually versioned package'>"
            End If
            Response.write "</td>"
            Response.write "<td>"

            ' check if a daemon instruction exists for this package
            Dim sDmInstr
            sDmInstr = GetOpCodeListForRtagIdAndPvId( "", Request("rtag_id"), pkgInfoHash.Item("pv_id"), "" )
            If sDmInstr <> "" Then
              Response.write "<img src='icons/i_daemon_instr.gif' width='19' height='17' border='0' title='Daemon instruction:" & "&#13;" & sDmInstr & "&#13;" & "Click to view details." & "' onClick=""location.href='build_status.asp?rtag_id=" & irtag_id & "';"" >"
            End If
            Response.write "</td>"
            Response.write "<td>"

            ' check if this package has a build failure file
            If pkgInfoHash("has_build_failure") Then
              Response.write "<img src='icons/i_build_failure.gif' width='19' height='17' border='0' title='Package build failure." & "&#13;" & "Click to view details." &"' onClick=""location.href='build_status.asp?rtag_id=" & irtag_id & "';"" >"
            ElseIf pkgInfoHash("is_excluded") Then
            ' check if this package has been excluded from the build
              Response.write "<img src='icons/i_build_exclusion.gif' width='19' height='17' border='0' title='Package excluded from build." & "&#13;" & "Click to view details." &"' onClick=""location.href='build_status.asp?rtag_id=" & irtag_id & "';"" >"
            End If
            Response.write "</td>"
            Response.write "<td>"

            Response.write "</td>"

            Response.write "</tr>"
            Response.write "</table>"

         End If
         %>

      </td>
   </tr>
   <tr>
      <td style=color:Red>
         <%'=GetOpCodeListForRtagIdAndPvId( "NOTE: '", Request("rtag_id"), pkgInfoHash.Item("pv_id"), "' has been requested" )%>
      </td>
   </tr>
   </table>
<%
End Sub

'-----------------------------------------------------------------------------------------------------------------------------
Sub RenderStatus(irtag_id,ipv_id)
%>
   <table width="100%" border="0" cellspacing="10" cellpadding="0">
   <tr>
     <td width="100%">
       <!-- PACKAGE PROPERTIES ----------------------------  -->
       <%
         If ipv_id <> "" Then
           Call RenderPackageProperties (irtag_id)
         End If
       %>
     </td>
   </tr>
   </table>
<%
End Sub

'-----------------------------------------------------------------------------------------------------------------------------
Sub RenderDaemonBar(irtag_id,ipv_id)
%>
   <table width="100%" border="0" cellspacing="2" cellpadding="0">
   <tr>
     <td valign=bottom>
       <%
         If irtag_id<>"" Then
           Dim objDmSts: Set objDmSts = New DaemonStatus
       %>
           <fieldset style="margin:0px;padding:0px;">
               <%Call objDmSts.RenderDaemonStatusForRelease(irtag_id,16)%>
           </fieldset>
       <%
           Set objDmSts = Nothing
         End If
       %>
     </td>
   </tr>
   </table>
<%
End Sub

'-----------------------------------------------------------------------------------------------------------------------------
Sub RenderActionBar(irtag_id,ipv_id)
   Response.write("<table border=0 cellpadding=0 cellspacing=0>")
   Response.write("  <tr>")
   Response.write("    <td width='50%'>")
   If Not ((ipv_id = "") or (IsNull(ipv_id))) Then
     Call RenderActionButtons
   End If
   Response.write("    </td>")

   Response.write("    <td width='1%'>")
   Call RenderDaemonBar(irtag_id,ipv_id)
   Response.write("    </td>")
   Response.write("  </tr>")
   Response.write("</table>")
End Sub
'-----------------------------------------------------------------------------------------------------------------------------
%>